ModelHandle/source/website/navigatoritems.js
2022-01-10 18:10:51 +01:00

165 lines
4.5 KiB
JavaScript

import { IsDefined } from '../engine/core/core.js';
import { TreeViewButton, TreeViewButtonItem, TreeViewGroupButtonItem, TreeViewSingleItem } from './treeview.js';
export const NavigatorItemRecurse =
{
No : 0,
Parents : 1,
Children : 2,
All : 3
};
export class MaterialItem extends TreeViewSingleItem
{
constructor (name, materialIndex, callbacks)
{
super (name);
this.OnClick (() => {
callbacks.onSelected (materialIndex);
});
}
}
export class MeshItem extends TreeViewButtonItem
{
constructor (name, icon, meshInstanceId, callbacks)
{
super (name, icon);
this.meshInstanceId = meshInstanceId;
this.visible = true;
this.fitToWindowButton = new TreeViewButton ('fit');
this.fitToWindowButton.OnClick (() => {
callbacks.onFitToWindow (this.meshInstanceId);
});
this.AppendButton (this.fitToWindowButton);
this.showHideButton = new TreeViewButton ('visible');
this.showHideButton.OnClick (() => {
callbacks.onShowHide (this.meshInstanceId);
});
this.AppendButton (this.showHideButton);
this.OnClick (() => {
callbacks.onSelected (this.meshInstanceId);
});
}
GetMeshInstanceId ()
{
return this.meshInstanceId;
}
IsVisible ()
{
return this.visible;
}
SetVisible (visible, recurse)
{
if (this.visible === visible) {
return;
}
this.visible = visible;
if (this.visible) {
this.showHideButton.SetImage ('visible');
} else {
this.showHideButton.SetImage ('hidden');
}
if (recurse === NavigatorItemRecurse.Parents) {
if (this.parent instanceof NodeItem) {
let parentIsVisible = this.parent.CalculateIsVisible ();
this.parent.SetVisible (parentIsVisible, NavigatorItemRecurse.Parents);
}
}
}
}
export class NodeItem extends TreeViewGroupButtonItem
{
constructor (name, nodeId, callbacks)
{
super (name, null);
this.nodeId = nodeId;
this.callbacks = callbacks;
this.visible = true;
this.fitToWindowButton = new TreeViewButton ('fit');
this.fitToWindowButton.OnClick (() => {
this.callbacks.onFitToWindow (nodeId);
});
this.AppendButton (this.fitToWindowButton);
this.showHideButton = new TreeViewButton ('visible');
this.showHideButton.OnClick (() => {
this.callbacks.onShowHide (nodeId);
});
this.AppendButton (this.showHideButton);
}
GetNodeId ()
{
return this.nodeId;
}
IsVisible ()
{
return this.visible;
}
CalculateIsVisible ()
{
let isVisible = false;
for (let child of this.children) {
if (child instanceof NodeItem || child instanceof MeshItem) {
if (child.IsVisible ()) {
isVisible = true;
break;
}
}
}
return isVisible;
}
SetVisible (visible, recurse)
{
if (this.visible === visible) {
return;
}
this.visible = visible;
if (this.visible) {
this.showHideButton.SetImage ('visible');
} else {
this.showHideButton.SetImage ('hidden');
}
if (IsDefined (this.callbacks.onVisibilityChanged)) {
this.callbacks.onVisibilityChanged (this.visible);
}
if (recurse === NavigatorItemRecurse.Children || recurse === NavigatorItemRecurse.All) {
for (let child of this.children) {
if (child instanceof NodeItem || child instanceof MeshItem) {
child.SetVisible (this.visible, NavigatorItemRecurse.Children);
}
}
}
if (recurse === NavigatorItemRecurse.Parents || recurse === NavigatorItemRecurse.All) {
if (this.parent instanceof NodeItem) {
let parentIsVisible = this.parent.CalculateIsVisible ();
this.parent.SetVisible (parentIsVisible, NavigatorItemRecurse.Parents);
}
}
}
EnumerateMeshItems (processor)
{
for (let child of this.children) {
if (child instanceof NodeItem) {
child.EnumerateMeshItems (processor);
} else if (child instanceof MeshItem) {
processor (child);
}
}
}
}