gojs
Version:
Interactive diagrams, charts, and graphs, such as trees, flowcharts, orgcharts, UML, BPMN, or business diagrams
187 lines (163 loc) • 8.13 kB
text/typescript
import * as go from '../../../release/go';
import { tweakInspectorForFloorplanner } from './DataInspectorOverrides';
import { EditorHelper } from './EditorHelper';
import { Floorplan } from './Floorplan';
import { FloorplanPalette } from './FloorplanPalette';
/**
* Script to set up the Floorplanner editor
* @param JQUERY jQuery passed to this script in floorplannerTS/index.html via requireJS
* @hidden @internal
*/
export function init(JQUERY: any) {
const editorHelper = new EditorHelper(1, 2, '../../projects/storage', Floorplan, JQUERY);
(window as any).editorHelper = editorHelper;
// replace generic palettes with FloorplanPalettes
const myFloorplan: Floorplan = editorHelper.diagrams[0] as Floorplan;
editorHelper.palettes[0].div = null;
editorHelper.palettes[1].div = null;
const furniturePalette = new FloorplanPalette('ge-palette-0', myFloorplan);
furniturePalette.model = new go.GraphLinksModel(myFloorplan.makeDefaultFurniturePaletteNodeData());
editorHelper.palettes[0] = furniturePalette;
const wallPartsPalette = new FloorplanPalette('ge-palette-1', myFloorplan);
wallPartsPalette.model = new go.GraphLinksModel(myFloorplan.makeDefaultWallpartsPaletteNodeData());
editorHelper.palettes[1] = wallPartsPalette;
// set default model for all Cloud Storage subclasses
for (const i in editorHelper.storages) {
const storage = editorHelper.storages[i];
const dm = JSON.stringify({
'class': 'GraphLinksModel',
'copiesKey': false,
'modelData': {
'units': 'meters', 'unitsAbbreviation': 'm', 'unitsConversionFactor': 0.02, 'gridSize': 10,
'wallThickness': 10, 'preferences': {
'showWallGuidelines': true, 'showWallLengths': true, 'showWallAngles': true,
'showOnlySmallWallAngles': true, 'showGrid': true, 'gridSnap': true
}
},
'nodeDataArray': [],
'linkDataArray': []
});
storage.defaultModel = dm;
}
// listen if the model of the Floorplan changes completely -- if so, there has been a load event, and we must update walls / rooms
myFloorplan.addDiagramListener('InitialLayoutCompleted', function(e: go.DiagramEvent) {
// update units, grid size, units / px, showGrid, and preferences from the loading model's modelData
const unitsForm = document.getElementById('unitsForm') as HTMLFormElement;
const gridSizeInput = document.getElementById('gridSizeInput') as HTMLInputElement;
const showGridCheckbox = document.getElementById('showGridCheckbox') as HTMLInputElement;
const gridSnapCheckbox = document.getElementById('gridSnapCheckbox') as HTMLInputElement;
const showWallGuidelinesCheckbox = document.getElementById('wallGuidelinesCheckbox') as HTMLInputElement;
const showWallLengthsCheckbox = document.getElementById('wallLengthsCheckbox') as HTMLInputElement;
const showWallAnglesCheckbox = document.getElementById('wallAnglesCheckbox') as HTMLInputElement;
const showOnlySmallWallAnglesCheckbox = document.getElementById('onlySmallWallAnglesCheckbox') as HTMLInputElement;
const unitsConversionFactorInput = document.getElementById('unitsConversionFactorInput') as HTMLInputElement;
const fp = e.diagram as Floorplan;
const md = fp.model.modelData;
const units = md.units;
const unitsRadioChecked = document.getElementById(units) as HTMLInputElement;
unitsRadioChecked.checked = true;
let gridSize = md.gridSize;
gridSize = fp.convertPixelsToUnits(gridSize);
gridSizeInput.value = gridSize;
fp.changeGridSize(gridSizeInput);
const unitsConversionFactor = md.unitsConversionFactor;
unitsConversionFactorInput.value = unitsConversionFactor;
fp.changeUnitsConversionFactor(unitsConversionFactorInput, gridSizeInput);
fp.changeUnits(unitsForm);
const showGrid = md.preferences.showGrid;
const gridSnap = md.preferences.gridSnap;
const showWallGuidelines = md.preferences.showWallGuidelines;
const showWallLengths = md.preferences.showWallLengths;
const showWallAngles = md.preferences.showWallAngles;
const showOnlySmallWallAngles = md.preferences.showOnlySmallWallAngles;
showGridCheckbox.checked = showGrid;
gridSnapCheckbox.checked = gridSnap;
showWallGuidelinesCheckbox.checked = showWallGuidelines;
showWallLengthsCheckbox.checked = showWallLengths;
showWallAnglesCheckbox.checked = showWallAngles;
showOnlySmallWallAnglesCheckbox.checked = showOnlySmallWallAngles;
fp.checkboxChanged('showGridCheckbox');
fp.checkboxChanged('gridSnapCheckbox');
fp.checkboxChanged('wallGuidelinesCheckbox');
fp.checkboxChanged('wallLengthsCheckbox');
fp.checkboxChanged('wallAnglesCheckbox');
fp.checkboxChanged('onlySmallWallAnglesCheckbox');
// update walls and rooms geometries
fp.nodes.iterator.each(function(n) {
if (n.category === 'WallGroup') {
fp.updateWall(n as go.Group);
}
if (n.category === 'RoomNode') {
fp.updateRoom(n);
}
});
});
/**
* Update the tools buttons so the tool in use is highlighted
*/
(window as any).updateButtons = function(func: Function, el: HTMLElement) {
func.call(myFloorplan);
const toolButtons = document.getElementsByClassName('toolButtons');
for (let i = 0; i < toolButtons.length; i++) {
const tb = toolButtons[i] as HTMLElement;
if (tb === el) {
tb.style.background = '#4b545f';
tb.style.color = 'white';
} else {
tb.style.background = 'rgb(221, 221, 221)';
tb.style.color = 'black';
}
}
};
JQUERY(function() {
JQUERY('#ge-palettes-container').accordion({
heightStyle: 'content',
activate: function() {
for (let i = 0; i < editorHelper.palettes.length; i++) {
const palette = editorHelper.palettes[i];
palette.requestUpdate();
}
}
});
// JQUERY("#ge-overviews-container").accordion();
const draggables = document.getElementsByClassName('ge-draggable');
for (let i = 0; i < draggables.length; i++) {
const draggable = draggables[i];
const id = '#' + draggable.id; const hid = id + '-handle';
// When a window is dragged, its height is set. this is bad. unset height / maybe width after dragging
JQUERY(id).draggable({
handle: hid, stack: '.ge-draggable', containment: 'parent', scroll: false, stop: function(event: any) {
this.style.height = 'unset';
const did = event.target.id;
// only unset width for inspector and options menu, whose widths are dependent on contents
if (did === 'ge-inspector-window' || did === 'optionsWindow') {
this.style.width = 'unset';
}
}
});
}
}); // end jQuery
// add options window hotkey (other hotkeys are defined in goeditor-setup.js)
document.body.addEventListener('keydown', function(e) {
const keynum = e.which;
if (e.ctrlKey) {
e.preventDefault();
switch (keynum) {
case 66: editorHelper.geHideShowWindow('optionsWindow'); break; // ctrl + b
}
}
});
// function to tweak inspector for app-specific stuff is in floorplanner-datainspector-overrides.js
tweakInspectorForFloorplanner(editorHelper.inspector, myFloorplan, editorHelper);
const defaultModelTextarea = document.getElementById('defaultModelTextarea') as HTMLInputElement;
const defaultModelString = defaultModelTextarea.value;
const defaultModelJson = JSON.parse(defaultModelString);
myFloorplan.model = go.Model.fromJson(defaultModelJson);
// Some global function required to be on the window object for click handling
(window as any).handlePromise = (action: string) => {
EditorHelper.prototype.handlePromise.call(editorHelper, action);
};
(window as any).myFloorplan = myFloorplan;
(window as any).furniturePalette = furniturePalette;
(window as any).wallPartsPalette = wallPartsPalette;
}