@inweb/viewer-three 25.12.0 → 25.12.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/viewer-three.js +11650 -11236
- package/dist/viewer-three.js.map +1 -1
- package/dist/viewer-three.min.js +2 -2
- package/dist/viewer-three.module.js.map +1 -1
- package/package.json +5 -5
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"viewer-three.module.js","sources":["../../viewer-core/dist/viewer-core.module.js","../src/Viewer/commands/ApplyModelTransform.ts","../src/Viewer/commands/ClearMarkup.ts","../src/Viewer/components/SelectionComponent.ts","../src/Viewer/commands/ClearSelected.ts","../src/Viewer/commands/ClearSlices.ts","../src/Viewer/commands/CreatePreview.ts","../src/Viewer/commands/Explode.ts","../src/Viewer/commands/SetDefaultViewPosition.ts","../src/Viewer/commands/GetDefaultViewPositions.ts","../src/Viewer/commands/GetModels.ts","../src/Viewer/commands/GetSelected.ts","../src/Viewer/commands/HideSelected.ts","../src/Viewer/commands/IsolateSelected.ts","../src/Viewer/commands/RegenerateAll.ts","../src/Viewer/commands/ResetView.ts","../src/Viewer/commands/SelectModel.ts","../src/Viewer/commands/SetActiveDragger.ts","../src/Viewer/commands/SetMarkupColor.ts","../src/Viewer/commands/SetSelected.ts","../src/Viewer/commands/ShowAll.ts","../src/Viewer/commands/ZoomToExtents.ts","../src/Viewer/commands/ZoomToObjects.ts","../src/Viewer/commands/ZoomToSelected.ts","../src/Viewer/loaders/GLTFLoadingManager.ts","../../eventemitter2/dist/eventemitter2.module.js","../../markup/dist/markup.module.js","../src/Viewer/controls/OrbitControls.js","../src/Viewer/draggers/OrbitDragger.ts","../src/Viewer/draggers/PanDragger.ts","../src/Viewer/draggers/ZoomDragger.ts","../src/Viewer/controls/WalkControls.ts","../src/Viewer/draggers/WalkDragger.ts","../src/Viewer/helpers/PlaneHelper.ts","../src/Viewer/draggers/CuttingPlaneDragger.ts","../src/Viewer/draggers/CuttingPlaneXAxis.ts","../src/Viewer/draggers/CuttingPlaneYAxis.ts","../src/Viewer/draggers/CuttingPlaneZAxis.ts","../src/Viewer/draggers/MeasureLineDragger.ts","../src/Viewer/components/ExtentsComponent.ts","../src/Viewer/components/LightComponent.ts","../src/Viewer/components/BackgroundComponent.ts","../src/Viewer/components/DefaultPositionComponent.ts","../src/Viewer/components/ResizeCanvasComponent.ts","../src/Viewer/components/RenderLoopComponent.ts","../src/Viewer/helpers/WCSHelper.ts","../src/Viewer/components/WCSHelperComponent.ts","../src/Viewer/Viewer.ts"],"sourcesContent":["class Commands {\n constructor() {\n this._commands = new Map;\n }\n registerCommand(id, handler, description, thisArg) {\n this._commands.set(id, {\n id: id,\n handler: handler,\n thisArg: thisArg,\n description: description\n });\n }\n registerCommandAlias(id, alias) {\n this.registerCommand(alias, ((viewer, ...args) => this.executeCommand(id, viewer, ...args)));\n }\n getCommand(id) {\n return this._commands.get(id);\n }\n getCommands() {\n const map = new Map;\n this._commands.forEach(((value, key) => map.set(key, value)));\n return map;\n }\n executeCommand(id, viewer, ...args) {\n const command = this._commands.get(id);\n if (!command) {\n if (viewer) {\n const isDraggerCommand = viewer.draggers.includes(id);\n if (isDraggerCommand) return viewer.setActiveDragger(id);\n }\n console.warn(`Command '${id}' not found`);\n return undefined;\n }\n const {handler: handler, thisArg: thisArg} = command;\n const result = handler.apply(thisArg, [ viewer, ...args ]);\n viewer === null || viewer === void 0 ? void 0 : viewer.emit({\n type: \"command\",\n data: id,\n args: args\n });\n return result;\n }\n}\n\nconst _commands = new Map;\n\nfunction commands(viewerType = \"\") {\n let result = _commands.get(viewerType);\n if (!result) {\n result = new Commands;\n _commands.set(viewerType, result);\n }\n return result;\n}\n\ncommands(\"\").registerCommand(\"noop\", (() => {}));\n\ncommands(\"VisualizeJS\").registerCommand(\"noop\", (() => {}));\n\ncommands(\"ThreeJS\").registerCommand(\"noop\", (() => {}));\n\nfunction defaultOptions() {\n return {\n showWCS: true,\n cameraAnimation: true,\n antialiasing: true,\n groundShadow: false,\n shadows: false,\n cameraAxisXSpeed: 4,\n cameraAxisYSpeed: 1,\n ambientOcclusion: false,\n enableStreamingMode: true,\n enablePartialMode: false,\n memoryLimit: 3294967296,\n cuttingPlaneFillColor: {\n red: 255,\n green: 152,\n blue: 0\n },\n edgesColor: {\n r: 255,\n g: 152,\n b: 0\n },\n facesColor: {\n r: 255,\n g: 152,\n b: 0\n },\n edgesVisibility: true,\n edgesOverlap: true,\n facesOverlap: false,\n facesTransparancy: 200,\n enableCustomHighlight: true,\n sceneGraph: false,\n edgeModel: true,\n reverseZoomWheel: false,\n enableZoomWheel: true,\n enableGestures: true,\n geometryType: \"vsfx\",\n rulerUnit: \"Default\"\n };\n}\n\nclass Options {\n constructor(emitter) {\n this._emitter = emitter;\n this._data = defaultOptions();\n this.loadFromStorage();\n }\n static defaults() {\n return defaultOptions();\n }\n notifierChangeEvent() {\n console.warn(\"Options.notifierChangeEvent() has been deprecated since 25.3 and will be removed in a future release, use Options.change() instead.\");\n this.change();\n }\n change() {\n if (this._emitter !== undefined) {\n this.saveToStorage();\n this._emitter.emit({\n type: \"optionschange\",\n data: this\n });\n }\n }\n saveToStorage() {\n if (typeof window !== \"undefined\") try {\n localStorage.setItem(\"od-client-settings\", JSON.stringify(this.data));\n } catch (error) {\n console.error(\"Cannot save client settings.\", error);\n }\n }\n loadFromStorage() {\n if (typeof window !== \"undefined\") try {\n const item = localStorage.getItem(\"od-client-settings\");\n if (item) {\n const data = JSON.parse(item);\n this.data = {\n ...data\n };\n }\n } catch (error) {\n console.error(\"Cannot load client settings.\", error);\n }\n }\n resetToDefaults(fields) {\n if (fields !== undefined) {\n const defaults = Options.defaults();\n const resetData = fields.reduce(((acc, field) => {\n acc[field] = defaults[field];\n return acc;\n }), {});\n this.data = {\n ...this.data,\n ...resetData\n };\n } else {\n this.data = {\n ...this.data,\n ...Options.defaults()\n };\n }\n }\n get data() {\n return this._data;\n }\n set data(value) {\n const enablePartialMode = value.enableStreamingMode ? value.enablePartialMode : false;\n const sceneGraph = enablePartialMode ? false : value.sceneGraph;\n this._data = {\n ...Options.defaults(),\n ...this._data,\n ...value,\n enablePartialMode: enablePartialMode,\n sceneGraph: sceneGraph\n };\n this.change();\n }\n get showWCS() {\n return this._data.showWCS;\n }\n set showWCS(value) {\n this._data.showWCS = value;\n this.change();\n }\n get cameraAnimation() {\n return this._data.cameraAnimation;\n }\n set cameraAnimation(value) {\n this._data.cameraAnimation = value;\n this.change();\n }\n get antialiasing() {\n return this._data.antialiasing;\n }\n set antialiasing(value) {\n this._data.antialiasing = value;\n this.change();\n }\n get groundShadow() {\n return this._data.groundShadow;\n }\n set groundShadow(value) {\n this._data.groundShadow = value;\n this.change();\n }\n get shadows() {\n return this._data.shadows;\n }\n set shadows(value) {\n this._data.shadows = value;\n this.change();\n }\n get cameraAxisXSpeed() {\n return this._data.cameraAxisXSpeed;\n }\n set cameraAxisXSpeed(value) {\n this._data.cameraAxisXSpeed = value;\n this.change();\n }\n get cameraAxisYSpeed() {\n return this._data.cameraAxisYSpeed;\n }\n set cameraAxisYSpeed(value) {\n this.cameraAxisYSpeed = value;\n this.change();\n }\n get ambientOcclusion() {\n return this._data.ambientOcclusion;\n }\n set ambientOcclusion(value) {\n this._data.ambientOcclusion = value;\n this.change();\n }\n get enableStreamingMode() {\n return this._data.enableStreamingMode;\n }\n set enableStreamingMode(value) {\n this._data.enableStreamingMode = value;\n if (!value) this._data.enablePartialMode = false;\n this.change();\n }\n get enablePartialMode() {\n return this._data.enablePartialMode;\n }\n set enablePartialMode(value) {\n this._data.enablePartialMode = value;\n if (value) {\n this._data.enableStreamingMode = true;\n this._data.sceneGraph = false;\n }\n this.change();\n }\n get memoryLimit() {\n return this._data.memoryLimit;\n }\n set memoryLimit(value) {\n this._data.memoryLimit = value;\n this.change();\n }\n get cuttingPlaneFillColor() {\n return this._data.cuttingPlaneFillColor;\n }\n set cuttingPlaneFillColor(value) {\n this._data.cuttingPlaneFillColor = value;\n this.change();\n }\n get edgesColor() {\n return this._data.edgesColor;\n }\n set edgesColor(value) {\n this._data.edgesColor = value;\n this.change();\n }\n get facesColor() {\n return this._data.facesColor;\n }\n set facesColor(value) {\n this._data.facesColor = value;\n this.change();\n }\n get edgesVisibility() {\n return this._data.edgesVisibility;\n }\n set edgesVisibility(value) {\n this._data.edgesVisibility = value;\n this.change();\n }\n get edgesOverlap() {\n return this._data.edgesOverlap;\n }\n set edgesOverlap(value) {\n this._data.edgesOverlap = value;\n this.change();\n }\n get facesOverlap() {\n return this._data.facesOverlap;\n }\n set facesOverlap(value) {\n this._data.facesOverlap = value;\n this.change();\n }\n get facesTransparancy() {\n return this._data.facesTransparancy;\n }\n set facesTransparancy(value) {\n this._data.facesTransparancy = value;\n this.change();\n }\n get enableCustomHighlight() {\n return this._data.enableCustomHighlight;\n }\n set enableCustomHighlight(value) {\n this._data.enableCustomHighlight = value;\n this.change();\n }\n get sceneGraph() {\n return this._data.sceneGraph;\n }\n set sceneGraph(value) {\n this._data.sceneGraph = value;\n if (value) this._data.enablePartialMode = false;\n this.change();\n }\n get edgeModel() {\n return Boolean(this._data.edgeModel);\n }\n set edgeModel(value) {\n this._data.edgeModel = Boolean(value);\n this.change();\n }\n get reverseZoomWheel() {\n return this._data.reverseZoomWheel;\n }\n set reverseZoomWheel(value) {\n this._data.reverseZoomWheel = !!value;\n this.change();\n }\n get enableZoomWheel() {\n return this._data.enableZoomWheel;\n }\n set enableZoomWheel(value) {\n this._data.enableZoomWheel = !!value;\n this.change();\n }\n get enableGestures() {\n return this._data.enableGestures;\n }\n set enableGestures(value) {\n this._data.enableGestures = !!value;\n this.change();\n }\n get geometryType() {\n return this._data.geometryType;\n }\n set geometryType(value) {\n this._data.geometryType = value;\n this.change();\n }\n get rulerUnit() {\n return this._data.rulerUnit;\n }\n set rulerUnit(value) {\n this._data.rulerUnit = value;\n this.change();\n }\n}\n\nconst CanvasEvents = [ \"click\", \"contextmenu\", \"dblclick\", \"mousedown\", \"mouseleave\", \"mousemove\", \"mouseup\", \"pointercancel\", \"pointerdown\", \"pointerleave\", \"pointermove\", \"pointerup\", \"touchcancel\", \"touchend\", \"touchmove\", \"touchstart\", \"wheel\" ];\n\nconst CANVAS_EVENTS = CanvasEvents;\n\nclass Dragger {\n constructor(viewer) {\n this.name = \"\";\n }\n initialize() {}\n dispose() {}\n updatePreview() {}\n}\n\nexport { CANVAS_EVENTS, CanvasEvents, Dragger, Options, commands, defaultOptions };\n//# sourceMappingURL=viewer-core.module.js.map\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Model, File, Assembly } from \"@inweb/client\";\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\n// gltf root object don't have model handle\nfunction applyModelTransform(viewer: Viewer, model: Model | File | Assembly) {\n console.warn(\"applyModelTransform not implemented\");\n}\n\ncommands(\"ThreeJS\").registerCommand(\"applyModelTransform\", applyModelTransform);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"clearMarkup\", (viewer: Viewer) => viewer.clearOverlay());\ncommands(\"ThreeJS\").registerCommandAlias(\"clearMarkup\", \"clearOverlay\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Intersection, MeshBasicMaterial, Object3D, Raycaster, Vector2 } from \"three\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class SelectionComponent implements IDisposable {\n protected viewer: Viewer;\n protected raycaster: Raycaster;\n protected downPosition: Vector2;\n protected facesMaterial: MeshBasicMaterial;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.raycaster = new Raycaster();\n this.downPosition = new Vector2();\n\n const { facesColor, facesTransparancy } = this.viewer.options;\n this.facesMaterial = new MeshBasicMaterial();\n this.facesMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.facesMaterial.opacity = (255 - facesTransparancy) / 255;\n this.facesMaterial.transparent = true;\n\n this.viewer.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.addEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.addEventListener(\"optionschange\", this.optionsChange);\n }\n\n dispose() {\n this.facesMaterial.dispose();\n\n this.viewer.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.removeEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.removeEventListener(\"optionschange\", this.optionsChange);\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (!event.isPrimary || event.button !== 0) return;\n\n this.getMousePosition(event, this.downPosition);\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (!event.isPrimary) return;\n\n const upPosition = this.getMousePosition(event, new Vector2());\n if (this.downPosition.distanceTo(upPosition) !== 0) return;\n\n const intersects = this.getPointerIntersects(upPosition);\n\n this.clearSelection();\n if (intersects.length > 0) this.select(intersects[0].object);\n\n this.viewer.update();\n this.viewer.emitEvent({ type: \"select\", data: undefined, handles: this.viewer.getSelected() });\n };\n\n onDoubleClick = (event: MouseEvent) => {\n if (event.button !== 0) return;\n\n this.viewer.executeCommand(\"zoomToSelected\");\n };\n\n getMousePosition(event: MouseEvent, target: Vector2): Vector2 {\n return target.set(event.clientX, event.clientY);\n }\n\n getPointerIntersects(mouse: Vector2): Array<Intersection<Object3D>> {\n const rect = this.viewer.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.viewer.camera);\n\n const objects = [];\n this.viewer.scene.traverseVisible((child) => objects.push(child));\n\n this.raycaster.params = this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n return this.raycaster.intersectObjects(objects, false);\n }\n\n select(object: any) {\n if (object.isSelected) return;\n\n object.isSelected = true;\n object.originalMaterial = object.material;\n object.material = this.facesMaterial;\n\n this.viewer.selected.push(object);\n }\n\n clearSelection() {\n this.viewer.selected.forEach((object: any) => {\n object.isSelected = false;\n object.material = object.originalMaterial;\n });\n this.viewer.selected.length = 0;\n }\n\n optionsChange = () => {\n const { facesColor, facesTransparancy } = this.viewer.options;\n this.facesMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.facesMaterial.opacity = (255 - facesTransparancy) / 255;\n\n this.viewer.update();\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { SelectionComponent } from \"../components/SelectionComponent\";\n\nfunction clearSelected(viewer: Viewer): void {\n const selection = new SelectionComponent(viewer);\n selection.clearSelection();\n selection.dispose();\n\n viewer.update();\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"clearSelected\", clearSelected);\ncommands(\"ThreeJS\").registerCommandAlias(\"clearSelected\", \"unselect\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"clearSlices\", (viewer: Viewer) => viewer.clearSlices());\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction createPreview(viewer: Viewer, type = \"image/jpeg\", encoderOptions = 0.25): string {\n viewer.update(true);\n return viewer.canvas.toDataURL(type, encoderOptions);\n}\n\ncommands(\"ThreeJS\").registerCommand(\"createPreview\", createPreview);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Object3D, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction calcObjectDepth(object: Object3D, depth: number) {\n let res = depth;\n object.children.forEach((x) => {\n const objectDepth = calcObjectDepth(x, depth + 1);\n if (res < objectDepth) res = objectDepth;\n });\n\n (object as any).originalPosition = object.position.clone();\n\n return res;\n}\n\nfunction explodeScene(scene: Object3D, scale = 0) {\n scale /= 100;\n\n if (!(scene as any).maxDepth) (scene as any).maxDepth = calcObjectDepth(scene, 1);\n const maxDepth = (scene as any).maxDepth;\n\n let explodeDepth = scale * (maxDepth - 1) + 1;\n if (maxDepth === 1) explodeDepth = 1;\n\n function explodeObject(object: Object3D, depth: number, parentCenter: Vector3, parentOffset: Vector3) {\n const objectBox = new Box3().setFromObject(object);\n const objectCenter = objectBox.getCenter(new Vector3());\n\n const objectOffset = parentOffset.clone();\n if (depth > 0 && depth <= explodeDepth) {\n const offset = objectCenter.clone().sub(parentCenter).multiplyScalar(scale);\n objectOffset.add(offset);\n }\n\n object.children.forEach((object) => explodeObject(object, depth + 1, objectCenter, objectOffset));\n\n const originalPosition = (object as any).originalPosition;\n object.position.copy(originalPosition);\n if (scale > 0) {\n const direction = objectCenter.sub(parentCenter).normalize();\n object.position.add(direction.add(objectOffset));\n }\n }\n\n const sceneExtents = new Box3().setFromObject(scene);\n const sceneCenter = sceneExtents.getCenter(new Vector3());\n explodeObject(scene, 0, sceneCenter, new Vector3(0, 0, 0));\n}\n\nfunction explode(viewer: Viewer, index = 0): void {\n viewer.models.forEach((gltf) => explodeScene(gltf.scene, index));\n\n viewer.update();\n viewer.emitEvent({ type: \"explode\", data: index });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"explode\", explode);\ncommands(\"ThreeJS\").registerCommand(\"collect\", (viewer: any) => explode(viewer, 0));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport const defaultViewPositions = {\n top: new Vector3(0, 0, 1),\n bottom: new Vector3(0, 0, -1),\n left: new Vector3(-1, 0, 0),\n right: new Vector3(1, 0, 0),\n front: new Vector3(0, -1, 0),\n back: new Vector3(0, 1, 0),\n sw: new Vector3(-0.5, -0.5, 1.0).normalize(),\n se: new Vector3(0.5, -0.5, 1.0).normalize(),\n ne: new Vector3(0.5, 0.5, 1.0).normalize(),\n nw: new Vector3(-0.5, 0.5, 1.0).normalize(),\n};\n\nfunction setDefaultViewPosition(viewer: Viewer, position: string): void {\n const direction = defaultViewPositions[position] || defaultViewPositions[\"sw\"];\n\n const center = viewer.extents.getCenter(new Vector3());\n const sphere = viewer.extents.getBoundingSphere(new Sphere());\n const offet = direction.clone().multiplyScalar(sphere.radius);\n\n const camera = viewer.camera;\n camera.position.copy(center).add(offet);\n camera.lookAt(center);\n camera.updateProjectionMatrix();\n camera.updateMatrixWorld();\n\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emit({ type: \"viewposition\", data: position });\n\n viewer.executeCommand(\"zoomToExtents\");\n}\n\ncommands(\"ThreeJS\").registerCommand(\"setDefaultViewPosition\", setDefaultViewPosition);\ncommands(\"ThreeJS\").registerCommand(\"top\", (viewer) => setDefaultViewPosition(viewer, \"top\"));\ncommands(\"ThreeJS\").registerCommand(\"bottom\", (viewer) => setDefaultViewPosition(viewer, \"bottom\"));\ncommands(\"ThreeJS\").registerCommand(\"left\", (viewer) => setDefaultViewPosition(viewer, \"left\"));\ncommands(\"ThreeJS\").registerCommand(\"right\", (viewer) => setDefaultViewPosition(viewer, \"right\"));\ncommands(\"ThreeJS\").registerCommand(\"front\", (viewer) => setDefaultViewPosition(viewer, \"front\"));\ncommands(\"ThreeJS\").registerCommand(\"back\", (viewer) => setDefaultViewPosition(viewer, \"back\"));\ncommands(\"ThreeJS\").registerCommand(\"sw\", (viewer) => setDefaultViewPosition(viewer, \"sw\"));\ncommands(\"ThreeJS\").registerCommand(\"se\", (viewer) => setDefaultViewPosition(viewer, \"se\"));\ncommands(\"ThreeJS\").registerCommand(\"ne\", (viewer) => setDefaultViewPosition(viewer, \"ne\"));\ncommands(\"ThreeJS\").registerCommand(\"nw\", (viewer) => setDefaultViewPosition(viewer, \"nw\"));\n\ncommands(\"ThreeJS\").registerCommandAlias(\"top\", \"k3DViewTop\");\ncommands(\"ThreeJS\").registerCommandAlias(\"bottom\", \"k3DViewBottom\");\ncommands(\"ThreeJS\").registerCommandAlias(\"left\", \"k3DViewLeft\");\ncommands(\"ThreeJS\").registerCommandAlias(\"right\", \"k3DViewRight\");\ncommands(\"ThreeJS\").registerCommandAlias(\"front\", \"k3DViewFront\");\ncommands(\"ThreeJS\").registerCommandAlias(\"back\", \"k3DViewBack\");\ncommands(\"ThreeJS\").registerCommandAlias(\"se\", \"k3DViewSE\");\ncommands(\"ThreeJS\").registerCommandAlias(\"sw\", \"k3DViewSW\");\ncommands(\"ThreeJS\").registerCommandAlias(\"ne\", \"k3DViewNE\");\ncommands(\"ThreeJS\").registerCommandAlias(\"nw\", \"k3DViewNW\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport { defaultViewPositions } from \"./SetDefaultViewPosition\";\n\nfunction getDefaultViewPositions(): string[] {\n return Object.keys(defaultViewPositions);\n}\n\ncommands(\"ThreeJS\").registerCommand(\"getDefaultViewPositions\", getDefaultViewPositions);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction getModels(viewer: Viewer): string[] {\n const handles: string[] = viewer.models.map((model) => model.userData.handle || \"\").filter((handle) => handle);\n return handles;\n}\n\ncommands(\"ThreeJS\").registerCommand(\"getModels\", getModels);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction getSelected(viewer: Viewer): string[] {\n return viewer.selected.map((object) => object.userData?.handle).filter((handle) => handle);\n}\n\ncommands(\"ThreeJS\").registerCommand(\"getSelected\", getSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { SelectionComponent } from \"../components/SelectionComponent\";\n\nfunction hideSelected(viewer: Viewer): void {\n viewer.selected.forEach((object) => (object.visible = false));\n\n const selection = new SelectionComponent(viewer);\n selection.clearSelection();\n selection.dispose();\n\n viewer.update();\n viewer.emitEvent({ type: \"hide\" });\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"hideSelected\", hideSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Object3D } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction isolateSelected(viewer: Viewer): void {\n const selectedSet = new Set(viewer.selected);\n\n function isolateObject(object: Object3D, depth: number): boolean {\n let canBeIsolated = true;\n object.children.forEach((object) => {\n if (selectedSet.has(object)) canBeIsolated = false;\n else isolateObject(object, depth + 1);\n });\n\n if (canBeIsolated && depth > 0) object.visible = false;\n\n return canBeIsolated;\n }\n\n isolateObject(viewer.scene, 0);\n\n viewer.update();\n viewer.emitEvent({ type: \"isolate\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"isolateSelected\", isolateSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction regenerateAll(viewer: Viewer): void {\n console.warn(\"regenerateAll not implemented\");\n viewer.emit({ type: \"regenerateall\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"regenerateAll\", regenerateAll);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction resetView(viewer: Viewer): void {\n viewer.executeCommand(\"setActiveDragger\");\n viewer.executeCommand(\"clearSlices\");\n viewer.executeCommand(\"clearOverlay\");\n viewer.executeCommand(\"setMarkupColor\");\n viewer.executeCommand(\"clearSelected\");\n viewer.executeCommand(\"showAll\");\n viewer.executeCommand(\"explode\", 0);\n viewer.executeCommand(\"zoomToExtents\", true);\n viewer.executeCommand(\"k3DViewSW\");\n\n viewer.emit({ type: \"resetview\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"resetView\", resetView);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction selectModel(viewer: Viewer, handle: string): void {\n console.warn(\"selectModel not implemented\");\n viewer.emit({ type: \"select\", data: [] });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"selectModel\", selectModel);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"setActiveDragger\", (viewer: Viewer, dragger = \"\") => {\n viewer.setActiveDragger(dragger);\n});\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"setMarkupColor\", (viewer: Viewer, r = 255, g = 0, b = 0) => {\n console.warn(\"setMarkupColor not implemented\");\n // viewer.setMarkupColor(r, g, b);\n});\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { SelectionComponent } from \"../components/SelectionComponent\";\n\nfunction setSelected(viewer: Viewer, handles: string[] = []): void {\n const handleSet = new Set(handles);\n const objects = [];\n viewer.scene.traverseVisible((child) => {\n if (handleSet.has(child.userData?.handle)) objects.push(child);\n });\n\n const selection = new SelectionComponent(viewer);\n selection.clearSelection();\n objects.forEach((object) => selection.select(object));\n selection.dispose();\n\n viewer.update();\n viewer.emitEvent({ type: \"select\", data: undefined, handles });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"setSelected\", setSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction showAll(viewer: Viewer): void {\n viewer.scene.traverse((object) => (object.visible = true));\n\n viewer.update();\n viewer.emitEvent({ type: \"showall\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"showAll\", showAll);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction zoomToExtents(viewer: Viewer): void {\n if (viewer.extents.isEmpty()) return;\n\n const center = viewer.extents.getCenter(new Vector3());\n const distance = viewer.extents.getBoundingSphere(new Sphere()).radius;\n\n const delta = new Vector3(0, 0, 1);\n delta.applyQuaternion(viewer.camera.quaternion);\n delta.multiplyScalar(distance * 3);\n\n viewer.camera.position.copy(center).add(delta);\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"zoomToExtents\", zoomToExtents);\ncommands(\"ThreeJS\").registerCommandAlias(\"zoomToExtents\", \"zoomExtents\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction zoomToObjects(viewer: Viewer, handles: string[] = []): void {\n const handleSet = new Set(handles);\n const objects = [];\n viewer.scene.traverseVisible((child) => {\n if (handleSet.has(child.userData?.handle)) objects.push(child);\n });\n\n const extents = objects.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n const center = extents.getCenter(new Vector3());\n const distance = extents.getBoundingSphere(new Sphere()).radius;\n\n const delta = new Vector3(0, 0, 1);\n delta.applyQuaternion(viewer.camera.quaternion);\n delta.multiplyScalar(distance * 3);\n\n viewer.camera.position.copy(center).add(delta);\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"zoomToObjects\", zoomToObjects);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction zoomToSelected(viewer: Viewer): void {\n const extents = viewer.selected.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n\n if (extents.isEmpty()) extents.copy(viewer.extents);\n\n const center = extents.getCenter(new Vector3());\n const distance = extents.getBoundingSphere(new Sphere()).radius;\n\n const delta = new Vector3(0, 0, 1);\n delta.applyQuaternion(viewer.camera.quaternion);\n delta.multiplyScalar(distance * 3);\n\n viewer.camera.position.copy(center).add(delta);\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"zoomToSelected\", zoomToSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { LoadingManager, LoaderUtils } from \"three\";\n\nexport class GLTFLoadingManager extends LoadingManager {\n public path = \"\";\n public resourcePath = \"\";\n public fileURL = \"\";\n public dataURLs = new Map();\n\n constructor(\n file: string | globalThis.File | ArrayBuffer | Blob,\n externalData: Map<string, string | File | ArrayBuffer | Blob> = new Map(),\n params: { path?: string } = {}\n ) {\n super();\n\n this.path = params.path || \"\";\n\n if (typeof file === \"string\") {\n this.fileURL = file;\n this.resourcePath = LoaderUtils.extractUrlBase(file);\n } else {\n externalData.forEach((value, key) => (this.fileURL = value === file ? key : this.fileURL));\n externalData.set(this.fileURL, file);\n }\n\n externalData.forEach((value, key) => {\n let dataURL: string;\n if (typeof value === \"string\") dataURL = value;\n else dataURL = URL.createObjectURL(new Blob([value]));\n this.dataURLs.set(key, dataURL);\n });\n\n this.setURLModifier((url: string) => {\n const key = decodeURI(url)\n .replace(this.path, \"\")\n .replace(this.resourcePath, \"\")\n .replace(/^(\\.?\\/)/, \"\");\n const dataURL = this.dataURLs.get(key);\n return dataURL ?? url;\n });\n }\n\n dispose() {\n this.dataURLs.forEach(URL.revokeObjectURL);\n }\n}\n","class EventEmitter2 {\n constructor() {\n this._listeners = {};\n }\n addEventListener(type, listener) {\n if (this._listeners[type] === undefined) this._listeners[type] = [];\n this._listeners[type].push(listener);\n return this;\n }\n removeEventListener(type, listener) {\n if (this._listeners[type] === undefined) return this;\n const listeners = this._listeners[type].filter((x => x !== listener));\n if (listeners.length !== 0) this._listeners[type] = listeners; else delete this._listeners[type];\n return this;\n }\n removeAllListeners(type) {\n if (type) delete this._listeners[type]; else this._listeners = {};\n return this;\n }\n emitEvent(event) {\n if (this._listeners[event.type] === undefined) return false;\n const invoke = this._listeners[event.type].slice();\n invoke.forEach((listener => listener.call(this, event)));\n return true;\n }\n on(type, listener) {\n return this.addEventListener(type, listener);\n }\n off(type, listener) {\n return this.removeEventListener(type, listener);\n }\n emit(type, ...args) {\n if (typeof type === \"string\") return this.emitEvent({\n type: type,\n args: args\n }); else if (typeof type === \"object\") return this.emitEvent(type); else return false;\n }\n}\n\nexport { EventEmitter2 };\n//# sourceMappingURL=eventemitter2.module.js.map\n","import Konva from \"konva\";\n\nclass WorldTransform {\n screenToWorld(position) {\n return {\n x: position.x,\n y: position.y,\n z: 0\n };\n }\n worldToScreen(position) {\n return {\n x: position.x,\n y: position.y\n };\n }\n getScale() {\n return {\n x: 1,\n y: 1,\n z: 1\n };\n }\n}\n\nclass MarkupColor {\n constructor(r, g, b) {\n this.setColor(r, g, b);\n }\n asHex() {\n return \"#\" + this.HEX;\n }\n asRGB() {\n return {\n r: this.R,\n g: this.G,\n b: this.B\n };\n }\n setColor(r, g, b) {\n this.R = r;\n this.G = g;\n this.B = b;\n this.HEX = this.rgbToHex(r, g, b);\n }\n rgbToHex(r, g, b) {\n const valueToHex = c => {\n const hex = c.toString(16);\n return hex === \"0\" ? \"00\" : hex;\n };\n return valueToHex(r) + valueToHex(g) + valueToHex(b);\n }\n}\n\nconst LineTypeSpecs = new Map([ [ \"solid\", [] ], [ \"dot\", [ 30, 30, .001, 30 ] ], [ \"dash\", [ 30, 30 ] ] ]);\n\nclass KonvaLine {\n constructor(params, ref = null) {\n var _a, _b;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.points) params.points = [ {\n x: 50,\n y: 50\n }, {\n x: 100,\n y: 100\n } ];\n const konvaPoints = [];\n params.points.forEach((point => konvaPoints.push(point.x, point.y)));\n this._ref = new Konva.Line({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n strokeWidth: (_b = params.width) !== null && _b !== void 0 ? _b : 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n points: konvaPoints,\n draggable: true,\n strokeScaleEnabled: false,\n dash: LineTypeSpecs.get(params.type) || []\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n }));\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Line\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPoints() {\n return this._ref.points();\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n getLineType() {\n const typeSpecs = this._ref.dash() || [];\n let type;\n switch (typeSpecs) {\n case LineTypeSpecs.get(\"dot\"):\n type = \"dot\";\n break;\n\n case LineTypeSpecs.get(\"dash\"):\n type = \"dash\";\n break;\n\n default:\n type = \"solid\";\n break;\n }\n return type;\n }\n setLineType(type) {\n const specs = LineTypeSpecs.get(type);\n if (specs) this._ref.dash(specs);\n }\n addPoints(points) {\n let newPoints = this._ref.points();\n points.forEach((point => {\n newPoints = newPoints.concat([ point.x, point.y ]);\n }));\n this._ref.points(newPoints);\n }\n}\n\nclass KonvaText {\n constructor(params, ref = null) {\n var _a, _b, _c;\n this.TEXT_FONT_FAMILY = \"Calibri\";\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n if (!params.text) params.text = \"default\";\n this._ref = new Konva.Text({\n x: params.position.x,\n y: params.position.y,\n text: params.text,\n fontSize: (_a = params.fontSize) !== null && _a !== void 0 ? _a : 34,\n fontFamily: this.TEXT_FONT_FAMILY,\n fill: (_b = params.color) !== null && _b !== void 0 ? _b : \"#ff0000\",\n align: \"left\",\n draggable: true,\n rotation: (_c = params.rotation) !== null && _c !== void 0 ? _c : 0\n });\n this._ref.width(this._ref.getTextWidth());\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n const minWidth = 50;\n if (newWidth < minWidth) newWidth = minWidth;\n if (newHeight < Math.round(this.getFontSize())) newHeight = Math.round(this.getFontSize());\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Text\";\n }\n getColor() {\n return this._ref.fill();\n }\n setColor(hex) {\n this._ref.fill(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getText() {\n return this._ref.text();\n }\n setText(text) {\n this._ref.text(text);\n }\n getPosition() {\n return this._ref.getPosition();\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n getFontSize() {\n return this._ref.fontSize();\n }\n setFontSize(size) {\n this._ref.fontSize(size);\n }\n}\n\nclass KonvaRectangle {\n constructor(params, ref = null) {\n var _a, _b, _c, _d;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n this._ref = new Konva.Rect({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n strokeWidth: (_b = params.lineWidth) !== null && _b !== void 0 ? _b : 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n x: params.position.x,\n y: params.position.y,\n width: (_c = params.width) !== null && _c !== void 0 ? _c : 200,\n height: (_d = params.height) !== null && _d !== void 0 ? _d : 200,\n draggable: true,\n strokeScaleEnabled: false\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n const minWidth = 50;\n const minHeight = 50;\n if (newWidth < minWidth) newWidth = minWidth;\n if (newHeight < minHeight) newHeight = minHeight;\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n getPosition() {\n return this._ref.position();\n }\n getWidth() {\n return this._ref.width();\n }\n getHeigth() {\n return this._ref.height();\n }\n setWidth(w) {\n this._ref.width(w);\n }\n setHeight(h) {\n this._ref.height(h);\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Rectangle\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n}\n\nclass KonvaEllipse {\n constructor(params, ref = null) {\n var _a, _b;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n if (!params.radius) params.radius = {\n x: 25,\n y: 25\n };\n this._ref = new Konva.Ellipse({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n strokeWidth: (_b = params.lineWidth) !== null && _b !== void 0 ? _b : 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n x: params.position.x,\n y: params.position.y,\n radiusX: params.radius.x,\n radiusY: params.radius.y,\n draggable: true,\n strokeScaleEnabled: false\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newRadiusX = this._ref.radiusX();\n if (scaleByX) newRadiusX *= attrs.scaleX;\n let newRadiusY = this._ref.radiusY();\n if (scaleByY) newRadiusY *= attrs.scaleY;\n const minRadiusX = 25;\n const minRadiusY = 25;\n if (newRadiusX < minRadiusX) newRadiusX = minRadiusX;\n if (newRadiusY < minRadiusY) newRadiusY = minRadiusY;\n if (e.evt.ctrlKey || e.evt.shiftKey) {\n if (scaleByX) {\n this._ref.radius({\n x: newRadiusX,\n y: newRadiusX\n });\n } else {\n this._ref.radius({\n x: newRadiusY,\n y: newRadiusY\n });\n }\n } else {\n this._ref.radius({\n x: newRadiusX,\n y: newRadiusY\n });\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n getPosition() {\n return this._ref.position();\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n getRadiusX() {\n return this._ref.radiusX();\n }\n setRadiusX(r) {\n this._ref.radiusX(r);\n }\n getRadiusY() {\n return this._ref.radiusY();\n }\n setRadiusY(r) {\n this._ref.radiusY(r);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Ellipse\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n}\n\nclass KonvaArrow {\n constructor(params, ref = null) {\n var _a, _b;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.start) params.start = {\n x: 50,\n y: 50\n };\n if (!params.end) params.end = {\n x: 100,\n y: 100\n };\n this._ref = new Konva.Arrow({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n fill: (_b = params.color) !== null && _b !== void 0 ? _b : \"#ff0000\",\n strokeWidth: 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n points: [ params.start.x, params.start.y, params.end.x, params.end.y ],\n draggable: true,\n strokeScaleEnabled: false\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n }));\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Arrow\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n this._ref.fill(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPoints() {\n const points = this._ref.points();\n return [ {\n x: points[0],\n y: points[1]\n }, {\n x: points[2],\n y: points[3]\n } ];\n }\n setPoints(points) {\n if (points.length === 2) {\n this._ref.points([ points[0].x, points[0].y, points[1].x, points[1].y ]);\n }\n }\n getStartPoint() {\n const points = this._ref.points();\n return {\n x: points[0],\n y: points[1]\n };\n }\n setStartPoint(x, y) {\n const points = this._ref.points();\n this._ref.points([ x, y, points[2], points[3] ]);\n }\n getEndPoint() {\n const points = this._ref.points();\n return {\n x: points[2],\n y: points[3]\n };\n }\n setEndPoint(x, y) {\n const points = this._ref.points();\n this._ref.points([ points[0], points[1], x, y ]);\n }\n}\n\nclass KonvaImage {\n constructor(params, ref = null) {\n var _a, _b;\n this._ratio = 1;\n this.EPSILON = 1e-5;\n this.BASE64_HEADER_START = \"data:image/\";\n this.BASE64_NOT_FOUND = \"\";\n if (ref) {\n if (!ref.src || !ref.src.startsWith(this.BASE64_HEADER_START)) ref.src = this.BASE64_NOT_FOUND;\n if (ref.height() <= this.EPSILON) ref.height(32);\n if (ref.width() <= this.EPSILON) ref.width(32);\n this._ref = ref;\n this._canvasImage = ref.image();\n this._ratio = this._ref.height() <= this.EPSILON || this._ref.width() <= this.EPSILON ? 1 : this._ref.height() / this._ref.width();\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 50,\n y: 50\n };\n if (!params.src || !params.src.startsWith(this.BASE64_HEADER_START)) params.src = this.BASE64_NOT_FOUND;\n this._canvasImage = new Image;\n this._canvasImage.onload = () => {\n this._ref.image(this._canvasImage);\n if (this._ref.height() <= this.EPSILON) this._ref.height(this._canvasImage.height);\n if (this._ref.width() <= this.EPSILON) this._ref.width(this._canvasImage.width);\n this._ratio = this._ref.height() <= this.EPSILON || this._ref.width() <= this.EPSILON ? 1 : this._ref.height() / this._ref.width();\n if ((params.width <= this.EPSILON || params.height <= this.EPSILON) && (params.maxWidth >= this.EPSILON || params.maxWidth >= this.EPSILON)) {\n const heightOutOfCanvas = params.maxHeight - this._canvasImage.height;\n const widthOutOfCanvas = params.maxWidth - this._canvasImage.width;\n if (heightOutOfCanvas <= this.EPSILON || widthOutOfCanvas <= this.EPSILON) {\n if (widthOutOfCanvas <= this.EPSILON && widthOutOfCanvas < heightOutOfCanvas / this._ratio) {\n this._ref.height(params.maxWidth * this._ratio);\n this._ref.width(params.maxWidth);\n } else {\n this._ref.width(params.maxHeight / this._ratio);\n this._ref.height(params.maxHeight);\n }\n }\n }\n };\n this._canvasImage.onerror = () => {\n this._canvasImage.onerror = function() {};\n this._canvasImage.src = this.BASE64_NOT_FOUND;\n };\n this._canvasImage.src = params.src;\n this._ref = new Konva.Image({\n x: params.position.x,\n y: params.position.y,\n image: this._canvasImage,\n width: (_a = params.width) !== null && _a !== void 0 ? _a : 0,\n height: (_b = params.height) !== null && _b !== void 0 ? _b : 0,\n draggable: true\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n if (e.evt.ctrlKey || e.evt.shiftKey) {\n if (scaleByX) {\n this._ref.width(newWidth);\n this._ref.height(newWidth * this._ratio);\n } else {\n this._ref.width(newHeight / this._ratio);\n this._ref.height(newHeight);\n }\n } else {\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n getSrc() {\n return this._canvasImage.src;\n }\n setSrc(src) {\n this._canvasImage.src = src;\n }\n getWidth() {\n return this._ref.width();\n }\n setWidth(w) {\n this._ref.width(w);\n this._ref.height(w * this._ratio);\n }\n getHeight() {\n return this._ref.height();\n }\n setHeight(h) {\n this._ref.height(h);\n this._ref.width(h / this._ratio);\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Image\";\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPosition() {\n return this._ref.getPosition();\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n}\n\nclass KonvaCloud {\n constructor(params, ref = null) {\n var _a, _b, _c, _d;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n const arcRadius = 16;\n this._ref = new Konva.Shape({\n x: params.position.x,\n y: params.position.y,\n width: (_a = params.width) !== null && _a !== void 0 ? _a : 200,\n height: (_b = params.height) !== null && _b !== void 0 ? _b : 200,\n stroke: (_c = params.color) !== null && _c !== void 0 ? _c : \"#ff0000\",\n strokeWidth: (_d = params.lineWidth) !== null && _d !== void 0 ? _d : 4,\n draggable: true,\n strokeScaleEnabled: false,\n globalCompositeOperation: \"source-over\",\n sceneFunc: (context, shape) => {\n function calculateMidpoint(position, width, height) {\n const midX = position.x + width / 2;\n const midY = position.y + height / 2;\n return {\n x: midX,\n y: midY\n };\n }\n const points = [ {\n x: 0,\n y: 0\n }, {\n x: 0 + this._ref.width(),\n y: 0\n }, {\n x: 0 + this._ref.width(),\n y: 0 + this._ref.height()\n }, {\n x: 0,\n y: 0 + this._ref.height()\n }, {\n x: 0,\n y: 0\n } ];\n const midPoint = calculateMidpoint({\n x: 0,\n y: 0\n }, this._ref.width(), this._ref.height());\n const baseArcLength = 30;\n context.beginPath();\n for (let iPoint = 0; iPoint < points.length - 1; iPoint++) {\n let approxArcLength = baseArcLength;\n const dx = points[iPoint + 1].x - points[iPoint].x;\n const dy = points[iPoint + 1].y - points[iPoint].y;\n const length = Math.sqrt(dx * dx + dy * dy);\n const arcCount = Math.floor(length / approxArcLength);\n const lengthMod = length % approxArcLength;\n approxArcLength = baseArcLength + arcCount / lengthMod;\n let pX = points[iPoint].x + dx / arcCount / 2;\n let pY = points[iPoint].y + dy / arcCount / 2;\n const pEndX = points[iPoint + 1].x;\n const pEndY = points[iPoint + 1].y;\n const endAngle = Math.atan((pEndY - pY) / (pEndX - pX));\n const startAngle = endAngle + Math.PI;\n const counterClockwise = pX > midPoint.x && pY > midPoint.y;\n for (let iArc = 0; iArc < arcCount; iArc++) {\n if (counterClockwise) {\n context.arc(pX, pY, arcRadius, endAngle, startAngle);\n } else {\n context.arc(pX, pY, arcRadius, startAngle, endAngle);\n }\n pX += dx / arcCount;\n pY += dy / arcCount;\n }\n }\n context.closePath();\n context.fillStrokeShape(shape);\n }\n });\n this._ref.className = \"Cloud\";\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n const minWidth = 100;\n const minHeight = 100;\n if (newWidth < minWidth) newWidth = minWidth;\n if (newHeight < minHeight) newHeight = minHeight;\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.getSelfRect = () => ({\n x: 0 - arcRadius,\n y: 0 - arcRadius,\n width: this._ref.width() + 2 * arcRadius,\n height: this._ref.height() + 2 * arcRadius\n });\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Cloud\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPosition() {\n return this._ref.position();\n }\n setPosition(x, y) {\n this._ref.position({\n x: x,\n y: y\n });\n }\n getWidth() {\n return this._ref.width();\n }\n setWidth(w) {\n this._ref.width(w);\n }\n getHeigth() {\n return this._ref.height();\n }\n setHeight(h) {\n this._ref.height(h);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n}\n\nconst MarkupMode2Konva = {\n SelectMarkup: {\n name: \"SelectMarkup\",\n initializer: null\n },\n Line: {\n name: \"Line\",\n initializer: (ref, params = null) => new KonvaLine(params, ref)\n },\n Text: {\n name: \"Text\",\n initializer: (ref, params = null) => new KonvaText(params, ref)\n },\n Rectangle: {\n name: \"Rect\",\n initializer: (ref, params = null) => new KonvaRectangle(params, ref)\n },\n Ellipse: {\n name: \"Ellipse\",\n initializer: (ref, params = null) => new KonvaEllipse(params, ref)\n },\n Arrow: {\n name: \"Arrow\",\n initializer: (ref, params = null) => new KonvaArrow(params, ref)\n },\n Image: {\n name: \"Image\",\n initializer: (ref, params = null) => new KonvaImage(params, ref)\n },\n Cloud: {\n name: \"Cloud\",\n initializer: (ref, params = null) => new KonvaCloud(params, ref)\n }\n};\n\nclass KonvaMarkup {\n constructor() {\n this._containerEvents = [];\n this._markupIsActive = false;\n this._markupColor = new MarkupColor(255, 0, 0);\n this.lineWidth = 4;\n this.lineType = \"solid\";\n this.fontSize = 34;\n this.changeActiveDragger = event => {\n const draggerName = event.data;\n this._markupContainer.className = this._container.className.split(\" \").filter((x => !x.startsWith(\"oda-cursor-\"))).filter((x => x)).concat(`oda-cursor-${draggerName.toLowerCase()}`).join(\" \");\n this.removeTextInput();\n this.removeImageInput();\n this.enableEditMode(draggerName);\n };\n this.resizeContainer = entries => {\n const {width: width, height: height} = entries[0].contentRect;\n if (!width || !height) return;\n if (!this._konvaStage) return;\n this._konvaStage.width(width);\n this._konvaStage.height(height);\n };\n this.pan = event => {\n const newPos = {\n x: this._konvaStage.x() + event.dX,\n y: this._konvaStage.y() + event.dY\n };\n this._konvaStage.position(newPos);\n };\n this.zoomAt = event => {\n const newScale = this._konvaStage.scaleX() * event.data;\n this._konvaStage.scale({\n x: newScale,\n y: newScale\n });\n const newPos = {\n x: event.x - (event.x - this._konvaStage.x()) * event.data,\n y: event.y - (event.y - this._konvaStage.y()) * event.data\n };\n this._konvaStage.position(newPos);\n };\n this.redirectToViewer = event => {\n if (this._viewer) this._viewer.emit(event);\n };\n this.getRelativePointPosition = (point, node) => {\n const transform = node.getAbsoluteTransform().copy();\n transform.invert();\n return transform.point(point);\n };\n this.getRelativePointerPosition = node => this.getRelativePointPosition(node.getStage().getPointerPosition(), node);\n }\n initialize(container, containerEvents, viewer, worldTransformer) {\n if (!Konva) throw new Error('Markup error: Konva is not initialized. Forgot to add <script src=\"https://unpkg.com/konva@9/konva.min.js\"><\\/script> to your page?');\n this._viewer = viewer;\n this._worldTransformer = worldTransformer !== null && worldTransformer !== void 0 ? worldTransformer : new WorldTransform;\n this._container = container;\n this._containerEvents = containerEvents !== null && containerEvents !== void 0 ? containerEvents : [];\n this._markupContainer = document.createElement(\"div\");\n this._markupContainer.id = \"markup-container\";\n this._markupContainer.style.position = \"absolute\";\n this._markupContainer.style.top = \"0px\";\n this._markupContainer.style.left = \"0px\";\n this._markupContainer.style.outline = \"0px\";\n this._markupContainer.style.pointerEvents = \"none\";\n const parentDiv = this._container.parentElement;\n parentDiv.appendChild(this._markupContainer);\n this._resizeObserver = new ResizeObserver(this.resizeContainer);\n this._resizeObserver.observe(parentDiv);\n this._markupColor.setColor(255, 0, 0);\n this.initializeKonva();\n if (this._viewer) {\n this._viewer.addEventListener(\"changeactivedragger\", this.changeActiveDragger);\n this._viewer.addEventListener(\"pan\", this.pan);\n this._viewer.addEventListener(\"zoomat\", this.zoomAt);\n }\n }\n dispose() {\n var _a, _b;\n if (this._viewer) {\n this._viewer.removeEventListener(\"zoomat\", this.zoomAt);\n this._viewer.removeEventListener(\"pan\", this.pan);\n this._viewer.removeEventListener(\"changeactivedragger\", this.changeActiveDragger);\n }\n this.destroyKonva();\n (_a = this._resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();\n this._resizeObserver = undefined;\n (_b = this._markupContainer) === null || _b === void 0 ? void 0 : _b.remove();\n this._markupContainer = undefined;\n this._container = undefined;\n this._viewer = undefined;\n this._worldTransformer = undefined;\n this._markupIsActive = false;\n }\n syncOverlay() {}\n clearOverlay() {\n this.removeTextInput();\n this.removeImageInput();\n this.clearSelected();\n this.getObjects().forEach((obj => obj.delete()));\n }\n getMarkupColor() {\n return this._markupColor.asRGB();\n }\n setMarkupColor(r, g, b) {\n this._markupColor.setColor(r, g, b);\n this._viewer.emit({\n type: \"changemarkupcolor\",\n data: {\n r: r,\n g: g,\n b: b\n }\n });\n }\n colorizeAllMarkup(r, g, b) {\n const hexColor = new MarkupColor(r, g, b).asHex();\n this.getObjects().filter((obj => {\n var _a;\n return (_a = obj.setColor) === null || _a === void 0 ? void 0 : _a.call(obj, hexColor);\n }));\n }\n colorizeSelectedMarkups(r, g, b) {\n const hexColor = new MarkupColor(r, g, b).asHex();\n this.getSelectedObjects().filter((obj => {\n var _a;\n return (_a = obj.setColor) === null || _a === void 0 ? void 0 : _a.call(obj, hexColor);\n }));\n }\n setViewpoint(viewpoint) {\n var _a, _b, _c, _d, _e, _f, _g, _h;\n this.clearSelected();\n this.removeTextInput();\n this.removeImageInput();\n this._konvaStage.scale({\n x: 1,\n y: 1\n });\n this._konvaStage.position({\n x: 0,\n y: 0\n });\n const markupColor = ((_a = viewpoint.custom_fields) === null || _a === void 0 ? void 0 : _a.markup_color) || {\n r: 255,\n g: 0,\n b: 0\n };\n this.setMarkupColor(markupColor.r, markupColor.g, markupColor.b);\n (_b = viewpoint.lines) === null || _b === void 0 ? void 0 : _b.forEach((line => {\n const linePoints = [];\n line.points.forEach((point => {\n const screenPoint = this._worldTransformer.worldToScreen(point);\n linePoints.push(screenPoint.x);\n linePoints.push(screenPoint.y);\n }));\n this.addLine(linePoints, line.color, line.type, line.width, line.id);\n }));\n (_c = viewpoint.texts) === null || _c === void 0 ? void 0 : _c.forEach((text => {\n const screenPoint = this._worldTransformer.worldToScreen(text.position);\n this.addText(text.text, screenPoint, text.angle, text.color, text.text_size, text.font_size, text.id);\n }));\n (_d = viewpoint.rectangles) === null || _d === void 0 ? void 0 : _d.forEach((rect => {\n const screenPoint = this._worldTransformer.worldToScreen(rect.position);\n this.addRectangle(screenPoint, rect.width, rect.height, rect.line_width, rect.color, rect.id);\n }));\n (_e = viewpoint.ellipses) === null || _e === void 0 ? void 0 : _e.forEach((ellipse => {\n const screenPoint = this._worldTransformer.worldToScreen(ellipse.position);\n this.addEllipse(screenPoint, ellipse.radius, ellipse.line_width, ellipse.color, ellipse.id);\n }));\n (_f = viewpoint.arrows) === null || _f === void 0 ? void 0 : _f.forEach((arrow => {\n const startPoint = this._worldTransformer.worldToScreen(arrow.start);\n const endPoint = this._worldTransformer.worldToScreen(arrow.end);\n this.addArrow(startPoint, endPoint, arrow.color, arrow.id);\n }));\n (_g = viewpoint.clouds) === null || _g === void 0 ? void 0 : _g.forEach((cloud => {\n const screenPoint = this._worldTransformer.worldToScreen(cloud.position);\n this.addCloud(screenPoint, cloud.width, cloud.height, cloud.line_width, cloud.color, cloud.id);\n }));\n (_h = viewpoint.images) === null || _h === void 0 ? void 0 : _h.forEach((image => {\n const screenPoint = this._worldTransformer.worldToScreen(image.position);\n this.addImage(screenPoint, image.src, image.width, image.height, image.id);\n }));\n }\n getViewpoint(viewpoint) {\n if (!viewpoint) viewpoint = {};\n viewpoint.lines = this.getMarkupLines();\n viewpoint.texts = this.getMarkupTexts();\n viewpoint.arrows = this.getMarkupArrows();\n viewpoint.clouds = this.getMarkupClouds();\n viewpoint.ellipses = this.getMarkupEllipses();\n viewpoint.images = this.getMarkupImages();\n viewpoint.rectangles = this.getMarkupRectangles();\n viewpoint.custom_fields = {\n markup_color: this.getMarkupColor()\n };\n viewpoint.snapshot = {\n data: this.combineMarkupWithDrawing()\n };\n return viewpoint;\n }\n enableEditMode(mode) {\n if (!mode || !MarkupMode2Konva[mode]) {\n this.clearSelected();\n this.removeTextInput();\n this.removeImageInput();\n this._markupContainer.style.pointerEvents = \"none\";\n this._markupIsActive = false;\n } else {\n this._markupMode = mode;\n this._markupContainer.style.pointerEvents = \"all\";\n this._markupIsActive = true;\n }\n return this;\n }\n createObject(type, params) {\n const konvaShape = MarkupMode2Konva[type];\n if (!konvaShape || !konvaShape.initializer) throw new Error(`Markup CreateObject - unsupported markup type ${type}`);\n const object = konvaShape.initializer(null, params);\n this.addObject(object);\n return object;\n }\n getObjects() {\n const objects = [];\n Object.keys(MarkupMode2Konva).forEach((type => {\n const konvaShape = MarkupMode2Konva[type];\n this.konvaLayerFind(type).forEach((ref => objects.push(konvaShape.initializer(ref))));\n }));\n return objects;\n }\n getSelectedObjects() {\n if (!this._konvaTransformer) return [];\n return this._konvaTransformer.nodes().map((ref => {\n const name = ref.className;\n const konvaShape = Object.values(MarkupMode2Konva).find((shape => shape.name === name));\n return konvaShape ? konvaShape.initializer(ref) : null;\n })).filter((x => x));\n }\n selectObjects(objects) {\n if (!this._konvaTransformer) return;\n const selectedObjs = this._konvaTransformer.nodes().concat(objects.map((x => x.ref())));\n this._konvaTransformer.nodes(selectedObjs);\n }\n clearSelected() {\n if (this._konvaTransformer) this._konvaTransformer.nodes([]);\n }\n addObject(object) {\n if (object.type() === \"Image\") this._groupImages.add(object.ref()); else if (object.type() === \"Text\") this._groupTexts.add(object.ref()); else this._groupGeometry.add(object.ref());\n }\n konvaLayerFind(type) {\n if (!this._konvaLayer) return [];\n const konvaShape = MarkupMode2Konva[type];\n if (!konvaShape || !konvaShape.initializer) return [];\n return this._konvaLayer.find(konvaShape.name).filter((ref => ref.parent === this._konvaLayer || ref.parent === this._groupImages || ref.parent === this._groupGeometry || ref.parent === this._groupTexts));\n }\n initializeKonva() {\n const stage = new Konva.Stage({\n container: this._markupContainer,\n width: this._container.clientWidth,\n height: this._container.clientHeight\n });\n this._konvaStage = stage;\n const layer = new Konva.Layer({\n pixelRation: window.devicePixelRatio\n });\n stage.add(layer);\n this._groupImages = new Konva.Group;\n layer.add(this._groupImages);\n this._groupGeometry = new Konva.Group;\n layer.add(this._groupGeometry);\n this._groupTexts = new Konva.Group;\n layer.add(this._groupTexts);\n this._konvaLayer = layer;\n const transformer = new Konva.Transformer({\n shouldOverdrawWholeArea: false,\n keepRatio: false,\n flipEnabled: false\n });\n layer.add(transformer);\n this._konvaTransformer = transformer;\n let isPaint = false;\n let lastLine;\n let mouseDownPos;\n let lastObj;\n stage.on(\"mousedown touchstart\", (e => {\n if (!this._markupIsActive || e.target !== stage || this._markupMode === \"Text\" || this._markupMode === \"Image\") return;\n if (e.target === stage && transformer.nodes().length > 0) {\n transformer.nodes([]);\n return;\n }\n const pos = this.getRelativePointerPosition(stage);\n mouseDownPos = pos;\n isPaint = [ \"Arrow\", \"Cloud\", \"Ellipse\", \"Line\", \"Rectangle\" ].some((m => m === this._markupMode));\n if (this._markupMode === \"Line\") {\n lastLine = this.addLine([ pos.x, pos.y, pos.x, pos.y ]);\n }\n }));\n stage.on(\"mouseup touchend\", (e => {\n if (!this._markupIsActive) return;\n if (isPaint) {\n const pos = this.getRelativePointerPosition(stage);\n const defParams = mouseDownPos && pos.x === mouseDownPos.x && pos.y === mouseDownPos.y;\n const startX = defParams ? mouseDownPos.x : Math.min(mouseDownPos.x, pos.x);\n const startY = defParams ? mouseDownPos.y : Math.min(mouseDownPos.y, pos.y);\n const dX = defParams ? 200 : Math.abs(mouseDownPos.x - pos.x);\n const dY = defParams ? 200 : Math.abs(mouseDownPos.y - pos.y);\n if (defParams) {\n if (this._markupMode === \"Rectangle\") {\n this.addRectangle({\n x: startX,\n y: startY\n }, dX, dY);\n } else if (this._markupMode === \"Ellipse\") {\n this.addEllipse({\n x: startX,\n y: startY\n }, {\n x: dX / 2,\n y: dY / 2\n });\n } else if (this._markupMode === \"Arrow\") {\n this.addArrow({\n x: mouseDownPos.x,\n y: mouseDownPos.y\n }, {\n x: defParams ? mouseDownPos.x + 200 : pos.x,\n y: defParams ? startY : pos.y\n });\n } else if (this._markupMode === \"Cloud\") {\n this.addCloud({\n x: startX,\n y: startY\n }, Math.max(100, dX), Math.max(100, dY));\n }\n }\n }\n lastObj = undefined;\n isPaint = false;\n }));\n stage.on(\"mousemove touchmove\", (e => {\n if (!this._markupIsActive) return;\n if (!isPaint) {\n return;\n }\n const pos = this.getRelativePointerPosition(stage);\n const defParams = mouseDownPos && pos.x === mouseDownPos.x && pos.y === mouseDownPos.y;\n const startX = defParams ? mouseDownPos.x : Math.min(mouseDownPos.x, pos.x);\n const startY = defParams ? mouseDownPos.y : Math.min(mouseDownPos.y, pos.y);\n const dX = defParams ? 200 : Math.abs(mouseDownPos.x - pos.x);\n const dY = defParams ? 200 : Math.abs(mouseDownPos.y - pos.y);\n if (this._markupMode === \"Line\") {\n lastLine.addPoints([ {\n x: pos.x,\n y: pos.y\n } ]);\n } else if (this._markupMode === \"Arrow\") {\n if (lastObj) lastObj.setEndPoint(pos.x, pos.y); else lastObj = this.addArrow({\n x: mouseDownPos.x,\n y: mouseDownPos.y\n }, {\n x: pos.x,\n y: pos.y\n });\n } else if (this._markupMode === \"Rectangle\") {\n if (lastObj) {\n lastObj.setPosition(startX, startY);\n lastObj.setWidth(dX);\n lastObj.setHeight(dY);\n } else lastObj = this.addRectangle({\n x: startX,\n y: startY\n }, dX, dY);\n } else if (this._markupMode === \"Ellipse\") {\n if (lastObj) {\n lastObj.setPosition(startX, startY);\n lastObj.setRadiusX(dX);\n lastObj.setRadiusY(dY);\n } else lastObj = this.addEllipse({\n x: startX,\n y: startY\n }, {\n x: dX,\n y: dY\n });\n } else if (this._markupMode === \"Cloud\") {\n if (lastObj) {\n lastObj.setPosition(startX, startY);\n lastObj.setWidth(Math.max(100, dX));\n lastObj.setHeight(Math.max(100, dY));\n } else lastObj = this.addCloud({\n x: startX,\n y: startY\n }, dX, dY);\n }\n }));\n stage.on(\"click tap\", (e => {\n if (!this._markupIsActive) return;\n if (e.target === stage) {\n if (this._markupMode === \"Text\") {\n if (this._textInputRef && this._textInputRef.value) this.addText(this._textInputRef.value, this._textInputPos, this._textInputAngle); else if (transformer.nodes().length === 0) {\n const pos = this.getRelativePointerPosition(stage);\n this.createTextInput(pos, e.evt.pageX, e.evt.pageY, 0, null);\n }\n } else if (this._markupMode === \"Image\") {\n if (this._imageInputRef && this._imageInputRef.value) this.addImage({\n x: this._imageInputPos.x,\n y: this._imageInputPos.y\n }, this._imageInputRef.value, 0, 0, this._imageInputRef.value); else if (transformer.nodes().length === 0) {\n const pos = this.getRelativePointerPosition(stage);\n this.createImageInput(pos);\n }\n }\n transformer.nodes([]);\n return;\n }\n if (this._markupMode === \"Text\" || this._markupMode === \"SelectMarkup\") {\n if (e.target.className === \"Text\" && transformer.nodes().length === 1 && transformer.nodes()[0] === e.target) {\n if (this._textInputRef && this._textInputRef.value) this.addText(this._textInputRef.value, this._textInputPos, this._textInputAngle); else this.createTextInput({\n x: e.target.attrs.x,\n y: e.target.attrs.y\n }, e.evt.pageX, e.evt.pageY, e.target.attrs.rotation, e.target.attrs.text);\n return;\n } else {\n this.removeTextInput();\n }\n }\n if (this._markupMode === \"Image\" || this._markupMode === \"SelectMarkup\") {\n if (e.target.className === \"Image\" && transformer.nodes().length === 1 && transformer.nodes()[0] === e.target) {\n if (this._imageInputRef && this._imageInputRef.value) this.addImage(this._imageInputPos, this._imageInputRef.value, 0, 0); else this.createImageInput({\n x: e.target.attrs.x,\n y: e.target.attrs.y\n });\n return;\n } else {\n this.removeImageInput();\n }\n }\n if (transformer.nodes().filter((x => x.className === \"Cloud\" || x.className === \"Image\")).length > 0 || e.target.className === \"Cloud\" || e.target.className === \"Image\") {\n transformer.rotateEnabled(false);\n } else {\n transformer.rotateEnabled(true);\n }\n const metaPressed = e.evt.shiftKey || e.evt.ctrlKey || e.evt.metaKey;\n const isSelected = transformer.nodes().indexOf(e.target) >= 0;\n if (!metaPressed && !isSelected) {\n transformer.nodes([ e.target ]);\n } else if (metaPressed && isSelected) {\n const nodes = transformer.nodes().slice();\n nodes.splice(nodes.indexOf(e.target), 1);\n transformer.nodes(nodes);\n } else if (metaPressed && !isSelected) {\n const nodes = transformer.nodes().concat([ e.target ]);\n transformer.nodes(nodes);\n }\n }));\n const container = stage.container();\n container.tabIndex = 1;\n container.focus();\n container.addEventListener(\"keydown\", (e => {\n if (!this._markupIsActive) return;\n if (e.code === \"Delete\") {\n this.getSelectedObjects().forEach((obj => obj.delete()));\n this.clearSelected();\n return;\n }\n e.preventDefault();\n }));\n }\n destroyKonva() {\n var _a;\n this.removeTextInput();\n this.removeImageInput();\n this.clearOverlay();\n (_a = this._konvaStage) === null || _a === void 0 ? void 0 : _a.destroy();\n this._groupImages = undefined;\n this._groupGeometry = undefined;\n this._groupTexts = undefined;\n this._konvaLayer = undefined;\n this._konvaTransformer = undefined;\n this._konvaStage = undefined;\n }\n getMarkupLines() {\n const lines = [];\n this.konvaLayerFind(\"Line\").forEach((ref => {\n const linePoints = ref.points();\n if (!linePoints) return;\n const worldPoints = [];\n const absoluteTransform = ref.getAbsoluteTransform();\n for (let i = 0; i < linePoints.length; i += 2) {\n const atPoint = absoluteTransform.point({\n x: linePoints[i],\n y: linePoints[i + 1]\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n worldPoints.push(worldPoint);\n }\n const konvaLine = new KonvaLine(null, ref);\n const line = {\n id: konvaLine.id(),\n points: worldPoints,\n color: konvaLine.getColor() || \"#ff0000\",\n type: konvaLine.getLineType() || this.lineType,\n width: konvaLine.getLineWidth() || this.lineWidth\n };\n lines.push(line);\n }));\n return lines;\n }\n getMarkupTexts() {\n const texts = [];\n this.konvaLayerFind(\"Text\").forEach((ref => {\n const textSize = .02;\n const textScale = this._worldTransformer.getScale();\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const shape = new KonvaText(null, ref);\n const text = {\n id: shape.id(),\n position: worldPoint,\n text: shape.getText(),\n text_size: textSize * textScale.y,\n angle: shape.getRotation(),\n color: shape.getColor(),\n font_size: shape.getFontSize() * stageAbsoluteTransform.getMatrix()[0]\n };\n texts.push(text);\n }));\n return texts;\n }\n getMarkupRectangles() {\n const rectangles = [];\n this.konvaLayerFind(\"Rectangle\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaRectangle(null, ref);\n const rectangle = {\n id: shape.id(),\n position: worldPoint,\n width: shape.getWidth() * scale,\n height: shape.getHeigth() * scale,\n line_width: shape.getLineWidth(),\n color: shape.getColor()\n };\n rectangles.push(rectangle);\n }));\n return rectangles;\n }\n getMarkupEllipses() {\n const ellipses = [];\n this.konvaLayerFind(\"Ellipse\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaEllipse(null, ref);\n const ellipse = {\n id: shape.id(),\n position: worldPoint,\n radius: {\n x: ref.getRadiusX() * scale,\n y: ref.getRadiusY() * scale\n },\n line_width: shape.getLineWidth(),\n color: shape.getColor()\n };\n ellipses.push(ellipse);\n }));\n return ellipses;\n }\n getMarkupArrows() {\n const arrows = [];\n this.konvaLayerFind(\"Arrow\").forEach((ref => {\n const absoluteTransform = ref.getAbsoluteTransform();\n const atStartPoint = absoluteTransform.point({\n x: ref.points()[0],\n y: ref.points()[1]\n });\n const worldStartPoint = this._worldTransformer.screenToWorld(atStartPoint);\n const atEndPoint = absoluteTransform.point({\n x: ref.points()[2],\n y: ref.points()[3]\n });\n const worldEndPoint = this._worldTransformer.screenToWorld(atEndPoint);\n const shape = new KonvaArrow(null, ref);\n const arrow = {\n id: shape.id(),\n start: worldStartPoint,\n end: worldEndPoint,\n color: shape.getColor()\n };\n arrows.push(arrow);\n }));\n return arrows;\n }\n getMarkupImages() {\n const images = [];\n this.konvaLayerFind(\"Image\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaImage(null, ref);\n const image = {\n id: shape.id(),\n position: worldPoint,\n src: shape.getSrc(),\n width: shape.getWidth() * scale,\n height: shape.getHeight() * scale\n };\n images.push(image);\n }));\n return images;\n }\n getMarkupClouds() {\n const clouds = [];\n this.konvaLayerFind(\"Cloud\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaCloud(null, ref);\n const cloud = {\n id: shape.id(),\n position: worldPoint,\n width: shape.getWidth() * scale,\n height: shape.getHeigth() * scale,\n line_width: shape.getLineWidth(),\n color: shape.getColor()\n };\n clouds.push(cloud);\n }));\n return clouds;\n }\n combineMarkupWithDrawing() {\n this.clearSelected();\n const tempCanvas = document.createElement(\"canvas\");\n if (this._konvaStage) {\n tempCanvas.width = this._konvaStage.width();\n tempCanvas.height = this._konvaStage.height();\n const ctx = tempCanvas.getContext(\"2d\");\n if (this._container instanceof HTMLCanvasElement) ctx.drawImage(this._container, 0, 0);\n ctx.drawImage(this._konvaStage.toCanvas({\n pixelRatio: window.devicePixelRatio\n }), 0, 0);\n }\n return tempCanvas.toDataURL(\"image/jpeg\", .25);\n }\n addLine(linePoints, color, type, width, id) {\n if (!linePoints || linePoints.length === 0) return;\n const points = [];\n for (let i = 0; i < linePoints.length; i += 2) {\n points.push({\n x: linePoints[i],\n y: linePoints[i + 1]\n });\n }\n const konvaLine = new KonvaLine({\n points: points,\n type: type || this.lineType,\n width: width || this.lineWidth,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaLine);\n return konvaLine;\n }\n createTextInput(pos, inputX, inputY, angle, text) {\n if (!this._textInputRef) {\n this._textInputPos = pos;\n this._textInputAngle = angle;\n this._textInputRef = document.createElement(\"textarea\");\n this._textInputRef.style.zIndex = \"9999\";\n this._textInputRef.style.position = \"absolute\";\n this._textInputRef.style.display = \"block\";\n this._textInputRef.style.top = inputY + \"px\";\n this._textInputRef.style.left = inputX + \"px\";\n this._textInputRef.style.fontSize = `${this.fontSize}px`;\n this._textInputRef.style.color = `${this._markupColor.asHex()}`;\n this._textInputRef.style.fontFamily = \"Calibri\";\n this._textInputRef.onkeydown = event => {\n if (event.key === \"Enter\" && !event.shiftKey) {\n event.preventDefault();\n this.addText(this._textInputRef.value, this._textInputPos, this._textInputAngle);\n }\n if (event.key === \"Escape\") {\n event.preventDefault();\n this.removeTextInput();\n }\n };\n if (text) this._textInputRef.value = text;\n document.body.appendChild(this._textInputRef);\n setTimeout((() => {\n this._textInputRef.focus();\n }), 50);\n } else {\n this.removeTextInput();\n }\n }\n removeTextInput() {\n var _a;\n (_a = this._textInputRef) === null || _a === void 0 ? void 0 : _a.remove();\n this._textInputRef = null;\n this._textInputPos = null;\n this._textInputAngle = 0;\n }\n createImageInput(pos) {\n if (!this._imageInputRef) {\n const convertBase64 = file => new Promise(((resolve, reject) => {\n const fileReader = new FileReader;\n fileReader.readAsDataURL(file);\n fileReader.onload = () => {\n resolve(fileReader.result);\n };\n fileReader.onerror = error => {\n reject(error);\n };\n }));\n this._imageInputPos = pos;\n this._imageInputRef = document.createElement(\"input\");\n this._imageInputRef.style.display = \"none\";\n this._imageInputRef.type = \"file\";\n this._imageInputRef.accept = \"image/png, image/jpeg\";\n this._imageInputRef.onchange = async event => {\n const file = event.target.files[0];\n const base64 = await convertBase64(file);\n this.addImage({\n x: this._imageInputPos.x,\n y: this._imageInputPos.y\n }, base64.toString(), 0, 0);\n };\n this._imageInputRef.oncancel = event => {\n this.removeImageInput();\n };\n document.body.appendChild(this._imageInputRef);\n setTimeout((() => {\n this._imageInputRef.click();\n }), 50);\n } else {\n this.removeImageInput();\n }\n }\n removeImageInput() {\n var _a;\n (_a = this._imageInputRef) === null || _a === void 0 ? void 0 : _a.remove();\n this._imageInputRef = null;\n this._imageInputPos = null;\n }\n addText(text, position, angle, color, textSize, fontSize, id) {\n var _a;\n if (!text) return;\n (_a = this.getSelectedObjects().at(0)) === null || _a === void 0 ? void 0 : _a.delete();\n this.clearSelected();\n this.removeTextInput();\n const tolerance = 1e-6;\n if (textSize && textSize > tolerance && (!fontSize || fontSize < tolerance)) {\n const size = .02;\n const scale = this._worldTransformer.getScale();\n fontSize = textSize / (scale.y / size) / 34;\n }\n const konvaText = new KonvaText({\n position: {\n x: position.x,\n y: position.y\n },\n text: text,\n rotation: angle,\n fontSize: fontSize || this.fontSize,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaText);\n return konvaText;\n }\n addRectangle(position, width, height, lineWidth, color, id) {\n if (!position) return;\n const konvaRectangle = new KonvaRectangle({\n position: position,\n width: width,\n height: height,\n lineWidth: lineWidth || this.lineWidth,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaRectangle);\n return konvaRectangle;\n }\n addEllipse(position, radius, lineWidth, color, id) {\n if (!position) return;\n const konvaEllipse = new KonvaEllipse({\n position: position,\n radius: radius,\n lineWidth: lineWidth,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaEllipse);\n return konvaEllipse;\n }\n addArrow(start, end, color, id) {\n if (!start || !end) return;\n const konvaArrow = new KonvaArrow({\n start: start,\n end: end,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaArrow);\n return konvaArrow;\n }\n addCloud(position, width, height, lineWidth, color, id) {\n if (!position || !width || !height) return;\n const konvaCloud = new KonvaCloud({\n position: position,\n width: width,\n height: height,\n color: color || this._markupColor.asHex(),\n lineWidth: lineWidth || this.lineWidth,\n id: id\n });\n this.addObject(konvaCloud);\n return konvaCloud;\n }\n addImage(position, src, width, height, id) {\n var _a;\n if (!position || !src) return;\n (_a = this.getSelectedObjects().at(0)) === null || _a === void 0 ? void 0 : _a.delete();\n this.clearSelected();\n this.removeImageInput();\n const konvaImage = new KonvaImage({\n position: position,\n src: src,\n width: width,\n height: height,\n maxWidth: this._konvaStage.width() - position.x,\n maxHeight: this._konvaStage.height() - position.y,\n id: id\n });\n this.addObject(konvaImage);\n return konvaImage;\n }\n}\n\nexport { KonvaMarkup as Markup };\n//# sourceMappingURL=markup.module.js.map\n","import { EventDispatcher, MOUSE, Quaternion, Spherical, TOUCH, Vector2, Vector3 } from \"three\";\n\n// OrbitControls performs orbiting, dollying (zooming), and panning.\n// Unlike TrackballControls, it maintains the \"up\" direction object.up (+Y by default).\n//\n// Orbit - left mouse / touch: one-finger move\n// Zoom - middle mouse, or mousewheel / touch: two-finger spread or squish\n// Pan - right mouse, or left mouse + ctrl/meta/shiftKey, or arrow keys / touch: two-finger move\n\nconst _changeEvent = { type: \"change\" };\nconst _startEvent = { type: \"start\" };\nconst _endEvent = { type: \"end\" };\n\nconst STATE = {\n NONE: -1,\n ROTATE: 0,\n DOLLY: 1,\n PAN: 2,\n TOUCH_ROTATE: 3,\n TOUCH_PAN: 4,\n TOUCH_DOLLY_PAN: 5,\n TOUCH_DOLLY_ROTATE: 6,\n};\n\nclass OrbitControls extends EventDispatcher {\n constructor(object, domElement) {\n super();\n\n this.object = object;\n this.domElement = domElement;\n this.domElement.style.touchAction = \"none\"; // disable touch scroll\n\n // Set to false to disable this control\n this.enabled = true;\n\n // \"target\" sets the location of focus, where the object orbits around\n this.target = new Vector3();\n\n // How far you can dolly in and out ( PerspectiveCamera only )\n this.minDistance = 0;\n this.maxDistance = Infinity;\n\n // How far you can zoom in and out ( OrthographicCamera only )\n this.minZoom = 0;\n this.maxZoom = Infinity;\n\n // How far you can orbit vertically, upper and lower limits.\n // Range is 0 to Math.PI radians.\n this.minPolarAngle = 0; // radians\n this.maxPolarAngle = Math.PI; // radians\n\n // How far you can orbit horizontally, upper and lower limits.\n // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )\n this.minAzimuthAngle = -Infinity; // radians\n this.maxAzimuthAngle = Infinity; // radians\n\n // Set to true to enable damping (inertia)\n // If damping is enabled, you must call controls.update() in your animation loop\n this.enableDamping = false;\n this.dampingFactor = 0.05;\n\n // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\n // Set to false to disable zooming\n this.enableZoom = true;\n this.zoomSpeed = 1.0;\n\n // Set to false to disable rotating\n this.enableRotate = true;\n this.rotateSpeed = 1.0;\n\n // Set to false to disable panning\n this.enablePan = true;\n this.panSpeed = 1.0;\n this.screenSpacePanning = true; // if false, pan orthogonal to world-space direction camera.up\n this.keyPanSpeed = 7.0; // pixels moved per arrow key push\n\n // Set to true to automatically rotate around the target\n // If auto-rotate is enabled, you must call controls.update() in your animation loop\n this.autoRotate = false;\n this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60\n\n // The four arrow keys\n this.keys = { LEFT: \"ArrowLeft\", UP: \"ArrowUp\", RIGHT: \"ArrowRight\", BOTTOM: \"ArrowDown\" };\n\n // Mouse buttons\n this.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.DOLLY, RIGHT: MOUSE.PAN };\n\n // Touch fingers\n this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n\n // for reset\n this.target0 = this.target.clone();\n this.position0 = this.object.position.clone();\n this.zoom0 = this.object.zoom;\n\n // the target DOM element for key events\n this._domElementKeyEvents = null;\n\n //\n // public methods\n //\n\n this.getPolarAngle = function () {\n return spherical.phi;\n };\n\n this.getAzimuthalAngle = function () {\n return spherical.theta;\n };\n\n this.getDistance = function () {\n return this.object.position.distanceTo(this.target);\n };\n\n this.listenToKeyEvents = function (domElement) {\n domElement.addEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = domElement;\n };\n\n this.stopListenToKeyEvents = function () {\n this._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = null;\n };\n\n this.saveState = function () {\n scope.target0.copy(scope.target);\n scope.position0.copy(scope.object.position);\n scope.zoom0 = scope.object.zoom;\n };\n\n this.reset = function () {\n scope.target.copy(scope.target0);\n scope.object.position.copy(scope.position0);\n scope.object.zoom = scope.zoom0;\n\n scope.object.updateProjectionMatrix();\n scope.dispatchEvent(_changeEvent);\n\n scope.update();\n\n scope.state = STATE.NONE;\n };\n\n // this method is exposed, but perhaps it would be better if we can make it private...\n this.update = (function () {\n const offset = new Vector3();\n\n // so camera.up is the orbit axis\n const quat = new Quaternion().setFromUnitVectors(object.up, new Vector3(0, 1, 0));\n const quatInverse = quat.clone().invert();\n\n const lastPosition = new Vector3();\n const lastQuaternion = new Quaternion();\n const lastTargetPosition = new Vector3();\n\n const twoPI = 2 * Math.PI;\n\n return function update() {\n const position = scope.object.position;\n\n offset.copy(position).sub(scope.target);\n\n // rotate offset to \"y-axis-is-up\" space\n offset.applyQuaternion(quat);\n\n // angle from z-axis around y-axis\n spherical.setFromVector3(offset);\n\n if (scope.autoRotate && scope.state === STATE.NONE) {\n rotateLeft(getAutoRotationAngle());\n }\n\n if (scope.enableDamping) {\n spherical.theta += sphericalDelta.theta * scope.dampingFactor;\n spherical.phi += sphericalDelta.phi * scope.dampingFactor;\n } else {\n spherical.theta += sphericalDelta.theta;\n spherical.phi += sphericalDelta.phi;\n }\n\n // restrict theta to be between desired limits\n\n let min = scope.minAzimuthAngle;\n let max = scope.maxAzimuthAngle;\n\n if (isFinite(min) && isFinite(max)) {\n if (min < -Math.PI) min += twoPI;\n else if (min > Math.PI) min -= twoPI;\n\n if (max < -Math.PI) max += twoPI;\n else if (max > Math.PI) max -= twoPI;\n\n if (min <= max) {\n spherical.theta = Math.max(min, Math.min(max, spherical.theta));\n } else {\n spherical.theta =\n spherical.theta > (min + max) / 2 ? Math.max(min, spherical.theta) : Math.min(max, spherical.theta);\n }\n }\n\n // restrict phi to be between desired limits\n spherical.phi = Math.max(scope.minPolarAngle, Math.min(scope.maxPolarAngle, spherical.phi));\n\n spherical.makeSafe();\n\n spherical.radius *= scope.scale;\n\n // restrict radius to be between desired limits\n spherical.radius = Math.max(scope.minDistance, Math.min(scope.maxDistance, spherical.radius));\n\n // move target to panned location\n\n if (scope.enableDamping === true) {\n scope.target.addScaledVector(scope.panOffset, scope.dampingFactor);\n } else {\n scope.target.add(scope.panOffset);\n }\n\n offset.setFromSpherical(spherical);\n\n // rotate offset back to \"camera-up-vector-is-up\" space\n offset.applyQuaternion(quatInverse);\n\n position.copy(scope.target).add(offset);\n\n scope.object.lookAt(scope.target);\n\n if (scope.enableDamping === true) {\n sphericalDelta.theta *= 1 - scope.dampingFactor;\n sphericalDelta.phi *= 1 - scope.dampingFactor;\n\n scope.panOffset.multiplyScalar(1 - scope.dampingFactor);\n } else {\n sphericalDelta.set(0, 0, 0);\n\n scope.panOffset.set(0, 0, 0);\n }\n\n scope.scale = 1;\n\n // update condition is:\n // min(camera displacement, camera rotation in radians)^2 > EPS\n // using small-angle approximation cos(x/2) = 1 - x^2 / 8\n\n if (\n scope.zoomChanged ||\n lastPosition.distanceToSquared(scope.object.position) > EPS ||\n 8 * (1 - lastQuaternion.dot(scope.object.quaternion)) > EPS ||\n lastTargetPosition.distanceToSquared(scope.target) > 0\n ) {\n scope.dispatchEvent(_changeEvent);\n\n lastPosition.copy(scope.object.position);\n lastQuaternion.copy(scope.object.quaternion);\n lastTargetPosition.copy(scope.target);\n\n scope.zoomChanged = false;\n\n return true;\n }\n\n return false;\n };\n })();\n\n this.dispose = function () {\n scope.domElement.removeEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.removeEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.removeEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.removeEventListener(\"wheel\", onMouseWheel);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n\n if (scope._domElementKeyEvents !== null) {\n scope._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n scope._domElementKeyEvents = null;\n }\n\n //scope.dispatchEvent( { type: 'dispose' } ); // should this be added here?\n };\n\n //\n // internals\n //\n\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const scope = this;\n\n scope.state = STATE.NONE;\n\n const EPS = 0.000001;\n\n // current position in spherical coordinates\n const spherical = new Spherical();\n const sphericalDelta = new Spherical();\n\n scope.scale = 1;\n scope.panOffset = new Vector3();\n scope.zoomChanged = false;\n\n scope.rotateStart = new Vector2();\n scope.rotateEnd = new Vector2();\n scope.rotateDelta = new Vector2();\n\n scope.panStart = new Vector2();\n scope.panEnd = new Vector2();\n scope.panDelta = new Vector2();\n\n scope.dollyStart = new Vector2();\n scope.dollyEnd = new Vector2();\n scope.dollyDelta = new Vector2();\n scope.dollyScale = 0;\n\n scope.pointers = [];\n scope.pointerPositions = {};\n\n function getAutoRotationAngle() {\n return ((2 * Math.PI) / 60 / 60) * scope.autoRotateSpeed;\n }\n\n function getZoomScale() {\n return Math.pow(0.95, scope.zoomSpeed);\n }\n\n function rotateLeft(angle) {\n sphericalDelta.theta -= angle;\n }\n\n function rotateUp(angle) {\n sphericalDelta.phi -= angle;\n }\n\n const panLeft = (function () {\n const v = new Vector3();\n\n return function panLeft(distance, objectMatrix) {\n v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\n v.multiplyScalar(-distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n const panUp = (function () {\n const v = new Vector3();\n\n return function panUp(distance, objectMatrix) {\n if (scope.screenSpacePanning === true) {\n v.setFromMatrixColumn(objectMatrix, 1);\n } else {\n v.setFromMatrixColumn(objectMatrix, 0);\n v.crossVectors(scope.object.up, v);\n }\n\n v.multiplyScalar(distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n // deltaX and deltaY are in pixels; right and down are positive\n const pan = (function () {\n const offset = new Vector3();\n\n return function pan(deltaX, deltaY) {\n const element = scope.domElement;\n\n if (scope.object.isPerspectiveCamera) {\n // perspective\n const position = scope.object.position;\n offset.copy(position).sub(scope.target);\n let targetDistance = offset.length();\n\n // half of the fov is center to top of screen\n targetDistance *= Math.tan(((scope.object.fov / 2) * Math.PI) / 180.0);\n\n // we use only clientHeight here so aspect ratio does not distort speed\n panLeft((2 * deltaX * targetDistance) / element.clientHeight, scope.object.matrix);\n panUp((2 * deltaY * targetDistance) / element.clientHeight, scope.object.matrix);\n } else if (scope.object.isOrthographicCamera) {\n // orthographic\n panLeft(\n (deltaX * (scope.object.right - scope.object.left)) / scope.object.zoom / element.clientWidth,\n scope.object.matrix\n );\n panUp(\n (deltaY * (scope.object.top - scope.object.bottom)) / scope.object.zoom / element.clientHeight,\n scope.object.matrix\n );\n } else {\n // camera neither orthographic nor perspective\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.\");\n scope.enablePan = false;\n }\n };\n })();\n\n function dollyOut(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale /= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom * dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n function dollyIn(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale *= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom / dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n //\n // event callbacks - update the object state\n //\n\n function handleMouseDownRotate(event) {\n scope.rotateStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownDolly(event) {\n scope.dollyStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownPan(event) {\n scope.panStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseMoveRotate(event) {\n scope.rotateEnd.set(event.clientX, event.clientY);\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n\n scope.update();\n }\n\n function handleMouseMoveDolly(event) {\n scope.dollyEnd.set(event.clientX, event.clientY);\n\n scope.dollyDelta.subVectors(scope.dollyEnd, scope.dollyStart);\n\n if (scope.dollyDelta.y < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyOut(getZoomScale());\n } else if (scope.dollyDelta.y > 0) {\n scope.dollyScale = getZoomScale();\n dollyIn(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n }\n\n function handleMouseMovePan(event) {\n scope.panEnd.set(event.clientX, event.clientY);\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n\n scope.update();\n }\n\n function handleMouseWheel(event) {\n scope.dollyEnd.set(scope.domElement.clientWidth / 2, scope.domElement.clientHeight / 2);\n\n scope.dollyDelta.set(event.deltaX, event.deltaY);\n\n if (event.deltaY < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyIn(getZoomScale());\n } else if (event.deltaY > 0) {\n scope.dollyScale = getZoomScale();\n dollyOut(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n\n if (event.deltaY !== 0) {\n scope.state = STATE.DOLLY;\n scope.dispatchEvent(_changeEvent);\n scope.state = STATE.NONE;\n }\n }\n\n function handleKeyDown(event) {\n let needsUpdate = false;\n\n switch (event.code) {\n case scope.keys.UP:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.BOTTOM:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, -scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.LEFT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.RIGHT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(-scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n }\n\n if (needsUpdate) {\n // prevent the browser from scrolling on cursor keys\n event.preventDefault();\n\n scope.update();\n }\n }\n\n function handleTouchStartRotate() {\n if (scope.pointers.length === 1) {\n scope.rotateStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.rotateStart.set(x, y);\n }\n }\n\n function handleTouchStartPan() {\n if (scope.pointers.length === 1) {\n scope.panStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.panStart.set(x, y);\n }\n }\n\n function handleTouchStartDolly() {\n const dx = scope.pointers[0].pageX - scope.pointers[1].pageX;\n const dy = scope.pointers[0].pageY - scope.pointers[1].pageY;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyStart.set(0, distance);\n }\n\n function handleTouchStartDollyPan() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enablePan) handleTouchStartPan();\n }\n\n function handleTouchStartDollyRotate() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enableRotate) handleTouchStartRotate();\n }\n\n function handleTouchMoveRotate(event) {\n if (scope.pointers.length == 1) {\n scope.rotateEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.rotateEnd.set(x, y);\n }\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n }\n\n function handleTouchMovePan(event) {\n if (scope.pointers.length === 1) {\n scope.panEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.panEnd.set(x, y);\n }\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n }\n\n function handleTouchMoveDolly(event) {\n const position = getSecondPointerPosition(event);\n\n const dx = event.pageX - position.x;\n const dy = event.pageY - position.y;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyEnd.set(0, distance);\n\n scope.dollyDelta.set(0, Math.pow(scope.dollyEnd.y / scope.dollyStart.y, scope.zoomSpeed));\n\n dollyOut(scope.dollyDelta.y);\n\n scope.dollyStart.copy(scope.dollyEnd);\n }\n\n function handleTouchMoveDollyPan(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enablePan) handleTouchMovePan(event);\n }\n\n function handleTouchMoveDollyRotate(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enableRotate) handleTouchMoveRotate(event);\n }\n\n //\n // event handlers - FSM: listen for events and reset state\n //\n\n function onPointerDown(event) {\n if (scope.enabled === false) return;\n\n if (scope.pointers.length === 0) {\n scope.domElement.setPointerCapture(event.pointerId);\n\n scope.domElement.addEventListener(\"pointermove\", onPointerMove);\n scope.domElement.addEventListener(\"pointerup\", onPointerUp);\n }\n\n //\n\n addPointer(event);\n\n if (event.pointerType === \"touch\") {\n onTouchStart(event);\n } else {\n onMouseDown(event);\n }\n }\n\n function onPointerMove(event) {\n if (scope.enabled === false) return;\n\n if (event.pointerType === \"touch\") {\n onTouchMove(event);\n } else {\n onMouseMove(event);\n }\n }\n\n function onPointerUp(event) {\n removePointer(event);\n\n if (scope.pointers.length === 0) {\n scope.domElement.releasePointerCapture(event.pointerId);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n }\n\n scope.dispatchEvent(_endEvent);\n\n scope.state = STATE.NONE;\n }\n\n function onMouseDown(event) {\n let mouseAction;\n\n switch (event.button) {\n case 0:\n mouseAction = scope.mouseButtons.LEFT;\n break;\n\n case 1:\n mouseAction = scope.mouseButtons.MIDDLE;\n break;\n\n case 2:\n mouseAction = scope.mouseButtons.RIGHT;\n break;\n\n default:\n mouseAction = -1;\n }\n\n switch (mouseAction) {\n case MOUSE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseDownDolly(event);\n\n scope.state = STATE.DOLLY;\n\n break;\n\n case MOUSE.ROTATE:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n } else {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n }\n\n break;\n\n case MOUSE.PAN:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n } else {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onMouseMove(event) {\n switch (scope.state) {\n case STATE.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleMouseMoveRotate(event);\n\n break;\n\n case STATE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseMoveDolly(event);\n\n break;\n\n case STATE.PAN:\n if (scope.enablePan === false) return;\n\n handleMouseMovePan(event);\n\n break;\n }\n }\n\n function onMouseWheel(event) {\n if (scope.enabled === false || scope.enableZoom === false || scope.state !== STATE.NONE) return;\n\n event.preventDefault();\n\n scope.dispatchEvent(_startEvent);\n\n handleMouseWheel(event);\n\n scope.dispatchEvent(_endEvent);\n }\n\n function onKeyDown(event) {\n if (scope.enabled === false || scope.enablePan === false) return;\n\n handleKeyDown(event);\n }\n\n function onTouchStart(event) {\n trackPointer(event);\n\n switch (scope.pointers.length) {\n case 1:\n switch (scope.touches.ONE) {\n case TOUCH.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchStartRotate();\n\n scope.state = STATE.TOUCH_ROTATE;\n\n break;\n\n case TOUCH.PAN:\n if (scope.enablePan === false) return;\n\n handleTouchStartPan();\n\n scope.state = STATE.TOUCH_PAN;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n case 2:\n switch (scope.touches.TWO) {\n case TOUCH.DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchStartDollyPan();\n\n scope.state = STATE.TOUCH_DOLLY_PAN;\n\n break;\n\n case TOUCH.DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchStartDollyRotate();\n\n scope.state = STATE.TOUCH_DOLLY_ROTATE;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onTouchMove(event) {\n trackPointer(event);\n\n switch (scope.state) {\n case STATE.TOUCH_ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchMoveRotate(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_PAN:\n if (scope.enablePan === false) return;\n\n handleTouchMovePan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchMoveDollyPan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchMoveDollyRotate(event);\n\n scope.update();\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n }\n\n function onContextMenu(event) {\n if (scope.enabled === false) return;\n\n event.preventDefault();\n }\n\n function addPointer(event) {\n scope.pointers.push(event);\n }\n\n function removePointer(event) {\n delete scope.pointerPositions[event.pointerId];\n\n for (let i = 0; i < scope.pointers.length; i++) {\n if (scope.pointers[i].pointerId == event.pointerId) {\n scope.pointers.splice(i, 1);\n return;\n }\n }\n }\n\n function trackPointer(event) {\n let position = scope.pointerPositions[event.pointerId];\n\n if (position === undefined) {\n position = new Vector2();\n scope.pointerPositions[event.pointerId] = position;\n }\n\n position.set(event.pageX, event.pageY);\n }\n\n function getSecondPointerPosition(event) {\n const pointer = event.pointerId === scope.pointers[0].pointerId ? scope.pointers[1] : scope.pointers[0];\n\n return scope.pointerPositions[pointer.pointerId];\n }\n\n //\n\n scope.domElement.addEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.addEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.addEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.addEventListener(\"wheel\", onMouseWheel, { passive: false });\n\n // force an update at start\n\n this.update();\n }\n}\n\nexport { OrbitControls, STATE };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE, TOUCH } from \"three\";\n\nimport type { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitControls, STATE } from \"../controls/OrbitControls.js\";\n\nexport class OrbitDragger implements IDisposable {\n protected viewer: Viewer;\n protected orbit: OrbitControls;\n protected changed: boolean;\n\n constructor(viewer: Viewer) {\n this.orbit = new OrbitControls(viewer.camera, viewer.canvas);\n this.orbit.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n this.orbit.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n this.orbit.screenSpacePanning = true;\n this.orbit.rotateSpeed = 0.33;\n this.orbit.addEventListener(\"start\", this.controlsStart);\n this.orbit.addEventListener(\"change\", this.controlsChange);\n this.changed = false;\n this.viewer = viewer;\n this.viewer.on(\"geometryend\", this.updateControls);\n this.viewer.on(\"viewposition\", this.updateControls);\n this.viewer.on(\"zoom\", this.updateControls);\n this.viewer.on(\"drawviewpoint\", this.updateControls);\n this.viewer.on(\"contextmenu\", this.stopContextMenu);\n this.updateControls();\n }\n\n dispose(): void {\n this.viewer.off(\"geometryend\", this.updateControls);\n this.viewer.off(\"viewposition\", this.updateControls);\n this.viewer.off(\"zoom\", this.updateControls);\n this.viewer.off(\"drawviewpoint\", this.updateControls);\n this.viewer.off(\"contextmenu\", this.stopContextMenu);\n\n this.orbit.removeEventListener(\"change\", this.controlsChange);\n this.orbit.dispose();\n }\n\n updateControls = () => {\n this.orbit.maxDistance = this.viewer.camera.far;\n this.orbit.minDistance = this.viewer.camera.near;\n this.orbit.target.copy(this.viewer.target);\n this.orbit.update();\n };\n\n controlsStart = () => {\n this.changed = false;\n };\n\n controlsChange = () => {\n this.viewer.target.copy(this.orbit.target);\n this.viewer.update();\n\n switch (this.orbit.state) {\n case STATE.PAN:\n case STATE.TOUCH_PAN:\n this.viewer.emitEvent({\n type: \"pan\",\n x: this.orbit.panEnd.x,\n y: this.orbit.panEnd.y,\n dX: this.orbit.panDelta.x,\n dY: this.orbit.panDelta.y,\n });\n break;\n\n case STATE.DOLLY:\n this.viewer.emitEvent({\n type: \"zoomat\",\n data: this.orbit.dollyScale,\n x: this.orbit.dollyEnd.x,\n y: this.orbit.dollyEnd.y,\n });\n break;\n }\n\n this.changed = true;\n };\n\n stopContextMenu = (event: PointerEvent) => {\n if (this.changed) {\n event.preventDefault();\n event.stopPropagation();\n }\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class PanDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.PAN, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.PAN, TWO: TOUCH.DOLLY_ROTATE };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ZoomDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.DOLLY, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.DOLLY_PAN, TWO: TOUCH.DOLLY_PAN };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Clock, Camera, Controls, Quaternion, Vector2, Vector3 } from \"three\";\n\ninterface WalkControlsEventMap {\n change: { type: \"change\" };\n walkspeedchange: { type: \"walkspeedchange\"; data: number };\n}\n\nexport class WalkControls extends Controls<WalkControlsEventMap> {\n public movementSpeed = 0.2;\n public lookSpeed = 5;\n public multiplier = 5;\n\n private moveKeys: Set<string>;\n private moveWheel = 0;\n private moveClock: Clock;\n\n private quaternion: Quaternion;\n private downPosition: Vector2;\n private mouseDragOn = false;\n public rotateDelta: Vector2;\n\n constructor(camera: Camera, canvas: HTMLElement) {\n super(camera, canvas);\n\n this.moveKeys = new Set();\n this.moveClock = new Clock();\n\n this.quaternion = camera.quaternion.clone();\n this.downPosition = new Vector2(0, 0);\n this.rotateDelta = new Vector2(0, 0);\n\n this.domElement.addEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.addEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.addEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.addEventListener(\"wheel\", this.onWheel);\n\n window.addEventListener(\"keydown\", this.onKeyDown);\n window.addEventListener(\"keyup\", this.onKeyUp);\n }\n\n override dispose() {\n this.domElement.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.removeEventListener(\"wheel\", this.onWheel);\n\n window.removeEventListener(\"keydown\", this.onKeyDown);\n window.removeEventListener(\"keyup\", this.onKeyUp);\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.domElement.setPointerCapture(event.pointerId);\n this.downPosition.set(event.clientX, event.clientY);\n this.quaternion.copy(this.object.quaternion);\n this.mouseDragOn = true;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (!this.mouseDragOn) return;\n\n const movePosition = new Vector2(event.clientX, event.clientY);\n if (this.downPosition.distanceTo(movePosition) === 0) return;\n\n this.rotateDelta.copy(this.downPosition).sub(movePosition);\n this.rotateCamera(this.rotateDelta);\n this.dispatchEvent({ type: \"change\" });\n };\n\n onPointerUp = (event: PointerEvent) => {\n this.domElement.releasePointerCapture(event.pointerId);\n this.mouseDragOn = false;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.domElement.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onWheel = (event: WheelEvent) => {\n this.moveWheel = event.deltaY;\n this.update();\n };\n\n onKeyDown = (event: KeyboardEvent) => {\n switch (event.code) {\n case \"NumpadSubtract\":\n case \"Minus\":\n if (this.multiplier > 1) {\n this.multiplier = this.multiplier - 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"NumpadAdd\":\n case \"Equal\":\n if (this.multiplier < 10) {\n this.multiplier = this.multiplier + 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"ArrowLeft\":\n case \"ArrowRight\":\n case \"ArrowUp\":\n case \"ArrowDown\":\n case \"KeyW\":\n case \"KeyS\":\n case \"KeyA\":\n case \"KeyD\":\n case \"KeyQ\":\n case \"KeyE\":\n this.moveKeys.add(event.code);\n this.update();\n break;\n }\n };\n\n onKeyUp = (event: KeyboardEvent) => {\n if (this.moveKeys.delete(event.code)) this.update();\n };\n\n override update() {\n if (this.moveKeys.size > 0) {\n const timeDelta = this.moveClock.getDelta();\n const moveDelta = timeDelta * this.movementSpeed * this.multiplier;\n\n if (this.moveKeys.has(\"KeyW\")) this.object.translateZ(-moveDelta);\n if (this.moveKeys.has(\"KeyS\")) this.object.translateZ(moveDelta);\n\n if (this.moveKeys.has(\"KeyA\")) this.object.translateX(-moveDelta);\n if (this.moveKeys.has(\"KeyD\")) this.object.translateX(moveDelta);\n\n if (this.moveKeys.has(\"KeyQ\")) this.object.translateY(moveDelta);\n if (this.moveKeys.has(\"KeyE\")) this.object.translateY(-moveDelta);\n\n const lookDelta = this.lookSpeed + (this.multiplier - 1);\n\n if (this.moveKeys.has(\"ArrowUp\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, -lookDelta / 2)));\n if (this.moveKeys.has(\"ArrowDown\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, lookDelta / 2)));\n\n if (this.moveKeys.has(\"ArrowLeft\")) this.rotateCamera(this.rotateDelta.add(new Vector2(lookDelta, 0)));\n if (this.moveKeys.has(\"ArrowRight\")) this.rotateCamera(this.rotateDelta.add(new Vector2(-lookDelta, 0)));\n\n this.moveWheel = 0;\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveWheel !== 0) {\n const moveDelta = this.moveWheel * 0.0001 * this.movementSpeed * this.multiplier;\n\n this.object.translateZ(-moveDelta);\n this.moveWheel += -1 * Math.sign(this.moveWheel);\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveKeys.size === 0 && this.moveWheel === 0) {\n this.moveClock.stop();\n this.moveClock.autoStart = true;\n }\n }\n\n rotateCamera(delta: Vector2) {\n const rotateX = (Math.PI * delta.x) / this.domElement.clientWidth;\n const rotateY = (Math.PI * delta.y) / this.domElement.clientHeight;\n\n const xRotation = new Quaternion();\n xRotation.setFromAxisAngle(this.object.up, rotateX);\n\n const yRotation = new Quaternion();\n yRotation.setFromAxisAngle(new Vector3(1, 0, 0), rotateY);\n\n const quaternion = this.quaternion.clone();\n quaternion.premultiply(xRotation).multiply(yRotation).normalize();\n\n this.object.setRotationFromQuaternion(quaternion);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { WalkControls } from \"../controls/WalkControls\";\n\nexport class WalkDragger {\n protected viewer: Viewer;\n public controls: WalkControls;\n\n constructor(viewer: Viewer) {\n this.controls = new WalkControls(viewer.camera, viewer.canvas);\n this.controls.addEventListener(\"change\", this.controlsChange);\n this.controls.addEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.viewer = viewer;\n this.viewer.on(\"render\", this.viewerRender);\n this.viewer.on(\"zoom\", this.viewerZoom);\n this.updateControls();\n }\n\n dispose() {\n this.viewer.off(\"render\", this.viewerRender);\n this.viewer.off(\"zoom\", this.viewerZoom);\n this.controls.removeEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.controls.removeEventListener(\"change\", this.controlsChange);\n this.controls.dispose();\n }\n\n updateControls = () => {\n const size = this.viewer.extents.getSize(new Vector3());\n this.controls.movementSpeed = Math.min(size.x, size.y, size.z) / 2;\n };\n\n controlsChange = () => {\n this.viewer.update();\n };\n\n walkspeedChange = (event: any) => {\n this.viewer.emitEvent(event);\n };\n\n viewerRender = () => {\n this.controls.update();\n };\n\n viewerZoom = () => {\n this.controls.rotateDelta.set(0, 0);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport {\n BufferGeometry,\n DoubleSide,\n Float32BufferAttribute,\n Line,\n LineBasicMaterial,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n Plane,\n Vector3,\n} from \"three\";\n\nclass PlaneHelper extends Line {\n public plane: Plane;\n public size: number;\n public offset: Vector3;\n public helper: Object3D;\n\n constructor(plane: Plane, size = 1, color = 0xffff00, offset: Vector3 = new Vector3()) {\n // const positions = [1, -1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n const positions = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n\n const geometry = new BufferGeometry();\n geometry.setAttribute(\"position\", new Float32BufferAttribute(positions, 3));\n geometry.computeBoundingSphere();\n\n super(geometry, new LineBasicMaterial({ color, toneMapped: false }));\n\n (this as any).type = \"PlaneHelper\";\n\n this.plane = plane;\n this.size = size;\n this.offset = offset;\n\n const positions2 = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, -1, 0, 1, -1, 0];\n\n const geometry2 = new BufferGeometry();\n geometry2.setAttribute(\"position\", new Float32BufferAttribute(positions2, 3));\n geometry2.computeBoundingSphere();\n\n this.helper = new Mesh(\n geometry2,\n new MeshBasicMaterial({\n color,\n opacity: 0.2,\n transparent: true,\n depthWrite: false,\n toneMapped: false,\n side: DoubleSide,\n })\n );\n this.add(this.helper);\n }\n\n dispose() {\n this.geometry.dispose();\n (this.material as any).dispose();\n (this.children[0] as any).geometry.dispose();\n (this.children[0] as any).material.dispose();\n }\n\n override updateMatrixWorld(force: boolean) {\n this.position.set(0, 0, 0);\n this.lookAt(this.plane.normal);\n\n this.position.copy(this.offset);\n this.translateZ(-(this.offset.dot(this.plane.normal) + this.plane.constant));\n\n this.scale.set(0.5 * this.size, 0.5 * this.size, 1);\n\n super.updateMatrixWorld(force);\n }\n}\n\nexport { PlaneHelper };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Object3D, Plane, Vector3 } from \"three\";\nimport { TransformControls } from \"three/examples/jsm/controls/TransformControls.js\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { PlaneHelper } from \"../helpers/PlaneHelper\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nexport class CuttingPlaneDragger extends OrbitDragger {\n protected plane: Plane;\n protected planeCenter: Object3D;\n protected planeHelper: PlaneHelper;\n protected transform: TransformControls;\n\n constructor(viewer: Viewer, normal: Vector3, color: number) {\n super(viewer);\n\n const size = viewer.extents.getSize(new Vector3()).length();\n const center = viewer.extents.getCenter(new Vector3());\n const constant = -center.dot(normal);\n\n this.plane = new Plane(normal, constant);\n\n if (!viewer.renderer.clippingPlanes) viewer.renderer.clippingPlanes = [];\n viewer.renderer.clippingPlanes.push(this.plane);\n\n this.planeHelper = new PlaneHelper(this.plane, size, color, center);\n this.viewer.helpers.add(this.planeHelper);\n\n this.planeCenter = new Object3D();\n this.planeCenter.position.copy(viewer.extents.getCenter(new Vector3()));\n this.viewer.helpers.add(this.planeCenter);\n\n this.transform = new TransformControls(viewer.camera, viewer.canvas);\n this.transform.showX = !!normal.x;\n this.transform.showY = !!normal.y;\n this.transform.showZ = !!normal.z;\n this.transform.attach(this.planeCenter);\n this.transform.addEventListener(\"change\", this.transformChange);\n this.transform.addEventListener(\"dragging-changed\", this.transformDrag);\n this.viewer.helpers.add(this.transform.getHelper());\n\n this.viewer.on(\"explode\", this.viewerExplode);\n this.viewer.canvas.addEventListener(\"dblclick\", this.onDoubleClick, true);\n this.viewer.update();\n }\n\n override dispose() {\n this.viewer.off(\"explode\", this.viewerExplode);\n this.viewer.canvas.removeEventListener(\"dblclick\", this.onDoubleClick, true);\n\n this.transform.removeEventListener(\"change\", this.transformChange);\n this.transform.removeEventListener(\"dragging-changed\", this.transformDrag);\n this.transform.getHelper().removeFromParent();\n this.transform.detach();\n this.transform.dispose();\n\n this.planeHelper.removeFromParent();\n this.planeHelper.dispose();\n\n this.planeCenter.removeFromParent();\n\n // this.viewer.renderer.clippingPlanes = this.viewer.renderer.clippingPlanes.filter((plane) => plane !== this.plane);\n // this.viewer.update();\n\n super.dispose();\n }\n\n transformChange = () => {\n this.plane.constant = -this.planeCenter.position.dot(this.plane.normal);\n this.viewer.update();\n };\n\n transformDrag = (event) => {\n this.orbit.enabled = !event.value;\n };\n\n viewerExplode = () => {\n this.planeHelper.size = this.viewer.extents.getSize(new Vector3()).length();\n this.viewer.update();\n };\n\n onDoubleClick = (event: PointerEvent) => {\n event.stopPropagation();\n\n this.plane.negate();\n this.viewer.update();\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneXAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(1, 0, 0), 0xff0000);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneYAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 1, 0), 0x00ff00);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneZAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 0, 1), 0x0000ff);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Camera, Matrix4, Object3D, Scene, Raycaster, Vector2, Vector3, Vector4 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nconst PRECISION = 0.01;\n\nexport class MeasureLineDragger extends OrbitDragger {\n private overlay: MeasureOverlay;\n private line: MeasureLine;\n private snapper: MeasureSnapper;\n\n constructor(viewer: Viewer) {\n super(viewer);\n\n this.overlay = new MeasureOverlay(viewer.camera, viewer.canvas);\n this.overlay.attach();\n\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n\n this.snapper = new MeasureSnapper(viewer.camera, viewer.canvas);\n this.snapper.update(viewer.scene);\n\n this.viewer.canvas.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.addEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.addEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.addEventListener(\"render\", this.renderOverlay);\n this.viewer.addEventListener(\"hide\", this.updateSnapper);\n this.viewer.addEventListener(\"isolate\", this.updateSnapper);\n this.viewer.addEventListener(\"showall\", this.updateSnapper);\n }\n\n override dispose() {\n this.viewer.canvas.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.removeEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.removeEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.removeEventListener(\"render\", this.renderOverlay);\n this.viewer.removeEventListener(\"hide\", this.updateSnapper);\n this.viewer.removeEventListener(\"isolate\", this.updateSnapper);\n this.viewer.removeEventListener(\"showall\", this.updateSnapper);\n\n this.overlay.detach();\n this.overlay.dispose();\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.line.startPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n this.viewer.canvas.setPointerCapture(event.pointerId);\n this.orbit.enabled = !this.line.startPoint;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (this.orbit.enabled && this.orbit.state !== -1) return;\n\n this.line.endPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n if (this.line.startPoint) this.changed = true; // <- to prevent context menu\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (this.line.startPoint && this.line.endPoint && this.line.getDistance() >= PRECISION) {\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n } else {\n this.line.startPoint = undefined;\n this.line.endPoint = undefined;\n this.line.render();\n }\n\n this.viewer.canvas.releasePointerCapture(event.pointerId);\n this.orbit.enabled = true;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.viewer.canvas.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onPointerLeave = () => {\n this.line.endPoint = undefined;\n this.line.render();\n };\n\n renderOverlay = () => {\n this.overlay.render();\n };\n\n updateSnapper = () => {\n this.snapper.update(this.viewer.scene);\n };\n}\n\nclass MeasureSnapper {\n private camera: Camera;\n private canvas: HTMLCanvasElement;\n private objects: Object3D[] = [];\n private raycaster: Raycaster;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.raycaster = new Raycaster();\n }\n\n getSnapPoint(event: PointerEvent): Vector3 | undefined {\n const mouse = new Vector2(event.clientX, event.clientY);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.camera);\n\n this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n const intersects = this.raycaster.intersectObjects(this.objects, false);\n if (intersects.length === 0) return undefined;\n\n return intersects[0].point;\n }\n\n update(scene: Scene) {\n this.objects = [];\n scene.traverseVisible((child) => this.objects.push(child));\n }\n}\n\nclass MeasureOverlay {\n public camera: Camera;\n public canvas: HTMLCanvasElement;\n public container: HTMLElement;\n public lines: MeasureLine[] = [];\n public projector: MeasureProjector;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.projector = new MeasureProjector(camera, canvas);\n }\n\n attach() {\n this.container = document.createElement(\"div\");\n this.container.id = \"measure-container\";\n this.container.style.background = \"rgba(0,0,0,0)\";\n this.container.style.position = \"absolute\";\n this.container.style.top = \"0px\";\n this.container.style.left = \"0px\";\n this.container.style.width = \"100%\";\n this.container.style.height = \"100%\";\n this.container.style.outline = \"none\";\n this.container.style.pointerEvents = \"none\";\n this.container.style.overflow = \"hidden\";\n\n this.canvas.parentElement.appendChild(this.container);\n }\n\n dispose() {\n this.clear();\n }\n\n detach() {\n this.container.remove();\n this.container = undefined;\n }\n\n clear() {\n this.lines.forEach((line) => line.dispose());\n this.lines = [];\n }\n\n render() {\n this.projector.updateProjectionMatrix();\n this.lines.forEach((line) => line.render());\n }\n\n update() {\n this.lines.forEach((line) => line.update());\n }\n\n addLine(line: MeasureLine) {\n this.lines.push(line);\n }\n\n removeLine(line: MeasureLine) {\n this.lines = this.lines.filter((x) => x !== line);\n }\n}\n\nconst _middlePoint = new Vector3();\n\nclass MeasureLine {\n private overlay: MeasureOverlay;\n\n private elementStartPoint: HTMLElement;\n private elementEndPoint: HTMLElement;\n private elementLine: HTMLElement;\n private elementLabel: HTMLElement;\n\n public startPoint: Vector3;\n public endPoint: Vector3;\n\n public id = Date.now();\n public unit = \"\";\n public scale = 1.0;\n public size = 10.0;\n public lineWidth = 2;\n\n public style = {\n border: \"2px solid #FFFFFF\",\n background: \"#009bff\",\n boxShadow: \"0 0 10px rgba(0,0,0,0.5)\",\n color: \"white\",\n font: \"1rem system-ui\",\n };\n\n constructor(overlay: MeasureOverlay) {\n this.overlay = overlay;\n\n this.elementStartPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementEndPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLine = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLabel = overlay.container.appendChild(document.createElement(\"div\"));\n\n this.update();\n }\n\n dispose() {\n this.elementStartPoint.remove();\n this.elementEndPoint.remove();\n this.elementLine.remove();\n this.elementLabel.remove();\n }\n\n render() {\n const projector = this.overlay.projector;\n\n if (this.startPoint) {\n const { point, visible } = projector.projectPoint(this.startPoint);\n\n this.elementStartPoint.style.display = visible ? \"block\" : \"none\";\n this.elementStartPoint.style.left = `${point.x}px`;\n this.elementStartPoint.style.top = `${point.y}px`;\n } else {\n this.elementStartPoint.style.display = \"none\";\n }\n\n if (this.endPoint) {\n const { point, visible } = projector.projectPoint(this.endPoint);\n\n this.elementEndPoint.style.display = visible ? \"block\" : \"none\";\n this.elementEndPoint.style.left = `${point.x}px`;\n this.elementEndPoint.style.top = `${point.y}px`;\n } else {\n this.elementEndPoint.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n const { point1, point2, visible } = projector.projectLine(this.startPoint, this.endPoint);\n\n point2.sub(point1);\n const angle = point2.angle();\n const width = point2.length();\n\n this.elementLine.style.display = visible ? \"block\" : \"none\";\n this.elementLine.style.left = `${point1.x}px`;\n this.elementLine.style.top = `${point1.y}px`;\n this.elementLine.style.width = `${width}px`;\n this.elementLine.style.transform = `translate(0px, ${-this.lineWidth / 2}px) rotate(${angle}rad)`;\n } else {\n this.elementLine.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n _middlePoint.lerpVectors(this.startPoint, this.endPoint, 0.5);\n const { point, visible } = projector.projectPoint(_middlePoint);\n\n const distance = this.getDistance();\n\n this.elementLabel.style.display = visible && distance >= PRECISION ? \"block\" : \"none\";\n this.elementLabel.style.left = `${point.x}px`;\n this.elementLabel.style.top = `${point.y}px`;\n this.elementLabel.innerHTML = `${distance.toFixed(2)} ${this.unit}`;\n } else {\n this.elementLabel.style.display = \"none\";\n }\n }\n\n update() {\n this.elementStartPoint.id = `markup-dot-start-${this.id}`;\n this.elementStartPoint.style.position = \"absolute\";\n this.elementStartPoint.style.zIndex = \"2\";\n this.elementStartPoint.style.width = `${this.size}px`;\n this.elementStartPoint.style.height = `${this.size}px`;\n this.elementStartPoint.style.border = this.style.border;\n this.elementStartPoint.style.borderRadius = `${this.size}px`;\n this.elementStartPoint.style.background = this.style.background;\n this.elementStartPoint.style.boxShadow = this.style.boxShadow;\n this.elementStartPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementEndPoint.id = `markup-dot-end-${this.id}`;\n this.elementEndPoint.style.position = \"absolute\";\n this.elementEndPoint.style.zIndex = \"2\";\n this.elementEndPoint.style.width = `${this.size}px`;\n this.elementEndPoint.style.height = `${this.size}px`;\n this.elementEndPoint.style.border = this.style.border;\n this.elementEndPoint.style.borderRadius = `${this.size}px`;\n this.elementEndPoint.style.background = this.style.background;\n this.elementEndPoint.style.boxShadow = this.style.boxShadow;\n this.elementEndPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementLine.id = `markup-line-${this.id}`;\n this.elementLine.style.position = \"absolute\";\n this.elementLine.style.zIndex = \"1\";\n this.elementLine.style.height = `${this.lineWidth}px`;\n this.elementLine.style.background = this.style.background;\n this.elementLine.style.boxShadow = this.style.boxShadow;\n this.elementLine.style.transformOrigin = `0px ${this.lineWidth / 2}px`;\n\n this.elementLabel.id = `markup-label-${this.id}`;\n this.elementLabel.style.position = \"absolute\";\n this.elementLabel.style.zIndex = \"3\";\n this.elementLabel.style.padding = \"2px\";\n this.elementLabel.style.paddingInline = \"5px\";\n this.elementLabel.style.borderRadius = \"5px\";\n this.elementLabel.style.background = this.style.background;\n this.elementLabel.style.boxShadow = this.style.boxShadow;\n this.elementLabel.style.color = this.style.color;\n this.elementLabel.style.font = this.style.font;\n this.elementLabel.style.transform = \"translate(-50%, -50%)\";\n }\n\n getDistance(): number {\n return this.startPoint.distanceTo(this.endPoint) / this.scale;\n }\n}\n\nlet _widthHalf: number;\nlet _heightHalf: number;\nconst _viewMatrix = new Matrix4();\nconst _viewProjectionMatrix = new Matrix4();\nconst _vector = new Vector3();\nconst _vector1 = new Vector4();\nconst _vector2 = new Vector4();\nconst point = new Vector2();\nconst point1 = new Vector2();\nconst point2 = new Vector2();\n\nclass MeasureProjector {\n private camera: Camera;\n private canvas: HTMLElement;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n }\n\n updateProjectionMatrix() {\n const rect = this.canvas.getBoundingClientRect();\n _widthHalf = rect.width / 2;\n _heightHalf = rect.height / 2;\n\n _viewMatrix.copy(this.camera.matrixWorldInverse);\n _viewProjectionMatrix.multiplyMatrices(this.camera.projectionMatrix, _viewMatrix);\n }\n\n projectPoint(p: Vector3) {\n _vector.copy(p).applyMatrix4(_viewProjectionMatrix);\n const visible = _vector.z >= -1 && _vector.z <= 1;\n\n point.x = (_vector.x + 1) * _widthHalf;\n point.y = (-_vector.y + 1) * _heightHalf;\n\n return { point, visible };\n }\n\n projectLine(p1: Vector3, p2: Vector3) {\n let visible: boolean;\n\n _vector1.copy(p1 as any).applyMatrix4(_viewProjectionMatrix);\n _vector2.copy(p2 as any).applyMatrix4(_viewProjectionMatrix);\n\n // see three/examples/jsm/renderers/Projector.js/clipLine for more details\n\n const bc1near = _vector1.z + _vector1.w;\n const bc2near = _vector2.z + _vector2.w;\n const bc1far = -_vector1.z + _vector1.w;\n const bc2far = -_vector2.z + _vector2.w;\n\n if (bc1near >= 0 && bc2near >= 0 && bc1far >= 0 && bc2far >= 0) visible = true;\n else if ((bc1near < 0 && bc2near < 0) || (bc1far < 0 && bc2far < 0)) visible = false;\n else {\n let alpha1 = 0;\n let alpha2 = 1;\n\n if (bc1near < 0) alpha1 = Math.max(alpha1, bc1near / (bc1near - bc2near));\n else if (bc2near < 0) alpha2 = Math.min(alpha2, bc1near / (bc1near - bc2near));\n\n if (bc1far < 0) alpha1 = Math.max(alpha1, bc1far / (bc1far - bc2far));\n else if (bc2far < 0) alpha2 = Math.min(alpha2, bc1far / (bc1far - bc2far));\n\n visible = alpha2 >= alpha1;\n\n if (visible) {\n _vector1.lerp(_vector2, alpha1);\n _vector2.lerp(_vector1, 1 - alpha2);\n }\n }\n\n _vector1.multiplyScalar(1 / _vector1.w);\n _vector2.multiplyScalar(1 / _vector2.w);\n\n point1.x = (_vector1.x + 1) * _widthHalf;\n point1.y = (-_vector1.y + 1) * _heightHalf;\n\n point2.x = (_vector2.x + 1) * _widthHalf;\n point2.y = (-_vector2.y + 1) * _heightHalf;\n\n return { point1, point2, visible };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Vector3 } from \"three\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ExtentsComponent implements IDisposable {\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"geometryend\", this.syncExtents);\n this.viewer.addEventListener(\"clear\", this.syncExtents);\n this.viewer.on(\"explode\", this.syncExtents);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"geometryend\", this.syncExtents);\n this.viewer.removeEventListener(\"clear\", this.syncExtents);\n this.viewer.off(\"explode\", this.syncExtents);\n }\n\n syncExtents = () => {\n const extents = this.viewer.models.reduce((result: Box3, gltf) => result.expandByObject(gltf.scene), new Box3());\n\n this.viewer.extents.copy(extents);\n this.viewer.target.copy(extents.getCenter(new Vector3()));\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { AmbientLight, DirectionalLight } from \"three\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class LightComponent implements IDisposable {\n protected viewer: Viewer;\n protected ambientLight: AmbientLight;\n protected directionalLight: DirectionalLight;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.ambientLight = new AmbientLight(0xffffff, 0);\n this.viewer.camera.add(this.ambientLight);\n\n this.directionalLight = new DirectionalLight(0xffffff, 1);\n this.directionalLight.position.set(0.5, 0, 0.866); // ~60º\n this.viewer.camera.add(this.directionalLight);\n }\n\n dispose(): void {\n this.ambientLight.removeFromParent();\n this.ambientLight = undefined;\n\n this.directionalLight.removeFromParent();\n this.directionalLight = undefined;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Color, PMREMGenerator } from \"three\";\nimport { RoomEnvironment } from \"three/examples/jsm/environments/RoomEnvironment.js\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class BackgroundComponent implements IDisposable {\n protected viewer: Viewer;\n protected backgroundColor: Color;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.backgroundColor = new Color(0xffffff);\n\n const environment = new RoomEnvironment();\n const pmremGenerator = new PMREMGenerator(this.viewer.renderer);\n\n this.viewer.renderer.setClearColor(this.backgroundColor);\n this.viewer.scene.background = this.backgroundColor;\n this.viewer.scene.environment = pmremGenerator.fromScene(environment).texture;\n this.viewer.addEventListener(\"optionschange\", this.syncOptions);\n\n environment.dispose();\n }\n\n dispose() {\n this.viewer.removeEventListener(\"optionschange\", this.syncOptions);\n this.viewer.scene.environment = undefined;\n this.viewer.scene.background = undefined;\n }\n\n syncOptions = () => {\n this.backgroundColor.setHex(0xffffff);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport { GeometryEndEvent } from \"@inweb/viewer-core\";\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class DefaultPositionComponent implements IDisposable {\n protected viewer: Viewer;\n public defaultCameraPositions: any;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"geometryend\", this.geometryEnd);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"geometryend\", this.geometryEnd);\n }\n\n geometryEnd = (event: GeometryEndEvent) => {\n const box = this.viewer.extents;\n const size = box.getSize(new Vector3()).length();\n\n this.viewer.camera.near = size / 100;\n this.viewer.camera.far = size * 100;\n this.viewer.camera.updateMatrixWorld();\n this.viewer.camera.updateProjectionMatrix();\n\n this.viewer.executeCommand(\"setDefaultViewPosition\", \"sw\");\n this.viewer.executeCommand(\"zoomToExtents\");\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ResizeCanvasComponent implements IDisposable {\n protected viewer: Viewer;\n protected resizeObserver: ResizeObserver;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.resizeObserver = new ResizeObserver(this.resizeViewer);\n this.resizeObserver.observe(viewer.canvas.parentElement);\n }\n\n dispose() {\n this.resizeObserver.disconnect();\n }\n\n resizeViewer = (entries: ResizeObserverEntry[]) => {\n const { width, height } = entries[0].contentRect;\n\n if (!width || !height) return; // <- invisible viewer, or viewer with parent removed\n\n this.viewer.camera.aspect = width / height;\n this.viewer.camera.updateProjectionMatrix();\n this.viewer.renderer.setSize(width, height, true);\n\n this.viewer.update(true);\n this.viewer.emitEvent({ type: \"resize\", width, height });\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class RenderLoopComponent implements IDisposable {\n protected viewer: Viewer;\n protected requestId: number;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.animate();\n }\n\n dispose() {\n cancelAnimationFrame(this.requestId);\n }\n\n animate = (time = 0) => {\n this.requestId = requestAnimationFrame(this.animate);\n this.viewer.render(time);\n };\n}\n","import {\n Camera,\n CylinderGeometry,\n CanvasTexture,\n Color,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n OrthographicCamera,\n Sprite,\n SpriteMaterial,\n SRGBColorSpace,\n Vector4,\n WebGLRenderer,\n} from \"three\";\n\nexport class WCSHelper extends Object3D {\n private camera: Camera;\n private orthoCamera: OrthographicCamera;\n public size: number;\n\n constructor(camera: Camera) {\n super();\n\n this.camera = camera;\n this.size = 160;\n\n this.orthoCamera = new OrthographicCamera(-2, 2, 2, -2, 0, 4);\n this.orthoCamera.position.set(0, 0, 2);\n\n const matRed = new MeshBasicMaterial({ toneMapped: false, color: \"#aa0000\" });\n const matGreen = new MeshBasicMaterial({ toneMapped: false, color: \"#00aa00\" });\n const matBlue = new MeshBasicMaterial({ toneMapped: false, color: \"#0000aa\" });\n\n const spriteRed = this.getSpriteMaterial(matRed.color, \"X\");\n const spriteGreen = this.getSpriteMaterial(matGreen.color, \"Y\");\n const spriteBlue = this.getSpriteMaterial(matBlue.color, \"Z\");\n\n const lineGeometry = new CylinderGeometry(0.01, 0.01, 1, 3);\n lineGeometry.translate(0, 0.5, 0);\n\n const arrowGeometry = new CylinderGeometry(0, 0.1, 0.25, 12);\n arrowGeometry.translate(0, 0.625, 0);\n\n const axesMap = {\n X: [\n [new Mesh(arrowGeometry, matRed), [0.5, 0, 0], [0, 0, -Math.PI / 2]],\n [new Mesh(lineGeometry, matRed), [0, 0, 0], [0, 0, -Math.PI / 2]],\n [new Sprite(spriteRed), [1.55, 0, 0]],\n ],\n Y: [\n [new Mesh(arrowGeometry, matGreen), [0, 0.5, 0], null],\n [new Mesh(lineGeometry, matGreen), null, null],\n [new Sprite(spriteGreen), [0, 1.55, 0]],\n ],\n Z: [\n [new Mesh(arrowGeometry, matBlue), [0, 0, 0.5], [Math.PI / 2, 0, 0]],\n [new Mesh(lineGeometry, matBlue), null, [Math.PI / 2, 0, 0]],\n [new Sprite(spriteBlue), [0, 0, 1.55]],\n ],\n };\n\n Object.keys(axesMap).forEach((key) => {\n axesMap[key].forEach((objects: any) => {\n const object = objects[0];\n const position = objects[1];\n const rotation = objects[2];\n\n object.name = key;\n if (position) object.position.set(position[0], position[1], position[2]);\n if (rotation) object.rotation.set(rotation[0], rotation[1], rotation[2]);\n object.updateMatrixWorld();\n\n this.add(object);\n });\n });\n }\n\n dispose() {\n this.traverse((object: any) => {\n if (object.geometry) object.geometry.dispose();\n if (object.material) object.material.dispose();\n });\n }\n\n getSpriteMaterial(color: Color, text: string) {\n const canvas = document.createElement(\"canvas\");\n canvas.width = 64;\n canvas.height = 64;\n\n const context = canvas.getContext(\"2d\");\n context.clearRect(0, 0, 64, 64);\n context.font = \"24px Arial\";\n context.textAlign = \"center\";\n context.fillStyle = color.getStyle();\n context.fillText(text, 32, 41);\n\n const texture = new CanvasTexture(canvas);\n texture.colorSpace = SRGBColorSpace;\n\n return new SpriteMaterial({ map: texture, toneMapped: false });\n }\n\n render(renderer: WebGLRenderer) {\n this.quaternion.copy(this.camera.quaternion).invert();\n this.updateMatrixWorld();\n\n const clippingPlanes = renderer.clippingPlanes;\n const viewport = renderer.getViewport(new Vector4());\n\n renderer.setViewport(this.position.x, this.position.y, this.size, this.size);\n renderer.clippingPlanes = [];\n renderer.clearDepth();\n renderer.render(this, this.orthoCamera);\n\n renderer.setViewport(viewport);\n renderer.clippingPlanes = clippingPlanes;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\nimport { WCSHelper } from \"../helpers/WCSHelper\";\n\nexport class WCSHelperComponent implements IDisposable {\n private wcsHelper: WCSHelper;\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.wcsHelper = new WCSHelper(viewer.camera);\n this.viewer = viewer;\n this.viewer.addEventListener(\"render\", this.viewerRender);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"render\", this.viewerRender);\n this.wcsHelper.dispose();\n }\n\n viewerRender = () => {\n if (!this.viewer.options.showWCS) return;\n if (this.viewer.extents.isEmpty()) return;\n\n this.wcsHelper.render(this.viewer.renderer);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, LinearToneMapping, Object3D, PerspectiveCamera, Plane, Scene, Vector3, WebGLRenderer } from \"three\";\nimport { GLTF, GLTFLoader } from \"three/examples/jsm/loaders/GLTFLoader.js\";\nimport { GLTFLoadingManager } from \"./loaders/GLTFLoadingManager\";\n\nimport { EventEmitter2 } from \"@inweb/eventemitter2\";\nimport { Assembly, Client, Model, File } from \"@inweb/client\";\nimport {\n CANVAS_EVENTS,\n CanvasEventMap,\n commands,\n IClippingPlane,\n IComponent,\n IDragger,\n IOptions,\n IPerspectiveCamera,\n IPoint,\n IViewer,\n IViewpoint,\n Options,\n OptionsEventMap,\n ViewerEventMap,\n} from \"@inweb/viewer-core\";\nimport { IMarkup, IWorldTransform, Markup } from \"@inweb/markup\";\n\nimport { PanDragger } from \"./draggers/PanDragger\";\nimport { OrbitDragger } from \"./draggers/OrbitDragger\";\nimport { ZoomDragger } from \"./draggers/ZoomDragger\";\nimport { WalkDragger } from \"./draggers/WalkDragger\";\nimport { CuttingPlaneXAxisDragger } from \"./draggers/CuttingPlaneXAxis\";\nimport { CuttingPlaneYAxisDragger } from \"./draggers/CuttingPlaneYAxis\";\nimport { CuttingPlaneZAxisDragger } from \"./draggers/CuttingPlaneZAxis\";\nimport { MeasureLineDragger } from \"./draggers/MeasureLineDragger\";\n\nimport { IDisposable } from \"./IDisposable\";\nimport { ExtentsComponent } from \"./components/ExtentsComponent\";\nimport { LightComponent } from \"./components/LightComponent\";\nimport { BackgroundComponent } from \"./components/BackgroundComponent\";\nimport { DefaultPositionComponent } from \"./components/DefaultPositionComponent\";\nimport { ResizeCanvasComponent } from \"./components/ResizeCanvasComponent\";\nimport { RenderLoopComponent } from \"./components/RenderLoopComponent\";\nimport { SelectionComponent } from \"./components/SelectionComponent\";\n// import { ViewPositionComponent } from \"./components/ViewPositionComponent\";\nimport { WCSHelperComponent } from \"./components/WCSHelperComponent\";\n// import { AxesHelperComponent } from \"./components/AxesHelperComponent\";\n// import { ExtentsHelperComponent } from \"./components/ExtentsHelperComponent\";\n\n/**\n * 3D viewer powered by {@link https://threejs.org/ | Three.js}.\n */\nexport class Viewer\n extends EventEmitter2<ViewerEventMap & CanvasEventMap & OptionsEventMap>\n implements IViewer, IWorldTransform\n{\n public client: Client | undefined;\n protected _options: Options;\n\n private canvaseventlistener: (event: any) => void;\n\n public canvas: HTMLCanvasElement | undefined;\n public canvasEvents: string[];\n\n public scene: Scene | undefined;\n public helpers: Scene | undefined;\n public camera: PerspectiveCamera | undefined;\n public renderer: WebGLRenderer | undefined;\n public models: Array<GLTF>;\n public selected: Array<Object3D>;\n public extents: Box3;\n public target: Vector3;\n\n private draggerFactory: Record<string, any>;\n private _activeDragger: IDragger | null;\n\n private components: Array<IDisposable>;\n\n private renderNeeded: boolean;\n private renderTime: DOMHighResTimeStamp;\n\n private _markup: IMarkup;\n\n /**\n * @param client - The `Client` instance that is used to load model reference files from the\n * Open Cloud Server. Do not specify `Client` if you need a standalone viewer instance to\n * view `glTF` files from the web or from local computer.\n */\n constructor(client?: Client) {\n super();\n this._options = new Options(this);\n\n this.client = client;\n\n this.canvasEvents = CANVAS_EVENTS;\n this.canvaseventlistener = (event: Event) => this.emit(event);\n\n this.extents = new Box3();\n this.target = new Vector3();\n\n this.draggerFactory = {\n Pan: PanDragger,\n Zoom: ZoomDragger,\n Orbit: OrbitDragger,\n Walk: WalkDragger,\n CuttingPlaneXAxis: CuttingPlaneXAxisDragger,\n CuttingPlaneYAxis: CuttingPlaneYAxisDragger,\n CuttingPlaneZAxis: CuttingPlaneZAxisDragger,\n MeasureLine: MeasureLineDragger,\n };\n this._activeDragger = null;\n\n this.models = [];\n this.components = [];\n this.selected = [];\n\n this.renderTime = 0;\n\n this.render = this.render.bind(this);\n this.update = this.update.bind(this);\n\n this._markup = new Markup();\n }\n\n get options(): IOptions {\n return this._options;\n }\n\n get draggers(): string[] {\n return Object.keys(this.draggerFactory);\n }\n\n /**\n * 2D markup core instance used to create markups.\n *\n * @readonly\n */\n get markup(): IMarkup {\n return this._markup;\n }\n\n initialize(canvas: HTMLCanvasElement, onProgress?: (event: ProgressEvent<EventTarget>) => void): Promise<this> {\n this.addEventListener(\"optionschange\", (event) => this.syncOptions(event.data));\n\n this.scene = new Scene();\n this.helpers = new Scene();\n\n const rect = canvas.parentElement.getBoundingClientRect();\n const width = rect.width || 1;\n const height = rect.height || 1;\n this.camera = new PerspectiveCamera(45, width / height, 0.01, 1000);\n this.camera.up.set(0, 0, 1);\n\n this.renderer = new WebGLRenderer({ canvas, antialias: true, preserveDrawingBuffer: true });\n this.renderer.setPixelRatio(window.devicePixelRatio);\n this.renderer.setSize(width, height);\n this.renderer.toneMapping = LinearToneMapping;\n\n this.canvas = canvas;\n this.canvasEvents.forEach((x) => canvas.addEventListener(x, this.canvaseventlistener));\n\n this._markup.initialize(this.canvas, this.canvasEvents, this, this);\n\n this.components.push(new ExtentsComponent(this));\n this.components.push(new LightComponent(this));\n this.components.push(new BackgroundComponent(this));\n // this.components.push(new ViewPositionComponent(this));\n this.components.push(new DefaultPositionComponent(this));\n this.components.push(new ResizeCanvasComponent(this));\n this.components.push(new RenderLoopComponent(this));\n this.components.push(new SelectionComponent(this));\n this.components.push(new WCSHelperComponent(this));\n // this.components.push(new AxesHelperComponent(this));\n // this.components.push(new ExtentsHelperComponent(this));\n\n this.syncOptions();\n this.syncOverlay();\n\n this.renderTime = performance.now();\n this.render(this.renderTime);\n\n if (typeof onProgress === \"function\")\n onProgress(new ProgressEvent(\"progress\", { lengthComputable: true, loaded: 1, total: 1 }));\n\n this.emitEvent({ type: \"initializeprogress\", data: 1, loaded: 1, total: 1 });\n this.emitEvent({ type: \"initialize\" });\n\n return Promise.resolve(this);\n }\n\n dispose(): this {\n this.cancel();\n this.emitEvent({ type: \"dispose\" });\n\n this.components.forEach((component: IDisposable) => component.dispose());\n this.components = [];\n\n this.setActiveDragger();\n this.removeAllListeners();\n\n this.clear();\n\n this._markup.dispose();\n\n if (this.canvas) {\n this.canvasEvents.forEach((x) => this.canvas.removeEventListener(x, this.canvaseventlistener));\n this.canvas = undefined;\n }\n\n if (this.renderer) this.renderer.dispose();\n\n this.renderer = undefined;\n this.camera = undefined;\n this.scene = undefined;\n this.helpers = undefined;\n\n return this;\n }\n\n isInitialized(): boolean {\n return !!this.renderer;\n }\n\n public render(time: DOMHighResTimeStamp): void {\n if (!this.renderNeeded) return;\n if (!this.renderer) return;\n\n this.renderNeeded = false;\n\n this.renderer.setViewport(0, 0, this.canvas.offsetWidth, this.canvas.offsetHeight);\n this.renderer.autoClear = true;\n this.renderer.render(this.scene, this.camera);\n\n const clippingPlanes = this.renderer.clippingPlanes;\n this.renderer.clippingPlanes = [];\n this.renderer.autoClear = false;\n this.renderer.render(this.helpers, this.camera);\n this.renderer.clippingPlanes = clippingPlanes;\n\n const deltaTime = (time - this.renderTime) / 1000;\n this.renderTime = time;\n this.emitEvent({ type: \"render\", time, deltaTime });\n }\n\n public update(force = false): void {\n this.renderNeeded = true;\n if (force) this.render(performance.now());\n this.emitEvent({ type: \"update\", data: force });\n }\n\n public syncOptions(options: IOptions = this.options): void {\n // this.update();\n }\n\n loadReferences(model: Model | File | Assembly): Promise<this> {\n // todo: load reference as text fonts\n return Promise.resolve(this);\n }\n\n /**\n * Loads a file from Open Cloud Server into the viewer.\n *\n * The file geometry data on the server must be converted to `glTF` format.\n *\n * This method requires a `Client` instance to be specified when creating the viewer to load\n * model reference files from the Open Cloud Server. For a standalone viewer instance use\n * {@link openGltfFile | openGltfFile()}.\n *\n * If there was an active dragger before opening the file, it will be deactivated. After\n * opening the file, you must manually activate the required dragger.\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryChunkEvent | geometrychunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File, assembly or specific model to load. If a `File` instance with multiple\n * models is specified, the default model will be loaded. If there is no default model,\n * first availiable model will be loaded.\n */\n async open(file: Model | File | Assembly): Promise<this> {\n if (!this.renderer) return this;\n\n this.cancel();\n this.clear();\n\n this.emitEvent({ type: \"open\", file, model: file });\n\n let model: Model | undefined = undefined;\n if (file) {\n const models = (await file.getModels()) || [];\n model = models.find((model: Model) => model.default) || models[0];\n }\n if (!model) throw new Error(\"No default model found\");\n\n const geometryType = model.database.split(\".\").pop();\n if (geometryType !== \"gltf\") throw new Error(`Unknown geometry type: ${geometryType}`);\n\n const url = `${model.httpClient.serverUrl}${model.path}/${model.database}`;\n const params = { requestHeader: model.httpClient.headers };\n\n await this.loadReferences(model);\n await this.loadGltfFile(url, undefined, params);\n\n return this;\n }\n\n cancel(): this {\n this.emitEvent({ type: \"cancel\" });\n return this;\n }\n\n /**\n * Loads a `glTF` file into the viewer.\n *\n * If there was an active dragger before opening the file, it will be deactivated. After\n * opening the file, you must manually activate the required dragger.\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File URL or binary data buffer to load.\n * @param externalData - External resource map such as binary data buffers or images. Each\n * resource should be represented by a `uri` and a corresponding resource URL, or\n * {@link https://developer.mozilla.org/docs/Web/API/File | Web API File} object, or\n * {@link https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer | ArrayBuffer}\n * or {@link https://developer.mozilla.org/docs/Web/API/Blob/Blob | Blob}, or\n * {@link https://developer.mozilla.org/docs/Web/HTTP/Basics_of_HTTP/Data_URIs | Data URL} string,\n * @param params - Loader parameters.\n * @param params.path - The base path from which to find subsequent glTF resources such as\n * textures and .bin data files. If not defined, the base path of the file URL will be used.\n * @param params.requestHeader - The\n * {@link https://developer.mozilla.org/docs/Glossary/Request_header | request header} used\n * in HTTP request.\n * @param params.crossOrigin - The crossOrigin string to implement CORS for loading the url\n * from a different domain that allows CORS. Default is `anonymous`.\n * @param params.withCredentials - Whether the XMLHttpRequest uses credentials such as\n * cookies, authorization headers or TLS client certificates. See\n * {@link https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/withCredentials | XMLHttpRequest.withCredentials}.\n */\n openGltfFile(\n file: string | globalThis.File | ArrayBuffer | Blob,\n externalData: Map<string, string | globalThis.File | ArrayBuffer | Blob> = new Map(),\n params: {\n path?: string;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n } = {}\n ): Promise<this> {\n if (!this.renderer) return Promise.resolve(this);\n\n this.cancel();\n this.clear();\n\n this.emitEvent({ type: \"open\" });\n\n return this.loadGltfFile(file, externalData, params);\n }\n\n /**\n * Appends a `glTF` file to the existing opened file.\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File URL or binary data buffer to load.\n * @param externalData - External resource map such as binary data buffers or images. Each\n * resource should be represented by a `uri` and a corresponding resource URL, or\n * {@link https://developer.mozilla.org/docs/Web/API/File | Web API File} object, or\n * {@link https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer | ArrayBuffer}\n * or {@link https://developer.mozilla.org/docs/Web/API/Blob/Blob | Blob}, or\n * {@link https://developer.mozilla.org/docs/Web/HTTP/Basics_of_HTTP/Data_URIs | Data URL} string,\n * @param params - Loader parameters.\n * @param params.path - The base path from which to find subsequent glTF resources such as\n * textures and .bin data files.\n * @param params.requestHeader - The\n * {@link https://developer.mozilla.org/docs/Glossary/Request_header | request header} used\n * in HTTP request.\n * @param params.crossOrigin - The crossOrigin string to implement CORS for loading the url\n * from a different domain that allows CORS. Default is `anonymous`.\n * @param params.withCredentials - Whether the XMLHttpRequest uses credentials such as\n * cookies, authorization headers or TLS client certificates. See\n * {@link https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/withCredentials | XMLHttpRequest.withCredentials}.\n */\n async loadGltfFile(\n file: string | globalThis.File | ArrayBuffer | Blob,\n externalData: Map<string, string | globalThis.File | ArrayBuffer | Blob> = new Map(),\n params: {\n path?: string;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n } = {}\n ): Promise<this> {\n const manager = new GLTFLoadingManager(file, externalData, params);\n try {\n this.emitEvent({ type: \"geometrystart\" });\n\n const loader = new GLTFLoader(manager);\n loader.setPath(manager.path);\n loader.setRequestHeader(params.requestHeader as any);\n loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);\n loader.setWithCredentials(params.withCredentials || loader.withCredentials);\n\n const gltf = await loader.loadAsync(manager.fileURL, (event: ProgressEvent) => {\n const { lengthComputable, loaded, total } = event;\n const progress = lengthComputable ? loaded / total : 1;\n this.emitEvent({ type: \"geometryprogress\", data: progress });\n });\n\n if (!this.scene) return this;\n if (!gltf.scene) throw new Error(\"No glTF scene found\");\n\n this.models.push(gltf);\n this.scene.add(gltf.scene);\n\n this.syncOptions();\n this.syncOverlay();\n this.update();\n\n this.emitEvent({ type: \"databasechunk\" });\n this.emitEvent({ type: \"geometryend\", data: gltf.scene });\n } catch (error) {\n this.emitEvent({ type: \"geometryerror\", data: error });\n throw error;\n } finally {\n manager.dispose();\n }\n\n return this;\n }\n\n clear(): this {\n if (!this.renderer) return this;\n\n function disposeMaterial(material: any) {\n const materials = Array.isArray(material) ? material : [material];\n materials.forEach((material: any) => {\n // Object.keys(material).forEach((key) => material[key]?.dispose?.());\n material.dispose();\n });\n }\n\n function disposeObject(object: any) {\n if (object.geometry) object.geometry.dispose();\n if (object.material) disposeMaterial(object.material);\n }\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n this.clearSelected();\n\n this.helpers.traverse(disposeObject);\n this.helpers.clear();\n\n this.models.forEach((gltf) => gltf.scene.traverse(disposeObject));\n this.models.forEach((gltf) => gltf.scene.removeFromParent());\n this.models = [];\n\n this.scene.clear();\n\n this.syncOptions();\n this.syncOverlay();\n this.update(true);\n\n this.emitEvent({ type: \"clear\" });\n\n return this;\n }\n\n syncOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.syncOverlay();\n this.update();\n }\n\n clearOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.clearOverlay();\n this.update();\n }\n\n clearSlices(): void {\n if (!this.renderer) return;\n\n this.renderer.clippingPlanes = [];\n this.update();\n }\n\n getSelected(): string[] {\n return this.executeCommand(\"getSelected\");\n }\n\n setSelected(handles?: string[]): void {\n this.executeCommand(\"setSelected\", handles);\n }\n\n clearSelected(): void {\n this.executeCommand(\"clearSelected\");\n }\n\n hideSelected(): void {\n this.executeCommand(\"hideSelected\");\n }\n\n isolateSelected(): void {\n this.executeCommand(\"isolateSelected\");\n }\n\n showAll(): void {\n this.executeCommand(\"showAll\");\n }\n\n explode(index = 0): void {\n this.executeCommand(\"explode\", index);\n }\n\n collect(): void {\n this.executeCommand(\"collect\");\n }\n\n activeDragger(): IDragger | null {\n return this._activeDragger;\n }\n\n setActiveDragger(name = \"\"): IDragger | null {\n if (!this._activeDragger || this._activeDragger.name !== name) {\n if (this._activeDragger) {\n this._activeDragger.dispose();\n this._activeDragger = null;\n }\n if (this.isInitialized()) {\n const Constructor = this.draggerFactory[name];\n if (Constructor) {\n this._activeDragger = new Constructor(this);\n this._activeDragger.name = name;\n }\n }\n const canvas = this.canvas;\n if (canvas) {\n canvas.className = canvas.className\n .split(\" \")\n .filter((x) => !x.startsWith(\"oda-cursor-\"))\n .filter((x) => x)\n .concat(`oda-cursor-${name.toLowerCase()}`)\n .join(\" \");\n }\n this.emitEvent({ type: \"changeactivedragger\", data: name });\n this.update();\n }\n return this._activeDragger;\n }\n\n resetActiveDragger(): void {\n const dragger = this._activeDragger;\n if (dragger) {\n this.setActiveDragger();\n this.setActiveDragger(dragger.name);\n }\n }\n\n is3D(): boolean {\n return true;\n }\n\n screenToWorld(position: { x: number; y: number }): { x: number; y: number; z: number } {\n if (!this.renderer) return { x: position.x, y: position.y, z: 0 };\n\n const rect = this.canvas.getBoundingClientRect();\n const x = position.x / (rect.width / 2) - 1;\n const y = -position.y / (rect.height / 2) + 1;\n\n const point = new Vector3(x, y, -1);\n point.unproject(this.camera);\n\n return { x: point.x, y: point.y, z: point.z };\n }\n\n worldToScreen(position: { x: number; y: number; z: number }): { x: number; y: number } {\n if (!this.renderer) return { x: position.x, y: position.y };\n\n const point = new Vector3(position.x, position.y, position.z);\n point.project(this.camera);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = (point.x + 1) * (rect.width / 2);\n const y = (-point.y + 1) * (rect.height / 2);\n\n return { x, y };\n }\n\n getScale(): { x: number; y: number; z: number } {\n return { x: 1, y: 1, z: 1 };\n }\n\n executeCommand(id: string, ...args: any[]): any {\n return commands(\"ThreeJS\").executeCommand(id, this, ...args);\n }\n\n getComponent(type): any {\n return this.components.find((component) => component instanceof type);\n }\n\n drawViewpoint(viewpoint: IViewpoint): void {\n if (!this.renderer) return;\n\n const getVector3FromPoint3d = ({ x, y, z }): Vector3 => new Vector3(x, y, z);\n\n const setPerspectiveCamera = (camera: IPerspectiveCamera) => {\n if (camera) {\n this.camera.up.copy(getVector3FromPoint3d(camera.up_vector));\n this.camera.fov = camera.field_of_view;\n this.camera.position.copy(getVector3FromPoint3d(camera.view_point));\n this.camera.lookAt(getVector3FromPoint3d(camera.direction).add(this.camera.position));\n this.camera.updateMatrixWorld();\n this.camera.updateProjectionMatrix();\n }\n };\n\n const setClippingPlanes = (clipping_planes: IClippingPlane[]) => {\n clipping_planes?.forEach((clipping_plane) => {\n const plane = new Plane();\n plane.setFromNormalAndCoplanarPoint(\n getVector3FromPoint3d(clipping_plane.direction),\n getVector3FromPoint3d(clipping_plane.location)\n );\n\n this.renderer.clippingPlanes.push(plane);\n });\n };\n\n const setSelection = (selection: IComponent[]) => {\n this.setSelected(selection?.map((component) => component.handle));\n };\n\n const draggerName = this._activeDragger?.name;\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n\n this.clearSelected();\n this.showAll();\n this.explode();\n\n setPerspectiveCamera(viewpoint.perspective_camera);\n setClippingPlanes(viewpoint.clipping_planes);\n setSelection(viewpoint.selection);\n this._markup.setViewpoint(viewpoint);\n\n this.target = getVector3FromPoint3d(viewpoint.custom_fields?.camera_target ?? this.target);\n\n this.setActiveDragger(draggerName);\n this.emitEvent({ type: \"drawviewpoint\", data: viewpoint });\n this.update();\n }\n\n createViewpoint(): IViewpoint {\n if (!this.renderer) return {};\n\n const getPoint3dFromVector3 = ({ x, y, z }): IPoint => ({ x, y, z });\n\n const getPerspectiveCamera = (): IPerspectiveCamera => {\n return {\n view_point: getPoint3dFromVector3(this.camera.position),\n direction: getPoint3dFromVector3(this.camera.getWorldDirection(new Vector3())),\n up_vector: getPoint3dFromVector3(this.camera.up),\n field_of_view: this.camera.fov,\n };\n };\n\n const getClippingPlanes = (): IClippingPlane[] => {\n const clipping_planes = [];\n this.renderer.clippingPlanes.forEach((plane: Plane) => {\n const clipping_plane = {\n location: getPoint3dFromVector3(plane.coplanarPoint(new Vector3())),\n direction: getPoint3dFromVector3(plane.normal),\n };\n clipping_planes.push(clipping_plane);\n });\n return clipping_planes;\n };\n\n const getSelection = (): IComponent[] => {\n return this.getSelected().map((handle) => ({ handle }));\n };\n\n const viewpoint: IViewpoint = { custom_fields: {} };\n\n viewpoint.perspective_camera = getPerspectiveCamera();\n viewpoint.clipping_planes = getClippingPlanes();\n viewpoint.selection = getSelection();\n viewpoint.description = new Date().toDateString();\n this._markup.getViewpoint(viewpoint);\n\n viewpoint.custom_fields.camera_target = getPoint3dFromVector3(this.target);\n\n this.emitEvent({ type: \"createviewpoint\", data: viewpoint });\n\n return viewpoint;\n }\n}\n"],"names":["Commands","constructor","this","_commands","Map","registerCommand","id","handler","description","thisArg","set","registerCommandAlias","alias","viewer","args","executeCommand","getCommand","get","getCommands","map","forEach","value","key","command","isDraggerCommand","draggers","includes","setActiveDragger","console","warn","undefined","result","apply","emit","type","data","commands","viewerType","defaultOptions","showWCS","cameraAnimation","antialiasing","groundShadow","shadows","cameraAxisXSpeed","cameraAxisYSpeed","ambientOcclusion","enableStreamingMode","enablePartialMode","memoryLimit","cuttingPlaneFillColor","red","green","blue","edgesColor","r","g","b","facesColor","edgesVisibility","edgesOverlap","facesOverlap","facesTransparancy","enableCustomHighlight","sceneGraph","edgeModel","reverseZoomWheel","enableZoomWheel","enableGestures","geometryType","rulerUnit","Options","emitter","_emitter","_data","loadFromStorage","defaults","notifierChangeEvent","change","saveToStorage","window","localStorage","setItem","JSON","stringify","error","item","getItem","parse","resetToDefaults","fields","resetData","reduce","acc","field","Boolean","CanvasEvents","CANVAS_EVENTS","Dragger","name","initialize","dispose","updatePreview","applyModelTransform","model","clearOverlay","SelectionComponent","onPointerDown","event","isPrimary","button","getMousePosition","downPosition","onPointerUp","upPosition","Vector2","distanceTo","intersects","getPointerIntersects","clearSelection","length","select","object","update","emitEvent","handles","getSelected","onDoubleClick","optionsChange","options","facesMaterial","color","setRGB","opacity","raycaster","Raycaster","MeshBasicMaterial","transparent","addEventListener","removeEventListener","target","clientX","clientY","mouse","rect","canvas","getBoundingClientRect","x","left","width","y","top","height","coords","setFromCamera","camera","objects","scene","traverseVisible","child","push","params","Mesh","Line","threshold","Line2","LOD","Points","Sprite","intersectObjects","isSelected","originalMaterial","material","selected","clearSelected","selection","clearSlices","createPreview","encoderOptions","toDataURL","calcObjectDepth","depth","res","children","objectDepth","originalPosition","position","clone","explodeScene","scale","maxDepth","explodeDepth","explodeObject","parentCenter","parentOffset","objectBox","Box3","setFromObject","objectCenter","getCenter","Vector3","objectOffset","offset","sub","multiplyScalar","add","copy","direction","normalize","sceneExtents","sceneCenter","explode","index","models","gltf","defaultViewPositions","bottom","right","front","back","sw","se","ne","nw","setDefaultViewPosition","center","extents","sphere","getBoundingSphere","Sphere","offet","radius","lookAt","updateProjectionMatrix","updateMatrixWorld","getDefaultViewPositions","Object","keys","getModels","userData","handle","filter","_a","hideSelected","visible","isolateSelected","selectedSet","Set","isolateObject","canBeIsolated","has","regenerateAll","resetView","selectModel","dragger","setSelected","handleSet","showAll","traverse","zoomToExtents","isEmpty","distance","delta","applyQuaternion","quaternion","zoomToObjects","expandByObject","zoomToSelected","GLTFLoadingManager","LoadingManager","file","externalData","super","path","resourcePath","fileURL","dataURLs","LoaderUtils","extractUrlBase","dataURL","URL","createObjectURL","Blob","setURLModifier","url","decodeURI","replace","revokeObjectURL","EventEmitter2","_listeners","listener","listeners","removeAllListeners","invoke","slice","call","on","off","WorldTransform","screenToWorld","z","worldToScreen","getScale","MarkupColor","setColor","asHex","HEX","asRGB","R","G","B","rgbToHex","valueToHex","c","hex","toString","LineTypeSpecs","KonvaLine","ref","_b","_ref","points","konvaPoints","point","Konva","stroke","strokeWidth","globalCompositeOperation","lineCap","lineJoin","draggable","strokeScaleEnabled","dash","e","attrs","rotation","_id","enableMouseEditing","getColor","getRotation","setRotation","degrees","getZIndex","zIndex","setZIndex","destroy","getPoints","setLineWidth","size","getLineWidth","getLineType","typeSpecs","setLineType","specs","addPoints","newPoints","concat","KonvaText","_c","TEXT_FONT_FAMILY","text","Text","fontSize","fontFamily","fill","align","getTextWidth","scaleByX","Math","abs","scaleX","scaleByY","scaleY","newWidth","newHeight","minWidth","round","getFontSize","getText","setText","getPosition","setPosition","setFontSize","KonvaRectangle","_d","Rect","lineWidth","minHeight","getWidth","getHeigth","setWidth","w","setHeight","h","KonvaEllipse","Ellipse","radiusX","radiusY","newRadiusX","newRadiusY","minRadiusX","minRadiusY","evt","ctrlKey","shiftKey","getRadiusX","setRadiusX","getRadiusY","setRadiusY","KonvaArrow","start","end","Arrow","setPoints","getStartPoint","setStartPoint","getEndPoint","setEndPoint","KonvaImage","_ratio","EPSILON","BASE64_HEADER_START","BASE64_NOT_FOUND","src","startsWith","_canvasImage","image","Image","onload","maxWidth","heightOutOfCanvas","maxHeight","widthOutOfCanvas","onerror","getSrc","setSrc","getHeight","KonvaCloud","arcRadius","Shape","sceneFunc","context","shape","calculateMidpoint","midX","midY","midPoint","baseArcLength","beginPath","iPoint","approxArcLength","dx","dy","sqrt","arcCount","floor","lengthMod","pX","pY","pEndX","pEndY","endAngle","atan","startAngle","PI","counterClockwise","iArc","arc","closePath","fillStrokeShape","className","getSelfRect","MarkupMode2Konva","SelectMarkup","initializer","Rectangle","Cloud","KonvaMarkup","_containerEvents","_markupIsActive","_markupColor","lineType","changeActiveDragger","draggerName","_markupContainer","_container","split","toLowerCase","join","removeTextInput","removeImageInput","enableEditMode","resizeContainer","entries","contentRect","_konvaStage","pan","newPos","dX","dY","zoomAt","newScale","redirectToViewer","_viewer","getRelativePointPosition","node","transform","getAbsoluteTransform","invert","getRelativePointerPosition","getStage","getPointerPosition","container","containerEvents","worldTransformer","Error","_worldTransformer","document","createElement","style","outline","pointerEvents","parentDiv","parentElement","appendChild","_resizeObserver","ResizeObserver","observe","initializeKonva","destroyKonva","disconnect","remove","syncOverlay","getObjects","obj","delete","getMarkupColor","setMarkupColor","colorizeAllMarkup","hexColor","colorizeSelectedMarkups","getSelectedObjects","setViewpoint","viewpoint","_e","_f","_g","_h","markupColor","custom_fields","markup_color","lines","line","linePoints","screenPoint","addLine","texts","addText","angle","text_size","font_size","rectangles","addRectangle","line_width","ellipses","ellipse","addEllipse","arrows","arrow","startPoint","endPoint","addArrow","clouds","cloud","addCloud","images","addImage","getViewpoint","getMarkupLines","getMarkupTexts","getMarkupArrows","getMarkupClouds","getMarkupEllipses","getMarkupImages","getMarkupRectangles","snapshot","combineMarkupWithDrawing","mode","_markupMode","createObject","konvaShape","addObject","konvaLayerFind","_konvaTransformer","nodes","values","find","selectObjects","selectedObjs","_groupImages","_groupTexts","_groupGeometry","_konvaLayer","parent","stage","Stage","clientWidth","clientHeight","layer","Layer","pixelRation","devicePixelRatio","Group","transformer","Transformer","shouldOverdrawWholeArea","keepRatio","flipEnabled","isPaint","lastLine","mouseDownPos","lastObj","pos","some","m","defParams","startX","min","startY","max","_textInputRef","_textInputPos","_textInputAngle","createTextInput","pageX","pageY","_imageInputRef","_imageInputPos","createImageInput","rotateEnabled","metaPressed","metaKey","indexOf","splice","tabIndex","focus","code","preventDefault","worldPoints","absoluteTransform","i","atPoint","worldPoint","konvaLine","textSize","textScale","stageAbsoluteTransform","getMatrix","rectangle","atStartPoint","worldStartPoint","atEndPoint","worldEndPoint","tempCanvas","ctx","getContext","HTMLCanvasElement","drawImage","toCanvas","pixelRatio","inputX","inputY","display","onkeydown","body","setTimeout","convertBase64","Promise","resolve","reject","fileReader","FileReader","readAsDataURL","accept","onchange","async","files","base64","oncancel","click","at","tolerance","konvaText","konvaRectangle","konvaEllipse","konvaArrow","konvaCloud","konvaImage","_changeEvent","_startEvent","_endEvent","STATE","NONE","ROTATE","DOLLY","PAN","TOUCH_ROTATE","TOUCH_PAN","TOUCH_DOLLY_PAN","TOUCH_DOLLY_ROTATE","OrbitControls","EventDispatcher","domElement","touchAction","enabled","minDistance","maxDistance","Infinity","minZoom","maxZoom","minPolarAngle","maxPolarAngle","minAzimuthAngle","maxAzimuthAngle","enableDamping","dampingFactor","enableZoom","zoomSpeed","enableRotate","rotateSpeed","enablePan","panSpeed","screenSpacePanning","keyPanSpeed","autoRotate","autoRotateSpeed","LEFT","UP","RIGHT","BOTTOM","mouseButtons","MOUSE","MIDDLE","touches","ONE","TOUCH","TWO","DOLLY_PAN","target0","position0","zoom0","zoom","_domElementKeyEvents","getPolarAngle","spherical","phi","getAzimuthalAngle","theta","getDistance","listenToKeyEvents","onKeyDown","stopListenToKeyEvents","saveState","scope","reset","dispatchEvent","state","quat","Quaternion","setFromUnitVectors","up","quatInverse","lastPosition","lastQuaternion","lastTargetPosition","twoPI","setFromVector3","rotateLeft","getAutoRotationAngle","sphericalDelta","isFinite","makeSafe","addScaledVector","panOffset","setFromSpherical","zoomChanged","distanceToSquared","EPS","dot","onContextMenu","onMouseWheel","onPointerMove","Spherical","rotateStart","rotateEnd","rotateDelta","panStart","panEnd","panDelta","dollyStart","dollyEnd","dollyDelta","dollyScale","pointers","pointerPositions","getZoomScale","pow","rotateUp","panLeft","v","objectMatrix","setFromMatrixColumn","panUp","crossVectors","deltaX","deltaY","element","isPerspectiveCamera","targetDistance","tan","fov","matrix","isOrthographicCamera","dollyOut","dollyIn","handleMouseDownRotate","handleMouseDownDolly","handleMouseDownPan","handleMouseMoveRotate","subVectors","handleMouseMoveDolly","handleMouseMovePan","handleMouseWheel","handleKeyDown","needsUpdate","handleTouchStartRotate","handleTouchStartPan","handleTouchStartDolly","handleTouchStartDollyPan","handleTouchStartDollyRotate","handleTouchMoveRotate","getSecondPointerPosition","handleTouchMovePan","handleTouchMoveDolly","handleTouchMoveDollyPan","handleTouchMoveDollyRotate","setPointerCapture","pointerId","addPointer","pointerType","onTouchStart","onMouseDown","onTouchMove","onMouseMove","removePointer","releasePointerCapture","mouseAction","trackPointer","DOLLY_ROTATE","pointer","passive","OrbitDragger","updateControls","orbit","far","near","controlsStart","changed","controlsChange","stopContextMenu","stopPropagation","PanDragger","ZoomDragger","WalkControls","Controls","movementSpeed","lookSpeed","multiplier","moveWheel","mouseDragOn","movePosition","rotateCamera","onPointerCancel","PointerEvent","onWheel","moveKeys","onKeyUp","moveClock","Clock","timeDelta","getDelta","moveDelta","translateZ","translateX","translateY","lookDelta","sign","stop","autoStart","rotateX","rotateY","xRotation","setFromAxisAngle","yRotation","premultiply","multiply","setRotationFromQuaternion","WalkDragger","getSize","controls","walkspeedChange","viewerRender","viewerZoom","PlaneHelper","plane","positions","geometry","BufferGeometry","setAttribute","Float32BufferAttribute","computeBoundingSphere","LineBasicMaterial","toneMapped","positions2","geometry2","helper","depthWrite","side","DoubleSide","force","normal","constant","CuttingPlaneDragger","transformChange","planeCenter","transformDrag","viewerExplode","planeHelper","negate","Plane","renderer","clippingPlanes","helpers","Object3D","TransformControls","showX","showY","showZ","attach","getHelper","removeFromParent","detach","CuttingPlaneXAxisDragger","CuttingPlaneYAxisDragger","CuttingPlaneZAxisDragger","PRECISION","MeasureLineDragger","snapper","getSnapPoint","render","MeasureLine","overlay","onPointerLeave","renderOverlay","updateSnapper","MeasureOverlay","MeasureSnapper","projector","MeasureProjector","background","overflow","clear","removeLine","_middlePoint","Date","now","unit","border","boxShadow","font","elementStartPoint","elementEndPoint","elementLine","elementLabel","projectPoint","point1","point2","projectLine","lerpVectors","innerHTML","toFixed","borderRadius","transformOrigin","padding","paddingInline","_widthHalf","_heightHalf","_viewMatrix","Matrix4","_viewProjectionMatrix","_vector","_vector1","Vector4","_vector2","matrixWorldInverse","multiplyMatrices","projectionMatrix","p","applyMatrix4","p1","p2","bc1near","bc2near","bc1far","bc2far","alpha1","alpha2","lerp","ExtentsComponent","syncExtents","LightComponent","ambientLight","AmbientLight","directionalLight","DirectionalLight","BackgroundComponent","syncOptions","backgroundColor","setHex","Color","environment","RoomEnvironment","pmremGenerator","PMREMGenerator","setClearColor","fromScene","texture","DefaultPositionComponent","geometryEnd","box","ResizeCanvasComponent","resizeViewer","aspect","setSize","resizeObserver","RenderLoopComponent","animate","time","requestId","requestAnimationFrame","cancelAnimationFrame","WCSHelper","orthoCamera","OrthographicCamera","matRed","matGreen","matBlue","spriteRed","getSpriteMaterial","spriteGreen","spriteBlue","lineGeometry","CylinderGeometry","translate","arrowGeometry","axesMap","X","Y","Z","clearRect","textAlign","fillStyle","getStyle","fillText","CanvasTexture","colorSpace","SRGBColorSpace","SpriteMaterial","viewport","getViewport","setViewport","clearDepth","WCSHelperComponent","wcsHelper","Viewer","client","_options","canvasEvents","canvaseventlistener","draggerFactory","Pan","Zoom","Orbit","Walk","CuttingPlaneXAxis","CuttingPlaneYAxis","CuttingPlaneZAxis","_activeDragger","components","renderTime","bind","_markup","Markup","markup","onProgress","Scene","PerspectiveCamera","WebGLRenderer","antialias","preserveDrawingBuffer","setPixelRatio","toneMapping","LinearToneMapping","performance","ProgressEvent","lengthComputable","loaded","total","cancel","component","isInitialized","renderNeeded","offsetWidth","offsetHeight","autoClear","deltaTime","loadReferences","open","default","database","pop","httpClient","serverUrl","requestHeader","headers","loadGltfFile","openGltfFile","manager","loader","GLTFLoader","setPath","setRequestHeader","setCrossOrigin","crossOrigin","setWithCredentials","withCredentials","loadAsync","progress","disposeMaterial","materials","Array","isArray","disposeObject","collect","activeDragger","Constructor","resetActiveDragger","is3D","unproject","project","getComponent","drawViewpoint","getVector3FromPoint3d","setPerspectiveCamera","up_vector","field_of_view","view_point","setClippingPlanes","clipping_planes","clipping_plane","setFromNormalAndCoplanarPoint","location","setSelection","perspective_camera","camera_target","createViewpoint","getPoint3dFromVector3","getPerspectiveCamera","getWorldDirection","getClippingPlanes","coplanarPoint","getSelection","toDateString"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"viewer-three.module.js","sources":["../../viewer-core/dist/viewer-core.module.js","../src/Viewer/commands/ApplyModelTransform.ts","../src/Viewer/commands/ClearMarkup.ts","../src/Viewer/components/SelectionComponent.ts","../src/Viewer/commands/ClearSelected.ts","../src/Viewer/commands/ClearSlices.ts","../src/Viewer/commands/CreatePreview.ts","../src/Viewer/commands/Explode.ts","../src/Viewer/commands/SetDefaultViewPosition.ts","../src/Viewer/commands/GetDefaultViewPositions.ts","../src/Viewer/commands/GetModels.ts","../src/Viewer/commands/GetSelected.ts","../src/Viewer/commands/HideSelected.ts","../src/Viewer/commands/IsolateSelected.ts","../src/Viewer/commands/RegenerateAll.ts","../src/Viewer/commands/ResetView.ts","../src/Viewer/commands/SelectModel.ts","../src/Viewer/commands/SetActiveDragger.ts","../src/Viewer/commands/SetMarkupColor.ts","../src/Viewer/commands/SetSelected.ts","../src/Viewer/commands/ShowAll.ts","../src/Viewer/commands/ZoomToExtents.ts","../src/Viewer/commands/ZoomToObjects.ts","../src/Viewer/commands/ZoomToSelected.ts","../src/Viewer/loaders/GLTFLoadingManager.ts","../../eventemitter2/dist/eventemitter2.module.js","../../markup/dist/markup.module.js","../src/Viewer/controls/OrbitControls.js","../src/Viewer/draggers/OrbitDragger.ts","../src/Viewer/draggers/PanDragger.ts","../src/Viewer/draggers/ZoomDragger.ts","../src/Viewer/controls/WalkControls.ts","../src/Viewer/draggers/WalkDragger.ts","../src/Viewer/helpers/PlaneHelper.ts","../src/Viewer/draggers/CuttingPlaneDragger.ts","../src/Viewer/draggers/CuttingPlaneXAxis.ts","../src/Viewer/draggers/CuttingPlaneYAxis.ts","../src/Viewer/draggers/CuttingPlaneZAxis.ts","../src/Viewer/draggers/MeasureLineDragger.ts","../src/Viewer/components/ExtentsComponent.ts","../src/Viewer/components/LightComponent.ts","../src/Viewer/components/BackgroundComponent.ts","../src/Viewer/components/DefaultPositionComponent.ts","../src/Viewer/components/ResizeCanvasComponent.ts","../src/Viewer/components/RenderLoopComponent.ts","../src/Viewer/helpers/WCSHelper.ts","../src/Viewer/components/WCSHelperComponent.ts","../src/Viewer/Viewer.ts"],"sourcesContent":["class Commands {\n constructor() {\n this._commands = new Map;\n }\n registerCommand(id, handler, description, thisArg) {\n this._commands.set(id, {\n id: id,\n handler: handler,\n thisArg: thisArg,\n description: description\n });\n }\n registerCommandAlias(id, alias) {\n this.registerCommand(alias, ((viewer, ...args) => this.executeCommand(id, viewer, ...args)));\n }\n getCommand(id) {\n return this._commands.get(id);\n }\n getCommands() {\n const map = new Map;\n this._commands.forEach(((value, key) => map.set(key, value)));\n return map;\n }\n executeCommand(id, viewer, ...args) {\n const command = this._commands.get(id);\n if (!command) {\n if (viewer) {\n const isDraggerCommand = viewer.draggers.includes(id);\n if (isDraggerCommand) return viewer.setActiveDragger(id);\n }\n console.warn(`Command '${id}' not found`);\n return undefined;\n }\n const {handler: handler, thisArg: thisArg} = command;\n const result = handler.apply(thisArg, [ viewer, ...args ]);\n viewer === null || viewer === void 0 ? void 0 : viewer.emit({\n type: \"command\",\n data: id,\n args: args\n });\n return result;\n }\n}\n\nconst _commands = new Map;\n\nfunction commands(viewerType = \"\") {\n let result = _commands.get(viewerType);\n if (!result) {\n result = new Commands;\n _commands.set(viewerType, result);\n }\n return result;\n}\n\ncommands(\"\").registerCommand(\"noop\", (() => {}));\n\ncommands(\"VisualizeJS\").registerCommand(\"noop\", (() => {}));\n\ncommands(\"ThreeJS\").registerCommand(\"noop\", (() => {}));\n\nfunction defaultOptions() {\n return {\n showWCS: true,\n cameraAnimation: true,\n antialiasing: true,\n groundShadow: false,\n shadows: false,\n cameraAxisXSpeed: 4,\n cameraAxisYSpeed: 1,\n ambientOcclusion: false,\n enableStreamingMode: true,\n enablePartialMode: false,\n memoryLimit: 3294967296,\n cuttingPlaneFillColor: {\n red: 255,\n green: 152,\n blue: 0\n },\n edgesColor: {\n r: 255,\n g: 152,\n b: 0\n },\n facesColor: {\n r: 255,\n g: 152,\n b: 0\n },\n edgesVisibility: true,\n edgesOverlap: true,\n facesOverlap: false,\n facesTransparancy: 200,\n enableCustomHighlight: true,\n sceneGraph: false,\n edgeModel: true,\n reverseZoomWheel: false,\n enableZoomWheel: true,\n enableGestures: true,\n geometryType: \"vsfx\",\n rulerUnit: \"Default\"\n };\n}\n\nclass Options {\n constructor(emitter) {\n this._emitter = emitter;\n this._data = defaultOptions();\n this.loadFromStorage();\n }\n static defaults() {\n return defaultOptions();\n }\n notifierChangeEvent() {\n console.warn(\"Options.notifierChangeEvent() has been deprecated since 25.3 and will be removed in a future release, use Options.change() instead.\");\n this.change();\n }\n change() {\n if (this._emitter !== undefined) {\n this.saveToStorage();\n this._emitter.emit({\n type: \"optionschange\",\n data: this\n });\n }\n }\n saveToStorage() {\n if (typeof window !== \"undefined\") try {\n localStorage.setItem(\"od-client-settings\", JSON.stringify(this.data));\n } catch (error) {\n console.error(\"Cannot save client settings.\", error);\n }\n }\n loadFromStorage() {\n if (typeof window !== \"undefined\") try {\n const item = localStorage.getItem(\"od-client-settings\");\n if (item) {\n const data = JSON.parse(item);\n this.data = {\n ...data\n };\n }\n } catch (error) {\n console.error(\"Cannot load client settings.\", error);\n }\n }\n resetToDefaults(fields) {\n if (fields !== undefined) {\n const defaults = Options.defaults();\n const resetData = fields.reduce(((acc, field) => {\n acc[field] = defaults[field];\n return acc;\n }), {});\n this.data = {\n ...this.data,\n ...resetData\n };\n } else {\n this.data = {\n ...this.data,\n ...Options.defaults()\n };\n }\n }\n get data() {\n return this._data;\n }\n set data(value) {\n const enablePartialMode = value.enableStreamingMode ? value.enablePartialMode : false;\n const sceneGraph = enablePartialMode ? false : value.sceneGraph;\n this._data = {\n ...Options.defaults(),\n ...this._data,\n ...value,\n enablePartialMode: enablePartialMode,\n sceneGraph: sceneGraph\n };\n this.change();\n }\n get showWCS() {\n return this._data.showWCS;\n }\n set showWCS(value) {\n this._data.showWCS = value;\n this.change();\n }\n get cameraAnimation() {\n return this._data.cameraAnimation;\n }\n set cameraAnimation(value) {\n this._data.cameraAnimation = value;\n this.change();\n }\n get antialiasing() {\n return this._data.antialiasing;\n }\n set antialiasing(value) {\n this._data.antialiasing = value;\n this.change();\n }\n get groundShadow() {\n return this._data.groundShadow;\n }\n set groundShadow(value) {\n this._data.groundShadow = value;\n this.change();\n }\n get shadows() {\n return this._data.shadows;\n }\n set shadows(value) {\n this._data.shadows = value;\n this.change();\n }\n get cameraAxisXSpeed() {\n return this._data.cameraAxisXSpeed;\n }\n set cameraAxisXSpeed(value) {\n this._data.cameraAxisXSpeed = value;\n this.change();\n }\n get cameraAxisYSpeed() {\n return this._data.cameraAxisYSpeed;\n }\n set cameraAxisYSpeed(value) {\n this.cameraAxisYSpeed = value;\n this.change();\n }\n get ambientOcclusion() {\n return this._data.ambientOcclusion;\n }\n set ambientOcclusion(value) {\n this._data.ambientOcclusion = value;\n this.change();\n }\n get enableStreamingMode() {\n return this._data.enableStreamingMode;\n }\n set enableStreamingMode(value) {\n this._data.enableStreamingMode = value;\n if (!value) this._data.enablePartialMode = false;\n this.change();\n }\n get enablePartialMode() {\n return this._data.enablePartialMode;\n }\n set enablePartialMode(value) {\n this._data.enablePartialMode = value;\n if (value) {\n this._data.enableStreamingMode = true;\n this._data.sceneGraph = false;\n }\n this.change();\n }\n get memoryLimit() {\n return this._data.memoryLimit;\n }\n set memoryLimit(value) {\n this._data.memoryLimit = value;\n this.change();\n }\n get cuttingPlaneFillColor() {\n return this._data.cuttingPlaneFillColor;\n }\n set cuttingPlaneFillColor(value) {\n this._data.cuttingPlaneFillColor = value;\n this.change();\n }\n get edgesColor() {\n return this._data.edgesColor;\n }\n set edgesColor(value) {\n this._data.edgesColor = value;\n this.change();\n }\n get facesColor() {\n return this._data.facesColor;\n }\n set facesColor(value) {\n this._data.facesColor = value;\n this.change();\n }\n get edgesVisibility() {\n return this._data.edgesVisibility;\n }\n set edgesVisibility(value) {\n this._data.edgesVisibility = value;\n this.change();\n }\n get edgesOverlap() {\n return this._data.edgesOverlap;\n }\n set edgesOverlap(value) {\n this._data.edgesOverlap = value;\n this.change();\n }\n get facesOverlap() {\n return this._data.facesOverlap;\n }\n set facesOverlap(value) {\n this._data.facesOverlap = value;\n this.change();\n }\n get facesTransparancy() {\n return this._data.facesTransparancy;\n }\n set facesTransparancy(value) {\n this._data.facesTransparancy = value;\n this.change();\n }\n get enableCustomHighlight() {\n return this._data.enableCustomHighlight;\n }\n set enableCustomHighlight(value) {\n this._data.enableCustomHighlight = value;\n this.change();\n }\n get sceneGraph() {\n return this._data.sceneGraph;\n }\n set sceneGraph(value) {\n this._data.sceneGraph = value;\n if (value) this._data.enablePartialMode = false;\n this.change();\n }\n get edgeModel() {\n return Boolean(this._data.edgeModel);\n }\n set edgeModel(value) {\n this._data.edgeModel = Boolean(value);\n this.change();\n }\n get reverseZoomWheel() {\n return this._data.reverseZoomWheel;\n }\n set reverseZoomWheel(value) {\n this._data.reverseZoomWheel = !!value;\n this.change();\n }\n get enableZoomWheel() {\n return this._data.enableZoomWheel;\n }\n set enableZoomWheel(value) {\n this._data.enableZoomWheel = !!value;\n this.change();\n }\n get enableGestures() {\n return this._data.enableGestures;\n }\n set enableGestures(value) {\n this._data.enableGestures = !!value;\n this.change();\n }\n get geometryType() {\n return this._data.geometryType;\n }\n set geometryType(value) {\n this._data.geometryType = value;\n this.change();\n }\n get rulerUnit() {\n return this._data.rulerUnit;\n }\n set rulerUnit(value) {\n this._data.rulerUnit = value;\n this.change();\n }\n}\n\nconst CanvasEvents = [ \"click\", \"contextmenu\", \"dblclick\", \"mousedown\", \"mouseleave\", \"mousemove\", \"mouseup\", \"pointercancel\", \"pointerdown\", \"pointerleave\", \"pointermove\", \"pointerup\", \"touchcancel\", \"touchend\", \"touchmove\", \"touchstart\", \"wheel\" ];\n\nconst CANVAS_EVENTS = CanvasEvents;\n\nclass Dragger {\n constructor(viewer) {\n this.name = \"\";\n }\n initialize() {}\n dispose() {}\n updatePreview() {}\n}\n\nexport { CANVAS_EVENTS, CanvasEvents, Dragger, Options, commands, defaultOptions };\n//# sourceMappingURL=viewer-core.module.js.map\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Model, File, Assembly } from \"@inweb/client\";\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\n// gltf root object don't have model handle\nfunction applyModelTransform(viewer: Viewer, model: Model | File | Assembly) {\n console.warn(\"applyModelTransform not implemented\");\n}\n\ncommands(\"ThreeJS\").registerCommand(\"applyModelTransform\", applyModelTransform);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"clearMarkup\", (viewer: Viewer) => viewer.clearOverlay());\ncommands(\"ThreeJS\").registerCommandAlias(\"clearMarkup\", \"clearOverlay\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Intersection, MeshBasicMaterial, Object3D, Raycaster, Vector2 } from \"three\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class SelectionComponent implements IDisposable {\n protected viewer: Viewer;\n protected raycaster: Raycaster;\n protected downPosition: Vector2;\n protected facesMaterial: MeshBasicMaterial;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.raycaster = new Raycaster();\n this.downPosition = new Vector2();\n\n const { facesColor, facesTransparancy } = this.viewer.options;\n this.facesMaterial = new MeshBasicMaterial();\n this.facesMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.facesMaterial.opacity = (255 - facesTransparancy) / 255;\n this.facesMaterial.transparent = true;\n\n this.viewer.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.addEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.addEventListener(\"optionschange\", this.optionsChange);\n }\n\n dispose() {\n this.facesMaterial.dispose();\n\n this.viewer.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.removeEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.removeEventListener(\"optionschange\", this.optionsChange);\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (!event.isPrimary || event.button !== 0) return;\n\n this.getMousePosition(event, this.downPosition);\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (!event.isPrimary) return;\n\n const upPosition = this.getMousePosition(event, new Vector2());\n if (this.downPosition.distanceTo(upPosition) !== 0) return;\n\n const intersects = this.getPointerIntersects(upPosition);\n\n this.clearSelection();\n if (intersects.length > 0) this.select(intersects[0].object);\n\n this.viewer.update();\n this.viewer.emitEvent({ type: \"select\", data: undefined, handles: this.viewer.getSelected() });\n };\n\n onDoubleClick = (event: MouseEvent) => {\n if (event.button !== 0) return;\n\n this.viewer.executeCommand(\"zoomToSelected\");\n };\n\n getMousePosition(event: MouseEvent, target: Vector2): Vector2 {\n return target.set(event.clientX, event.clientY);\n }\n\n getPointerIntersects(mouse: Vector2): Array<Intersection<Object3D>> {\n const rect = this.viewer.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.viewer.camera);\n\n const objects = [];\n this.viewer.scene.traverseVisible((child) => objects.push(child));\n\n this.raycaster.params = this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n return this.raycaster.intersectObjects(objects, false);\n }\n\n select(object: any) {\n if (object.isSelected) return;\n\n object.isSelected = true;\n object.originalMaterial = object.material;\n object.material = this.facesMaterial;\n\n this.viewer.selected.push(object);\n }\n\n clearSelection() {\n this.viewer.selected.forEach((object: any) => {\n object.isSelected = false;\n object.material = object.originalMaterial;\n });\n this.viewer.selected.length = 0;\n }\n\n optionsChange = () => {\n const { facesColor, facesTransparancy } = this.viewer.options;\n this.facesMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.facesMaterial.opacity = (255 - facesTransparancy) / 255;\n\n this.viewer.update();\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { SelectionComponent } from \"../components/SelectionComponent\";\n\nfunction clearSelected(viewer: Viewer): void {\n const selection = new SelectionComponent(viewer);\n selection.clearSelection();\n selection.dispose();\n\n viewer.update();\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"clearSelected\", clearSelected);\ncommands(\"ThreeJS\").registerCommandAlias(\"clearSelected\", \"unselect\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"clearSlices\", (viewer: Viewer) => viewer.clearSlices());\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction createPreview(viewer: Viewer, type = \"image/jpeg\", encoderOptions = 0.25): string {\n viewer.update(true);\n return viewer.canvas.toDataURL(type, encoderOptions);\n}\n\ncommands(\"ThreeJS\").registerCommand(\"createPreview\", createPreview);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Object3D, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction calcObjectDepth(object: Object3D, depth: number) {\n let res = depth;\n object.children.forEach((x) => {\n const objectDepth = calcObjectDepth(x, depth + 1);\n if (res < objectDepth) res = objectDepth;\n });\n\n (object as any).originalPosition = object.position.clone();\n\n return res;\n}\n\nfunction explodeScene(scene: Object3D, scale = 0) {\n scale /= 100;\n\n if (!(scene as any).maxDepth) (scene as any).maxDepth = calcObjectDepth(scene, 1);\n const maxDepth = (scene as any).maxDepth;\n\n let explodeDepth = scale * (maxDepth - 1) + 1;\n if (maxDepth === 1) explodeDepth = 1;\n\n function explodeObject(object: Object3D, depth: number, parentCenter: Vector3, parentOffset: Vector3) {\n const objectBox = new Box3().setFromObject(object);\n const objectCenter = objectBox.getCenter(new Vector3());\n\n const objectOffset = parentOffset.clone();\n if (depth > 0 && depth <= explodeDepth) {\n const offset = objectCenter.clone().sub(parentCenter).multiplyScalar(scale);\n objectOffset.add(offset);\n }\n\n object.children.forEach((object) => explodeObject(object, depth + 1, objectCenter, objectOffset));\n\n const originalPosition = (object as any).originalPosition;\n object.position.copy(originalPosition);\n if (scale > 0) {\n const direction = objectCenter.sub(parentCenter).normalize();\n object.position.add(direction.add(objectOffset));\n }\n }\n\n const sceneExtents = new Box3().setFromObject(scene);\n const sceneCenter = sceneExtents.getCenter(new Vector3());\n explodeObject(scene, 0, sceneCenter, new Vector3(0, 0, 0));\n}\n\nfunction explode(viewer: Viewer, index = 0): void {\n viewer.models.forEach((gltf) => explodeScene(gltf.scene, index));\n\n viewer.update();\n viewer.emitEvent({ type: \"explode\", data: index });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"explode\", explode);\ncommands(\"ThreeJS\").registerCommand(\"collect\", (viewer: any) => explode(viewer, 0));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport const defaultViewPositions = {\n top: new Vector3(0, 0, 1),\n bottom: new Vector3(0, 0, -1),\n left: new Vector3(-1, 0, 0),\n right: new Vector3(1, 0, 0),\n front: new Vector3(0, -1, 0),\n back: new Vector3(0, 1, 0),\n sw: new Vector3(-0.5, -0.5, 1.0).normalize(),\n se: new Vector3(0.5, -0.5, 1.0).normalize(),\n ne: new Vector3(0.5, 0.5, 1.0).normalize(),\n nw: new Vector3(-0.5, 0.5, 1.0).normalize(),\n};\n\nfunction setDefaultViewPosition(viewer: Viewer, position: string): void {\n const direction = defaultViewPositions[position] || defaultViewPositions[\"sw\"];\n\n const center = viewer.extents.getCenter(new Vector3());\n const sphere = viewer.extents.getBoundingSphere(new Sphere());\n const offet = direction.clone().multiplyScalar(sphere.radius);\n\n const camera = viewer.camera;\n camera.position.copy(center).add(offet);\n camera.lookAt(center);\n camera.updateProjectionMatrix();\n camera.updateMatrixWorld();\n\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emit({ type: \"viewposition\", data: position });\n\n viewer.executeCommand(\"zoomToExtents\");\n}\n\ncommands(\"ThreeJS\").registerCommand(\"setDefaultViewPosition\", setDefaultViewPosition);\ncommands(\"ThreeJS\").registerCommand(\"top\", (viewer) => setDefaultViewPosition(viewer, \"top\"));\ncommands(\"ThreeJS\").registerCommand(\"bottom\", (viewer) => setDefaultViewPosition(viewer, \"bottom\"));\ncommands(\"ThreeJS\").registerCommand(\"left\", (viewer) => setDefaultViewPosition(viewer, \"left\"));\ncommands(\"ThreeJS\").registerCommand(\"right\", (viewer) => setDefaultViewPosition(viewer, \"right\"));\ncommands(\"ThreeJS\").registerCommand(\"front\", (viewer) => setDefaultViewPosition(viewer, \"front\"));\ncommands(\"ThreeJS\").registerCommand(\"back\", (viewer) => setDefaultViewPosition(viewer, \"back\"));\ncommands(\"ThreeJS\").registerCommand(\"sw\", (viewer) => setDefaultViewPosition(viewer, \"sw\"));\ncommands(\"ThreeJS\").registerCommand(\"se\", (viewer) => setDefaultViewPosition(viewer, \"se\"));\ncommands(\"ThreeJS\").registerCommand(\"ne\", (viewer) => setDefaultViewPosition(viewer, \"ne\"));\ncommands(\"ThreeJS\").registerCommand(\"nw\", (viewer) => setDefaultViewPosition(viewer, \"nw\"));\n\ncommands(\"ThreeJS\").registerCommandAlias(\"top\", \"k3DViewTop\");\ncommands(\"ThreeJS\").registerCommandAlias(\"bottom\", \"k3DViewBottom\");\ncommands(\"ThreeJS\").registerCommandAlias(\"left\", \"k3DViewLeft\");\ncommands(\"ThreeJS\").registerCommandAlias(\"right\", \"k3DViewRight\");\ncommands(\"ThreeJS\").registerCommandAlias(\"front\", \"k3DViewFront\");\ncommands(\"ThreeJS\").registerCommandAlias(\"back\", \"k3DViewBack\");\ncommands(\"ThreeJS\").registerCommandAlias(\"se\", \"k3DViewSE\");\ncommands(\"ThreeJS\").registerCommandAlias(\"sw\", \"k3DViewSW\");\ncommands(\"ThreeJS\").registerCommandAlias(\"ne\", \"k3DViewNE\");\ncommands(\"ThreeJS\").registerCommandAlias(\"nw\", \"k3DViewNW\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport { defaultViewPositions } from \"./SetDefaultViewPosition\";\n\nfunction getDefaultViewPositions(): string[] {\n return Object.keys(defaultViewPositions);\n}\n\ncommands(\"ThreeJS\").registerCommand(\"getDefaultViewPositions\", getDefaultViewPositions);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction getModels(viewer: Viewer): string[] {\n const handles: string[] = viewer.models.map((model) => model.userData.handle || \"\").filter((handle) => handle);\n return handles;\n}\n\ncommands(\"ThreeJS\").registerCommand(\"getModels\", getModels);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction getSelected(viewer: Viewer): string[] {\n return viewer.selected.map((object) => object.userData?.handle).filter((handle) => handle);\n}\n\ncommands(\"ThreeJS\").registerCommand(\"getSelected\", getSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { SelectionComponent } from \"../components/SelectionComponent\";\n\nfunction hideSelected(viewer: Viewer): void {\n viewer.selected.forEach((object) => (object.visible = false));\n\n const selection = new SelectionComponent(viewer);\n selection.clearSelection();\n selection.dispose();\n\n viewer.update();\n viewer.emitEvent({ type: \"hide\" });\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"hideSelected\", hideSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Object3D } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction isolateSelected(viewer: Viewer): void {\n const selectedSet = new Set(viewer.selected);\n\n function isolateObject(object: Object3D, depth: number): boolean {\n let canBeIsolated = true;\n object.children.forEach((object) => {\n if (selectedSet.has(object)) canBeIsolated = false;\n else isolateObject(object, depth + 1);\n });\n\n if (canBeIsolated && depth > 0) object.visible = false;\n\n return canBeIsolated;\n }\n\n isolateObject(viewer.scene, 0);\n\n viewer.update();\n viewer.emitEvent({ type: \"isolate\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"isolateSelected\", isolateSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction regenerateAll(viewer: Viewer): void {\n console.warn(\"regenerateAll not implemented\");\n viewer.emit({ type: \"regenerateall\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"regenerateAll\", regenerateAll);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction resetView(viewer: Viewer): void {\n viewer.executeCommand(\"setActiveDragger\");\n viewer.executeCommand(\"clearSlices\");\n viewer.executeCommand(\"clearOverlay\");\n viewer.executeCommand(\"setMarkupColor\");\n viewer.executeCommand(\"clearSelected\");\n viewer.executeCommand(\"showAll\");\n viewer.executeCommand(\"explode\", 0);\n viewer.executeCommand(\"zoomToExtents\", true);\n viewer.executeCommand(\"k3DViewSW\");\n\n viewer.emit({ type: \"resetview\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"resetView\", resetView);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction selectModel(viewer: Viewer, handle: string): void {\n console.warn(\"selectModel not implemented\");\n viewer.emit({ type: \"select\", data: [] });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"selectModel\", selectModel);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"setActiveDragger\", (viewer: Viewer, dragger = \"\") => {\n viewer.setActiveDragger(dragger);\n});\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\ncommands(\"ThreeJS\").registerCommand(\"setMarkupColor\", (viewer: Viewer, r = 255, g = 0, b = 0) => {\n console.warn(\"setMarkupColor not implemented\");\n // viewer.setMarkupColor(r, g, b);\n});\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { SelectionComponent } from \"../components/SelectionComponent\";\n\nfunction setSelected(viewer: Viewer, handles: string[] = []): void {\n const handleSet = new Set(handles);\n const objects = [];\n viewer.scene.traverseVisible((child) => {\n if (handleSet.has(child.userData?.handle)) objects.push(child);\n });\n\n const selection = new SelectionComponent(viewer);\n selection.clearSelection();\n objects.forEach((object) => selection.select(object));\n selection.dispose();\n\n viewer.update();\n viewer.emitEvent({ type: \"select\", data: undefined, handles });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"setSelected\", setSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction showAll(viewer: Viewer): void {\n viewer.scene.traverse((object) => (object.visible = true));\n\n viewer.update();\n viewer.emitEvent({ type: \"showall\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"showAll\", showAll);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction zoomToExtents(viewer: Viewer): void {\n if (viewer.extents.isEmpty()) return;\n\n const center = viewer.extents.getCenter(new Vector3());\n const distance = viewer.extents.getBoundingSphere(new Sphere()).radius;\n\n const delta = new Vector3(0, 0, 1);\n delta.applyQuaternion(viewer.camera.quaternion);\n delta.multiplyScalar(distance * 3);\n\n viewer.camera.position.copy(center).add(delta);\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"zoomToExtents\", zoomToExtents);\ncommands(\"ThreeJS\").registerCommandAlias(\"zoomToExtents\", \"zoomExtents\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction zoomToObjects(viewer: Viewer, handles: string[] = []): void {\n const handleSet = new Set(handles);\n const objects = [];\n viewer.scene.traverseVisible((child) => {\n if (handleSet.has(child.userData?.handle)) objects.push(child);\n });\n\n const extents = objects.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n const center = extents.getCenter(new Vector3());\n const distance = extents.getBoundingSphere(new Sphere()).radius;\n\n const delta = new Vector3(0, 0, 1);\n delta.applyQuaternion(viewer.camera.quaternion);\n delta.multiplyScalar(distance * 3);\n\n viewer.camera.position.copy(center).add(delta);\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"zoomToObjects\", zoomToObjects);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Sphere, Vector3 } from \"three\";\n\nimport { commands } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction zoomToSelected(viewer: Viewer): void {\n const extents = viewer.selected.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n\n if (extents.isEmpty()) extents.copy(viewer.extents);\n\n const center = extents.getCenter(new Vector3());\n const distance = extents.getBoundingSphere(new Sphere()).radius;\n\n const delta = new Vector3(0, 0, 1);\n delta.applyQuaternion(viewer.camera.quaternion);\n delta.multiplyScalar(distance * 3);\n\n viewer.camera.position.copy(center).add(delta);\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n\ncommands(\"ThreeJS\").registerCommand(\"zoomToSelected\", zoomToSelected);\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { LoadingManager, LoaderUtils } from \"three\";\n\nexport class GLTFLoadingManager extends LoadingManager {\n public path = \"\";\n public resourcePath = \"\";\n public fileURL = \"\";\n public dataURLs = new Map();\n\n constructor(\n file: string | globalThis.File | ArrayBuffer | Blob,\n externalData: Map<string, string | File | ArrayBuffer | Blob> = new Map(),\n params: { path?: string } = {}\n ) {\n super();\n\n this.path = params.path || \"\";\n\n if (typeof file === \"string\") {\n this.fileURL = file;\n this.resourcePath = LoaderUtils.extractUrlBase(file);\n } else {\n externalData.forEach((value, key) => (this.fileURL = value === file ? key : this.fileURL));\n externalData.set(this.fileURL, file);\n }\n\n externalData.forEach((value, key) => {\n let dataURL: string;\n if (typeof value === \"string\") dataURL = value;\n else dataURL = URL.createObjectURL(new Blob([value]));\n this.dataURLs.set(key, dataURL);\n });\n\n this.setURLModifier((url: string) => {\n const key = decodeURI(url)\n .replace(this.path, \"\")\n .replace(this.resourcePath, \"\")\n .replace(/^(\\.?\\/)/, \"\");\n const dataURL = this.dataURLs.get(key);\n return dataURL ?? url;\n });\n }\n\n dispose() {\n this.dataURLs.forEach(URL.revokeObjectURL);\n }\n}\n","class EventEmitter2 {\n constructor() {\n this._listeners = {};\n }\n addEventListener(type, listener) {\n if (this._listeners[type] === undefined) this._listeners[type] = [];\n this._listeners[type].push(listener);\n return this;\n }\n removeEventListener(type, listener) {\n if (this._listeners[type] === undefined) return this;\n const listeners = this._listeners[type].filter((x => x !== listener));\n if (listeners.length !== 0) this._listeners[type] = listeners; else delete this._listeners[type];\n return this;\n }\n removeAllListeners(type) {\n if (type) delete this._listeners[type]; else this._listeners = {};\n return this;\n }\n emitEvent(event) {\n if (this._listeners[event.type] === undefined) return false;\n const invoke = this._listeners[event.type].slice();\n invoke.forEach((listener => listener.call(this, event)));\n return true;\n }\n on(type, listener) {\n return this.addEventListener(type, listener);\n }\n off(type, listener) {\n return this.removeEventListener(type, listener);\n }\n emit(type, ...args) {\n if (typeof type === \"string\") return this.emitEvent({\n type: type,\n args: args\n }); else if (typeof type === \"object\") return this.emitEvent(type); else return false;\n }\n}\n\nexport { EventEmitter2 };\n//# sourceMappingURL=eventemitter2.module.js.map\n","import Konva from \"konva\";\n\nclass WorldTransform {\n screenToWorld(position) {\n return {\n x: position.x,\n y: position.y,\n z: 0\n };\n }\n worldToScreen(position) {\n return {\n x: position.x,\n y: position.y\n };\n }\n getScale() {\n return {\n x: 1,\n y: 1,\n z: 1\n };\n }\n}\n\nclass MarkupColor {\n constructor(r, g, b) {\n this.setColor(r, g, b);\n }\n asHex() {\n return \"#\" + this.HEX;\n }\n asRGB() {\n return {\n r: this.R,\n g: this.G,\n b: this.B\n };\n }\n setColor(r, g, b) {\n this.R = r;\n this.G = g;\n this.B = b;\n this.HEX = this.rgbToHex(r, g, b);\n }\n rgbToHex(r, g, b) {\n const valueToHex = c => {\n const hex = c.toString(16);\n return hex === \"0\" ? \"00\" : hex;\n };\n return valueToHex(r) + valueToHex(g) + valueToHex(b);\n }\n}\n\nconst LineTypeSpecs = new Map([ [ \"solid\", [] ], [ \"dot\", [ 30, 30, .001, 30 ] ], [ \"dash\", [ 30, 30 ] ] ]);\n\nclass KonvaLine {\n constructor(params, ref = null) {\n var _a, _b;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.points) params.points = [ {\n x: 50,\n y: 50\n }, {\n x: 100,\n y: 100\n } ];\n const konvaPoints = [];\n params.points.forEach((point => konvaPoints.push(point.x, point.y)));\n this._ref = new Konva.Line({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n strokeWidth: (_b = params.width) !== null && _b !== void 0 ? _b : 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n points: konvaPoints,\n draggable: true,\n strokeScaleEnabled: false,\n dash: LineTypeSpecs.get(params.type) || []\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n }));\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Line\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPoints() {\n return this._ref.points();\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n getLineType() {\n const typeSpecs = this._ref.dash() || [];\n let type;\n switch (typeSpecs) {\n case LineTypeSpecs.get(\"dot\"):\n type = \"dot\";\n break;\n\n case LineTypeSpecs.get(\"dash\"):\n type = \"dash\";\n break;\n\n default:\n type = \"solid\";\n break;\n }\n return type;\n }\n setLineType(type) {\n const specs = LineTypeSpecs.get(type);\n if (specs) this._ref.dash(specs);\n }\n addPoints(points) {\n let newPoints = this._ref.points();\n points.forEach((point => {\n newPoints = newPoints.concat([ point.x, point.y ]);\n }));\n this._ref.points(newPoints);\n }\n}\n\nclass KonvaText {\n constructor(params, ref = null) {\n var _a, _b, _c;\n this.TEXT_FONT_FAMILY = \"Calibri\";\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n if (!params.text) params.text = \"default\";\n this._ref = new Konva.Text({\n x: params.position.x,\n y: params.position.y,\n text: params.text,\n fontSize: (_a = params.fontSize) !== null && _a !== void 0 ? _a : 34,\n fontFamily: this.TEXT_FONT_FAMILY,\n fill: (_b = params.color) !== null && _b !== void 0 ? _b : \"#ff0000\",\n align: \"left\",\n draggable: true,\n rotation: (_c = params.rotation) !== null && _c !== void 0 ? _c : 0\n });\n this._ref.width(this._ref.getTextWidth());\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n const minWidth = 50;\n if (newWidth < minWidth) newWidth = minWidth;\n if (newHeight < Math.round(this.getFontSize())) newHeight = Math.round(this.getFontSize());\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Text\";\n }\n getColor() {\n return this._ref.fill();\n }\n setColor(hex) {\n this._ref.fill(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getText() {\n return this._ref.text();\n }\n setText(text) {\n this._ref.text(text);\n }\n getPosition() {\n return this._ref.getPosition();\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n getFontSize() {\n return this._ref.fontSize();\n }\n setFontSize(size) {\n this._ref.fontSize(size);\n }\n}\n\nclass KonvaRectangle {\n constructor(params, ref = null) {\n var _a, _b, _c, _d;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n this._ref = new Konva.Rect({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n strokeWidth: (_b = params.lineWidth) !== null && _b !== void 0 ? _b : 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n x: params.position.x,\n y: params.position.y,\n width: (_c = params.width) !== null && _c !== void 0 ? _c : 200,\n height: (_d = params.height) !== null && _d !== void 0 ? _d : 200,\n draggable: true,\n strokeScaleEnabled: false\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n const minWidth = 50;\n const minHeight = 50;\n if (newWidth < minWidth) newWidth = minWidth;\n if (newHeight < minHeight) newHeight = minHeight;\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n getPosition() {\n return this._ref.position();\n }\n getWidth() {\n return this._ref.width();\n }\n getHeigth() {\n return this._ref.height();\n }\n setWidth(w) {\n this._ref.width(w);\n }\n setHeight(h) {\n this._ref.height(h);\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Rectangle\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n}\n\nclass KonvaEllipse {\n constructor(params, ref = null) {\n var _a, _b;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n if (!params.radius) params.radius = {\n x: 25,\n y: 25\n };\n this._ref = new Konva.Ellipse({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n strokeWidth: (_b = params.lineWidth) !== null && _b !== void 0 ? _b : 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n x: params.position.x,\n y: params.position.y,\n radiusX: params.radius.x,\n radiusY: params.radius.y,\n draggable: true,\n strokeScaleEnabled: false\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newRadiusX = this._ref.radiusX();\n if (scaleByX) newRadiusX *= attrs.scaleX;\n let newRadiusY = this._ref.radiusY();\n if (scaleByY) newRadiusY *= attrs.scaleY;\n const minRadiusX = 25;\n const minRadiusY = 25;\n if (newRadiusX < minRadiusX) newRadiusX = minRadiusX;\n if (newRadiusY < minRadiusY) newRadiusY = minRadiusY;\n if (e.evt.ctrlKey || e.evt.shiftKey) {\n if (scaleByX) {\n this._ref.radius({\n x: newRadiusX,\n y: newRadiusX\n });\n } else {\n this._ref.radius({\n x: newRadiusY,\n y: newRadiusY\n });\n }\n } else {\n this._ref.radius({\n x: newRadiusX,\n y: newRadiusY\n });\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n getPosition() {\n return this._ref.position();\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n getRadiusX() {\n return this._ref.radiusX();\n }\n setRadiusX(r) {\n this._ref.radiusX(r);\n }\n getRadiusY() {\n return this._ref.radiusY();\n }\n setRadiusY(r) {\n this._ref.radiusY(r);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Ellipse\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n}\n\nclass KonvaArrow {\n constructor(params, ref = null) {\n var _a, _b;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.start) params.start = {\n x: 50,\n y: 50\n };\n if (!params.end) params.end = {\n x: 100,\n y: 100\n };\n this._ref = new Konva.Arrow({\n stroke: (_a = params.color) !== null && _a !== void 0 ? _a : \"#ff0000\",\n fill: (_b = params.color) !== null && _b !== void 0 ? _b : \"#ff0000\",\n strokeWidth: 4,\n globalCompositeOperation: \"source-over\",\n lineCap: \"round\",\n lineJoin: \"round\",\n points: [ params.start.x, params.start.y, params.end.x, params.end.y ],\n draggable: true,\n strokeScaleEnabled: false\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n }));\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Arrow\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n this._ref.fill(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPoints() {\n const points = this._ref.points();\n return [ {\n x: points[0],\n y: points[1]\n }, {\n x: points[2],\n y: points[3]\n } ];\n }\n setPoints(points) {\n if (points.length === 2) {\n this._ref.points([ points[0].x, points[0].y, points[1].x, points[1].y ]);\n }\n }\n getStartPoint() {\n const points = this._ref.points();\n return {\n x: points[0],\n y: points[1]\n };\n }\n setStartPoint(x, y) {\n const points = this._ref.points();\n this._ref.points([ x, y, points[2], points[3] ]);\n }\n getEndPoint() {\n const points = this._ref.points();\n return {\n x: points[2],\n y: points[3]\n };\n }\n setEndPoint(x, y) {\n const points = this._ref.points();\n this._ref.points([ points[0], points[1], x, y ]);\n }\n}\n\nclass KonvaImage {\n constructor(params, ref = null) {\n var _a, _b;\n this._ratio = 1;\n this.EPSILON = 1e-5;\n this.BASE64_HEADER_START = \"data:image/\";\n this.BASE64_NOT_FOUND = \"\";\n if (ref) {\n if (!ref.src || !ref.src.startsWith(this.BASE64_HEADER_START)) ref.src = this.BASE64_NOT_FOUND;\n if (ref.height() <= this.EPSILON) ref.height(32);\n if (ref.width() <= this.EPSILON) ref.width(32);\n this._ref = ref;\n this._canvasImage = ref.image();\n this._ratio = this._ref.height() <= this.EPSILON || this._ref.width() <= this.EPSILON ? 1 : this._ref.height() / this._ref.width();\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 50,\n y: 50\n };\n if (!params.src || !params.src.startsWith(this.BASE64_HEADER_START)) params.src = this.BASE64_NOT_FOUND;\n this._canvasImage = new Image;\n this._canvasImage.onload = () => {\n this._ref.image(this._canvasImage);\n if (this._ref.height() <= this.EPSILON) this._ref.height(this._canvasImage.height);\n if (this._ref.width() <= this.EPSILON) this._ref.width(this._canvasImage.width);\n this._ratio = this._ref.height() <= this.EPSILON || this._ref.width() <= this.EPSILON ? 1 : this._ref.height() / this._ref.width();\n if ((params.width <= this.EPSILON || params.height <= this.EPSILON) && (params.maxWidth >= this.EPSILON || params.maxWidth >= this.EPSILON)) {\n const heightOutOfCanvas = params.maxHeight - this._canvasImage.height;\n const widthOutOfCanvas = params.maxWidth - this._canvasImage.width;\n if (heightOutOfCanvas <= this.EPSILON || widthOutOfCanvas <= this.EPSILON) {\n if (widthOutOfCanvas <= this.EPSILON && widthOutOfCanvas < heightOutOfCanvas / this._ratio) {\n this._ref.height(params.maxWidth * this._ratio);\n this._ref.width(params.maxWidth);\n } else {\n this._ref.width(params.maxHeight / this._ratio);\n this._ref.height(params.maxHeight);\n }\n }\n }\n };\n this._canvasImage.onerror = () => {\n this._canvasImage.onerror = function() {};\n this._canvasImage.src = this.BASE64_NOT_FOUND;\n };\n this._canvasImage.src = params.src;\n this._ref = new Konva.Image({\n x: params.position.x,\n y: params.position.y,\n image: this._canvasImage,\n width: (_a = params.width) !== null && _a !== void 0 ? _a : 0,\n height: (_b = params.height) !== null && _b !== void 0 ? _b : 0,\n draggable: true\n });\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n if (e.evt.ctrlKey || e.evt.shiftKey) {\n if (scaleByX) {\n this._ref.width(newWidth);\n this._ref.height(newWidth * this._ratio);\n } else {\n this._ref.width(newHeight / this._ratio);\n this._ref.height(newHeight);\n }\n } else {\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.id(this._ref._id.toString());\n }\n getSrc() {\n return this._canvasImage.src;\n }\n setSrc(src) {\n this._canvasImage.src = src;\n }\n getWidth() {\n return this._ref.width();\n }\n setWidth(w) {\n this._ref.width(w);\n this._ref.height(w * this._ratio);\n }\n getHeight() {\n return this._ref.height();\n }\n setHeight(h) {\n this._ref.height(h);\n this._ref.width(h / this._ratio);\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Image\";\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPosition() {\n return this._ref.getPosition();\n }\n setPosition(x, y) {\n this._ref.setPosition({\n x: x,\n y: y\n });\n }\n}\n\nclass KonvaCloud {\n constructor(params, ref = null) {\n var _a, _b, _c, _d;\n if (ref) {\n this._ref = ref;\n return;\n }\n if (!params) params = {};\n if (!params.position) params.position = {\n x: 100,\n y: 100\n };\n const arcRadius = 16;\n this._ref = new Konva.Shape({\n x: params.position.x,\n y: params.position.y,\n width: (_a = params.width) !== null && _a !== void 0 ? _a : 200,\n height: (_b = params.height) !== null && _b !== void 0 ? _b : 200,\n stroke: (_c = params.color) !== null && _c !== void 0 ? _c : \"#ff0000\",\n strokeWidth: (_d = params.lineWidth) !== null && _d !== void 0 ? _d : 4,\n draggable: true,\n strokeScaleEnabled: false,\n globalCompositeOperation: \"source-over\",\n sceneFunc: (context, shape) => {\n function calculateMidpoint(position, width, height) {\n const midX = position.x + width / 2;\n const midY = position.y + height / 2;\n return {\n x: midX,\n y: midY\n };\n }\n const points = [ {\n x: 0,\n y: 0\n }, {\n x: 0 + this._ref.width(),\n y: 0\n }, {\n x: 0 + this._ref.width(),\n y: 0 + this._ref.height()\n }, {\n x: 0,\n y: 0 + this._ref.height()\n }, {\n x: 0,\n y: 0\n } ];\n const midPoint = calculateMidpoint({\n x: 0,\n y: 0\n }, this._ref.width(), this._ref.height());\n const baseArcLength = 30;\n context.beginPath();\n for (let iPoint = 0; iPoint < points.length - 1; iPoint++) {\n let approxArcLength = baseArcLength;\n const dx = points[iPoint + 1].x - points[iPoint].x;\n const dy = points[iPoint + 1].y - points[iPoint].y;\n const length = Math.sqrt(dx * dx + dy * dy);\n const arcCount = Math.floor(length / approxArcLength);\n const lengthMod = length % approxArcLength;\n approxArcLength = baseArcLength + arcCount / lengthMod;\n let pX = points[iPoint].x + dx / arcCount / 2;\n let pY = points[iPoint].y + dy / arcCount / 2;\n const pEndX = points[iPoint + 1].x;\n const pEndY = points[iPoint + 1].y;\n const endAngle = Math.atan((pEndY - pY) / (pEndX - pX));\n const startAngle = endAngle + Math.PI;\n const counterClockwise = pX > midPoint.x && pY > midPoint.y;\n for (let iArc = 0; iArc < arcCount; iArc++) {\n if (counterClockwise) {\n context.arc(pX, pY, arcRadius, endAngle, startAngle);\n } else {\n context.arc(pX, pY, arcRadius, startAngle, endAngle);\n }\n pX += dx / arcCount;\n pY += dy / arcCount;\n }\n }\n context.closePath();\n context.fillStrokeShape(shape);\n }\n });\n this._ref.className = \"Cloud\";\n this._ref.on(\"transform\", (e => {\n const attrs = e.target.attrs;\n if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);\n const scaleByX = Math.abs(attrs.scaleX - 1) > 1e-5;\n const scaleByY = Math.abs(attrs.scaleY - 1) > 1e-5;\n let newWidth = this._ref.width();\n if (scaleByX) newWidth *= attrs.scaleX;\n let newHeight = this._ref.height();\n if (scaleByY) newHeight *= attrs.scaleY;\n const minWidth = 100;\n const minHeight = 100;\n if (newWidth < minWidth) newWidth = minWidth;\n if (newHeight < minHeight) newHeight = minHeight;\n if (scaleByX) {\n this._ref.width(newWidth);\n }\n if (scaleByY) {\n this._ref.height(newHeight);\n }\n this._ref.scale({\n x: 1,\n y: 1\n });\n }));\n this._ref.getSelfRect = () => ({\n x: 0 - arcRadius,\n y: 0 - arcRadius,\n width: this._ref.width() + 2 * arcRadius,\n height: this._ref.height() + 2 * arcRadius\n });\n this._ref.id(this._ref._id.toString());\n }\n ref() {\n return this._ref;\n }\n id() {\n return this._ref.id();\n }\n enableMouseEditing(value) {\n this._ref.draggable(value);\n }\n type() {\n return \"Cloud\";\n }\n getColor() {\n return this._ref.stroke();\n }\n setColor(hex) {\n this._ref.stroke(hex);\n }\n getRotation() {\n return this._ref.rotation();\n }\n setRotation(degrees) {\n this._ref.rotation(degrees);\n }\n getZIndex() {\n return this._ref.zIndex();\n }\n setZIndex(zIndex) {\n this._ref.zIndex(zIndex);\n }\n delete() {\n this._ref.destroy();\n this._ref = null;\n }\n getPosition() {\n return this._ref.position();\n }\n setPosition(x, y) {\n this._ref.position({\n x: x,\n y: y\n });\n }\n getWidth() {\n return this._ref.width();\n }\n setWidth(w) {\n this._ref.width(w);\n }\n getHeigth() {\n return this._ref.height();\n }\n setHeight(h) {\n this._ref.height(h);\n }\n getLineWidth() {\n return this._ref.strokeWidth();\n }\n setLineWidth(size) {\n this._ref.strokeWidth(size);\n }\n}\n\nconst MarkupMode2Konva = {\n SelectMarkup: {\n name: \"SelectMarkup\",\n initializer: null\n },\n Line: {\n name: \"Line\",\n initializer: (ref, params = null) => new KonvaLine(params, ref)\n },\n Text: {\n name: \"Text\",\n initializer: (ref, params = null) => new KonvaText(params, ref)\n },\n Rectangle: {\n name: \"Rect\",\n initializer: (ref, params = null) => new KonvaRectangle(params, ref)\n },\n Ellipse: {\n name: \"Ellipse\",\n initializer: (ref, params = null) => new KonvaEllipse(params, ref)\n },\n Arrow: {\n name: \"Arrow\",\n initializer: (ref, params = null) => new KonvaArrow(params, ref)\n },\n Image: {\n name: \"Image\",\n initializer: (ref, params = null) => new KonvaImage(params, ref)\n },\n Cloud: {\n name: \"Cloud\",\n initializer: (ref, params = null) => new KonvaCloud(params, ref)\n }\n};\n\nclass KonvaMarkup {\n constructor() {\n this._containerEvents = [];\n this._markupIsActive = false;\n this._markupColor = new MarkupColor(255, 0, 0);\n this.lineWidth = 4;\n this.lineType = \"solid\";\n this.fontSize = 34;\n this.changeActiveDragger = event => {\n const draggerName = event.data;\n this._markupContainer.className = this._container.className.split(\" \").filter((x => !x.startsWith(\"oda-cursor-\"))).filter((x => x)).concat(`oda-cursor-${draggerName.toLowerCase()}`).join(\" \");\n this.removeTextInput();\n this.removeImageInput();\n this.enableEditMode(draggerName);\n };\n this.resizeContainer = entries => {\n const {width: width, height: height} = entries[0].contentRect;\n if (!width || !height) return;\n if (!this._konvaStage) return;\n this._konvaStage.width(width);\n this._konvaStage.height(height);\n };\n this.pan = event => {\n const newPos = {\n x: this._konvaStage.x() + event.dX,\n y: this._konvaStage.y() + event.dY\n };\n this._konvaStage.position(newPos);\n };\n this.zoomAt = event => {\n const newScale = this._konvaStage.scaleX() * event.data;\n this._konvaStage.scale({\n x: newScale,\n y: newScale\n });\n const newPos = {\n x: event.x - (event.x - this._konvaStage.x()) * event.data,\n y: event.y - (event.y - this._konvaStage.y()) * event.data\n };\n this._konvaStage.position(newPos);\n };\n this.redirectToViewer = event => {\n if (this._viewer) this._viewer.emit(event);\n };\n this.getRelativePointPosition = (point, node) => {\n const transform = node.getAbsoluteTransform().copy();\n transform.invert();\n return transform.point(point);\n };\n this.getRelativePointerPosition = node => this.getRelativePointPosition(node.getStage().getPointerPosition(), node);\n }\n initialize(container, containerEvents, viewer, worldTransformer) {\n if (!Konva) throw new Error('Markup error: Konva is not initialized. Forgot to add <script src=\"https://unpkg.com/konva@9/konva.min.js\"><\\/script> to your page?');\n this._viewer = viewer;\n this._worldTransformer = worldTransformer !== null && worldTransformer !== void 0 ? worldTransformer : new WorldTransform;\n this._container = container;\n this._containerEvents = containerEvents !== null && containerEvents !== void 0 ? containerEvents : [];\n this._markupContainer = document.createElement(\"div\");\n this._markupContainer.id = \"markup-container\";\n this._markupContainer.style.position = \"absolute\";\n this._markupContainer.style.top = \"0px\";\n this._markupContainer.style.left = \"0px\";\n this._markupContainer.style.outline = \"0px\";\n this._markupContainer.style.pointerEvents = \"none\";\n const parentDiv = this._container.parentElement;\n parentDiv.appendChild(this._markupContainer);\n this._resizeObserver = new ResizeObserver(this.resizeContainer);\n this._resizeObserver.observe(parentDiv);\n this._markupColor.setColor(255, 0, 0);\n this.initializeKonva();\n if (this._viewer) {\n this._viewer.addEventListener(\"changeactivedragger\", this.changeActiveDragger);\n this._viewer.addEventListener(\"pan\", this.pan);\n this._viewer.addEventListener(\"zoomat\", this.zoomAt);\n }\n }\n dispose() {\n var _a, _b;\n if (this._viewer) {\n this._viewer.removeEventListener(\"zoomat\", this.zoomAt);\n this._viewer.removeEventListener(\"pan\", this.pan);\n this._viewer.removeEventListener(\"changeactivedragger\", this.changeActiveDragger);\n }\n this.destroyKonva();\n (_a = this._resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();\n this._resizeObserver = undefined;\n (_b = this._markupContainer) === null || _b === void 0 ? void 0 : _b.remove();\n this._markupContainer = undefined;\n this._container = undefined;\n this._viewer = undefined;\n this._worldTransformer = undefined;\n this._markupIsActive = false;\n }\n syncOverlay() {}\n clearOverlay() {\n this.removeTextInput();\n this.removeImageInput();\n this.clearSelected();\n this.getObjects().forEach((obj => obj.delete()));\n }\n getMarkupColor() {\n return this._markupColor.asRGB();\n }\n setMarkupColor(r, g, b) {\n this._markupColor.setColor(r, g, b);\n this._viewer.emit({\n type: \"changemarkupcolor\",\n data: {\n r: r,\n g: g,\n b: b\n }\n });\n }\n colorizeAllMarkup(r, g, b) {\n const hexColor = new MarkupColor(r, g, b).asHex();\n this.getObjects().filter((obj => {\n var _a;\n return (_a = obj.setColor) === null || _a === void 0 ? void 0 : _a.call(obj, hexColor);\n }));\n }\n colorizeSelectedMarkups(r, g, b) {\n const hexColor = new MarkupColor(r, g, b).asHex();\n this.getSelectedObjects().filter((obj => {\n var _a;\n return (_a = obj.setColor) === null || _a === void 0 ? void 0 : _a.call(obj, hexColor);\n }));\n }\n setViewpoint(viewpoint) {\n var _a, _b, _c, _d, _e, _f, _g, _h;\n this.clearSelected();\n this.removeTextInput();\n this.removeImageInput();\n this._konvaStage.scale({\n x: 1,\n y: 1\n });\n this._konvaStage.position({\n x: 0,\n y: 0\n });\n const markupColor = ((_a = viewpoint.custom_fields) === null || _a === void 0 ? void 0 : _a.markup_color) || {\n r: 255,\n g: 0,\n b: 0\n };\n this.setMarkupColor(markupColor.r, markupColor.g, markupColor.b);\n (_b = viewpoint.lines) === null || _b === void 0 ? void 0 : _b.forEach((line => {\n const linePoints = [];\n line.points.forEach((point => {\n const screenPoint = this._worldTransformer.worldToScreen(point);\n linePoints.push(screenPoint.x);\n linePoints.push(screenPoint.y);\n }));\n this.addLine(linePoints, line.color, line.type, line.width, line.id);\n }));\n (_c = viewpoint.texts) === null || _c === void 0 ? void 0 : _c.forEach((text => {\n const screenPoint = this._worldTransformer.worldToScreen(text.position);\n this.addText(text.text, screenPoint, text.angle, text.color, text.text_size, text.font_size, text.id);\n }));\n (_d = viewpoint.rectangles) === null || _d === void 0 ? void 0 : _d.forEach((rect => {\n const screenPoint = this._worldTransformer.worldToScreen(rect.position);\n this.addRectangle(screenPoint, rect.width, rect.height, rect.line_width, rect.color, rect.id);\n }));\n (_e = viewpoint.ellipses) === null || _e === void 0 ? void 0 : _e.forEach((ellipse => {\n const screenPoint = this._worldTransformer.worldToScreen(ellipse.position);\n this.addEllipse(screenPoint, ellipse.radius, ellipse.line_width, ellipse.color, ellipse.id);\n }));\n (_f = viewpoint.arrows) === null || _f === void 0 ? void 0 : _f.forEach((arrow => {\n const startPoint = this._worldTransformer.worldToScreen(arrow.start);\n const endPoint = this._worldTransformer.worldToScreen(arrow.end);\n this.addArrow(startPoint, endPoint, arrow.color, arrow.id);\n }));\n (_g = viewpoint.clouds) === null || _g === void 0 ? void 0 : _g.forEach((cloud => {\n const screenPoint = this._worldTransformer.worldToScreen(cloud.position);\n this.addCloud(screenPoint, cloud.width, cloud.height, cloud.line_width, cloud.color, cloud.id);\n }));\n (_h = viewpoint.images) === null || _h === void 0 ? void 0 : _h.forEach((image => {\n const screenPoint = this._worldTransformer.worldToScreen(image.position);\n this.addImage(screenPoint, image.src, image.width, image.height, image.id);\n }));\n }\n getViewpoint(viewpoint) {\n if (!viewpoint) viewpoint = {};\n viewpoint.lines = this.getMarkupLines();\n viewpoint.texts = this.getMarkupTexts();\n viewpoint.arrows = this.getMarkupArrows();\n viewpoint.clouds = this.getMarkupClouds();\n viewpoint.ellipses = this.getMarkupEllipses();\n viewpoint.images = this.getMarkupImages();\n viewpoint.rectangles = this.getMarkupRectangles();\n viewpoint.custom_fields = {\n markup_color: this.getMarkupColor()\n };\n viewpoint.snapshot = {\n data: this.combineMarkupWithDrawing()\n };\n return viewpoint;\n }\n enableEditMode(mode) {\n if (!mode || !MarkupMode2Konva[mode]) {\n this.clearSelected();\n this.removeTextInput();\n this.removeImageInput();\n this._markupContainer.style.pointerEvents = \"none\";\n this._markupIsActive = false;\n } else {\n this._markupMode = mode;\n this._markupContainer.style.pointerEvents = \"all\";\n this._markupIsActive = true;\n }\n return this;\n }\n createObject(type, params) {\n const konvaShape = MarkupMode2Konva[type];\n if (!konvaShape || !konvaShape.initializer) throw new Error(`Markup CreateObject - unsupported markup type ${type}`);\n const object = konvaShape.initializer(null, params);\n this.addObject(object);\n return object;\n }\n getObjects() {\n const objects = [];\n Object.keys(MarkupMode2Konva).forEach((type => {\n const konvaShape = MarkupMode2Konva[type];\n this.konvaLayerFind(type).forEach((ref => objects.push(konvaShape.initializer(ref))));\n }));\n return objects;\n }\n getSelectedObjects() {\n if (!this._konvaTransformer) return [];\n return this._konvaTransformer.nodes().map((ref => {\n const name = ref.className;\n const konvaShape = Object.values(MarkupMode2Konva).find((shape => shape.name === name));\n return konvaShape ? konvaShape.initializer(ref) : null;\n })).filter((x => x));\n }\n selectObjects(objects) {\n if (!this._konvaTransformer) return;\n const selectedObjs = this._konvaTransformer.nodes().concat(objects.map((x => x.ref())));\n this._konvaTransformer.nodes(selectedObjs);\n }\n clearSelected() {\n if (this._konvaTransformer) this._konvaTransformer.nodes([]);\n }\n addObject(object) {\n if (object.type() === \"Image\") this._groupImages.add(object.ref()); else if (object.type() === \"Text\") this._groupTexts.add(object.ref()); else this._groupGeometry.add(object.ref());\n }\n konvaLayerFind(type) {\n if (!this._konvaLayer) return [];\n const konvaShape = MarkupMode2Konva[type];\n if (!konvaShape || !konvaShape.initializer) return [];\n return this._konvaLayer.find(konvaShape.name).filter((ref => ref.parent === this._konvaLayer || ref.parent === this._groupImages || ref.parent === this._groupGeometry || ref.parent === this._groupTexts));\n }\n initializeKonva() {\n const stage = new Konva.Stage({\n container: this._markupContainer,\n width: this._container.clientWidth,\n height: this._container.clientHeight\n });\n this._konvaStage = stage;\n const layer = new Konva.Layer({\n pixelRation: window.devicePixelRatio\n });\n stage.add(layer);\n this._groupImages = new Konva.Group;\n layer.add(this._groupImages);\n this._groupGeometry = new Konva.Group;\n layer.add(this._groupGeometry);\n this._groupTexts = new Konva.Group;\n layer.add(this._groupTexts);\n this._konvaLayer = layer;\n const transformer = new Konva.Transformer({\n shouldOverdrawWholeArea: false,\n keepRatio: false,\n flipEnabled: false\n });\n layer.add(transformer);\n this._konvaTransformer = transformer;\n let isPaint = false;\n let lastLine;\n let mouseDownPos;\n let lastObj;\n stage.on(\"mousedown touchstart\", (e => {\n if (!this._markupIsActive || e.target !== stage || this._markupMode === \"Text\" || this._markupMode === \"Image\") return;\n if (e.target === stage && transformer.nodes().length > 0) {\n transformer.nodes([]);\n return;\n }\n const pos = this.getRelativePointerPosition(stage);\n mouseDownPos = pos;\n isPaint = [ \"Arrow\", \"Cloud\", \"Ellipse\", \"Line\", \"Rectangle\" ].some((m => m === this._markupMode));\n if (this._markupMode === \"Line\") {\n lastLine = this.addLine([ pos.x, pos.y, pos.x, pos.y ]);\n }\n }));\n stage.on(\"mouseup touchend\", (e => {\n if (!this._markupIsActive) return;\n if (isPaint) {\n const pos = this.getRelativePointerPosition(stage);\n const defParams = mouseDownPos && pos.x === mouseDownPos.x && pos.y === mouseDownPos.y;\n const startX = defParams ? mouseDownPos.x : Math.min(mouseDownPos.x, pos.x);\n const startY = defParams ? mouseDownPos.y : Math.min(mouseDownPos.y, pos.y);\n const dX = defParams ? 200 : Math.abs(mouseDownPos.x - pos.x);\n const dY = defParams ? 200 : Math.abs(mouseDownPos.y - pos.y);\n if (defParams) {\n if (this._markupMode === \"Rectangle\") {\n this.addRectangle({\n x: startX,\n y: startY\n }, dX, dY);\n } else if (this._markupMode === \"Ellipse\") {\n this.addEllipse({\n x: startX,\n y: startY\n }, {\n x: dX / 2,\n y: dY / 2\n });\n } else if (this._markupMode === \"Arrow\") {\n this.addArrow({\n x: mouseDownPos.x,\n y: mouseDownPos.y\n }, {\n x: defParams ? mouseDownPos.x + 200 : pos.x,\n y: defParams ? startY : pos.y\n });\n } else if (this._markupMode === \"Cloud\") {\n this.addCloud({\n x: startX,\n y: startY\n }, Math.max(100, dX), Math.max(100, dY));\n }\n }\n }\n lastObj = undefined;\n isPaint = false;\n }));\n stage.on(\"mousemove touchmove\", (e => {\n if (!this._markupIsActive) return;\n if (!isPaint) {\n return;\n }\n const pos = this.getRelativePointerPosition(stage);\n const defParams = mouseDownPos && pos.x === mouseDownPos.x && pos.y === mouseDownPos.y;\n const startX = defParams ? mouseDownPos.x : Math.min(mouseDownPos.x, pos.x);\n const startY = defParams ? mouseDownPos.y : Math.min(mouseDownPos.y, pos.y);\n const dX = defParams ? 200 : Math.abs(mouseDownPos.x - pos.x);\n const dY = defParams ? 200 : Math.abs(mouseDownPos.y - pos.y);\n if (this._markupMode === \"Line\") {\n lastLine.addPoints([ {\n x: pos.x,\n y: pos.y\n } ]);\n } else if (this._markupMode === \"Arrow\") {\n if (lastObj) lastObj.setEndPoint(pos.x, pos.y); else lastObj = this.addArrow({\n x: mouseDownPos.x,\n y: mouseDownPos.y\n }, {\n x: pos.x,\n y: pos.y\n });\n } else if (this._markupMode === \"Rectangle\") {\n if (lastObj) {\n lastObj.setPosition(startX, startY);\n lastObj.setWidth(dX);\n lastObj.setHeight(dY);\n } else lastObj = this.addRectangle({\n x: startX,\n y: startY\n }, dX, dY);\n } else if (this._markupMode === \"Ellipse\") {\n if (lastObj) {\n lastObj.setPosition(startX, startY);\n lastObj.setRadiusX(dX);\n lastObj.setRadiusY(dY);\n } else lastObj = this.addEllipse({\n x: startX,\n y: startY\n }, {\n x: dX,\n y: dY\n });\n } else if (this._markupMode === \"Cloud\") {\n if (lastObj) {\n lastObj.setPosition(startX, startY);\n lastObj.setWidth(Math.max(100, dX));\n lastObj.setHeight(Math.max(100, dY));\n } else lastObj = this.addCloud({\n x: startX,\n y: startY\n }, dX, dY);\n }\n }));\n stage.on(\"click tap\", (e => {\n if (!this._markupIsActive) return;\n if (e.target === stage) {\n if (this._markupMode === \"Text\") {\n if (this._textInputRef && this._textInputRef.value) this.addText(this._textInputRef.value, this._textInputPos, this._textInputAngle); else if (transformer.nodes().length === 0) {\n const pos = this.getRelativePointerPosition(stage);\n this.createTextInput(pos, e.evt.pageX, e.evt.pageY, 0, null);\n }\n } else if (this._markupMode === \"Image\") {\n if (this._imageInputRef && this._imageInputRef.value) this.addImage({\n x: this._imageInputPos.x,\n y: this._imageInputPos.y\n }, this._imageInputRef.value, 0, 0, this._imageInputRef.value); else if (transformer.nodes().length === 0) {\n const pos = this.getRelativePointerPosition(stage);\n this.createImageInput(pos);\n }\n }\n transformer.nodes([]);\n return;\n }\n if (this._markupMode === \"Text\" || this._markupMode === \"SelectMarkup\") {\n if (e.target.className === \"Text\" && transformer.nodes().length === 1 && transformer.nodes()[0] === e.target) {\n if (this._textInputRef && this._textInputRef.value) this.addText(this._textInputRef.value, this._textInputPos, this._textInputAngle); else this.createTextInput({\n x: e.target.attrs.x,\n y: e.target.attrs.y\n }, e.evt.pageX, e.evt.pageY, e.target.attrs.rotation, e.target.attrs.text);\n return;\n } else {\n this.removeTextInput();\n }\n }\n if (this._markupMode === \"Image\" || this._markupMode === \"SelectMarkup\") {\n if (e.target.className === \"Image\" && transformer.nodes().length === 1 && transformer.nodes()[0] === e.target) {\n if (this._imageInputRef && this._imageInputRef.value) this.addImage(this._imageInputPos, this._imageInputRef.value, 0, 0); else this.createImageInput({\n x: e.target.attrs.x,\n y: e.target.attrs.y\n });\n return;\n } else {\n this.removeImageInput();\n }\n }\n if (transformer.nodes().filter((x => x.className === \"Cloud\" || x.className === \"Image\")).length > 0 || e.target.className === \"Cloud\" || e.target.className === \"Image\") {\n transformer.rotateEnabled(false);\n } else {\n transformer.rotateEnabled(true);\n }\n const metaPressed = e.evt.shiftKey || e.evt.ctrlKey || e.evt.metaKey;\n const isSelected = transformer.nodes().indexOf(e.target) >= 0;\n if (!metaPressed && !isSelected) {\n transformer.nodes([ e.target ]);\n } else if (metaPressed && isSelected) {\n const nodes = transformer.nodes().slice();\n nodes.splice(nodes.indexOf(e.target), 1);\n transformer.nodes(nodes);\n } else if (metaPressed && !isSelected) {\n const nodes = transformer.nodes().concat([ e.target ]);\n transformer.nodes(nodes);\n }\n }));\n const container = stage.container();\n container.tabIndex = 1;\n container.focus();\n container.addEventListener(\"keydown\", (e => {\n if (!this._markupIsActive) return;\n if (e.code === \"Delete\") {\n this.getSelectedObjects().forEach((obj => obj.delete()));\n this.clearSelected();\n return;\n }\n e.preventDefault();\n }));\n }\n destroyKonva() {\n var _a;\n this.removeTextInput();\n this.removeImageInput();\n this.clearOverlay();\n (_a = this._konvaStage) === null || _a === void 0 ? void 0 : _a.destroy();\n this._groupImages = undefined;\n this._groupGeometry = undefined;\n this._groupTexts = undefined;\n this._konvaLayer = undefined;\n this._konvaTransformer = undefined;\n this._konvaStage = undefined;\n }\n getMarkupLines() {\n const lines = [];\n this.konvaLayerFind(\"Line\").forEach((ref => {\n const linePoints = ref.points();\n if (!linePoints) return;\n const worldPoints = [];\n const absoluteTransform = ref.getAbsoluteTransform();\n for (let i = 0; i < linePoints.length; i += 2) {\n const atPoint = absoluteTransform.point({\n x: linePoints[i],\n y: linePoints[i + 1]\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n worldPoints.push(worldPoint);\n }\n const konvaLine = new KonvaLine(null, ref);\n const line = {\n id: konvaLine.id(),\n points: worldPoints,\n color: konvaLine.getColor() || \"#ff0000\",\n type: konvaLine.getLineType() || this.lineType,\n width: konvaLine.getLineWidth() || this.lineWidth\n };\n lines.push(line);\n }));\n return lines;\n }\n getMarkupTexts() {\n const texts = [];\n this.konvaLayerFind(\"Text\").forEach((ref => {\n const textSize = .02;\n const textScale = this._worldTransformer.getScale();\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const shape = new KonvaText(null, ref);\n const text = {\n id: shape.id(),\n position: worldPoint,\n text: shape.getText(),\n text_size: textSize * textScale.y,\n angle: shape.getRotation(),\n color: shape.getColor(),\n font_size: shape.getFontSize() * stageAbsoluteTransform.getMatrix()[0]\n };\n texts.push(text);\n }));\n return texts;\n }\n getMarkupRectangles() {\n const rectangles = [];\n this.konvaLayerFind(\"Rectangle\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaRectangle(null, ref);\n const rectangle = {\n id: shape.id(),\n position: worldPoint,\n width: shape.getWidth() * scale,\n height: shape.getHeigth() * scale,\n line_width: shape.getLineWidth(),\n color: shape.getColor()\n };\n rectangles.push(rectangle);\n }));\n return rectangles;\n }\n getMarkupEllipses() {\n const ellipses = [];\n this.konvaLayerFind(\"Ellipse\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaEllipse(null, ref);\n const ellipse = {\n id: shape.id(),\n position: worldPoint,\n radius: {\n x: ref.getRadiusX() * scale,\n y: ref.getRadiusY() * scale\n },\n line_width: shape.getLineWidth(),\n color: shape.getColor()\n };\n ellipses.push(ellipse);\n }));\n return ellipses;\n }\n getMarkupArrows() {\n const arrows = [];\n this.konvaLayerFind(\"Arrow\").forEach((ref => {\n const absoluteTransform = ref.getAbsoluteTransform();\n const atStartPoint = absoluteTransform.point({\n x: ref.points()[0],\n y: ref.points()[1]\n });\n const worldStartPoint = this._worldTransformer.screenToWorld(atStartPoint);\n const atEndPoint = absoluteTransform.point({\n x: ref.points()[2],\n y: ref.points()[3]\n });\n const worldEndPoint = this._worldTransformer.screenToWorld(atEndPoint);\n const shape = new KonvaArrow(null, ref);\n const arrow = {\n id: shape.id(),\n start: worldStartPoint,\n end: worldEndPoint,\n color: shape.getColor()\n };\n arrows.push(arrow);\n }));\n return arrows;\n }\n getMarkupImages() {\n const images = [];\n this.konvaLayerFind(\"Image\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaImage(null, ref);\n const image = {\n id: shape.id(),\n position: worldPoint,\n src: shape.getSrc(),\n width: shape.getWidth() * scale,\n height: shape.getHeight() * scale\n };\n images.push(image);\n }));\n return images;\n }\n getMarkupClouds() {\n const clouds = [];\n this.konvaLayerFind(\"Cloud\").forEach((ref => {\n const position = ref.position();\n const stageAbsoluteTransform = this._konvaStage.getAbsoluteTransform();\n const atPoint = stageAbsoluteTransform.point({\n x: position.x,\n y: position.y\n });\n const worldPoint = this._worldTransformer.screenToWorld(atPoint);\n const scale = stageAbsoluteTransform.getMatrix()[0];\n const shape = new KonvaCloud(null, ref);\n const cloud = {\n id: shape.id(),\n position: worldPoint,\n width: shape.getWidth() * scale,\n height: shape.getHeigth() * scale,\n line_width: shape.getLineWidth(),\n color: shape.getColor()\n };\n clouds.push(cloud);\n }));\n return clouds;\n }\n combineMarkupWithDrawing() {\n this.clearSelected();\n const tempCanvas = document.createElement(\"canvas\");\n if (this._konvaStage) {\n tempCanvas.width = this._konvaStage.width();\n tempCanvas.height = this._konvaStage.height();\n const ctx = tempCanvas.getContext(\"2d\");\n if (this._container instanceof HTMLCanvasElement) ctx.drawImage(this._container, 0, 0);\n ctx.drawImage(this._konvaStage.toCanvas({\n pixelRatio: window.devicePixelRatio\n }), 0, 0);\n }\n return tempCanvas.toDataURL(\"image/jpeg\", .25);\n }\n addLine(linePoints, color, type, width, id) {\n if (!linePoints || linePoints.length === 0) return;\n const points = [];\n for (let i = 0; i < linePoints.length; i += 2) {\n points.push({\n x: linePoints[i],\n y: linePoints[i + 1]\n });\n }\n const konvaLine = new KonvaLine({\n points: points,\n type: type || this.lineType,\n width: width || this.lineWidth,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaLine);\n return konvaLine;\n }\n createTextInput(pos, inputX, inputY, angle, text) {\n if (!this._textInputRef) {\n this._textInputPos = pos;\n this._textInputAngle = angle;\n this._textInputRef = document.createElement(\"textarea\");\n this._textInputRef.style.zIndex = \"9999\";\n this._textInputRef.style.position = \"absolute\";\n this._textInputRef.style.display = \"block\";\n this._textInputRef.style.top = inputY + \"px\";\n this._textInputRef.style.left = inputX + \"px\";\n this._textInputRef.style.fontSize = `${this.fontSize}px`;\n this._textInputRef.style.color = `${this._markupColor.asHex()}`;\n this._textInputRef.style.fontFamily = \"Calibri\";\n this._textInputRef.onkeydown = event => {\n if (event.key === \"Enter\" && !event.shiftKey) {\n event.preventDefault();\n this.addText(this._textInputRef.value, this._textInputPos, this._textInputAngle);\n }\n if (event.key === \"Escape\") {\n event.preventDefault();\n this.removeTextInput();\n }\n };\n if (text) this._textInputRef.value = text;\n document.body.appendChild(this._textInputRef);\n setTimeout((() => {\n this._textInputRef.focus();\n }), 50);\n } else {\n this.removeTextInput();\n }\n }\n removeTextInput() {\n var _a;\n (_a = this._textInputRef) === null || _a === void 0 ? void 0 : _a.remove();\n this._textInputRef = null;\n this._textInputPos = null;\n this._textInputAngle = 0;\n }\n createImageInput(pos) {\n if (!this._imageInputRef) {\n const convertBase64 = file => new Promise(((resolve, reject) => {\n const fileReader = new FileReader;\n fileReader.readAsDataURL(file);\n fileReader.onload = () => {\n resolve(fileReader.result);\n };\n fileReader.onerror = error => {\n reject(error);\n };\n }));\n this._imageInputPos = pos;\n this._imageInputRef = document.createElement(\"input\");\n this._imageInputRef.style.display = \"none\";\n this._imageInputRef.type = \"file\";\n this._imageInputRef.accept = \"image/png, image/jpeg\";\n this._imageInputRef.onchange = async event => {\n const file = event.target.files[0];\n const base64 = await convertBase64(file);\n this.addImage({\n x: this._imageInputPos.x,\n y: this._imageInputPos.y\n }, base64.toString(), 0, 0);\n };\n this._imageInputRef.oncancel = event => {\n this.removeImageInput();\n };\n document.body.appendChild(this._imageInputRef);\n setTimeout((() => {\n this._imageInputRef.click();\n }), 50);\n } else {\n this.removeImageInput();\n }\n }\n removeImageInput() {\n var _a;\n (_a = this._imageInputRef) === null || _a === void 0 ? void 0 : _a.remove();\n this._imageInputRef = null;\n this._imageInputPos = null;\n }\n addText(text, position, angle, color, textSize, fontSize, id) {\n var _a;\n if (!text) return;\n (_a = this.getSelectedObjects().at(0)) === null || _a === void 0 ? void 0 : _a.delete();\n this.clearSelected();\n this.removeTextInput();\n const tolerance = 1e-6;\n if (textSize && textSize > tolerance && (!fontSize || fontSize < tolerance)) {\n const size = .02;\n const scale = this._worldTransformer.getScale();\n fontSize = textSize / (scale.y / size) / 34;\n }\n const konvaText = new KonvaText({\n position: {\n x: position.x,\n y: position.y\n },\n text: text,\n rotation: angle,\n fontSize: fontSize || this.fontSize,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaText);\n return konvaText;\n }\n addRectangle(position, width, height, lineWidth, color, id) {\n if (!position) return;\n const konvaRectangle = new KonvaRectangle({\n position: position,\n width: width,\n height: height,\n lineWidth: lineWidth || this.lineWidth,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaRectangle);\n return konvaRectangle;\n }\n addEllipse(position, radius, lineWidth, color, id) {\n if (!position) return;\n const konvaEllipse = new KonvaEllipse({\n position: position,\n radius: radius,\n lineWidth: lineWidth,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaEllipse);\n return konvaEllipse;\n }\n addArrow(start, end, color, id) {\n if (!start || !end) return;\n const konvaArrow = new KonvaArrow({\n start: start,\n end: end,\n color: color || this._markupColor.asHex(),\n id: id\n });\n this.addObject(konvaArrow);\n return konvaArrow;\n }\n addCloud(position, width, height, lineWidth, color, id) {\n if (!position || !width || !height) return;\n const konvaCloud = new KonvaCloud({\n position: position,\n width: width,\n height: height,\n color: color || this._markupColor.asHex(),\n lineWidth: lineWidth || this.lineWidth,\n id: id\n });\n this.addObject(konvaCloud);\n return konvaCloud;\n }\n addImage(position, src, width, height, id) {\n var _a;\n if (!position || !src) return;\n (_a = this.getSelectedObjects().at(0)) === null || _a === void 0 ? void 0 : _a.delete();\n this.clearSelected();\n this.removeImageInput();\n const konvaImage = new KonvaImage({\n position: position,\n src: src,\n width: width,\n height: height,\n maxWidth: this._konvaStage.width() - position.x,\n maxHeight: this._konvaStage.height() - position.y,\n id: id\n });\n this.addObject(konvaImage);\n return konvaImage;\n }\n}\n\nexport { KonvaMarkup as Markup };\n//# sourceMappingURL=markup.module.js.map\n","import { EventDispatcher, MOUSE, Quaternion, Spherical, TOUCH, Vector2, Vector3 } from \"three\";\n\n// OrbitControls performs orbiting, dollying (zooming), and panning.\n// Unlike TrackballControls, it maintains the \"up\" direction object.up (+Y by default).\n//\n// Orbit - left mouse / touch: one-finger move\n// Zoom - middle mouse, or mousewheel / touch: two-finger spread or squish\n// Pan - right mouse, or left mouse + ctrl/meta/shiftKey, or arrow keys / touch: two-finger move\n\nconst _changeEvent = { type: \"change\" };\nconst _startEvent = { type: \"start\" };\nconst _endEvent = { type: \"end\" };\n\nconst STATE = {\n NONE: -1,\n ROTATE: 0,\n DOLLY: 1,\n PAN: 2,\n TOUCH_ROTATE: 3,\n TOUCH_PAN: 4,\n TOUCH_DOLLY_PAN: 5,\n TOUCH_DOLLY_ROTATE: 6,\n};\n\nclass OrbitControls extends EventDispatcher {\n constructor(object, domElement) {\n super();\n\n this.object = object;\n this.domElement = domElement;\n this.domElement.style.touchAction = \"none\"; // disable touch scroll\n\n // Set to false to disable this control\n this.enabled = true;\n\n // \"target\" sets the location of focus, where the object orbits around\n this.target = new Vector3();\n\n // How far you can dolly in and out ( PerspectiveCamera only )\n this.minDistance = 0;\n this.maxDistance = Infinity;\n\n // How far you can zoom in and out ( OrthographicCamera only )\n this.minZoom = 0;\n this.maxZoom = Infinity;\n\n // How far you can orbit vertically, upper and lower limits.\n // Range is 0 to Math.PI radians.\n this.minPolarAngle = 0; // radians\n this.maxPolarAngle = Math.PI; // radians\n\n // How far you can orbit horizontally, upper and lower limits.\n // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )\n this.minAzimuthAngle = -Infinity; // radians\n this.maxAzimuthAngle = Infinity; // radians\n\n // Set to true to enable damping (inertia)\n // If damping is enabled, you must call controls.update() in your animation loop\n this.enableDamping = false;\n this.dampingFactor = 0.05;\n\n // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\n // Set to false to disable zooming\n this.enableZoom = true;\n this.zoomSpeed = 1.0;\n\n // Set to false to disable rotating\n this.enableRotate = true;\n this.rotateSpeed = 1.0;\n\n // Set to false to disable panning\n this.enablePan = true;\n this.panSpeed = 1.0;\n this.screenSpacePanning = true; // if false, pan orthogonal to world-space direction camera.up\n this.keyPanSpeed = 7.0; // pixels moved per arrow key push\n\n // Set to true to automatically rotate around the target\n // If auto-rotate is enabled, you must call controls.update() in your animation loop\n this.autoRotate = false;\n this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60\n\n // The four arrow keys\n this.keys = { LEFT: \"ArrowLeft\", UP: \"ArrowUp\", RIGHT: \"ArrowRight\", BOTTOM: \"ArrowDown\" };\n\n // Mouse buttons\n this.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.DOLLY, RIGHT: MOUSE.PAN };\n\n // Touch fingers\n this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n\n // for reset\n this.target0 = this.target.clone();\n this.position0 = this.object.position.clone();\n this.zoom0 = this.object.zoom;\n\n // the target DOM element for key events\n this._domElementKeyEvents = null;\n\n //\n // public methods\n //\n\n this.getPolarAngle = function () {\n return spherical.phi;\n };\n\n this.getAzimuthalAngle = function () {\n return spherical.theta;\n };\n\n this.getDistance = function () {\n return this.object.position.distanceTo(this.target);\n };\n\n this.listenToKeyEvents = function (domElement) {\n domElement.addEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = domElement;\n };\n\n this.stopListenToKeyEvents = function () {\n this._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = null;\n };\n\n this.saveState = function () {\n scope.target0.copy(scope.target);\n scope.position0.copy(scope.object.position);\n scope.zoom0 = scope.object.zoom;\n };\n\n this.reset = function () {\n scope.target.copy(scope.target0);\n scope.object.position.copy(scope.position0);\n scope.object.zoom = scope.zoom0;\n\n scope.object.updateProjectionMatrix();\n scope.dispatchEvent(_changeEvent);\n\n scope.update();\n\n scope.state = STATE.NONE;\n };\n\n // this method is exposed, but perhaps it would be better if we can make it private...\n this.update = (function () {\n const offset = new Vector3();\n\n // so camera.up is the orbit axis\n const quat = new Quaternion().setFromUnitVectors(object.up, new Vector3(0, 1, 0));\n const quatInverse = quat.clone().invert();\n\n const lastPosition = new Vector3();\n const lastQuaternion = new Quaternion();\n const lastTargetPosition = new Vector3();\n\n const twoPI = 2 * Math.PI;\n\n return function update() {\n const position = scope.object.position;\n\n offset.copy(position).sub(scope.target);\n\n // rotate offset to \"y-axis-is-up\" space\n offset.applyQuaternion(quat);\n\n // angle from z-axis around y-axis\n spherical.setFromVector3(offset);\n\n if (scope.autoRotate && scope.state === STATE.NONE) {\n rotateLeft(getAutoRotationAngle());\n }\n\n if (scope.enableDamping) {\n spherical.theta += sphericalDelta.theta * scope.dampingFactor;\n spherical.phi += sphericalDelta.phi * scope.dampingFactor;\n } else {\n spherical.theta += sphericalDelta.theta;\n spherical.phi += sphericalDelta.phi;\n }\n\n // restrict theta to be between desired limits\n\n let min = scope.minAzimuthAngle;\n let max = scope.maxAzimuthAngle;\n\n if (isFinite(min) && isFinite(max)) {\n if (min < -Math.PI) min += twoPI;\n else if (min > Math.PI) min -= twoPI;\n\n if (max < -Math.PI) max += twoPI;\n else if (max > Math.PI) max -= twoPI;\n\n if (min <= max) {\n spherical.theta = Math.max(min, Math.min(max, spherical.theta));\n } else {\n spherical.theta =\n spherical.theta > (min + max) / 2 ? Math.max(min, spherical.theta) : Math.min(max, spherical.theta);\n }\n }\n\n // restrict phi to be between desired limits\n spherical.phi = Math.max(scope.minPolarAngle, Math.min(scope.maxPolarAngle, spherical.phi));\n\n spherical.makeSafe();\n\n spherical.radius *= scope.scale;\n\n // restrict radius to be between desired limits\n spherical.radius = Math.max(scope.minDistance, Math.min(scope.maxDistance, spherical.radius));\n\n // move target to panned location\n\n if (scope.enableDamping === true) {\n scope.target.addScaledVector(scope.panOffset, scope.dampingFactor);\n } else {\n scope.target.add(scope.panOffset);\n }\n\n offset.setFromSpherical(spherical);\n\n // rotate offset back to \"camera-up-vector-is-up\" space\n offset.applyQuaternion(quatInverse);\n\n position.copy(scope.target).add(offset);\n\n scope.object.lookAt(scope.target);\n\n if (scope.enableDamping === true) {\n sphericalDelta.theta *= 1 - scope.dampingFactor;\n sphericalDelta.phi *= 1 - scope.dampingFactor;\n\n scope.panOffset.multiplyScalar(1 - scope.dampingFactor);\n } else {\n sphericalDelta.set(0, 0, 0);\n\n scope.panOffset.set(0, 0, 0);\n }\n\n scope.scale = 1;\n\n // update condition is:\n // min(camera displacement, camera rotation in radians)^2 > EPS\n // using small-angle approximation cos(x/2) = 1 - x^2 / 8\n\n if (\n scope.zoomChanged ||\n lastPosition.distanceToSquared(scope.object.position) > EPS ||\n 8 * (1 - lastQuaternion.dot(scope.object.quaternion)) > EPS ||\n lastTargetPosition.distanceToSquared(scope.target) > 0\n ) {\n scope.dispatchEvent(_changeEvent);\n\n lastPosition.copy(scope.object.position);\n lastQuaternion.copy(scope.object.quaternion);\n lastTargetPosition.copy(scope.target);\n\n scope.zoomChanged = false;\n\n return true;\n }\n\n return false;\n };\n })();\n\n this.dispose = function () {\n scope.domElement.removeEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.removeEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.removeEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.removeEventListener(\"wheel\", onMouseWheel);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n\n if (scope._domElementKeyEvents !== null) {\n scope._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n scope._domElementKeyEvents = null;\n }\n\n //scope.dispatchEvent( { type: 'dispose' } ); // should this be added here?\n };\n\n //\n // internals\n //\n\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const scope = this;\n\n scope.state = STATE.NONE;\n\n const EPS = 0.000001;\n\n // current position in spherical coordinates\n const spherical = new Spherical();\n const sphericalDelta = new Spherical();\n\n scope.scale = 1;\n scope.panOffset = new Vector3();\n scope.zoomChanged = false;\n\n scope.rotateStart = new Vector2();\n scope.rotateEnd = new Vector2();\n scope.rotateDelta = new Vector2();\n\n scope.panStart = new Vector2();\n scope.panEnd = new Vector2();\n scope.panDelta = new Vector2();\n\n scope.dollyStart = new Vector2();\n scope.dollyEnd = new Vector2();\n scope.dollyDelta = new Vector2();\n scope.dollyScale = 0;\n\n scope.pointers = [];\n scope.pointerPositions = {};\n\n function getAutoRotationAngle() {\n return ((2 * Math.PI) / 60 / 60) * scope.autoRotateSpeed;\n }\n\n function getZoomScale() {\n return Math.pow(0.95, scope.zoomSpeed);\n }\n\n function rotateLeft(angle) {\n sphericalDelta.theta -= angle;\n }\n\n function rotateUp(angle) {\n sphericalDelta.phi -= angle;\n }\n\n const panLeft = (function () {\n const v = new Vector3();\n\n return function panLeft(distance, objectMatrix) {\n v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\n v.multiplyScalar(-distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n const panUp = (function () {\n const v = new Vector3();\n\n return function panUp(distance, objectMatrix) {\n if (scope.screenSpacePanning === true) {\n v.setFromMatrixColumn(objectMatrix, 1);\n } else {\n v.setFromMatrixColumn(objectMatrix, 0);\n v.crossVectors(scope.object.up, v);\n }\n\n v.multiplyScalar(distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n // deltaX and deltaY are in pixels; right and down are positive\n const pan = (function () {\n const offset = new Vector3();\n\n return function pan(deltaX, deltaY) {\n const element = scope.domElement;\n\n if (scope.object.isPerspectiveCamera) {\n // perspective\n const position = scope.object.position;\n offset.copy(position).sub(scope.target);\n let targetDistance = offset.length();\n\n // half of the fov is center to top of screen\n targetDistance *= Math.tan(((scope.object.fov / 2) * Math.PI) / 180.0);\n\n // we use only clientHeight here so aspect ratio does not distort speed\n panLeft((2 * deltaX * targetDistance) / element.clientHeight, scope.object.matrix);\n panUp((2 * deltaY * targetDistance) / element.clientHeight, scope.object.matrix);\n } else if (scope.object.isOrthographicCamera) {\n // orthographic\n panLeft(\n (deltaX * (scope.object.right - scope.object.left)) / scope.object.zoom / element.clientWidth,\n scope.object.matrix\n );\n panUp(\n (deltaY * (scope.object.top - scope.object.bottom)) / scope.object.zoom / element.clientHeight,\n scope.object.matrix\n );\n } else {\n // camera neither orthographic nor perspective\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.\");\n scope.enablePan = false;\n }\n };\n })();\n\n function dollyOut(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale /= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom * dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n function dollyIn(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale *= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom / dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n //\n // event callbacks - update the object state\n //\n\n function handleMouseDownRotate(event) {\n scope.rotateStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownDolly(event) {\n scope.dollyStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownPan(event) {\n scope.panStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseMoveRotate(event) {\n scope.rotateEnd.set(event.clientX, event.clientY);\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n\n scope.update();\n }\n\n function handleMouseMoveDolly(event) {\n scope.dollyEnd.set(event.clientX, event.clientY);\n\n scope.dollyDelta.subVectors(scope.dollyEnd, scope.dollyStart);\n\n if (scope.dollyDelta.y < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyOut(getZoomScale());\n } else if (scope.dollyDelta.y > 0) {\n scope.dollyScale = getZoomScale();\n dollyIn(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n }\n\n function handleMouseMovePan(event) {\n scope.panEnd.set(event.clientX, event.clientY);\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n\n scope.update();\n }\n\n function handleMouseWheel(event) {\n scope.dollyEnd.set(scope.domElement.clientWidth / 2, scope.domElement.clientHeight / 2);\n\n scope.dollyDelta.set(event.deltaX, event.deltaY);\n\n if (event.deltaY < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyIn(getZoomScale());\n } else if (event.deltaY > 0) {\n scope.dollyScale = getZoomScale();\n dollyOut(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n\n if (event.deltaY !== 0) {\n scope.state = STATE.DOLLY;\n scope.dispatchEvent(_changeEvent);\n scope.state = STATE.NONE;\n }\n }\n\n function handleKeyDown(event) {\n let needsUpdate = false;\n\n switch (event.code) {\n case scope.keys.UP:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.BOTTOM:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, -scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.LEFT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.RIGHT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(-scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n }\n\n if (needsUpdate) {\n // prevent the browser from scrolling on cursor keys\n event.preventDefault();\n\n scope.update();\n }\n }\n\n function handleTouchStartRotate() {\n if (scope.pointers.length === 1) {\n scope.rotateStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.rotateStart.set(x, y);\n }\n }\n\n function handleTouchStartPan() {\n if (scope.pointers.length === 1) {\n scope.panStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.panStart.set(x, y);\n }\n }\n\n function handleTouchStartDolly() {\n const dx = scope.pointers[0].pageX - scope.pointers[1].pageX;\n const dy = scope.pointers[0].pageY - scope.pointers[1].pageY;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyStart.set(0, distance);\n }\n\n function handleTouchStartDollyPan() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enablePan) handleTouchStartPan();\n }\n\n function handleTouchStartDollyRotate() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enableRotate) handleTouchStartRotate();\n }\n\n function handleTouchMoveRotate(event) {\n if (scope.pointers.length == 1) {\n scope.rotateEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.rotateEnd.set(x, y);\n }\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n }\n\n function handleTouchMovePan(event) {\n if (scope.pointers.length === 1) {\n scope.panEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.panEnd.set(x, y);\n }\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n }\n\n function handleTouchMoveDolly(event) {\n const position = getSecondPointerPosition(event);\n\n const dx = event.pageX - position.x;\n const dy = event.pageY - position.y;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyEnd.set(0, distance);\n\n scope.dollyDelta.set(0, Math.pow(scope.dollyEnd.y / scope.dollyStart.y, scope.zoomSpeed));\n\n dollyOut(scope.dollyDelta.y);\n\n scope.dollyStart.copy(scope.dollyEnd);\n }\n\n function handleTouchMoveDollyPan(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enablePan) handleTouchMovePan(event);\n }\n\n function handleTouchMoveDollyRotate(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enableRotate) handleTouchMoveRotate(event);\n }\n\n //\n // event handlers - FSM: listen for events and reset state\n //\n\n function onPointerDown(event) {\n if (scope.enabled === false) return;\n\n if (scope.pointers.length === 0) {\n scope.domElement.setPointerCapture(event.pointerId);\n\n scope.domElement.addEventListener(\"pointermove\", onPointerMove);\n scope.domElement.addEventListener(\"pointerup\", onPointerUp);\n }\n\n //\n\n addPointer(event);\n\n if (event.pointerType === \"touch\") {\n onTouchStart(event);\n } else {\n onMouseDown(event);\n }\n }\n\n function onPointerMove(event) {\n if (scope.enabled === false) return;\n\n if (event.pointerType === \"touch\") {\n onTouchMove(event);\n } else {\n onMouseMove(event);\n }\n }\n\n function onPointerUp(event) {\n removePointer(event);\n\n if (scope.pointers.length === 0) {\n scope.domElement.releasePointerCapture(event.pointerId);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n }\n\n scope.dispatchEvent(_endEvent);\n\n scope.state = STATE.NONE;\n }\n\n function onMouseDown(event) {\n let mouseAction;\n\n switch (event.button) {\n case 0:\n mouseAction = scope.mouseButtons.LEFT;\n break;\n\n case 1:\n mouseAction = scope.mouseButtons.MIDDLE;\n break;\n\n case 2:\n mouseAction = scope.mouseButtons.RIGHT;\n break;\n\n default:\n mouseAction = -1;\n }\n\n switch (mouseAction) {\n case MOUSE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseDownDolly(event);\n\n scope.state = STATE.DOLLY;\n\n break;\n\n case MOUSE.ROTATE:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n } else {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n }\n\n break;\n\n case MOUSE.PAN:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n } else {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onMouseMove(event) {\n switch (scope.state) {\n case STATE.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleMouseMoveRotate(event);\n\n break;\n\n case STATE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseMoveDolly(event);\n\n break;\n\n case STATE.PAN:\n if (scope.enablePan === false) return;\n\n handleMouseMovePan(event);\n\n break;\n }\n }\n\n function onMouseWheel(event) {\n if (scope.enabled === false || scope.enableZoom === false || scope.state !== STATE.NONE) return;\n\n event.preventDefault();\n\n scope.dispatchEvent(_startEvent);\n\n handleMouseWheel(event);\n\n scope.dispatchEvent(_endEvent);\n }\n\n function onKeyDown(event) {\n if (scope.enabled === false || scope.enablePan === false) return;\n\n handleKeyDown(event);\n }\n\n function onTouchStart(event) {\n trackPointer(event);\n\n switch (scope.pointers.length) {\n case 1:\n switch (scope.touches.ONE) {\n case TOUCH.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchStartRotate();\n\n scope.state = STATE.TOUCH_ROTATE;\n\n break;\n\n case TOUCH.PAN:\n if (scope.enablePan === false) return;\n\n handleTouchStartPan();\n\n scope.state = STATE.TOUCH_PAN;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n case 2:\n switch (scope.touches.TWO) {\n case TOUCH.DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchStartDollyPan();\n\n scope.state = STATE.TOUCH_DOLLY_PAN;\n\n break;\n\n case TOUCH.DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchStartDollyRotate();\n\n scope.state = STATE.TOUCH_DOLLY_ROTATE;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onTouchMove(event) {\n trackPointer(event);\n\n switch (scope.state) {\n case STATE.TOUCH_ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchMoveRotate(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_PAN:\n if (scope.enablePan === false) return;\n\n handleTouchMovePan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchMoveDollyPan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchMoveDollyRotate(event);\n\n scope.update();\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n }\n\n function onContextMenu(event) {\n if (scope.enabled === false) return;\n\n event.preventDefault();\n }\n\n function addPointer(event) {\n scope.pointers.push(event);\n }\n\n function removePointer(event) {\n delete scope.pointerPositions[event.pointerId];\n\n for (let i = 0; i < scope.pointers.length; i++) {\n if (scope.pointers[i].pointerId == event.pointerId) {\n scope.pointers.splice(i, 1);\n return;\n }\n }\n }\n\n function trackPointer(event) {\n let position = scope.pointerPositions[event.pointerId];\n\n if (position === undefined) {\n position = new Vector2();\n scope.pointerPositions[event.pointerId] = position;\n }\n\n position.set(event.pageX, event.pageY);\n }\n\n function getSecondPointerPosition(event) {\n const pointer = event.pointerId === scope.pointers[0].pointerId ? scope.pointers[1] : scope.pointers[0];\n\n return scope.pointerPositions[pointer.pointerId];\n }\n\n //\n\n scope.domElement.addEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.addEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.addEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.addEventListener(\"wheel\", onMouseWheel, { passive: false });\n\n // force an update at start\n\n this.update();\n }\n}\n\nexport { OrbitControls, STATE };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE, TOUCH } from \"three\";\n\nimport type { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitControls, STATE } from \"../controls/OrbitControls.js\";\n\nexport class OrbitDragger implements IDisposable {\n protected viewer: Viewer;\n protected orbit: OrbitControls;\n protected changed: boolean;\n\n constructor(viewer: Viewer) {\n this.orbit = new OrbitControls(viewer.camera, viewer.canvas);\n this.orbit.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n this.orbit.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n this.orbit.screenSpacePanning = true;\n this.orbit.rotateSpeed = 0.33;\n this.orbit.addEventListener(\"start\", this.controlsStart);\n this.orbit.addEventListener(\"change\", this.controlsChange);\n this.changed = false;\n this.viewer = viewer;\n this.viewer.on(\"geometryend\", this.updateControls);\n this.viewer.on(\"viewposition\", this.updateControls);\n this.viewer.on(\"zoom\", this.updateControls);\n this.viewer.on(\"drawviewpoint\", this.updateControls);\n this.viewer.on(\"contextmenu\", this.stopContextMenu);\n this.updateControls();\n }\n\n dispose(): void {\n this.viewer.off(\"geometryend\", this.updateControls);\n this.viewer.off(\"viewposition\", this.updateControls);\n this.viewer.off(\"zoom\", this.updateControls);\n this.viewer.off(\"drawviewpoint\", this.updateControls);\n this.viewer.off(\"contextmenu\", this.stopContextMenu);\n\n this.orbit.removeEventListener(\"change\", this.controlsChange);\n this.orbit.dispose();\n }\n\n updateControls = () => {\n this.orbit.maxDistance = this.viewer.camera.far;\n this.orbit.minDistance = this.viewer.camera.near;\n this.orbit.target.copy(this.viewer.target);\n this.orbit.update();\n };\n\n controlsStart = () => {\n this.changed = false;\n };\n\n controlsChange = () => {\n this.viewer.target.copy(this.orbit.target);\n this.viewer.update();\n\n switch (this.orbit.state) {\n case STATE.PAN:\n case STATE.TOUCH_PAN:\n this.viewer.emitEvent({\n type: \"pan\",\n x: this.orbit.panEnd.x,\n y: this.orbit.panEnd.y,\n dX: this.orbit.panDelta.x,\n dY: this.orbit.panDelta.y,\n });\n break;\n\n case STATE.DOLLY:\n this.viewer.emitEvent({\n type: \"zoomat\",\n data: this.orbit.dollyScale,\n x: this.orbit.dollyEnd.x,\n y: this.orbit.dollyEnd.y,\n });\n break;\n }\n\n this.changed = true;\n };\n\n stopContextMenu = (event: PointerEvent) => {\n if (this.changed) {\n event.preventDefault();\n event.stopPropagation();\n }\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class PanDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.PAN, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.PAN, TWO: TOUCH.DOLLY_ROTATE };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ZoomDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.DOLLY, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.DOLLY_PAN, TWO: TOUCH.DOLLY_PAN };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Clock, Camera, Controls, Quaternion, Vector2, Vector3 } from \"three\";\n\ninterface WalkControlsEventMap {\n change: { type: \"change\" };\n walkspeedchange: { type: \"walkspeedchange\"; data: number };\n}\n\nexport class WalkControls extends Controls<WalkControlsEventMap> {\n public movementSpeed = 0.2;\n public lookSpeed = 5;\n public multiplier = 5;\n\n private moveKeys: Set<string>;\n private moveWheel = 0;\n private moveClock: Clock;\n\n private quaternion: Quaternion;\n private downPosition: Vector2;\n private mouseDragOn = false;\n public rotateDelta: Vector2;\n\n constructor(camera: Camera, canvas: HTMLElement) {\n super(camera, canvas);\n\n this.moveKeys = new Set();\n this.moveClock = new Clock();\n\n this.quaternion = camera.quaternion.clone();\n this.downPosition = new Vector2(0, 0);\n this.rotateDelta = new Vector2(0, 0);\n\n this.domElement.addEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.addEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.addEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.addEventListener(\"wheel\", this.onWheel);\n\n window.addEventListener(\"keydown\", this.onKeyDown);\n window.addEventListener(\"keyup\", this.onKeyUp);\n }\n\n override dispose() {\n this.domElement.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.removeEventListener(\"wheel\", this.onWheel);\n\n window.removeEventListener(\"keydown\", this.onKeyDown);\n window.removeEventListener(\"keyup\", this.onKeyUp);\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.domElement.setPointerCapture(event.pointerId);\n this.downPosition.set(event.clientX, event.clientY);\n this.quaternion.copy(this.object.quaternion);\n this.mouseDragOn = true;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (!this.mouseDragOn) return;\n\n const movePosition = new Vector2(event.clientX, event.clientY);\n if (this.downPosition.distanceTo(movePosition) === 0) return;\n\n this.rotateDelta.copy(this.downPosition).sub(movePosition);\n this.rotateCamera(this.rotateDelta);\n this.dispatchEvent({ type: \"change\" });\n };\n\n onPointerUp = (event: PointerEvent) => {\n this.domElement.releasePointerCapture(event.pointerId);\n this.mouseDragOn = false;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.domElement.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onWheel = (event: WheelEvent) => {\n this.moveWheel = event.deltaY;\n this.update();\n };\n\n onKeyDown = (event: KeyboardEvent) => {\n switch (event.code) {\n case \"NumpadSubtract\":\n case \"Minus\":\n if (this.multiplier > 1) {\n this.multiplier = this.multiplier - 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"NumpadAdd\":\n case \"Equal\":\n if (this.multiplier < 10) {\n this.multiplier = this.multiplier + 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"ArrowLeft\":\n case \"ArrowRight\":\n case \"ArrowUp\":\n case \"ArrowDown\":\n case \"KeyW\":\n case \"KeyS\":\n case \"KeyA\":\n case \"KeyD\":\n case \"KeyQ\":\n case \"KeyE\":\n this.moveKeys.add(event.code);\n this.update();\n break;\n }\n };\n\n onKeyUp = (event: KeyboardEvent) => {\n if (this.moveKeys.delete(event.code)) this.update();\n };\n\n override update() {\n if (this.moveKeys.size > 0) {\n const timeDelta = this.moveClock.getDelta();\n const moveDelta = timeDelta * this.movementSpeed * this.multiplier;\n\n if (this.moveKeys.has(\"KeyW\")) this.object.translateZ(-moveDelta);\n if (this.moveKeys.has(\"KeyS\")) this.object.translateZ(moveDelta);\n\n if (this.moveKeys.has(\"KeyA\")) this.object.translateX(-moveDelta);\n if (this.moveKeys.has(\"KeyD\")) this.object.translateX(moveDelta);\n\n if (this.moveKeys.has(\"KeyQ\")) this.object.translateY(moveDelta);\n if (this.moveKeys.has(\"KeyE\")) this.object.translateY(-moveDelta);\n\n const lookDelta = this.lookSpeed + (this.multiplier - 1);\n\n if (this.moveKeys.has(\"ArrowUp\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, -lookDelta / 2)));\n if (this.moveKeys.has(\"ArrowDown\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, lookDelta / 2)));\n\n if (this.moveKeys.has(\"ArrowLeft\")) this.rotateCamera(this.rotateDelta.add(new Vector2(lookDelta, 0)));\n if (this.moveKeys.has(\"ArrowRight\")) this.rotateCamera(this.rotateDelta.add(new Vector2(-lookDelta, 0)));\n\n this.moveWheel = 0;\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveWheel !== 0) {\n const moveDelta = this.moveWheel * 0.0001 * this.movementSpeed * this.multiplier;\n\n this.object.translateZ(-moveDelta);\n this.moveWheel += -1 * Math.sign(this.moveWheel);\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveKeys.size === 0 && this.moveWheel === 0) {\n this.moveClock.stop();\n this.moveClock.autoStart = true;\n }\n }\n\n rotateCamera(delta: Vector2) {\n const rotateX = (Math.PI * delta.x) / this.domElement.clientWidth;\n const rotateY = (Math.PI * delta.y) / this.domElement.clientHeight;\n\n const xRotation = new Quaternion();\n xRotation.setFromAxisAngle(this.object.up, rotateX);\n\n const yRotation = new Quaternion();\n yRotation.setFromAxisAngle(new Vector3(1, 0, 0), rotateY);\n\n const quaternion = this.quaternion.clone();\n quaternion.premultiply(xRotation).multiply(yRotation).normalize();\n\n this.object.setRotationFromQuaternion(quaternion);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { WalkControls } from \"../controls/WalkControls\";\n\nexport class WalkDragger {\n protected viewer: Viewer;\n public controls: WalkControls;\n\n constructor(viewer: Viewer) {\n this.controls = new WalkControls(viewer.camera, viewer.canvas);\n this.controls.addEventListener(\"change\", this.controlsChange);\n this.controls.addEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.viewer = viewer;\n this.viewer.on(\"render\", this.viewerRender);\n this.viewer.on(\"zoom\", this.viewerZoom);\n this.updateControls();\n }\n\n dispose() {\n this.viewer.off(\"render\", this.viewerRender);\n this.viewer.off(\"zoom\", this.viewerZoom);\n this.controls.removeEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.controls.removeEventListener(\"change\", this.controlsChange);\n this.controls.dispose();\n }\n\n updateControls = () => {\n const size = this.viewer.extents.getSize(new Vector3());\n this.controls.movementSpeed = Math.min(size.x, size.y, size.z) / 2;\n };\n\n controlsChange = () => {\n this.viewer.update();\n };\n\n walkspeedChange = (event: any) => {\n this.viewer.emitEvent(event);\n };\n\n viewerRender = () => {\n this.controls.update();\n };\n\n viewerZoom = () => {\n this.controls.rotateDelta.set(0, 0);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport {\n BufferGeometry,\n DoubleSide,\n Float32BufferAttribute,\n Line,\n LineBasicMaterial,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n Plane,\n Vector3,\n} from \"three\";\n\nclass PlaneHelper extends Line {\n public plane: Plane;\n public size: number;\n public offset: Vector3;\n public helper: Object3D;\n\n constructor(plane: Plane, size = 1, color = 0xffff00, offset: Vector3 = new Vector3()) {\n // const positions = [1, -1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n const positions = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n\n const geometry = new BufferGeometry();\n geometry.setAttribute(\"position\", new Float32BufferAttribute(positions, 3));\n geometry.computeBoundingSphere();\n\n super(geometry, new LineBasicMaterial({ color, toneMapped: false }));\n\n (this as any).type = \"PlaneHelper\";\n\n this.plane = plane;\n this.size = size;\n this.offset = offset;\n\n const positions2 = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, -1, 0, 1, -1, 0];\n\n const geometry2 = new BufferGeometry();\n geometry2.setAttribute(\"position\", new Float32BufferAttribute(positions2, 3));\n geometry2.computeBoundingSphere();\n\n this.helper = new Mesh(\n geometry2,\n new MeshBasicMaterial({\n color,\n opacity: 0.2,\n transparent: true,\n depthWrite: false,\n toneMapped: false,\n side: DoubleSide,\n })\n );\n this.add(this.helper);\n }\n\n dispose() {\n this.geometry.dispose();\n (this.material as any).dispose();\n (this.children[0] as any).geometry.dispose();\n (this.children[0] as any).material.dispose();\n }\n\n override updateMatrixWorld(force: boolean) {\n this.position.set(0, 0, 0);\n this.lookAt(this.plane.normal);\n\n this.position.copy(this.offset);\n this.translateZ(-(this.offset.dot(this.plane.normal) + this.plane.constant));\n\n this.scale.set(0.5 * this.size, 0.5 * this.size, 1);\n\n super.updateMatrixWorld(force);\n }\n}\n\nexport { PlaneHelper };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Object3D, Plane, Vector3 } from \"three\";\nimport { TransformControls } from \"three/examples/jsm/controls/TransformControls.js\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { PlaneHelper } from \"../helpers/PlaneHelper\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nexport class CuttingPlaneDragger extends OrbitDragger {\n protected plane: Plane;\n protected planeCenter: Object3D;\n protected planeHelper: PlaneHelper;\n protected transform: TransformControls;\n\n constructor(viewer: Viewer, normal: Vector3, color: number) {\n super(viewer);\n\n const size = viewer.extents.getSize(new Vector3()).length();\n const center = viewer.extents.getCenter(new Vector3());\n const constant = -center.dot(normal);\n\n this.plane = new Plane(normal, constant);\n\n if (!viewer.renderer.clippingPlanes) viewer.renderer.clippingPlanes = [];\n viewer.renderer.clippingPlanes.push(this.plane);\n\n this.planeHelper = new PlaneHelper(this.plane, size, color, center);\n this.viewer.helpers.add(this.planeHelper);\n\n this.planeCenter = new Object3D();\n this.planeCenter.position.copy(viewer.extents.getCenter(new Vector3()));\n this.viewer.helpers.add(this.planeCenter);\n\n this.transform = new TransformControls(viewer.camera, viewer.canvas);\n this.transform.showX = !!normal.x;\n this.transform.showY = !!normal.y;\n this.transform.showZ = !!normal.z;\n this.transform.attach(this.planeCenter);\n this.transform.addEventListener(\"change\", this.transformChange);\n this.transform.addEventListener(\"dragging-changed\", this.transformDrag);\n this.viewer.helpers.add(this.transform.getHelper());\n\n this.viewer.on(\"explode\", this.viewerExplode);\n this.viewer.canvas.addEventListener(\"dblclick\", this.onDoubleClick, true);\n this.viewer.update();\n }\n\n override dispose() {\n this.viewer.off(\"explode\", this.viewerExplode);\n this.viewer.canvas.removeEventListener(\"dblclick\", this.onDoubleClick, true);\n\n this.transform.removeEventListener(\"change\", this.transformChange);\n this.transform.removeEventListener(\"dragging-changed\", this.transformDrag);\n this.transform.getHelper().removeFromParent();\n this.transform.detach();\n this.transform.dispose();\n\n this.planeHelper.removeFromParent();\n this.planeHelper.dispose();\n\n this.planeCenter.removeFromParent();\n\n // this.viewer.renderer.clippingPlanes = this.viewer.renderer.clippingPlanes.filter((plane) => plane !== this.plane);\n // this.viewer.update();\n\n super.dispose();\n }\n\n transformChange = () => {\n this.plane.constant = -this.planeCenter.position.dot(this.plane.normal);\n this.viewer.update();\n };\n\n transformDrag = (event) => {\n this.orbit.enabled = !event.value;\n };\n\n viewerExplode = () => {\n this.planeHelper.size = this.viewer.extents.getSize(new Vector3()).length();\n this.viewer.update();\n };\n\n onDoubleClick = (event: PointerEvent) => {\n event.stopPropagation();\n\n this.plane.negate();\n this.viewer.update();\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneXAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(1, 0, 0), 0xff0000);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneYAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 1, 0), 0x00ff00);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneZAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 0, 1), 0x0000ff);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Camera, Matrix4, Object3D, Scene, Raycaster, Vector2, Vector3, Vector4 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nconst PRECISION = 0.01;\n\nexport class MeasureLineDragger extends OrbitDragger {\n private overlay: MeasureOverlay;\n private line: MeasureLine;\n private snapper: MeasureSnapper;\n\n constructor(viewer: Viewer) {\n super(viewer);\n\n this.overlay = new MeasureOverlay(viewer.camera, viewer.canvas);\n this.overlay.attach();\n\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n\n this.snapper = new MeasureSnapper(viewer.camera, viewer.canvas);\n this.snapper.update(viewer.scene);\n\n this.viewer.canvas.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.addEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.addEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.addEventListener(\"render\", this.renderOverlay);\n this.viewer.addEventListener(\"hide\", this.updateSnapper);\n this.viewer.addEventListener(\"isolate\", this.updateSnapper);\n this.viewer.addEventListener(\"showall\", this.updateSnapper);\n }\n\n override dispose() {\n this.viewer.canvas.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.removeEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.removeEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.removeEventListener(\"render\", this.renderOverlay);\n this.viewer.removeEventListener(\"hide\", this.updateSnapper);\n this.viewer.removeEventListener(\"isolate\", this.updateSnapper);\n this.viewer.removeEventListener(\"showall\", this.updateSnapper);\n\n this.overlay.detach();\n this.overlay.dispose();\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.line.startPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n this.viewer.canvas.setPointerCapture(event.pointerId);\n this.orbit.enabled = !this.line.startPoint;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (this.orbit.enabled && this.orbit.state !== -1) return;\n\n this.line.endPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n if (this.line.startPoint) this.changed = true; // <- to prevent context menu\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (this.line.startPoint && this.line.endPoint && this.line.getDistance() >= PRECISION) {\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n } else {\n this.line.startPoint = undefined;\n this.line.endPoint = undefined;\n this.line.render();\n }\n\n this.viewer.canvas.releasePointerCapture(event.pointerId);\n this.orbit.enabled = true;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.viewer.canvas.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onPointerLeave = () => {\n this.line.endPoint = undefined;\n this.line.render();\n };\n\n renderOverlay = () => {\n this.overlay.render();\n };\n\n updateSnapper = () => {\n this.snapper.update(this.viewer.scene);\n };\n}\n\nclass MeasureSnapper {\n private camera: Camera;\n private canvas: HTMLCanvasElement;\n private objects: Object3D[] = [];\n private raycaster: Raycaster;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.raycaster = new Raycaster();\n }\n\n getSnapPoint(event: PointerEvent): Vector3 | undefined {\n const mouse = new Vector2(event.clientX, event.clientY);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.camera);\n\n this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n const intersects = this.raycaster.intersectObjects(this.objects, false);\n if (intersects.length === 0) return undefined;\n\n return intersects[0].point;\n }\n\n update(scene: Scene) {\n this.objects = [];\n scene.traverseVisible((child) => this.objects.push(child));\n }\n}\n\nclass MeasureOverlay {\n public camera: Camera;\n public canvas: HTMLCanvasElement;\n public container: HTMLElement;\n public lines: MeasureLine[] = [];\n public projector: MeasureProjector;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.projector = new MeasureProjector(camera, canvas);\n }\n\n attach() {\n this.container = document.createElement(\"div\");\n this.container.id = \"measure-container\";\n this.container.style.background = \"rgba(0,0,0,0)\";\n this.container.style.position = \"absolute\";\n this.container.style.top = \"0px\";\n this.container.style.left = \"0px\";\n this.container.style.width = \"100%\";\n this.container.style.height = \"100%\";\n this.container.style.outline = \"none\";\n this.container.style.pointerEvents = \"none\";\n this.container.style.overflow = \"hidden\";\n\n this.canvas.parentElement.appendChild(this.container);\n }\n\n dispose() {\n this.clear();\n }\n\n detach() {\n this.container.remove();\n this.container = undefined;\n }\n\n clear() {\n this.lines.forEach((line) => line.dispose());\n this.lines = [];\n }\n\n render() {\n this.projector.updateProjectionMatrix();\n this.lines.forEach((line) => line.render());\n }\n\n update() {\n this.lines.forEach((line) => line.update());\n }\n\n addLine(line: MeasureLine) {\n this.lines.push(line);\n }\n\n removeLine(line: MeasureLine) {\n this.lines = this.lines.filter((x) => x !== line);\n }\n}\n\nconst _middlePoint = new Vector3();\n\nclass MeasureLine {\n private overlay: MeasureOverlay;\n\n private elementStartPoint: HTMLElement;\n private elementEndPoint: HTMLElement;\n private elementLine: HTMLElement;\n private elementLabel: HTMLElement;\n\n public startPoint: Vector3;\n public endPoint: Vector3;\n\n public id = Date.now();\n public unit = \"\";\n public scale = 1.0;\n public size = 10.0;\n public lineWidth = 2;\n\n public style = {\n border: \"2px solid #FFFFFF\",\n background: \"#009bff\",\n boxShadow: \"0 0 10px rgba(0,0,0,0.5)\",\n color: \"white\",\n font: \"1rem system-ui\",\n };\n\n constructor(overlay: MeasureOverlay) {\n this.overlay = overlay;\n\n this.elementStartPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementEndPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLine = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLabel = overlay.container.appendChild(document.createElement(\"div\"));\n\n this.update();\n }\n\n dispose() {\n this.elementStartPoint.remove();\n this.elementEndPoint.remove();\n this.elementLine.remove();\n this.elementLabel.remove();\n }\n\n render() {\n const projector = this.overlay.projector;\n\n if (this.startPoint) {\n const { point, visible } = projector.projectPoint(this.startPoint);\n\n this.elementStartPoint.style.display = visible ? \"block\" : \"none\";\n this.elementStartPoint.style.left = `${point.x}px`;\n this.elementStartPoint.style.top = `${point.y}px`;\n } else {\n this.elementStartPoint.style.display = \"none\";\n }\n\n if (this.endPoint) {\n const { point, visible } = projector.projectPoint(this.endPoint);\n\n this.elementEndPoint.style.display = visible ? \"block\" : \"none\";\n this.elementEndPoint.style.left = `${point.x}px`;\n this.elementEndPoint.style.top = `${point.y}px`;\n } else {\n this.elementEndPoint.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n const { point1, point2, visible } = projector.projectLine(this.startPoint, this.endPoint);\n\n point2.sub(point1);\n const angle = point2.angle();\n const width = point2.length();\n\n this.elementLine.style.display = visible ? \"block\" : \"none\";\n this.elementLine.style.left = `${point1.x}px`;\n this.elementLine.style.top = `${point1.y}px`;\n this.elementLine.style.width = `${width}px`;\n this.elementLine.style.transform = `translate(0px, ${-this.lineWidth / 2}px) rotate(${angle}rad)`;\n } else {\n this.elementLine.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n _middlePoint.lerpVectors(this.startPoint, this.endPoint, 0.5);\n const { point, visible } = projector.projectPoint(_middlePoint);\n\n const distance = this.getDistance();\n\n this.elementLabel.style.display = visible && distance >= PRECISION ? \"block\" : \"none\";\n this.elementLabel.style.left = `${point.x}px`;\n this.elementLabel.style.top = `${point.y}px`;\n this.elementLabel.innerHTML = `${distance.toFixed(2)} ${this.unit}`;\n } else {\n this.elementLabel.style.display = \"none\";\n }\n }\n\n update() {\n this.elementStartPoint.id = `markup-dot-start-${this.id}`;\n this.elementStartPoint.style.position = \"absolute\";\n this.elementStartPoint.style.zIndex = \"2\";\n this.elementStartPoint.style.width = `${this.size}px`;\n this.elementStartPoint.style.height = `${this.size}px`;\n this.elementStartPoint.style.border = this.style.border;\n this.elementStartPoint.style.borderRadius = `${this.size}px`;\n this.elementStartPoint.style.background = this.style.background;\n this.elementStartPoint.style.boxShadow = this.style.boxShadow;\n this.elementStartPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementEndPoint.id = `markup-dot-end-${this.id}`;\n this.elementEndPoint.style.position = \"absolute\";\n this.elementEndPoint.style.zIndex = \"2\";\n this.elementEndPoint.style.width = `${this.size}px`;\n this.elementEndPoint.style.height = `${this.size}px`;\n this.elementEndPoint.style.border = this.style.border;\n this.elementEndPoint.style.borderRadius = `${this.size}px`;\n this.elementEndPoint.style.background = this.style.background;\n this.elementEndPoint.style.boxShadow = this.style.boxShadow;\n this.elementEndPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementLine.id = `markup-line-${this.id}`;\n this.elementLine.style.position = \"absolute\";\n this.elementLine.style.zIndex = \"1\";\n this.elementLine.style.height = `${this.lineWidth}px`;\n this.elementLine.style.background = this.style.background;\n this.elementLine.style.boxShadow = this.style.boxShadow;\n this.elementLine.style.transformOrigin = `0px ${this.lineWidth / 2}px`;\n\n this.elementLabel.id = `markup-label-${this.id}`;\n this.elementLabel.style.position = \"absolute\";\n this.elementLabel.style.zIndex = \"3\";\n this.elementLabel.style.padding = \"2px\";\n this.elementLabel.style.paddingInline = \"5px\";\n this.elementLabel.style.borderRadius = \"5px\";\n this.elementLabel.style.background = this.style.background;\n this.elementLabel.style.boxShadow = this.style.boxShadow;\n this.elementLabel.style.color = this.style.color;\n this.elementLabel.style.font = this.style.font;\n this.elementLabel.style.transform = \"translate(-50%, -50%)\";\n }\n\n getDistance(): number {\n return this.startPoint.distanceTo(this.endPoint) / this.scale;\n }\n}\n\nlet _widthHalf: number;\nlet _heightHalf: number;\nconst _viewMatrix = new Matrix4();\nconst _viewProjectionMatrix = new Matrix4();\nconst _vector = new Vector3();\nconst _vector1 = new Vector4();\nconst _vector2 = new Vector4();\nconst point = new Vector2();\nconst point1 = new Vector2();\nconst point2 = new Vector2();\n\nclass MeasureProjector {\n private camera: Camera;\n private canvas: HTMLElement;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n }\n\n updateProjectionMatrix() {\n const rect = this.canvas.getBoundingClientRect();\n _widthHalf = rect.width / 2;\n _heightHalf = rect.height / 2;\n\n _viewMatrix.copy(this.camera.matrixWorldInverse);\n _viewProjectionMatrix.multiplyMatrices(this.camera.projectionMatrix, _viewMatrix);\n }\n\n projectPoint(p: Vector3) {\n _vector.copy(p).applyMatrix4(_viewProjectionMatrix);\n const visible = _vector.z >= -1 && _vector.z <= 1;\n\n point.x = (_vector.x + 1) * _widthHalf;\n point.y = (-_vector.y + 1) * _heightHalf;\n\n return { point, visible };\n }\n\n projectLine(p1: Vector3, p2: Vector3) {\n let visible: boolean;\n\n _vector1.copy(p1 as any).applyMatrix4(_viewProjectionMatrix);\n _vector2.copy(p2 as any).applyMatrix4(_viewProjectionMatrix);\n\n // see three/examples/jsm/renderers/Projector.js/clipLine for more details\n\n const bc1near = _vector1.z + _vector1.w;\n const bc2near = _vector2.z + _vector2.w;\n const bc1far = -_vector1.z + _vector1.w;\n const bc2far = -_vector2.z + _vector2.w;\n\n if (bc1near >= 0 && bc2near >= 0 && bc1far >= 0 && bc2far >= 0) visible = true;\n else if ((bc1near < 0 && bc2near < 0) || (bc1far < 0 && bc2far < 0)) visible = false;\n else {\n let alpha1 = 0;\n let alpha2 = 1;\n\n if (bc1near < 0) alpha1 = Math.max(alpha1, bc1near / (bc1near - bc2near));\n else if (bc2near < 0) alpha2 = Math.min(alpha2, bc1near / (bc1near - bc2near));\n\n if (bc1far < 0) alpha1 = Math.max(alpha1, bc1far / (bc1far - bc2far));\n else if (bc2far < 0) alpha2 = Math.min(alpha2, bc1far / (bc1far - bc2far));\n\n visible = alpha2 >= alpha1;\n\n if (visible) {\n _vector1.lerp(_vector2, alpha1);\n _vector2.lerp(_vector1, 1 - alpha2);\n }\n }\n\n _vector1.multiplyScalar(1 / _vector1.w);\n _vector2.multiplyScalar(1 / _vector2.w);\n\n point1.x = (_vector1.x + 1) * _widthHalf;\n point1.y = (-_vector1.y + 1) * _heightHalf;\n\n point2.x = (_vector2.x + 1) * _widthHalf;\n point2.y = (-_vector2.y + 1) * _heightHalf;\n\n return { point1, point2, visible };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Vector3 } from \"three\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ExtentsComponent implements IDisposable {\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"geometryend\", this.syncExtents);\n this.viewer.addEventListener(\"clear\", this.syncExtents);\n this.viewer.on(\"explode\", this.syncExtents);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"geometryend\", this.syncExtents);\n this.viewer.removeEventListener(\"clear\", this.syncExtents);\n this.viewer.off(\"explode\", this.syncExtents);\n }\n\n syncExtents = () => {\n const extents = this.viewer.models.reduce((result: Box3, gltf) => result.expandByObject(gltf.scene), new Box3());\n\n this.viewer.extents.copy(extents);\n this.viewer.target.copy(extents.getCenter(new Vector3()));\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { AmbientLight, DirectionalLight } from \"three\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class LightComponent implements IDisposable {\n protected viewer: Viewer;\n protected ambientLight: AmbientLight;\n protected directionalLight: DirectionalLight;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.ambientLight = new AmbientLight(0xffffff, 0);\n this.viewer.camera.add(this.ambientLight);\n\n this.directionalLight = new DirectionalLight(0xffffff, 1);\n this.directionalLight.position.set(0.5, 0, 0.866); // ~60º\n this.viewer.camera.add(this.directionalLight);\n }\n\n dispose(): void {\n this.ambientLight.removeFromParent();\n this.ambientLight = undefined;\n\n this.directionalLight.removeFromParent();\n this.directionalLight = undefined;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Color, PMREMGenerator } from \"three\";\nimport { RoomEnvironment } from \"three/examples/jsm/environments/RoomEnvironment.js\";\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class BackgroundComponent implements IDisposable {\n protected viewer: Viewer;\n protected backgroundColor: Color;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.backgroundColor = new Color(0xffffff);\n\n const environment = new RoomEnvironment();\n const pmremGenerator = new PMREMGenerator(this.viewer.renderer);\n\n this.viewer.renderer.setClearColor(this.backgroundColor);\n this.viewer.scene.background = this.backgroundColor;\n this.viewer.scene.environment = pmremGenerator.fromScene(environment).texture;\n this.viewer.addEventListener(\"optionschange\", this.syncOptions);\n\n environment.dispose();\n }\n\n dispose() {\n this.viewer.removeEventListener(\"optionschange\", this.syncOptions);\n this.viewer.scene.environment = undefined;\n this.viewer.scene.background = undefined;\n }\n\n syncOptions = () => {\n this.backgroundColor.setHex(0xffffff);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport { GeometryEndEvent } from \"@inweb/viewer-core\";\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class DefaultPositionComponent implements IDisposable {\n protected viewer: Viewer;\n public defaultCameraPositions: any;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"geometryend\", this.geometryEnd);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"geometryend\", this.geometryEnd);\n }\n\n geometryEnd = (event: GeometryEndEvent) => {\n const box = this.viewer.extents;\n const size = box.getSize(new Vector3()).length();\n\n this.viewer.camera.near = size / 100;\n this.viewer.camera.far = size * 100;\n this.viewer.camera.updateMatrixWorld();\n this.viewer.camera.updateProjectionMatrix();\n\n this.viewer.executeCommand(\"setDefaultViewPosition\", \"sw\");\n this.viewer.executeCommand(\"zoomToExtents\");\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ResizeCanvasComponent implements IDisposable {\n protected viewer: Viewer;\n protected resizeObserver: ResizeObserver;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.resizeObserver = new ResizeObserver(this.resizeViewer);\n this.resizeObserver.observe(viewer.canvas.parentElement);\n }\n\n dispose() {\n this.resizeObserver.disconnect();\n }\n\n resizeViewer = (entries: ResizeObserverEntry[]) => {\n const { width, height } = entries[0].contentRect;\n\n if (!width || !height) return; // <- invisible viewer, or viewer with parent removed\n\n this.viewer.camera.aspect = width / height;\n this.viewer.camera.updateProjectionMatrix();\n this.viewer.renderer.setSize(width, height, true);\n\n this.viewer.update(true);\n this.viewer.emitEvent({ type: \"resize\", width, height });\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class RenderLoopComponent implements IDisposable {\n protected viewer: Viewer;\n protected requestId: number;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.animate();\n }\n\n dispose() {\n cancelAnimationFrame(this.requestId);\n }\n\n animate = (time = 0) => {\n this.requestId = requestAnimationFrame(this.animate);\n this.viewer.render(time);\n };\n}\n","import {\n Camera,\n CylinderGeometry,\n CanvasTexture,\n Color,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n OrthographicCamera,\n Sprite,\n SpriteMaterial,\n SRGBColorSpace,\n Vector4,\n WebGLRenderer,\n} from \"three\";\n\nexport class WCSHelper extends Object3D {\n private camera: Camera;\n private orthoCamera: OrthographicCamera;\n public size: number;\n\n constructor(camera: Camera) {\n super();\n\n this.camera = camera;\n this.size = 160;\n\n this.orthoCamera = new OrthographicCamera(-2, 2, 2, -2, 0, 4);\n this.orthoCamera.position.set(0, 0, 2);\n\n const matRed = new MeshBasicMaterial({ toneMapped: false, color: \"#aa0000\" });\n const matGreen = new MeshBasicMaterial({ toneMapped: false, color: \"#00aa00\" });\n const matBlue = new MeshBasicMaterial({ toneMapped: false, color: \"#0000aa\" });\n\n const spriteRed = this.getSpriteMaterial(matRed.color, \"X\");\n const spriteGreen = this.getSpriteMaterial(matGreen.color, \"Y\");\n const spriteBlue = this.getSpriteMaterial(matBlue.color, \"Z\");\n\n const lineGeometry = new CylinderGeometry(0.01, 0.01, 1, 3);\n lineGeometry.translate(0, 0.5, 0);\n\n const arrowGeometry = new CylinderGeometry(0, 0.1, 0.25, 12);\n arrowGeometry.translate(0, 0.625, 0);\n\n const axesMap = {\n X: [\n [new Mesh(arrowGeometry, matRed), [0.5, 0, 0], [0, 0, -Math.PI / 2]],\n [new Mesh(lineGeometry, matRed), [0, 0, 0], [0, 0, -Math.PI / 2]],\n [new Sprite(spriteRed), [1.55, 0, 0]],\n ],\n Y: [\n [new Mesh(arrowGeometry, matGreen), [0, 0.5, 0], null],\n [new Mesh(lineGeometry, matGreen), null, null],\n [new Sprite(spriteGreen), [0, 1.55, 0]],\n ],\n Z: [\n [new Mesh(arrowGeometry, matBlue), [0, 0, 0.5], [Math.PI / 2, 0, 0]],\n [new Mesh(lineGeometry, matBlue), null, [Math.PI / 2, 0, 0]],\n [new Sprite(spriteBlue), [0, 0, 1.55]],\n ],\n };\n\n Object.keys(axesMap).forEach((key) => {\n axesMap[key].forEach((objects: any) => {\n const object = objects[0];\n const position = objects[1];\n const rotation = objects[2];\n\n object.name = key;\n if (position) object.position.set(position[0], position[1], position[2]);\n if (rotation) object.rotation.set(rotation[0], rotation[1], rotation[2]);\n object.updateMatrixWorld();\n\n this.add(object);\n });\n });\n }\n\n dispose() {\n this.traverse((object: any) => {\n if (object.geometry) object.geometry.dispose();\n if (object.material) object.material.dispose();\n });\n }\n\n getSpriteMaterial(color: Color, text: string) {\n const canvas = document.createElement(\"canvas\");\n canvas.width = 64;\n canvas.height = 64;\n\n const context = canvas.getContext(\"2d\");\n context.clearRect(0, 0, 64, 64);\n context.font = \"24px Arial\";\n context.textAlign = \"center\";\n context.fillStyle = color.getStyle();\n context.fillText(text, 32, 41);\n\n const texture = new CanvasTexture(canvas);\n texture.colorSpace = SRGBColorSpace;\n\n return new SpriteMaterial({ map: texture, toneMapped: false });\n }\n\n render(renderer: WebGLRenderer) {\n this.quaternion.copy(this.camera.quaternion).invert();\n this.updateMatrixWorld();\n\n const clippingPlanes = renderer.clippingPlanes;\n const viewport = renderer.getViewport(new Vector4());\n\n renderer.setViewport(this.position.x, this.position.y, this.size, this.size);\n renderer.clippingPlanes = [];\n renderer.clearDepth();\n renderer.render(this, this.orthoCamera);\n\n renderer.setViewport(viewport);\n renderer.clippingPlanes = clippingPlanes;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDisposable } from \"../IDisposable\";\nimport type { Viewer } from \"../Viewer\";\nimport { WCSHelper } from \"../helpers/WCSHelper\";\n\nexport class WCSHelperComponent implements IDisposable {\n private wcsHelper: WCSHelper;\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.wcsHelper = new WCSHelper(viewer.camera);\n this.viewer = viewer;\n this.viewer.addEventListener(\"render\", this.viewerRender);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"render\", this.viewerRender);\n this.wcsHelper.dispose();\n }\n\n viewerRender = () => {\n if (!this.viewer.options.showWCS) return;\n if (this.viewer.extents.isEmpty()) return;\n\n this.wcsHelper.render(this.viewer.renderer);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2024, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2024 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, LinearToneMapping, Object3D, PerspectiveCamera, Plane, Scene, Vector3, WebGLRenderer } from \"three\";\nimport { GLTF, GLTFLoader } from \"three/examples/jsm/loaders/GLTFLoader.js\";\nimport { GLTFLoadingManager } from \"./loaders/GLTFLoadingManager\";\n\nimport { EventEmitter2 } from \"@inweb/eventemitter2\";\nimport { Assembly, Client, Model, File } from \"@inweb/client\";\nimport {\n CANVAS_EVENTS,\n CanvasEventMap,\n commands,\n IClippingPlane,\n IComponent,\n IDragger,\n IOptions,\n IPerspectiveCamera,\n IPoint,\n IViewer,\n IViewpoint,\n Options,\n OptionsEventMap,\n ViewerEventMap,\n} from \"@inweb/viewer-core\";\nimport { IMarkup, IWorldTransform, Markup } from \"@inweb/markup\";\n\nimport { PanDragger } from \"./draggers/PanDragger\";\nimport { OrbitDragger } from \"./draggers/OrbitDragger\";\nimport { ZoomDragger } from \"./draggers/ZoomDragger\";\nimport { WalkDragger } from \"./draggers/WalkDragger\";\nimport { CuttingPlaneXAxisDragger } from \"./draggers/CuttingPlaneXAxis\";\nimport { CuttingPlaneYAxisDragger } from \"./draggers/CuttingPlaneYAxis\";\nimport { CuttingPlaneZAxisDragger } from \"./draggers/CuttingPlaneZAxis\";\nimport { MeasureLineDragger } from \"./draggers/MeasureLineDragger\";\n\nimport { IDisposable } from \"./IDisposable\";\nimport { ExtentsComponent } from \"./components/ExtentsComponent\";\nimport { LightComponent } from \"./components/LightComponent\";\nimport { BackgroundComponent } from \"./components/BackgroundComponent\";\nimport { DefaultPositionComponent } from \"./components/DefaultPositionComponent\";\nimport { ResizeCanvasComponent } from \"./components/ResizeCanvasComponent\";\nimport { RenderLoopComponent } from \"./components/RenderLoopComponent\";\nimport { SelectionComponent } from \"./components/SelectionComponent\";\n// import { ViewPositionComponent } from \"./components/ViewPositionComponent\";\nimport { WCSHelperComponent } from \"./components/WCSHelperComponent\";\n// import { AxesHelperComponent } from \"./components/AxesHelperComponent\";\n// import { ExtentsHelperComponent } from \"./components/ExtentsHelperComponent\";\n\n/**\n * 3D viewer powered by {@link https://threejs.org/ | Three.js}.\n */\nexport class Viewer\n extends EventEmitter2<ViewerEventMap & CanvasEventMap & OptionsEventMap>\n implements IViewer, IWorldTransform\n{\n public client: Client | undefined;\n protected _options: Options;\n\n private canvaseventlistener: (event: any) => void;\n\n public canvas: HTMLCanvasElement | undefined;\n public canvasEvents: string[];\n\n public scene: Scene | undefined;\n public helpers: Scene | undefined;\n public camera: PerspectiveCamera | undefined;\n public renderer: WebGLRenderer | undefined;\n public models: Array<GLTF>;\n public selected: Array<Object3D>;\n public extents: Box3;\n public target: Vector3;\n\n private draggerFactory: Record<string, any>;\n private _activeDragger: IDragger | null;\n\n private components: Array<IDisposable>;\n\n private renderNeeded: boolean;\n private renderTime: DOMHighResTimeStamp;\n\n private _markup: IMarkup;\n\n /**\n * @param client - The `Client` instance that is used to load model reference files from the\n * Open Cloud Server. Do not specify `Client` if you need a standalone viewer instance to\n * view `glTF` files from the web or from local computer.\n */\n constructor(client?: Client) {\n super();\n this._options = new Options(this);\n\n this.client = client;\n\n this.canvasEvents = CANVAS_EVENTS;\n this.canvaseventlistener = (event: Event) => this.emit(event);\n\n this.extents = new Box3();\n this.target = new Vector3();\n\n this.draggerFactory = {\n Pan: PanDragger,\n Zoom: ZoomDragger,\n Orbit: OrbitDragger,\n Walk: WalkDragger,\n CuttingPlaneXAxis: CuttingPlaneXAxisDragger,\n CuttingPlaneYAxis: CuttingPlaneYAxisDragger,\n CuttingPlaneZAxis: CuttingPlaneZAxisDragger,\n MeasureLine: MeasureLineDragger,\n };\n this._activeDragger = null;\n\n this.models = [];\n this.components = [];\n this.selected = [];\n\n this.renderTime = 0;\n\n this.render = this.render.bind(this);\n this.update = this.update.bind(this);\n\n this._markup = new Markup();\n }\n\n get options(): IOptions {\n return this._options;\n }\n\n get draggers(): string[] {\n return Object.keys(this.draggerFactory);\n }\n\n /**\n * 2D markup core instance used to create markups.\n *\n * @readonly\n */\n get markup(): IMarkup {\n return this._markup;\n }\n\n initialize(canvas: HTMLCanvasElement, onProgress?: (event: ProgressEvent<EventTarget>) => void): Promise<this> {\n this.addEventListener(\"optionschange\", (event) => this.syncOptions(event.data));\n\n this.scene = new Scene();\n this.helpers = new Scene();\n\n const rect = canvas.parentElement.getBoundingClientRect();\n const width = rect.width || 1;\n const height = rect.height || 1;\n this.camera = new PerspectiveCamera(45, width / height, 0.01, 1000);\n this.camera.up.set(0, 0, 1);\n\n this.renderer = new WebGLRenderer({ canvas, antialias: true, preserveDrawingBuffer: true });\n this.renderer.setPixelRatio(window.devicePixelRatio);\n this.renderer.setSize(width, height);\n this.renderer.toneMapping = LinearToneMapping;\n\n this.canvas = canvas;\n this.canvasEvents.forEach((x) => canvas.addEventListener(x, this.canvaseventlistener));\n\n this._markup.initialize(this.canvas, this.canvasEvents, this, this);\n\n this.components.push(new ExtentsComponent(this));\n this.components.push(new LightComponent(this));\n this.components.push(new BackgroundComponent(this));\n // this.components.push(new ViewPositionComponent(this));\n this.components.push(new DefaultPositionComponent(this));\n this.components.push(new ResizeCanvasComponent(this));\n this.components.push(new RenderLoopComponent(this));\n this.components.push(new SelectionComponent(this));\n this.components.push(new WCSHelperComponent(this));\n // this.components.push(new AxesHelperComponent(this));\n // this.components.push(new ExtentsHelperComponent(this));\n\n this.syncOptions();\n this.syncOverlay();\n\n this.renderTime = performance.now();\n this.render(this.renderTime);\n\n if (typeof onProgress === \"function\")\n onProgress(new ProgressEvent(\"progress\", { lengthComputable: true, loaded: 1, total: 1 }));\n\n this.emitEvent({ type: \"initializeprogress\", data: 1, loaded: 1, total: 1 });\n this.emitEvent({ type: \"initialize\" });\n\n return Promise.resolve(this);\n }\n\n dispose(): this {\n this.cancel();\n this.emitEvent({ type: \"dispose\" });\n\n this.components.forEach((component: IDisposable) => component.dispose());\n this.components = [];\n\n this.setActiveDragger();\n this.removeAllListeners();\n\n this.clear();\n\n this._markup.dispose();\n\n if (this.canvas) {\n this.canvasEvents.forEach((x) => this.canvas.removeEventListener(x, this.canvaseventlistener));\n this.canvas = undefined;\n }\n\n if (this.renderer) this.renderer.dispose();\n\n this.renderer = undefined;\n this.camera = undefined;\n this.scene = undefined;\n this.helpers = undefined;\n\n return this;\n }\n\n isInitialized(): boolean {\n return !!this.renderer;\n }\n\n public render(time: DOMHighResTimeStamp): void {\n if (!this.renderNeeded) return;\n if (!this.renderer) return;\n\n this.renderNeeded = false;\n\n this.renderer.setViewport(0, 0, this.canvas.offsetWidth, this.canvas.offsetHeight);\n this.renderer.autoClear = true;\n this.renderer.render(this.scene, this.camera);\n\n const clippingPlanes = this.renderer.clippingPlanes;\n this.renderer.clippingPlanes = [];\n this.renderer.autoClear = false;\n this.renderer.render(this.helpers, this.camera);\n this.renderer.clippingPlanes = clippingPlanes;\n\n const deltaTime = (time - this.renderTime) / 1000;\n this.renderTime = time;\n this.emitEvent({ type: \"render\", time, deltaTime });\n }\n\n public update(force = false): void {\n this.renderNeeded = true;\n if (force) this.render(performance.now());\n this.emitEvent({ type: \"update\", data: force });\n }\n\n public syncOptions(options: IOptions = this.options): void {\n // this.update();\n }\n\n loadReferences(model: Model | File | Assembly): Promise<this> {\n // todo: load reference as text fonts\n return Promise.resolve(this);\n }\n\n /**\n * Loads a file from Open Cloud Server into the viewer.\n *\n * The file geometry data on the server must be converted to `glTF` format.\n *\n * This method requires a `Client` instance to be specified when creating the viewer to load\n * model reference files from the Open Cloud Server. For a standalone viewer instance use\n * {@link openGltfFile | openGltfFile()}.\n *\n * If there was an active dragger before opening the file, it will be deactivated. After\n * opening the file, you must manually activate the required dragger.\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryChunkEvent | geometrychunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File, assembly or specific model to load. If a `File` instance with multiple\n * models is specified, the default model will be loaded. If there is no default model,\n * first availiable model will be loaded.\n */\n async open(file: Model | File | Assembly): Promise<this> {\n if (!this.renderer) return this;\n\n this.cancel();\n this.clear();\n\n this.emitEvent({ type: \"open\", file, model: file });\n\n let model: Model | undefined = undefined;\n if (file) {\n const models = (await file.getModels()) || [];\n model = models.find((model: Model) => model.default) || models[0];\n }\n if (!model) throw new Error(\"No default model found\");\n\n const geometryType = model.database.split(\".\").pop();\n if (geometryType !== \"gltf\") throw new Error(`Unknown geometry type: ${geometryType}`);\n\n const url = `${model.httpClient.serverUrl}${model.path}/${model.database}`;\n const params = { requestHeader: model.httpClient.headers };\n\n await this.loadReferences(model);\n await this.loadGltfFile(url, undefined, params);\n\n return this;\n }\n\n cancel(): this {\n this.emitEvent({ type: \"cancel\" });\n return this;\n }\n\n /**\n * Loads a `glTF` file into the viewer.\n *\n * If there was an active dragger before opening the file, it will be deactivated. After\n * opening the file, you must manually activate the required dragger.\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File URL or binary data buffer to load.\n * @param externalData - External resource map such as binary data buffers or images. Each\n * resource should be represented by a `uri` and a corresponding resource URL, or\n * {@link https://developer.mozilla.org/docs/Web/API/File | Web API File} object, or\n * {@link https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer | ArrayBuffer}\n * or {@link https://developer.mozilla.org/docs/Web/API/Blob/Blob | Blob}, or\n * {@link https://developer.mozilla.org/docs/Web/HTTP/Basics_of_HTTP/Data_URIs | Data URL} string,\n * @param params - Loader parameters.\n * @param params.path - The base path from which to find subsequent glTF resources such as\n * textures and .bin data files. If not defined, the base path of the file URL will be used.\n * @param params.requestHeader - The\n * {@link https://developer.mozilla.org/docs/Glossary/Request_header | request header} used\n * in HTTP request.\n * @param params.crossOrigin - The crossOrigin string to implement CORS for loading the url\n * from a different domain that allows CORS. Default is `anonymous`.\n * @param params.withCredentials - Whether the XMLHttpRequest uses credentials such as\n * cookies, authorization headers or TLS client certificates. See\n * {@link https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/withCredentials | XMLHttpRequest.withCredentials}.\n */\n openGltfFile(\n file: string | globalThis.File | ArrayBuffer | Blob,\n externalData: Map<string, string | globalThis.File | ArrayBuffer | Blob> = new Map(),\n params: {\n path?: string;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n } = {}\n ): Promise<this> {\n if (!this.renderer) return Promise.resolve(this);\n\n this.cancel();\n this.clear();\n\n this.emitEvent({ type: \"open\" });\n\n return this.loadGltfFile(file, externalData, params);\n }\n\n /**\n * Appends a `glTF` file to the existing opened file.\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File URL or binary data buffer to load.\n * @param externalData - External resource map such as binary data buffers or images. Each\n * resource should be represented by a `uri` and a corresponding resource URL, or\n * {@link https://developer.mozilla.org/docs/Web/API/File | Web API File} object, or\n * {@link https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer | ArrayBuffer}\n * or {@link https://developer.mozilla.org/docs/Web/API/Blob/Blob | Blob}, or\n * {@link https://developer.mozilla.org/docs/Web/HTTP/Basics_of_HTTP/Data_URIs | Data URL} string,\n * @param params - Loader parameters.\n * @param params.path - The base path from which to find subsequent glTF resources such as\n * textures and .bin data files.\n * @param params.requestHeader - The\n * {@link https://developer.mozilla.org/docs/Glossary/Request_header | request header} used\n * in HTTP request.\n * @param params.crossOrigin - The crossOrigin string to implement CORS for loading the url\n * from a different domain that allows CORS. Default is `anonymous`.\n * @param params.withCredentials - Whether the XMLHttpRequest uses credentials such as\n * cookies, authorization headers or TLS client certificates. See\n * {@link https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/withCredentials | XMLHttpRequest.withCredentials}.\n */\n async loadGltfFile(\n file: string | globalThis.File | ArrayBuffer | Blob,\n externalData: Map<string, string | globalThis.File | ArrayBuffer | Blob> = new Map(),\n params: {\n path?: string;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n } = {}\n ): Promise<this> {\n const manager = new GLTFLoadingManager(file, externalData, params);\n try {\n this.emitEvent({ type: \"geometrystart\" });\n\n const loader = new GLTFLoader(manager);\n loader.setPath(manager.path);\n loader.setRequestHeader(params.requestHeader as any);\n loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);\n loader.setWithCredentials(params.withCredentials || loader.withCredentials);\n\n const gltf = await loader.loadAsync(manager.fileURL, (event: ProgressEvent) => {\n const { lengthComputable, loaded, total } = event;\n const progress = lengthComputable ? loaded / total : 1;\n this.emitEvent({ type: \"geometryprogress\", data: progress });\n });\n\n if (!this.scene) return this;\n if (!gltf.scene) throw new Error(\"No glTF scene found\");\n\n this.models.push(gltf);\n this.scene.add(gltf.scene);\n\n this.syncOptions();\n this.syncOverlay();\n this.update();\n\n this.emitEvent({ type: \"databasechunk\" });\n this.emitEvent({ type: \"geometryend\", data: gltf.scene });\n } catch (error) {\n this.emitEvent({ type: \"geometryerror\", data: error });\n throw error;\n } finally {\n manager.dispose();\n }\n\n return this;\n }\n\n clear(): this {\n if (!this.renderer) return this;\n\n function disposeMaterial(material: any) {\n const materials = Array.isArray(material) ? material : [material];\n materials.forEach((material: any) => {\n // Object.keys(material).forEach((key) => material[key]?.dispose?.());\n material.dispose();\n });\n }\n\n function disposeObject(object: any) {\n if (object.geometry) object.geometry.dispose();\n if (object.material) disposeMaterial(object.material);\n }\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n this.clearSelected();\n\n this.helpers.traverse(disposeObject);\n this.helpers.clear();\n\n this.models.forEach((gltf) => gltf.scene.traverse(disposeObject));\n this.models.forEach((gltf) => gltf.scene.removeFromParent());\n this.models = [];\n\n this.scene.clear();\n\n this.syncOptions();\n this.syncOverlay();\n this.update(true);\n\n this.emitEvent({ type: \"clear\" });\n\n return this;\n }\n\n syncOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.syncOverlay();\n this.update();\n }\n\n clearOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.clearOverlay();\n this.update();\n }\n\n clearSlices(): void {\n if (!this.renderer) return;\n\n this.renderer.clippingPlanes = [];\n this.update();\n }\n\n getSelected(): string[] {\n return this.executeCommand(\"getSelected\");\n }\n\n setSelected(handles?: string[]): void {\n this.executeCommand(\"setSelected\", handles);\n }\n\n clearSelected(): void {\n this.executeCommand(\"clearSelected\");\n }\n\n hideSelected(): void {\n this.executeCommand(\"hideSelected\");\n }\n\n isolateSelected(): void {\n this.executeCommand(\"isolateSelected\");\n }\n\n showAll(): void {\n this.executeCommand(\"showAll\");\n }\n\n explode(index = 0): void {\n this.executeCommand(\"explode\", index);\n }\n\n collect(): void {\n this.executeCommand(\"collect\");\n }\n\n activeDragger(): IDragger | null {\n return this._activeDragger;\n }\n\n setActiveDragger(name = \"\"): IDragger | null {\n if (!this._activeDragger || this._activeDragger.name !== name) {\n if (this._activeDragger) {\n this._activeDragger.dispose();\n this._activeDragger = null;\n }\n if (this.isInitialized()) {\n const Constructor = this.draggerFactory[name];\n if (Constructor) {\n this._activeDragger = new Constructor(this);\n this._activeDragger.name = name;\n }\n }\n const canvas = this.canvas;\n if (canvas) {\n canvas.className = canvas.className\n .split(\" \")\n .filter((x) => !x.startsWith(\"oda-cursor-\"))\n .filter((x) => x)\n .concat(`oda-cursor-${name.toLowerCase()}`)\n .join(\" \");\n }\n this.emitEvent({ type: \"changeactivedragger\", data: name });\n this.update();\n }\n return this._activeDragger;\n }\n\n resetActiveDragger(): void {\n const dragger = this._activeDragger;\n if (dragger) {\n this.setActiveDragger();\n this.setActiveDragger(dragger.name);\n }\n }\n\n is3D(): boolean {\n return true;\n }\n\n screenToWorld(position: { x: number; y: number }): { x: number; y: number; z: number } {\n if (!this.renderer) return { x: position.x, y: position.y, z: 0 };\n\n const rect = this.canvas.getBoundingClientRect();\n const x = position.x / (rect.width / 2) - 1;\n const y = -position.y / (rect.height / 2) + 1;\n\n const point = new Vector3(x, y, -1);\n point.unproject(this.camera);\n\n return { x: point.x, y: point.y, z: point.z };\n }\n\n worldToScreen(position: { x: number; y: number; z: number }): { x: number; y: number } {\n if (!this.renderer) return { x: position.x, y: position.y };\n\n const point = new Vector3(position.x, position.y, position.z);\n point.project(this.camera);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = (point.x + 1) * (rect.width / 2);\n const y = (-point.y + 1) * (rect.height / 2);\n\n return { x, y };\n }\n\n getScale(): { x: number; y: number; z: number } {\n return { x: 1, y: 1, z: 1 };\n }\n\n executeCommand(id: string, ...args: any[]): any {\n return commands(\"ThreeJS\").executeCommand(id, this, ...args);\n }\n\n getComponent(type): any {\n return this.components.find((component) => component instanceof type);\n }\n\n drawViewpoint(viewpoint: IViewpoint): void {\n if (!this.renderer) return;\n\n const getVector3FromPoint3d = ({ x, y, z }): Vector3 => new Vector3(x, y, z);\n\n const setPerspectiveCamera = (camera: IPerspectiveCamera) => {\n if (camera) {\n this.camera.up.copy(getVector3FromPoint3d(camera.up_vector));\n this.camera.fov = camera.field_of_view;\n this.camera.position.copy(getVector3FromPoint3d(camera.view_point));\n this.camera.lookAt(getVector3FromPoint3d(camera.direction).add(this.camera.position));\n this.camera.updateMatrixWorld();\n this.camera.updateProjectionMatrix();\n }\n };\n\n const setClippingPlanes = (clipping_planes: IClippingPlane[]) => {\n clipping_planes?.forEach((clipping_plane) => {\n const plane = new Plane();\n plane.setFromNormalAndCoplanarPoint(\n getVector3FromPoint3d(clipping_plane.direction),\n getVector3FromPoint3d(clipping_plane.location)\n );\n\n this.renderer.clippingPlanes.push(plane);\n });\n };\n\n const setSelection = (selection: IComponent[]) => {\n this.setSelected(selection?.map((component) => component.handle));\n };\n\n const draggerName = this._activeDragger?.name;\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n\n this.clearSelected();\n this.showAll();\n this.explode();\n\n setPerspectiveCamera(viewpoint.perspective_camera);\n setClippingPlanes(viewpoint.clipping_planes);\n setSelection(viewpoint.selection);\n this._markup.setViewpoint(viewpoint);\n\n this.target = getVector3FromPoint3d(viewpoint.custom_fields?.camera_target ?? this.target);\n\n this.setActiveDragger(draggerName);\n this.emitEvent({ type: \"drawviewpoint\", data: viewpoint });\n this.update();\n }\n\n createViewpoint(): IViewpoint {\n if (!this.renderer) return {};\n\n const getPoint3dFromVector3 = ({ x, y, z }): IPoint => ({ x, y, z });\n\n const getPerspectiveCamera = (): IPerspectiveCamera => {\n return {\n view_point: getPoint3dFromVector3(this.camera.position),\n direction: getPoint3dFromVector3(this.camera.getWorldDirection(new Vector3())),\n up_vector: getPoint3dFromVector3(this.camera.up),\n field_of_view: this.camera.fov,\n };\n };\n\n const getClippingPlanes = (): IClippingPlane[] => {\n const clipping_planes = [];\n this.renderer.clippingPlanes.forEach((plane: Plane) => {\n const clipping_plane = {\n location: getPoint3dFromVector3(plane.coplanarPoint(new Vector3())),\n direction: getPoint3dFromVector3(plane.normal),\n };\n clipping_planes.push(clipping_plane);\n });\n return clipping_planes;\n };\n\n const getSelection = (): IComponent[] => {\n return this.getSelected().map((handle) => ({ handle }));\n };\n\n const viewpoint: IViewpoint = { custom_fields: {} };\n\n viewpoint.perspective_camera = getPerspectiveCamera();\n viewpoint.clipping_planes = getClippingPlanes();\n viewpoint.selection = getSelection();\n viewpoint.description = new Date().toDateString();\n this._markup.getViewpoint(viewpoint);\n\n viewpoint.custom_fields.camera_target = getPoint3dFromVector3(this.target);\n\n this.emitEvent({ type: \"createviewpoint\", data: viewpoint });\n\n return viewpoint;\n }\n}\n"],"names":["Commands","constructor","this","_commands","Map","registerCommand","id","handler","description","thisArg","set","registerCommandAlias","alias","viewer","args","executeCommand","getCommand","get","getCommands","map","forEach","value","key","command","isDraggerCommand","draggers","includes","setActiveDragger","console","warn","undefined","result","apply","emit","type","data","commands","viewerType","defaultOptions","showWCS","cameraAnimation","antialiasing","groundShadow","shadows","cameraAxisXSpeed","cameraAxisYSpeed","ambientOcclusion","enableStreamingMode","enablePartialMode","memoryLimit","cuttingPlaneFillColor","red","green","blue","edgesColor","r","g","b","facesColor","edgesVisibility","edgesOverlap","facesOverlap","facesTransparancy","enableCustomHighlight","sceneGraph","edgeModel","reverseZoomWheel","enableZoomWheel","enableGestures","geometryType","rulerUnit","Options","emitter","_emitter","_data","loadFromStorage","defaults","notifierChangeEvent","change","saveToStorage","window","localStorage","setItem","JSON","stringify","error","item","getItem","parse","resetToDefaults","fields","resetData","reduce","acc","field","Boolean","CanvasEvents","CANVAS_EVENTS","Dragger","name","initialize","dispose","updatePreview","applyModelTransform","model","clearOverlay","SelectionComponent","onPointerDown","event","isPrimary","button","getMousePosition","downPosition","onPointerUp","upPosition","Vector2","distanceTo","intersects","getPointerIntersects","clearSelection","length","select","object","update","emitEvent","handles","getSelected","onDoubleClick","optionsChange","options","facesMaterial","color","setRGB","opacity","raycaster","Raycaster","MeshBasicMaterial","transparent","addEventListener","removeEventListener","target","clientX","clientY","mouse","rect","canvas","getBoundingClientRect","x","left","width","y","top","height","coords","setFromCamera","camera","objects","scene","traverseVisible","child","push","params","Mesh","Line","threshold","Line2","LOD","Points","Sprite","intersectObjects","isSelected","originalMaterial","material","selected","clearSelected","selection","clearSlices","createPreview","encoderOptions","toDataURL","calcObjectDepth","depth","res","children","objectDepth","originalPosition","position","clone","explodeScene","scale","maxDepth","explodeDepth","explodeObject","parentCenter","parentOffset","objectBox","Box3","setFromObject","objectCenter","getCenter","Vector3","objectOffset","offset","sub","multiplyScalar","add","copy","direction","normalize","sceneExtents","sceneCenter","explode","index","models","gltf","defaultViewPositions","bottom","right","front","back","sw","se","ne","nw","setDefaultViewPosition","center","extents","sphere","getBoundingSphere","Sphere","offet","radius","lookAt","updateProjectionMatrix","updateMatrixWorld","getDefaultViewPositions","Object","keys","getModels","userData","handle","filter","_a","hideSelected","visible","isolateSelected","selectedSet","Set","isolateObject","canBeIsolated","has","regenerateAll","resetView","selectModel","dragger","setSelected","handleSet","showAll","traverse","zoomToExtents","isEmpty","distance","delta","applyQuaternion","quaternion","zoomToObjects","expandByObject","zoomToSelected","GLTFLoadingManager","LoadingManager","file","externalData","super","path","resourcePath","fileURL","dataURLs","LoaderUtils","extractUrlBase","dataURL","URL","createObjectURL","Blob","setURLModifier","url","decodeURI","replace","revokeObjectURL","EventEmitter2","_listeners","listener","listeners","removeAllListeners","invoke","slice","call","on","off","WorldTransform","screenToWorld","z","worldToScreen","getScale","MarkupColor","setColor","asHex","HEX","asRGB","R","G","B","rgbToHex","valueToHex","c","hex","toString","LineTypeSpecs","KonvaLine","ref","_b","_ref","points","konvaPoints","point","Konva","stroke","strokeWidth","globalCompositeOperation","lineCap","lineJoin","draggable","strokeScaleEnabled","dash","e","attrs","rotation","_id","enableMouseEditing","getColor","getRotation","setRotation","degrees","getZIndex","zIndex","setZIndex","destroy","getPoints","setLineWidth","size","getLineWidth","getLineType","typeSpecs","setLineType","specs","addPoints","newPoints","concat","KonvaText","_c","TEXT_FONT_FAMILY","text","Text","fontSize","fontFamily","fill","align","getTextWidth","scaleByX","Math","abs","scaleX","scaleByY","scaleY","newWidth","newHeight","minWidth","round","getFontSize","getText","setText","getPosition","setPosition","setFontSize","KonvaRectangle","_d","Rect","lineWidth","minHeight","getWidth","getHeigth","setWidth","w","setHeight","h","KonvaEllipse","Ellipse","radiusX","radiusY","newRadiusX","newRadiusY","minRadiusX","minRadiusY","evt","ctrlKey","shiftKey","getRadiusX","setRadiusX","getRadiusY","setRadiusY","KonvaArrow","start","end","Arrow","setPoints","getStartPoint","setStartPoint","getEndPoint","setEndPoint","KonvaImage","_ratio","EPSILON","BASE64_HEADER_START","BASE64_NOT_FOUND","src","startsWith","_canvasImage","image","Image","onload","maxWidth","heightOutOfCanvas","maxHeight","widthOutOfCanvas","onerror","getSrc","setSrc","getHeight","KonvaCloud","arcRadius","Shape","sceneFunc","context","shape","calculateMidpoint","midX","midY","midPoint","baseArcLength","beginPath","iPoint","approxArcLength","dx","dy","sqrt","arcCount","floor","lengthMod","pX","pY","pEndX","pEndY","endAngle","atan","startAngle","PI","counterClockwise","iArc","arc","closePath","fillStrokeShape","className","getSelfRect","MarkupMode2Konva","SelectMarkup","initializer","Rectangle","Cloud","KonvaMarkup","_containerEvents","_markupIsActive","_markupColor","lineType","changeActiveDragger","draggerName","_markupContainer","_container","split","toLowerCase","join","removeTextInput","removeImageInput","enableEditMode","resizeContainer","entries","contentRect","_konvaStage","pan","newPos","dX","dY","zoomAt","newScale","redirectToViewer","_viewer","getRelativePointPosition","node","transform","getAbsoluteTransform","invert","getRelativePointerPosition","getStage","getPointerPosition","container","containerEvents","worldTransformer","Error","_worldTransformer","document","createElement","style","outline","pointerEvents","parentDiv","parentElement","appendChild","_resizeObserver","ResizeObserver","observe","initializeKonva","destroyKonva","disconnect","remove","syncOverlay","getObjects","obj","delete","getMarkupColor","setMarkupColor","colorizeAllMarkup","hexColor","colorizeSelectedMarkups","getSelectedObjects","setViewpoint","viewpoint","_e","_f","_g","_h","markupColor","custom_fields","markup_color","lines","line","linePoints","screenPoint","addLine","texts","addText","angle","text_size","font_size","rectangles","addRectangle","line_width","ellipses","ellipse","addEllipse","arrows","arrow","startPoint","endPoint","addArrow","clouds","cloud","addCloud","images","addImage","getViewpoint","getMarkupLines","getMarkupTexts","getMarkupArrows","getMarkupClouds","getMarkupEllipses","getMarkupImages","getMarkupRectangles","snapshot","combineMarkupWithDrawing","mode","_markupMode","createObject","konvaShape","addObject","konvaLayerFind","_konvaTransformer","nodes","values","find","selectObjects","selectedObjs","_groupImages","_groupTexts","_groupGeometry","_konvaLayer","parent","stage","Stage","clientWidth","clientHeight","layer","Layer","pixelRation","devicePixelRatio","Group","transformer","Transformer","shouldOverdrawWholeArea","keepRatio","flipEnabled","isPaint","lastLine","mouseDownPos","lastObj","pos","some","m","defParams","startX","min","startY","max","_textInputRef","_textInputPos","_textInputAngle","createTextInput","pageX","pageY","_imageInputRef","_imageInputPos","createImageInput","rotateEnabled","metaPressed","metaKey","indexOf","splice","tabIndex","focus","code","preventDefault","worldPoints","absoluteTransform","i","atPoint","worldPoint","konvaLine","textSize","textScale","stageAbsoluteTransform","getMatrix","rectangle","atStartPoint","worldStartPoint","atEndPoint","worldEndPoint","tempCanvas","ctx","getContext","HTMLCanvasElement","drawImage","toCanvas","pixelRatio","inputX","inputY","display","onkeydown","body","setTimeout","convertBase64","Promise","resolve","reject","fileReader","FileReader","readAsDataURL","accept","onchange","async","files","base64","oncancel","click","at","tolerance","konvaText","konvaRectangle","konvaEllipse","konvaArrow","konvaCloud","konvaImage","_changeEvent","_startEvent","_endEvent","STATE","NONE","ROTATE","DOLLY","PAN","TOUCH_ROTATE","TOUCH_PAN","TOUCH_DOLLY_PAN","TOUCH_DOLLY_ROTATE","OrbitControls","EventDispatcher","domElement","touchAction","enabled","minDistance","maxDistance","Infinity","minZoom","maxZoom","minPolarAngle","maxPolarAngle","minAzimuthAngle","maxAzimuthAngle","enableDamping","dampingFactor","enableZoom","zoomSpeed","enableRotate","rotateSpeed","enablePan","panSpeed","screenSpacePanning","keyPanSpeed","autoRotate","autoRotateSpeed","LEFT","UP","RIGHT","BOTTOM","mouseButtons","MOUSE","MIDDLE","touches","ONE","TOUCH","TWO","DOLLY_PAN","target0","position0","zoom0","zoom","_domElementKeyEvents","getPolarAngle","spherical","phi","getAzimuthalAngle","theta","getDistance","listenToKeyEvents","onKeyDown","stopListenToKeyEvents","saveState","scope","reset","dispatchEvent","state","quat","Quaternion","setFromUnitVectors","up","quatInverse","lastPosition","lastQuaternion","lastTargetPosition","twoPI","setFromVector3","rotateLeft","getAutoRotationAngle","sphericalDelta","isFinite","makeSafe","addScaledVector","panOffset","setFromSpherical","zoomChanged","distanceToSquared","EPS","dot","onContextMenu","onMouseWheel","onPointerMove","Spherical","rotateStart","rotateEnd","rotateDelta","panStart","panEnd","panDelta","dollyStart","dollyEnd","dollyDelta","dollyScale","pointers","pointerPositions","getZoomScale","pow","rotateUp","panLeft","v","objectMatrix","setFromMatrixColumn","panUp","crossVectors","deltaX","deltaY","element","isPerspectiveCamera","targetDistance","tan","fov","matrix","isOrthographicCamera","dollyOut","dollyIn","handleMouseDownRotate","handleMouseDownDolly","handleMouseDownPan","handleMouseMoveRotate","subVectors","handleMouseMoveDolly","handleMouseMovePan","handleMouseWheel","handleKeyDown","needsUpdate","handleTouchStartRotate","handleTouchStartPan","handleTouchStartDolly","handleTouchStartDollyPan","handleTouchStartDollyRotate","handleTouchMoveRotate","getSecondPointerPosition","handleTouchMovePan","handleTouchMoveDolly","handleTouchMoveDollyPan","handleTouchMoveDollyRotate","setPointerCapture","pointerId","addPointer","pointerType","onTouchStart","onMouseDown","onTouchMove","onMouseMove","removePointer","releasePointerCapture","mouseAction","trackPointer","DOLLY_ROTATE","pointer","passive","OrbitDragger","updateControls","orbit","far","near","controlsStart","changed","controlsChange","stopContextMenu","stopPropagation","PanDragger","ZoomDragger","WalkControls","Controls","movementSpeed","lookSpeed","multiplier","moveWheel","mouseDragOn","movePosition","rotateCamera","onPointerCancel","PointerEvent","onWheel","moveKeys","onKeyUp","moveClock","Clock","timeDelta","getDelta","moveDelta","translateZ","translateX","translateY","lookDelta","sign","stop","autoStart","rotateX","rotateY","xRotation","setFromAxisAngle","yRotation","premultiply","multiply","setRotationFromQuaternion","WalkDragger","getSize","controls","walkspeedChange","viewerRender","viewerZoom","PlaneHelper","plane","positions","geometry","BufferGeometry","setAttribute","Float32BufferAttribute","computeBoundingSphere","LineBasicMaterial","toneMapped","positions2","geometry2","helper","depthWrite","side","DoubleSide","force","normal","constant","CuttingPlaneDragger","transformChange","planeCenter","transformDrag","viewerExplode","planeHelper","negate","Plane","renderer","clippingPlanes","helpers","Object3D","TransformControls","showX","showY","showZ","attach","getHelper","removeFromParent","detach","CuttingPlaneXAxisDragger","CuttingPlaneYAxisDragger","CuttingPlaneZAxisDragger","PRECISION","MeasureLineDragger","snapper","getSnapPoint","render","MeasureLine","overlay","onPointerLeave","renderOverlay","updateSnapper","MeasureOverlay","MeasureSnapper","projector","MeasureProjector","background","overflow","clear","removeLine","_middlePoint","Date","now","unit","border","boxShadow","font","elementStartPoint","elementEndPoint","elementLine","elementLabel","projectPoint","point1","point2","projectLine","lerpVectors","innerHTML","toFixed","borderRadius","transformOrigin","padding","paddingInline","_widthHalf","_heightHalf","_viewMatrix","Matrix4","_viewProjectionMatrix","_vector","_vector1","Vector4","_vector2","matrixWorldInverse","multiplyMatrices","projectionMatrix","p","applyMatrix4","p1","p2","bc1near","bc2near","bc1far","bc2far","alpha1","alpha2","lerp","ExtentsComponent","syncExtents","LightComponent","ambientLight","AmbientLight","directionalLight","DirectionalLight","BackgroundComponent","syncOptions","backgroundColor","setHex","Color","environment","RoomEnvironment","pmremGenerator","PMREMGenerator","setClearColor","fromScene","texture","DefaultPositionComponent","geometryEnd","box","ResizeCanvasComponent","resizeViewer","aspect","setSize","resizeObserver","RenderLoopComponent","animate","time","requestId","requestAnimationFrame","cancelAnimationFrame","WCSHelper","orthoCamera","OrthographicCamera","matRed","matGreen","matBlue","spriteRed","getSpriteMaterial","spriteGreen","spriteBlue","lineGeometry","CylinderGeometry","translate","arrowGeometry","axesMap","X","Y","Z","clearRect","textAlign","fillStyle","getStyle","fillText","CanvasTexture","colorSpace","SRGBColorSpace","SpriteMaterial","viewport","getViewport","setViewport","clearDepth","WCSHelperComponent","wcsHelper","Viewer","client","_options","canvasEvents","canvaseventlistener","draggerFactory","Pan","Zoom","Orbit","Walk","CuttingPlaneXAxis","CuttingPlaneYAxis","CuttingPlaneZAxis","_activeDragger","components","renderTime","bind","_markup","Markup","markup","onProgress","Scene","PerspectiveCamera","WebGLRenderer","antialias","preserveDrawingBuffer","setPixelRatio","toneMapping","LinearToneMapping","performance","ProgressEvent","lengthComputable","loaded","total","cancel","component","isInitialized","renderNeeded","offsetWidth","offsetHeight","autoClear","deltaTime","loadReferences","open","default","database","pop","httpClient","serverUrl","requestHeader","headers","loadGltfFile","openGltfFile","manager","loader","GLTFLoader","setPath","setRequestHeader","setCrossOrigin","crossOrigin","setWithCredentials","withCredentials","loadAsync","progress","disposeMaterial","materials","Array","isArray","disposeObject","collect","activeDragger","Constructor","resetActiveDragger","is3D","unproject","project","getComponent","drawViewpoint","getVector3FromPoint3d","setPerspectiveCamera","up_vector","field_of_view","view_point","setClippingPlanes","clipping_planes","clipping_plane","setFromNormalAndCoplanarPoint","location","setSelection","perspective_camera","camera_target","createViewpoint","getPoint3dFromVector3","getPerspectiveCamera","getWorldDirection","getClippingPlanes","coplanarPoint","getSelection","toDateString"],"mappings":"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"}
|