@inweb/viewer-three 26.6.2 → 26.6.3
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/plugins/loaders/IFCXLoader.js +60 -60
- package/dist/plugins/loaders/IFCXLoader.js.map +1 -1
- package/dist/plugins/loaders/IFCXLoader.min.js +1 -1
- package/dist/plugins/loaders/IFCXLoader.module.js +49 -49
- package/dist/plugins/loaders/IFCXLoader.module.js.map +1 -1
- package/dist/viewer-three.js +31 -31
- package/dist/viewer-three.js.map +1 -1
- package/dist/viewer-three.min.js +1 -1
- package/dist/viewer-three.module.js +30 -30
- package/dist/viewer-three.module.js.map +1 -1
- package/lib/Viewer/loaders/{GLTFModelLoader.d.ts → GLTFCloudModelLoader.d.ts} +1 -1
- package/lib/Viewer/loaders/GLTFFileLoader.d.ts +1 -1
- package/package.json +5 -5
- package/plugins/loaders/{IFCXModelLoader.ts → IFCXCloudFileLoader.ts} +6 -6
- package/plugins/loaders/IFCXLoader.ts +2 -2
- package/src/Viewer/Viewer.ts +7 -7
- package/src/Viewer/components/index.ts +0 -1
- package/src/Viewer/loaders/{GLTFModelLoader.ts → GLTFCloudModelLoader.ts} +1 -1
- package/src/Viewer/loaders/GLTFFileLoader.ts +4 -4
- package/src/Viewer/loaders/index.ts +2 -2
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Loader, GLTFLoadingManager, loaders } from "@inweb/viewer-three";
|
|
1
|
+
import { Loader as Loader$1, GLTFLoadingManager, loaders } from "@inweb/viewer-three";
|
|
2
2
|
|
|
3
|
-
import { Box3, Vector3, Group, Matrix4, Scene, PerspectiveCamera, BufferGeometry, BufferAttribute, MeshBasicMaterial, Mesh, LineBasicMaterial, Line, Color, Loader
|
|
3
|
+
import { Box3, Vector3, Group, Matrix4, Scene, PerspectiveCamera, BufferGeometry, BufferAttribute, MeshBasicMaterial, Mesh, LineBasicMaterial, Line, Color, Loader, FileLoader } from "three";
|
|
4
4
|
|
|
5
5
|
const THREE = {
|
|
6
6
|
Box3: Box3,
|
|
@@ -587,51 +587,7 @@ function clear() {
|
|
|
587
587
|
autoCamera = true;
|
|
588
588
|
}
|
|
589
589
|
|
|
590
|
-
class
|
|
591
|
-
constructor(viewer) {
|
|
592
|
-
super();
|
|
593
|
-
this.viewer = viewer;
|
|
594
|
-
}
|
|
595
|
-
isSupport(file) {
|
|
596
|
-
return typeof file === "object" && typeof file.type === "string" && typeof file.download === "function" && /.ifcx$/i.test(file.type);
|
|
597
|
-
}
|
|
598
|
-
async load(model) {
|
|
599
|
-
const progress = progress => {
|
|
600
|
-
this.viewer.emitEvent({
|
|
601
|
-
type: "geometryprogress",
|
|
602
|
-
data: progress,
|
|
603
|
-
file: model
|
|
604
|
-
});
|
|
605
|
-
};
|
|
606
|
-
const arrayBuffer = await model.download(progress, this.abortController.signal);
|
|
607
|
-
if (!this.viewer.scene) return this;
|
|
608
|
-
const textDecoder = new TextDecoder;
|
|
609
|
-
const json = JSON.parse(textDecoder.decode(arrayBuffer));
|
|
610
|
-
const scene = parse(json);
|
|
611
|
-
clear();
|
|
612
|
-
let handle = 0;
|
|
613
|
-
scene.traverse((object => {
|
|
614
|
-
object.userData = {
|
|
615
|
-
handle: handle,
|
|
616
|
-
...object.userData
|
|
617
|
-
};
|
|
618
|
-
handle++;
|
|
619
|
-
}));
|
|
620
|
-
this.viewer.scene.add(scene);
|
|
621
|
-
this.viewer.models.push(scene);
|
|
622
|
-
this.viewer.syncOptions();
|
|
623
|
-
this.viewer.syncOverlay();
|
|
624
|
-
this.viewer.update();
|
|
625
|
-
this.viewer.emitEvent({
|
|
626
|
-
type: "databasechunk",
|
|
627
|
-
data: scene,
|
|
628
|
-
file: model
|
|
629
|
-
});
|
|
630
|
-
return this;
|
|
631
|
-
}
|
|
632
|
-
}
|
|
633
|
-
|
|
634
|
-
class IFCXLoader extends Loader$1 {
|
|
590
|
+
class IFCXLoader extends Loader {
|
|
635
591
|
load(url, onLoad, onProgress, onError) {
|
|
636
592
|
const manager = this.manager;
|
|
637
593
|
manager.itemStart(url);
|
|
@@ -662,7 +618,7 @@ class IFCXLoader extends Loader$1 {
|
|
|
662
618
|
}
|
|
663
619
|
}
|
|
664
620
|
|
|
665
|
-
class IFCXFileLoader extends Loader {
|
|
621
|
+
class IFCXFileLoader extends Loader$1 {
|
|
666
622
|
constructor(viewer) {
|
|
667
623
|
super();
|
|
668
624
|
this.viewer = viewer;
|
|
@@ -709,7 +665,51 @@ class IFCXFileLoader extends Loader {
|
|
|
709
665
|
}
|
|
710
666
|
}
|
|
711
667
|
|
|
712
|
-
|
|
668
|
+
class IFCXCloudFileLoader extends Loader$1 {
|
|
669
|
+
constructor(viewer) {
|
|
670
|
+
super();
|
|
671
|
+
this.viewer = viewer;
|
|
672
|
+
}
|
|
673
|
+
isSupport(file) {
|
|
674
|
+
return typeof file === "object" && typeof file.type === "string" && typeof file.download === "function" && /.ifcx$/i.test(file.type);
|
|
675
|
+
}
|
|
676
|
+
async load(file) {
|
|
677
|
+
const progress = progress => {
|
|
678
|
+
this.viewer.emitEvent({
|
|
679
|
+
type: "geometryprogress",
|
|
680
|
+
data: progress,
|
|
681
|
+
file: file
|
|
682
|
+
});
|
|
683
|
+
};
|
|
684
|
+
const arrayBuffer = await file.download(progress, this.abortController.signal);
|
|
685
|
+
if (!this.viewer.scene) return this;
|
|
686
|
+
const textDecoder = new TextDecoder;
|
|
687
|
+
const json = JSON.parse(textDecoder.decode(arrayBuffer));
|
|
688
|
+
const scene = parse(json);
|
|
689
|
+
clear();
|
|
690
|
+
let handle = 0;
|
|
691
|
+
scene.traverse((object => {
|
|
692
|
+
object.userData = {
|
|
693
|
+
handle: handle,
|
|
694
|
+
...object.userData
|
|
695
|
+
};
|
|
696
|
+
handle++;
|
|
697
|
+
}));
|
|
698
|
+
this.viewer.scene.add(scene);
|
|
699
|
+
this.viewer.models.push(scene);
|
|
700
|
+
this.viewer.syncOptions();
|
|
701
|
+
this.viewer.syncOverlay();
|
|
702
|
+
this.viewer.update();
|
|
703
|
+
this.viewer.emitEvent({
|
|
704
|
+
type: "databasechunk",
|
|
705
|
+
data: scene,
|
|
706
|
+
file: file
|
|
707
|
+
});
|
|
708
|
+
return this;
|
|
709
|
+
}
|
|
710
|
+
}
|
|
713
711
|
|
|
714
712
|
loaders.registerLoader("ifcx-file", (viewer => new IFCXFileLoader(viewer)));
|
|
713
|
+
|
|
714
|
+
loaders.registerLoader("ifcx-cloud-file", (viewer => new IFCXCloudFileLoader(viewer)));
|
|
715
715
|
//# sourceMappingURL=IFCXLoader.module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IFCXLoader.module.js","sources":["../../../plugins/loaders/IFCX/render.js","../../../plugins/loaders/IFCXModelLoader.ts","../../../plugins/loaders/IFCX/IFCXLoader.ts","../../../plugins/loaders/IFCXFileLoader.ts","../../../plugins/loaders/IFCXLoader.ts"],"sourcesContent":["///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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\n// Repository: https://github.com/buildingSMART/IFC5-development\n// Original File: docs/viewer/render.mjs\n// Commit SHA-1: 83a7ae862232c90065d1bd03fcd538315e7d2563\n// Commit Date: 20.05.2025 21:00:52\n\n// (C) buildingSMART International\n// published under MIT license\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable prefer-const */\n/* eslint-disable no-useless-catch */\n\nimport {\n Box3,\n BufferAttribute,\n BufferGeometry,\n Color,\n Group,\n Line,\n LineBasicMaterial,\n Matrix4,\n Mesh,\n MeshBasicMaterial,\n PerspectiveCamera,\n Scene,\n Vector3,\n} from \"three\";\n\nconst THREE = {\n Box3,\n BufferAttribute,\n BufferGeometry,\n Color,\n Group,\n Line,\n LineBasicMaterial,\n Matrix4,\n Mesh,\n MeshBasicMaterial,\n PerspectiveCamera,\n Scene,\n Vector3,\n};\n\n// composed-object.ts\nfunction getChildByName(root, childName, skip = 0) {\n let fragments = childName.replace(/^<\\/|^\\/|>$/g, \"\").split(\"/\");\n for (let i = 0; i < skip; ++i) {\n fragments.shift();\n }\n let start = root;\n while (fragments.length && start && start.children) {\n // console.log(start, fragments[0]);\n let f = fragments.shift();\n start = start.children.find((i) => i.name.split(\"/\").reverse()[0] === f);\n }\n if (fragments.length == 0) {\n return start;\n }\n}\n\n// compose-alpha.ts\nfunction GetNode(node, path) {\n if (path === \"\") return node;\n let parts = path.split(\"/\");\n let child = node.children.get(parts[0]);\n if (child) {\n if (parts.length === 1) {\n return child;\n }\n return GetNode(child, GetTail(path));\n } else {\n return null;\n }\n}\nfunction GetHead(path) {\n return path.split(\"/\")[0];\n}\nfunction GetTail(path) {\n let parts = path.split(\"/\");\n parts.shift();\n return parts.join(\"/\");\n}\nfunction MakeNode(node) {\n return {\n node,\n children: /* @__PURE__ */ new Map(),\n attributes: /* @__PURE__ */ new Map(),\n };\n}\nfunction ConvertToCompositionNode(path, inputNodes) {\n let compositionNode = {\n path,\n children: {},\n inherits: {},\n attributes: {},\n };\n inputNodes.forEach((node) => {\n Object.keys(node.children).forEach((childName) => {\n compositionNode.children[childName] = node.children[childName];\n });\n Object.keys(node.inherits).forEach((inheritName) => {\n let ih = node.inherits[inheritName];\n if (ih === null) {\n delete compositionNode.inherits[inheritName];\n } else {\n compositionNode.inherits[inheritName] = ih;\n }\n });\n Object.keys(node.attributes).forEach((attrName) => {\n compositionNode.attributes[attrName] = node.attributes[attrName];\n });\n });\n return compositionNode;\n}\nfunction MMSet(map, key, value) {\n if (map.has(key)) {\n map.get(key)?.push(value);\n } else {\n map.set(key, [value]);\n }\n}\nfunction FindRootsOrCycles(nodes) {\n let dependencies = /* @__PURE__ */ new Map();\n let dependents = /* @__PURE__ */ new Map();\n nodes.forEach((node, path) => {\n Object.keys(node.inherits).forEach((inheritName) => {\n MMSet(dependencies, path, node.inherits[inheritName]);\n MMSet(dependents, node.inherits[inheritName], path);\n });\n Object.keys(node.children).forEach((childName) => {\n MMSet(dependencies, path, node.children[childName]);\n MMSet(dependents, node.children[childName], path);\n });\n });\n let paths = [...nodes.keys()];\n let perm = {};\n let temp = {};\n function visit(path) {\n if (perm[path]) return;\n if (temp[path]) throw new Error(`CYCLE!`);\n temp[path] = true;\n let deps = dependencies.get(path);\n if (deps) {\n deps.forEach((dep) => visit(dep));\n }\n perm[path] = true;\n }\n let roots = /* @__PURE__ */ new Set();\n try {\n paths.forEach((path) => {\n if (!dependents.has(path) && path.indexOf(\"/\") === -1) {\n roots.add(path);\n }\n visit(path);\n });\n } catch (e) {\n return null;\n }\n return roots;\n}\nfunction ConvertNodes(input) {\n let compositionNodes = /* @__PURE__ */ new Map();\n for (let [path, inputNodes] of input) {\n compositionNodes.set(path, ConvertToCompositionNode(path, inputNodes));\n }\n return compositionNodes;\n}\nvar CycleError = class extends Error {};\nfunction ExpandFirstRootInInput(nodes) {\n let roots = FindRootsOrCycles(nodes);\n if (!roots) {\n throw new CycleError();\n }\n return ExpandNewNode([...roots.values()][0], nodes);\n}\nfunction CreateArtificialRoot(nodes) {\n let roots = FindRootsOrCycles(nodes);\n if (!roots) {\n throw new CycleError();\n }\n let pseudoRoot = {\n node: \"\",\n attributes: /* @__PURE__ */ new Map(),\n children: /* @__PURE__ */ new Map(),\n };\n roots.forEach((root) => {\n pseudoRoot.children.set(root, ExpandNewNode(root, nodes));\n });\n return pseudoRoot;\n}\nfunction ExpandNewNode(node, nodes) {\n return ExpandNode(node, MakeNode(node), nodes);\n}\nfunction ExpandNode(path, node, nodes) {\n let input = nodes.get(path);\n if (input) {\n AddDataFromInput(input, node, nodes);\n }\n node.children.forEach((child, name) => {\n ExpandNode(`${path}/${name}`, child, nodes);\n });\n return node;\n}\nfunction AddDataFromInput(input, node, nodes) {\n Object.values(input.inherits).forEach((inherit) => {\n let classNode = ExpandNewNode(GetHead(inherit), nodes);\n let subnode = GetNode(classNode, GetTail(inherit));\n if (!subnode) throw new Error(`Unknown node ${inherit}`);\n subnode.children.forEach((child, childName) => {\n node.children.set(childName, child);\n });\n for (let [attrID, attr] of subnode.attributes) {\n node.attributes.set(attrID, attr);\n }\n });\n Object.entries(input.children).forEach(([childName, child]) => {\n if (child !== null) {\n let classNode = ExpandNewNode(GetHead(child), nodes);\n let subnode = GetNode(classNode, GetTail(child));\n if (!subnode) throw new Error(`Unknown node ${child}`);\n node.children.set(childName, subnode);\n } else {\n node.children.delete(childName);\n }\n });\n Object.entries(input.attributes).forEach(([attrID, attr]) => {\n node.attributes.set(attrID, attr);\n });\n}\n\n// workflow-alpha.ts\nfunction MMSet2(map, key, value) {\n if (map.has(key)) {\n map.get(key)?.push(value);\n } else {\n map.set(key, [value]);\n }\n}\nfunction ToInputNodes(data) {\n let inputNodes = /* @__PURE__ */ new Map();\n data.forEach((ifcxNode) => {\n let node = {\n path: ifcxNode.path,\n children: ifcxNode.children ? ifcxNode.children : {},\n inherits: ifcxNode.inherits ? ifcxNode.inherits : {},\n attributes: ifcxNode.attributes ? ifcxNode.attributes : {},\n };\n MMSet2(inputNodes, node.path, node);\n });\n return inputNodes;\n}\nvar SchemaValidationError = class extends Error {};\nfunction ValidateAttributeValue(desc, value, path, schemas) {\n if (desc.inherits) {\n desc.inherits.forEach((inheritedSchemaID) => {\n let inheritedSchema = schemas[inheritedSchemaID];\n if (!inheritedSchema) {\n throw new SchemaValidationError(`Unknown inherited schema id \"${desc.inherits}\"`);\n }\n ValidateAttributeValue(inheritedSchema.value, value, path, schemas);\n });\n }\n if (desc.dataType === \"Boolean\") {\n if (typeof value !== \"boolean\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type boolean`);\n }\n } else if (desc.dataType === \"String\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type string`);\n }\n } else if (desc.dataType === \"DateTime\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type date`);\n }\n } else if (desc.dataType === \"Enum\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type string`);\n }\n let found = desc.enumRestrictions.options.filter((option) => option === value).length === 1;\n if (!found) {\n throw new SchemaValidationError(`Expected \"${value}\" to be one of [${desc.enumRestrictions.options.join(\",\")}]`);\n }\n } else if (desc.dataType === \"Integer\") {\n if (typeof value !== \"number\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type int`);\n }\n } else if (desc.dataType === \"Real\") {\n if (typeof value !== \"number\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type real`);\n }\n } else if (desc.dataType === \"Relation\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type string`);\n }\n } else if (desc.dataType === \"Object\") {\n if (typeof value !== \"object\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type object`);\n }\n if (desc.objectRestrictions) {\n Object.keys(desc.objectRestrictions.values).forEach((key) => {\n if (!Object.hasOwn(value, key)) {\n throw new SchemaValidationError(`Expected \"${value}\" to have key ${key}`);\n }\n ValidateAttributeValue(desc.objectRestrictions.values[key], value[key], path + \".\" + key, schemas);\n });\n }\n } else if (desc.dataType === \"Array\") {\n if (!Array.isArray(value)) {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type array`);\n }\n value.forEach((entry) => {\n ValidateAttributeValue(desc.arrayRestrictions.value, entry, path + \".<array>.\", schemas);\n });\n } else {\n throw new SchemaValidationError(`Unexpected datatype ${desc.dataType}`);\n }\n}\nfunction Validate(schemas, inputNodes) {\n inputNodes.forEach((node) => {\n Object.keys(node.attributes).forEach((schemaID) => {\n if (!schemas[schemaID]) {\n throw new SchemaValidationError(`Missing schema \"${schemaID}\" referenced by [\"${node.path}\"].attributes`);\n }\n let schema = schemas[schemaID];\n let value = node.attributes[schemaID];\n try {\n ValidateAttributeValue(schema.value, value, \"\", schemas);\n } catch (e) {\n if (e instanceof SchemaValidationError) {\n throw new SchemaValidationError(`Error validating [\"${node.path}\"].attributes[\"${schemaID}\"]: ${e.message}`);\n } else {\n throw e;\n }\n }\n });\n });\n}\nfunction LoadIfcxFile(file, checkSchemas = true, createArtificialRoot = false) {\n let inputNodes = ToInputNodes(file.data);\n let compositionNodes = ConvertNodes(inputNodes);\n try {\n if (checkSchemas) {\n Validate(file.schemas, compositionNodes);\n }\n } catch (e) {\n throw e;\n }\n if (createArtificialRoot) {\n return CreateArtificialRoot(compositionNodes);\n } else {\n return ExpandFirstRootInInput(compositionNodes);\n }\n}\nfunction Federate(files) {\n let result = {\n header: files[0].header,\n schemas: {},\n data: [],\n };\n files.forEach((file) => {\n Object.keys(file.schemas).forEach((schemaID) => (result.schemas[schemaID] = file.schemas[schemaID]));\n });\n files.forEach((file) => {\n file.data.forEach((node) => result.data.push(node));\n });\n return Prune(result);\n}\nfunction Collapse(nodes, deleteEmpty = false) {\n let result = {\n path: nodes[0].path,\n children: {},\n inherits: {},\n attributes: {},\n };\n nodes.forEach((node) => {\n Object.keys(node.children).forEach((name) => {\n result.children[name] = node.children[name];\n });\n Object.keys(node.inherits).forEach((name) => {\n result.inherits[name] = node.inherits[name];\n });\n Object.keys(node.attributes).forEach((name) => {\n result.attributes[name] = node.attributes[name];\n });\n });\n if (deleteEmpty) {\n let empty = true;\n Object.keys(result.children).forEach((name) => {\n if (result.children[name] !== null) empty = false;\n });\n Object.keys(result.inherits).forEach((name) => {\n if (result.inherits[name] !== null) empty = false;\n });\n Object.keys(result.attributes).forEach((name) => {\n if (result.attributes[name] !== null) empty = false;\n });\n if (empty) return null;\n }\n return result;\n}\nfunction Prune(file, deleteEmpty = false) {\n let result = {\n header: file.header,\n schemas: file.schemas,\n data: [],\n };\n let inputNodes = ToInputNodes(file.data);\n inputNodes.forEach((nodes) => {\n let collapsed = Collapse(nodes, deleteEmpty);\n if (collapsed)\n result.data.push({\n path: collapsed.path,\n children: collapsed.children,\n inherits: collapsed.inherits,\n attributes: collapsed.attributes,\n });\n });\n return result;\n}\n\n// compose-flattened.ts\nfunction TreeNodeToComposedObject(path, node, schemas) {\n let co = {\n name: path,\n attributes: {},\n children: [],\n };\n node.children.forEach((childNode, childName) => {\n co.children?.push(TreeNodeToComposedObject(`${path}/${childName}`, childNode, schemas));\n });\n node.attributes.forEach((attr, attrName) => {\n if (attr && typeof attr === \"object\" && !Array.isArray(attr)) {\n Object.keys(attr).forEach((compname) => {\n co.attributes[`${attrName}::${compname}`] = attr[compname];\n });\n } else {\n let schema = schemas[attrName];\n if (schema && schema.value.quantityKind) {\n let postfix = \"\";\n let quantityKind = schema.value.quantityKind;\n if (quantityKind === \"Length\") {\n postfix = \"m\";\n } else if (quantityKind === \"Volume\") {\n postfix = \"m\" + String.fromCodePoint(179);\n }\n co.attributes[attrName] = `${attr} ${postfix}`;\n } else {\n co.attributes[attrName] = attr;\n }\n }\n });\n if (Object.keys(co.attributes).length === 0) delete co.attributes;\n return co;\n}\nfunction compose3(files) {\n let federated = Federate(files);\n let tree = LoadIfcxFile(federated, true, true);\n return TreeNodeToComposedObject(\"\", tree, federated.schemas);\n}\n\n// render.ts\n// var controls;\n// var renderer;\nvar scene;\nvar camera;\nvar datas = [];\nvar autoCamera = true;\n// var THREE = window[\"THREE\"];\nfunction init() {\n scene = new THREE.Scene();\n camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 100);\n camera.up.set(0, 0, 1);\n camera.position.set(50, 50, 50);\n camera.lookAt(0, 0, 0);\n // const nd = document.querySelector(\".viewport\");\n // renderer = new THREE.WebGLRenderer({\n // alpha: true,\n // logarithmicDepthBuffer: true,\n // });\n // renderer.setSize(nd.offsetWidth, nd.offsetHeight);\n // controls = new THREE.OrbitControls(camera, renderer.domElement);\n // controls.enableDamping = true;\n // controls.dampingFactor = 0.25;\n // nd.appendChild(renderer.domElement);\n scene.add(camera);\n return scene;\n}\nfunction HasAttr(node, attrName) {\n if (!node || !node.attributes) return false;\n return !!node.attributes[attrName];\n}\nfunction FindChildWithAttr(node, attrName) {\n if (!node || !node.children) return void 0;\n for (let i = 0; i < node.children.length; i++) {\n if (HasAttr(node.children[i], attrName)) {\n return node.children[i];\n }\n }\n return void 0;\n}\nfunction createMaterialFromParent(parent, root) {\n let reference = parent.attributes[\"usd::usdshade::materialbindingapi::material::binding\"];\n let material = {\n color: new THREE.Color(0.6, 0.6, 0.6),\n transparent: false,\n opacity: 1,\n };\n if (reference) {\n const materialNode = getChildByName(root, reference.ref);\n if (materialNode) {\n let color = materialNode?.attributes[\"bsi::presentation::diffuseColor\"];\n material.color = new THREE.Color(...color);\n if (materialNode?.attributes[\"bsi::presentation::opacity\"]) {\n material.transparent = true;\n material.opacity = materialNode.attributes[\"bsi::presentation::opacity\"];\n }\n }\n }\n return material;\n}\nfunction createCurveFromJson(node, parent, root) {\n let points = new Float32Array(node.attributes[\"usd::usdgeom::basiscurves::points\"].flat());\n const geometry = new THREE.BufferGeometry();\n geometry.setAttribute(\"position\", new THREE.BufferAttribute(points, 3));\n const material = createMaterialFromParent(parent, root);\n let lineMaterial = new THREE.LineBasicMaterial({ ...material });\n lineMaterial.color.multiplyScalar(0.8);\n return new THREE.Line(geometry, lineMaterial);\n}\nfunction createMeshFromJson(node, parent, root) {\n let points = new Float32Array(node.attributes[\"usd::usdgeom::mesh::points\"].flat());\n let indices = new Uint16Array(node.attributes[\"usd::usdgeom::mesh::faceVertexIndices\"]);\n const geometry = new THREE.BufferGeometry();\n geometry.setAttribute(\"position\", new THREE.BufferAttribute(points, 3));\n geometry.setIndex(new THREE.BufferAttribute(indices, 1));\n geometry.computeVertexNormals();\n const material = createMaterialFromParent(parent, root);\n let meshMaterial = new THREE.MeshBasicMaterial({ ...material });\n return new THREE.Mesh(geometry, meshMaterial);\n}\nfunction traverseTree(node, parent, root, parentNode = void 0) {\n let elem = new THREE.Group();\n if (HasAttr(node, \"usd::usdgeom::visibility::visibility\")) {\n if (node.attributes[\"usd::usdgeom::visibility::visibility\"] === \"invisible\") {\n return;\n }\n } else if (HasAttr(node, \"usd::usdgeom::mesh::points\")) {\n elem = createMeshFromJson(node, parentNode, root);\n } else if (HasAttr(node, \"usd::usdgeom::basiscurves::points\")) {\n elem = createCurveFromJson(node, parentNode, root);\n }\n parent.add(elem);\n if (node !== root) {\n elem.matrixAutoUpdate = false;\n let matrixNode =\n node.attributes && node.attributes[\"usd::xformop::transform\"]\n ? node.attributes[\"usd::xformop::transform\"].flat()\n : null;\n if (matrixNode) {\n let matrix = new THREE.Matrix4();\n matrix.set(...matrixNode);\n matrix.transpose();\n elem.matrix = matrix;\n }\n }\n (node.children || []).forEach((child) => traverseTree(child, elem || parent, root, node));\n}\n// function encodeHtmlEntities(str) {\n// const div = document.createElement(\"div\");\n// div.textContent = str;\n// return div.innerHTML;\n// }\n// var icons = {\n// \"usd::usdgeom::mesh::points\": \"deployed_code\",\n// \"usd::usdgeom::basiscurves::points\": \"line_curve\",\n// \"usd::usdshade::material::outputs::surface.connect\": \"line_style\",\n// };\n// function buildDomTree(prim, node) {\n// const elem = document.createElement(\"div\");\n// let span;\n// elem.appendChild(document.createTextNode(prim.name ? prim.name.split(\"/\").reverse()[0] : \"root\"));\n// elem.appendChild((span = document.createElement(\"span\")));\n// Object.entries(icons).forEach(([k, v]) => (span.innerText += (prim.attributes || {})[k] ? v : \" \"));\n// span.className = \"material-symbols-outlined\";\n// elem.onclick = (evt) => {\n// let rows = [[\"name\", prim.name]]\n// .concat(Object.entries(prim.attributes))\n// .map(\n// ([k, v]) =>\n// `<tr><td>${encodeHtmlEntities(k)}</td><td>${encodeHtmlEntities(typeof v === \"object\" ? JSON.stringify(v) : v)}</td>`\n// )\n// .join(\"\");\n// document.querySelector(\".attributes .table\").innerHTML = `<table border=\"0\">${rows}</table>`;\n// evt.stopPropagation();\n// };\n// node.appendChild(elem);\n// (prim.children || []).forEach((p) => buildDomTree(p, elem));\n// }\nfunction composeAndRender() {\n if (scene) {\n scene.children = [];\n }\n // document.querySelector(\".tree\").innerHTML = \"\";\n if (datas.length === 0) {\n return;\n }\n let tree = null;\n let dataArray = datas.map((arr) => arr[1]);\n tree = compose3(dataArray);\n if (!tree) {\n console.error(\"No result from composition\");\n return;\n }\n traverseTree(tree, scene || init(), tree);\n if (autoCamera) {\n const boundingBox = new THREE.Box3();\n boundingBox.setFromObject(scene);\n if (!boundingBox.isEmpty()) {\n let avg = boundingBox.min.clone().add(boundingBox.max).multiplyScalar(0.5);\n let ext = boundingBox.max.clone().sub(boundingBox.min).length();\n camera.position.copy(avg.clone().add(new THREE.Vector3(1, 1, 1).normalize().multiplyScalar(ext)));\n camera.far = ext * 3;\n camera.updateProjectionMatrix();\n // controls.target.copy(avg);\n // controls.update();\n autoCamera = false;\n }\n }\n // buildDomTree(tree, document.querySelector(\".tree\"));\n // animate();\n}\n// function createLayerDom() {\n// document.querySelector(\".layers div\").innerHTML = \"\";\n// datas.forEach(([name, _], index) => {\n// const elem = document.createElement(\"div\");\n// elem.appendChild(document.createTextNode(name));\n// [\"\\u25B3\", \"\\u25BD\", \"\\xD7\"].reverse().forEach((lbl, cmd) => {\n// const btn = document.createElement(\"span\");\n// btn.onclick = (evt) => {\n// evt.stopPropagation();\n// if (cmd === 2) {\n// if (index > 0) {\n// [datas[index], datas[index - 1]] = [datas[index - 1], datas[index]];\n// }\n// } else if (cmd === 1) {\n// if (index < datas.length - 1) {\n// [datas[index], datas[index + 1]] = [datas[index + 1], datas[index]];\n// }\n// } else if (cmd === 0) {\n// datas.splice(index, 1);\n// }\n// composeAndRender();\n// createLayerDom();\n// };\n// btn.appendChild(document.createTextNode(lbl));\n// elem.appendChild(btn);\n// });\n// document.querySelector(\".layers div\").appendChild(elem);\n// });\n// }\n// function addModel(name, m) {\n// datas.push([name, m]);\n// createLayerDom();\n// composeAndRender();\n// }\n// function animate() {\n// requestAnimationFrame(animate);\n// controls.update();\n// renderer.render(scene, camera);\n// }\n// export { composeAndRender, addModel as default };\n\nexport function parse(m, name) {\n datas.push([name, m]);\n composeAndRender();\n return scene;\n}\nexport function clear() {\n scene = undefined;\n datas.length = 0;\n autoCamera = true;\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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 { Loader, Viewer } from \"@inweb/viewer-three\";\nimport { parse, clear } from \"./IFCX/render.js\";\n\nexport class IFCXModelLoader extends Loader {\n public viewer: Viewer;\n\n constructor(viewer: Viewer) {\n super();\n this.viewer = viewer;\n }\n\n override isSupport(file: any): boolean {\n return (\n typeof file === \"object\" &&\n typeof file.type === \"string\" &&\n typeof file.download === \"function\" &&\n /.ifcx$/i.test(file.type)\n );\n }\n\n override async load(model: any): Promise<this> {\n const progress = (progress: number) => {\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file: model });\n };\n\n const arrayBuffer = await model.download(progress, this.abortController.signal);\n if (!this.viewer.scene) return this;\n\n const textDecoder = new TextDecoder();\n const json = JSON.parse(textDecoder.decode(arrayBuffer));\n\n const scene = parse(json);\n clear();\n\n let handle = 0;\n scene.traverse((object) => {\n object.userData = { handle, ...object.userData };\n handle++;\n });\n\n this.viewer.scene.add(scene);\n this.viewer.models.push(scene);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data: scene, file: model });\n\n return this;\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 { FileLoader, Loader, Scene } from \"three\";\nimport { parse, clear } from \"./render.js\";\n\nclass IFCXLoader extends Loader<Scene> {\n override load(\n url: string,\n onLoad: (data: Scene) => void,\n onProgress?: (event: ProgressEvent) => void,\n onError?: (err: unknown) => void\n ) {\n const manager = this.manager;\n\n manager.itemStart(url);\n\n const _onLoad = (scene: Scene) => {\n onLoad(scene);\n manager.itemEnd(url);\n };\n\n const _onError = (e: unknown) => {\n if (onError) onError(e);\n else console.error(e);\n manager.itemError(url);\n manager.itemEnd(url);\n };\n\n const loader = new FileLoader(this.manager);\n\n loader.setPath(this.path);\n loader.setResponseType(\"json\");\n loader.setRequestHeader(this.requestHeader);\n loader.setWithCredentials(this.withCredentials);\n\n loader.load(url, (json) => this.parse(json, _onLoad, _onError), onProgress, onError);\n }\n\n parse(json: any, onLoad: (scene: Scene) => void, onError: (err: unknown) => void) {\n try {\n onLoad(parse(json));\n } catch (e) {\n onError(e);\n } finally {\n clear();\n }\n }\n}\n\nexport { IFCXLoader };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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 { GLTFLoadingManager, GLTFLoadParams, Loader, Viewer } from \"@inweb/viewer-three\";\nimport { IFCXLoader } from \"./IFCX/IFCXLoader\";\n\nexport class IFCXFileLoader extends Loader {\n public viewer: Viewer;\n\n constructor(viewer: Viewer) {\n super();\n this.viewer = viewer;\n }\n\n override isSupport(file: any, format?: string): boolean {\n return (\n (typeof file === \"string\" || file instanceof globalThis.File || file instanceof ArrayBuffer) &&\n /(ifcx)$/i.test(format)\n );\n }\n\n override async load(file: any, format?: string, params?: GLTFLoadParams): Promise<this> {\n const manager = new GLTFLoadingManager(file, params);\n\n const loader = new IFCXLoader(manager);\n loader.setPath(manager.path);\n loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);\n loader.setWithCredentials(params.withCredentials || loader.withCredentials);\n\n const progress = (event: ProgressEvent) => {\n const { lengthComputable, loaded, total } = event;\n const progress = lengthComputable ? loaded / total : 1;\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file });\n };\n\n const scene = await loader.loadAsync(manager.fileURL, progress);\n if (!this.viewer.scene) return this;\n\n let handle = 0;\n scene.traverse((object) => {\n object.userData = { handle, ...object.userData };\n handle++;\n });\n\n this.viewer.scene.add(scene);\n this.viewer.models.push(scene);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data: scene, file });\n\n return this;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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 { loaders } from \"@inweb/viewer-three\";\n\nimport { IFCXModelLoader } from \"./IFCXModelLoader\";\nimport { IFCXFileLoader } from \"./IFCXFileLoader\";\n\nloaders.registerLoader(\"ifcx\", (viewer: any) => new IFCXModelLoader(viewer));\nloaders.registerLoader(\"ifcx-file\", (viewer: any) => new IFCXFileLoader(viewer));\n"],"names":["THREE","Box3","BufferAttribute","BufferGeometry","Color","Group","Line","LineBasicMaterial","Matrix4","Mesh","MeshBasicMaterial","PerspectiveCamera","Scene","Vector3","getChildByName","root","childName","skip","fragments","replace","split","i","shift","start","length","children","f","find","name","reverse","GetNode","node","path","parts","child","get","GetTail","GetHead","join","MakeNode","Map","attributes","ConvertToCompositionNode","inputNodes","compositionNode","inherits","forEach","Object","keys","inheritName","ih","attrName","MMSet","map","key","value","has","push","set","FindRootsOrCycles","nodes","dependencies","dependents","paths","perm","temp","visit","Error","deps","dep","roots","Set","indexOf","add","e","ConvertNodes","input","compositionNodes","CycleError","ExpandFirstRootInInput","ExpandNewNode","values","CreateArtificialRoot","pseudoRoot","ExpandNode","AddDataFromInput","inherit","classNode","subnode","attrID","attr","entries","delete","MMSet2","ToInputNodes","data","ifcxNode","SchemaValidationError","ValidateAttributeValue","desc","schemas","inheritedSchemaID","inheritedSchema","dataType","found","enumRestrictions","options","filter","option","objectRestrictions","hasOwn","Array","isArray","entry","arrayRestrictions","Validate","schemaID","schema","message","LoadIfcxFile","file","checkSchemas","createArtificialRoot","Federate","files","result","header","Prune","Collapse","deleteEmpty","empty","collapsed","TreeNodeToComposedObject","co","childNode","compname","quantityKind","postfix","String","fromCodePoint","compose3","federated","tree","scene","camera","datas","autoCamera","init","window","innerWidth","innerHeight","up","position","lookAt","HasAttr","createMaterialFromParent","parent","reference","material","color","transparent","opacity","materialNode","ref","createCurveFromJson","points","Float32Array","flat","geometry","setAttribute","lineMaterial","multiplyScalar","createMeshFromJson","indices","Uint16Array","setIndex","computeVertexNormals","meshMaterial","traverseTree","parentNode","undefined","elem","matrixAutoUpdate","matrixNode","matrix","transpose","composeAndRender","dataArray","arr","console","error","boundingBox","setFromObject","isEmpty","avg","min","clone","max","ext","sub","copy","normalize","far","updateProjectionMatrix","parse","m","clear","IFCXModelLoader","Loader","constructor","viewer","super","this","isSupport","type","download","test","load","model","progress","emitEvent","arrayBuffer","abortController","signal","textDecoder","TextDecoder","json","JSON","decode","handle","traverse","object","userData","models","syncOptions","syncOverlay","update","IFCXLoader","url","onLoad","onProgress","onError","manager","itemStart","_onLoad","itemEnd","_onError","itemError","loader","FileLoader","setPath","setResponseType","setRequestHeader","requestHeader","setWithCredentials","withCredentials","IFCXFileLoader","format","globalThis","File","ArrayBuffer","params","GLTFLoadingManager","setCrossOrigin","crossOrigin","event","lengthComputable","loaded","total","loadAsync","fileURL","loaders","registerLoader"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"IFCXLoader.module.js","sources":["../../../plugins/loaders/IFCX/render.js","../../../plugins/loaders/IFCX/IFCXLoader.ts","../../../plugins/loaders/IFCXFileLoader.ts","../../../plugins/loaders/IFCXCloudFileLoader.ts","../../../plugins/loaders/IFCXLoader.ts"],"sourcesContent":["///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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\n// Repository: https://github.com/buildingSMART/IFC5-development\n// Original File: docs/viewer/render.mjs\n// Commit SHA-1: 83a7ae862232c90065d1bd03fcd538315e7d2563\n// Commit Date: 20.05.2025 21:00:52\n\n// (C) buildingSMART International\n// published under MIT license\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable prefer-const */\n/* eslint-disable no-useless-catch */\n\nimport {\n Box3,\n BufferAttribute,\n BufferGeometry,\n Color,\n Group,\n Line,\n LineBasicMaterial,\n Matrix4,\n Mesh,\n MeshBasicMaterial,\n PerspectiveCamera,\n Scene,\n Vector3,\n} from \"three\";\n\nconst THREE = {\n Box3,\n BufferAttribute,\n BufferGeometry,\n Color,\n Group,\n Line,\n LineBasicMaterial,\n Matrix4,\n Mesh,\n MeshBasicMaterial,\n PerspectiveCamera,\n Scene,\n Vector3,\n};\n\n// composed-object.ts\nfunction getChildByName(root, childName, skip = 0) {\n let fragments = childName.replace(/^<\\/|^\\/|>$/g, \"\").split(\"/\");\n for (let i = 0; i < skip; ++i) {\n fragments.shift();\n }\n let start = root;\n while (fragments.length && start && start.children) {\n // console.log(start, fragments[0]);\n let f = fragments.shift();\n start = start.children.find((i) => i.name.split(\"/\").reverse()[0] === f);\n }\n if (fragments.length == 0) {\n return start;\n }\n}\n\n// compose-alpha.ts\nfunction GetNode(node, path) {\n if (path === \"\") return node;\n let parts = path.split(\"/\");\n let child = node.children.get(parts[0]);\n if (child) {\n if (parts.length === 1) {\n return child;\n }\n return GetNode(child, GetTail(path));\n } else {\n return null;\n }\n}\nfunction GetHead(path) {\n return path.split(\"/\")[0];\n}\nfunction GetTail(path) {\n let parts = path.split(\"/\");\n parts.shift();\n return parts.join(\"/\");\n}\nfunction MakeNode(node) {\n return {\n node,\n children: /* @__PURE__ */ new Map(),\n attributes: /* @__PURE__ */ new Map(),\n };\n}\nfunction ConvertToCompositionNode(path, inputNodes) {\n let compositionNode = {\n path,\n children: {},\n inherits: {},\n attributes: {},\n };\n inputNodes.forEach((node) => {\n Object.keys(node.children).forEach((childName) => {\n compositionNode.children[childName] = node.children[childName];\n });\n Object.keys(node.inherits).forEach((inheritName) => {\n let ih = node.inherits[inheritName];\n if (ih === null) {\n delete compositionNode.inherits[inheritName];\n } else {\n compositionNode.inherits[inheritName] = ih;\n }\n });\n Object.keys(node.attributes).forEach((attrName) => {\n compositionNode.attributes[attrName] = node.attributes[attrName];\n });\n });\n return compositionNode;\n}\nfunction MMSet(map, key, value) {\n if (map.has(key)) {\n map.get(key)?.push(value);\n } else {\n map.set(key, [value]);\n }\n}\nfunction FindRootsOrCycles(nodes) {\n let dependencies = /* @__PURE__ */ new Map();\n let dependents = /* @__PURE__ */ new Map();\n nodes.forEach((node, path) => {\n Object.keys(node.inherits).forEach((inheritName) => {\n MMSet(dependencies, path, node.inherits[inheritName]);\n MMSet(dependents, node.inherits[inheritName], path);\n });\n Object.keys(node.children).forEach((childName) => {\n MMSet(dependencies, path, node.children[childName]);\n MMSet(dependents, node.children[childName], path);\n });\n });\n let paths = [...nodes.keys()];\n let perm = {};\n let temp = {};\n function visit(path) {\n if (perm[path]) return;\n if (temp[path]) throw new Error(`CYCLE!`);\n temp[path] = true;\n let deps = dependencies.get(path);\n if (deps) {\n deps.forEach((dep) => visit(dep));\n }\n perm[path] = true;\n }\n let roots = /* @__PURE__ */ new Set();\n try {\n paths.forEach((path) => {\n if (!dependents.has(path) && path.indexOf(\"/\") === -1) {\n roots.add(path);\n }\n visit(path);\n });\n } catch (e) {\n return null;\n }\n return roots;\n}\nfunction ConvertNodes(input) {\n let compositionNodes = /* @__PURE__ */ new Map();\n for (let [path, inputNodes] of input) {\n compositionNodes.set(path, ConvertToCompositionNode(path, inputNodes));\n }\n return compositionNodes;\n}\nvar CycleError = class extends Error {};\nfunction ExpandFirstRootInInput(nodes) {\n let roots = FindRootsOrCycles(nodes);\n if (!roots) {\n throw new CycleError();\n }\n return ExpandNewNode([...roots.values()][0], nodes);\n}\nfunction CreateArtificialRoot(nodes) {\n let roots = FindRootsOrCycles(nodes);\n if (!roots) {\n throw new CycleError();\n }\n let pseudoRoot = {\n node: \"\",\n attributes: /* @__PURE__ */ new Map(),\n children: /* @__PURE__ */ new Map(),\n };\n roots.forEach((root) => {\n pseudoRoot.children.set(root, ExpandNewNode(root, nodes));\n });\n return pseudoRoot;\n}\nfunction ExpandNewNode(node, nodes) {\n return ExpandNode(node, MakeNode(node), nodes);\n}\nfunction ExpandNode(path, node, nodes) {\n let input = nodes.get(path);\n if (input) {\n AddDataFromInput(input, node, nodes);\n }\n node.children.forEach((child, name) => {\n ExpandNode(`${path}/${name}`, child, nodes);\n });\n return node;\n}\nfunction AddDataFromInput(input, node, nodes) {\n Object.values(input.inherits).forEach((inherit) => {\n let classNode = ExpandNewNode(GetHead(inherit), nodes);\n let subnode = GetNode(classNode, GetTail(inherit));\n if (!subnode) throw new Error(`Unknown node ${inherit}`);\n subnode.children.forEach((child, childName) => {\n node.children.set(childName, child);\n });\n for (let [attrID, attr] of subnode.attributes) {\n node.attributes.set(attrID, attr);\n }\n });\n Object.entries(input.children).forEach(([childName, child]) => {\n if (child !== null) {\n let classNode = ExpandNewNode(GetHead(child), nodes);\n let subnode = GetNode(classNode, GetTail(child));\n if (!subnode) throw new Error(`Unknown node ${child}`);\n node.children.set(childName, subnode);\n } else {\n node.children.delete(childName);\n }\n });\n Object.entries(input.attributes).forEach(([attrID, attr]) => {\n node.attributes.set(attrID, attr);\n });\n}\n\n// workflow-alpha.ts\nfunction MMSet2(map, key, value) {\n if (map.has(key)) {\n map.get(key)?.push(value);\n } else {\n map.set(key, [value]);\n }\n}\nfunction ToInputNodes(data) {\n let inputNodes = /* @__PURE__ */ new Map();\n data.forEach((ifcxNode) => {\n let node = {\n path: ifcxNode.path,\n children: ifcxNode.children ? ifcxNode.children : {},\n inherits: ifcxNode.inherits ? ifcxNode.inherits : {},\n attributes: ifcxNode.attributes ? ifcxNode.attributes : {},\n };\n MMSet2(inputNodes, node.path, node);\n });\n return inputNodes;\n}\nvar SchemaValidationError = class extends Error {};\nfunction ValidateAttributeValue(desc, value, path, schemas) {\n if (desc.inherits) {\n desc.inherits.forEach((inheritedSchemaID) => {\n let inheritedSchema = schemas[inheritedSchemaID];\n if (!inheritedSchema) {\n throw new SchemaValidationError(`Unknown inherited schema id \"${desc.inherits}\"`);\n }\n ValidateAttributeValue(inheritedSchema.value, value, path, schemas);\n });\n }\n if (desc.dataType === \"Boolean\") {\n if (typeof value !== \"boolean\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type boolean`);\n }\n } else if (desc.dataType === \"String\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type string`);\n }\n } else if (desc.dataType === \"DateTime\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type date`);\n }\n } else if (desc.dataType === \"Enum\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type string`);\n }\n let found = desc.enumRestrictions.options.filter((option) => option === value).length === 1;\n if (!found) {\n throw new SchemaValidationError(`Expected \"${value}\" to be one of [${desc.enumRestrictions.options.join(\",\")}]`);\n }\n } else if (desc.dataType === \"Integer\") {\n if (typeof value !== \"number\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type int`);\n }\n } else if (desc.dataType === \"Real\") {\n if (typeof value !== \"number\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type real`);\n }\n } else if (desc.dataType === \"Relation\") {\n if (typeof value !== \"string\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type string`);\n }\n } else if (desc.dataType === \"Object\") {\n if (typeof value !== \"object\") {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type object`);\n }\n if (desc.objectRestrictions) {\n Object.keys(desc.objectRestrictions.values).forEach((key) => {\n if (!Object.hasOwn(value, key)) {\n throw new SchemaValidationError(`Expected \"${value}\" to have key ${key}`);\n }\n ValidateAttributeValue(desc.objectRestrictions.values[key], value[key], path + \".\" + key, schemas);\n });\n }\n } else if (desc.dataType === \"Array\") {\n if (!Array.isArray(value)) {\n throw new SchemaValidationError(`Expected \"${value}\" to be of type array`);\n }\n value.forEach((entry) => {\n ValidateAttributeValue(desc.arrayRestrictions.value, entry, path + \".<array>.\", schemas);\n });\n } else {\n throw new SchemaValidationError(`Unexpected datatype ${desc.dataType}`);\n }\n}\nfunction Validate(schemas, inputNodes) {\n inputNodes.forEach((node) => {\n Object.keys(node.attributes).forEach((schemaID) => {\n if (!schemas[schemaID]) {\n throw new SchemaValidationError(`Missing schema \"${schemaID}\" referenced by [\"${node.path}\"].attributes`);\n }\n let schema = schemas[schemaID];\n let value = node.attributes[schemaID];\n try {\n ValidateAttributeValue(schema.value, value, \"\", schemas);\n } catch (e) {\n if (e instanceof SchemaValidationError) {\n throw new SchemaValidationError(`Error validating [\"${node.path}\"].attributes[\"${schemaID}\"]: ${e.message}`);\n } else {\n throw e;\n }\n }\n });\n });\n}\nfunction LoadIfcxFile(file, checkSchemas = true, createArtificialRoot = false) {\n let inputNodes = ToInputNodes(file.data);\n let compositionNodes = ConvertNodes(inputNodes);\n try {\n if (checkSchemas) {\n Validate(file.schemas, compositionNodes);\n }\n } catch (e) {\n throw e;\n }\n if (createArtificialRoot) {\n return CreateArtificialRoot(compositionNodes);\n } else {\n return ExpandFirstRootInInput(compositionNodes);\n }\n}\nfunction Federate(files) {\n let result = {\n header: files[0].header,\n schemas: {},\n data: [],\n };\n files.forEach((file) => {\n Object.keys(file.schemas).forEach((schemaID) => (result.schemas[schemaID] = file.schemas[schemaID]));\n });\n files.forEach((file) => {\n file.data.forEach((node) => result.data.push(node));\n });\n return Prune(result);\n}\nfunction Collapse(nodes, deleteEmpty = false) {\n let result = {\n path: nodes[0].path,\n children: {},\n inherits: {},\n attributes: {},\n };\n nodes.forEach((node) => {\n Object.keys(node.children).forEach((name) => {\n result.children[name] = node.children[name];\n });\n Object.keys(node.inherits).forEach((name) => {\n result.inherits[name] = node.inherits[name];\n });\n Object.keys(node.attributes).forEach((name) => {\n result.attributes[name] = node.attributes[name];\n });\n });\n if (deleteEmpty) {\n let empty = true;\n Object.keys(result.children).forEach((name) => {\n if (result.children[name] !== null) empty = false;\n });\n Object.keys(result.inherits).forEach((name) => {\n if (result.inherits[name] !== null) empty = false;\n });\n Object.keys(result.attributes).forEach((name) => {\n if (result.attributes[name] !== null) empty = false;\n });\n if (empty) return null;\n }\n return result;\n}\nfunction Prune(file, deleteEmpty = false) {\n let result = {\n header: file.header,\n schemas: file.schemas,\n data: [],\n };\n let inputNodes = ToInputNodes(file.data);\n inputNodes.forEach((nodes) => {\n let collapsed = Collapse(nodes, deleteEmpty);\n if (collapsed)\n result.data.push({\n path: collapsed.path,\n children: collapsed.children,\n inherits: collapsed.inherits,\n attributes: collapsed.attributes,\n });\n });\n return result;\n}\n\n// compose-flattened.ts\nfunction TreeNodeToComposedObject(path, node, schemas) {\n let co = {\n name: path,\n attributes: {},\n children: [],\n };\n node.children.forEach((childNode, childName) => {\n co.children?.push(TreeNodeToComposedObject(`${path}/${childName}`, childNode, schemas));\n });\n node.attributes.forEach((attr, attrName) => {\n if (attr && typeof attr === \"object\" && !Array.isArray(attr)) {\n Object.keys(attr).forEach((compname) => {\n co.attributes[`${attrName}::${compname}`] = attr[compname];\n });\n } else {\n let schema = schemas[attrName];\n if (schema && schema.value.quantityKind) {\n let postfix = \"\";\n let quantityKind = schema.value.quantityKind;\n if (quantityKind === \"Length\") {\n postfix = \"m\";\n } else if (quantityKind === \"Volume\") {\n postfix = \"m\" + String.fromCodePoint(179);\n }\n co.attributes[attrName] = `${attr} ${postfix}`;\n } else {\n co.attributes[attrName] = attr;\n }\n }\n });\n if (Object.keys(co.attributes).length === 0) delete co.attributes;\n return co;\n}\nfunction compose3(files) {\n let federated = Federate(files);\n let tree = LoadIfcxFile(federated, true, true);\n return TreeNodeToComposedObject(\"\", tree, federated.schemas);\n}\n\n// render.ts\n// var controls;\n// var renderer;\nvar scene;\nvar camera;\nvar datas = [];\nvar autoCamera = true;\n// var THREE = window[\"THREE\"];\nfunction init() {\n scene = new THREE.Scene();\n camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 100);\n camera.up.set(0, 0, 1);\n camera.position.set(50, 50, 50);\n camera.lookAt(0, 0, 0);\n // const nd = document.querySelector(\".viewport\");\n // renderer = new THREE.WebGLRenderer({\n // alpha: true,\n // logarithmicDepthBuffer: true,\n // });\n // renderer.setSize(nd.offsetWidth, nd.offsetHeight);\n // controls = new THREE.OrbitControls(camera, renderer.domElement);\n // controls.enableDamping = true;\n // controls.dampingFactor = 0.25;\n // nd.appendChild(renderer.domElement);\n scene.add(camera);\n return scene;\n}\nfunction HasAttr(node, attrName) {\n if (!node || !node.attributes) return false;\n return !!node.attributes[attrName];\n}\nfunction FindChildWithAttr(node, attrName) {\n if (!node || !node.children) return void 0;\n for (let i = 0; i < node.children.length; i++) {\n if (HasAttr(node.children[i], attrName)) {\n return node.children[i];\n }\n }\n return void 0;\n}\nfunction createMaterialFromParent(parent, root) {\n let reference = parent.attributes[\"usd::usdshade::materialbindingapi::material::binding\"];\n let material = {\n color: new THREE.Color(0.6, 0.6, 0.6),\n transparent: false,\n opacity: 1,\n };\n if (reference) {\n const materialNode = getChildByName(root, reference.ref);\n if (materialNode) {\n let color = materialNode?.attributes[\"bsi::presentation::diffuseColor\"];\n material.color = new THREE.Color(...color);\n if (materialNode?.attributes[\"bsi::presentation::opacity\"]) {\n material.transparent = true;\n material.opacity = materialNode.attributes[\"bsi::presentation::opacity\"];\n }\n }\n }\n return material;\n}\nfunction createCurveFromJson(node, parent, root) {\n let points = new Float32Array(node.attributes[\"usd::usdgeom::basiscurves::points\"].flat());\n const geometry = new THREE.BufferGeometry();\n geometry.setAttribute(\"position\", new THREE.BufferAttribute(points, 3));\n const material = createMaterialFromParent(parent, root);\n let lineMaterial = new THREE.LineBasicMaterial({ ...material });\n lineMaterial.color.multiplyScalar(0.8);\n return new THREE.Line(geometry, lineMaterial);\n}\nfunction createMeshFromJson(node, parent, root) {\n let points = new Float32Array(node.attributes[\"usd::usdgeom::mesh::points\"].flat());\n let indices = new Uint16Array(node.attributes[\"usd::usdgeom::mesh::faceVertexIndices\"]);\n const geometry = new THREE.BufferGeometry();\n geometry.setAttribute(\"position\", new THREE.BufferAttribute(points, 3));\n geometry.setIndex(new THREE.BufferAttribute(indices, 1));\n geometry.computeVertexNormals();\n const material = createMaterialFromParent(parent, root);\n let meshMaterial = new THREE.MeshBasicMaterial({ ...material });\n return new THREE.Mesh(geometry, meshMaterial);\n}\nfunction traverseTree(node, parent, root, parentNode = void 0) {\n let elem = new THREE.Group();\n if (HasAttr(node, \"usd::usdgeom::visibility::visibility\")) {\n if (node.attributes[\"usd::usdgeom::visibility::visibility\"] === \"invisible\") {\n return;\n }\n } else if (HasAttr(node, \"usd::usdgeom::mesh::points\")) {\n elem = createMeshFromJson(node, parentNode, root);\n } else if (HasAttr(node, \"usd::usdgeom::basiscurves::points\")) {\n elem = createCurveFromJson(node, parentNode, root);\n }\n parent.add(elem);\n if (node !== root) {\n elem.matrixAutoUpdate = false;\n let matrixNode =\n node.attributes && node.attributes[\"usd::xformop::transform\"]\n ? node.attributes[\"usd::xformop::transform\"].flat()\n : null;\n if (matrixNode) {\n let matrix = new THREE.Matrix4();\n matrix.set(...matrixNode);\n matrix.transpose();\n elem.matrix = matrix;\n }\n }\n (node.children || []).forEach((child) => traverseTree(child, elem || parent, root, node));\n}\n// function encodeHtmlEntities(str) {\n// const div = document.createElement(\"div\");\n// div.textContent = str;\n// return div.innerHTML;\n// }\n// var icons = {\n// \"usd::usdgeom::mesh::points\": \"deployed_code\",\n// \"usd::usdgeom::basiscurves::points\": \"line_curve\",\n// \"usd::usdshade::material::outputs::surface.connect\": \"line_style\",\n// };\n// function buildDomTree(prim, node) {\n// const elem = document.createElement(\"div\");\n// let span;\n// elem.appendChild(document.createTextNode(prim.name ? prim.name.split(\"/\").reverse()[0] : \"root\"));\n// elem.appendChild((span = document.createElement(\"span\")));\n// Object.entries(icons).forEach(([k, v]) => (span.innerText += (prim.attributes || {})[k] ? v : \" \"));\n// span.className = \"material-symbols-outlined\";\n// elem.onclick = (evt) => {\n// let rows = [[\"name\", prim.name]]\n// .concat(Object.entries(prim.attributes))\n// .map(\n// ([k, v]) =>\n// `<tr><td>${encodeHtmlEntities(k)}</td><td>${encodeHtmlEntities(typeof v === \"object\" ? JSON.stringify(v) : v)}</td>`\n// )\n// .join(\"\");\n// document.querySelector(\".attributes .table\").innerHTML = `<table border=\"0\">${rows}</table>`;\n// evt.stopPropagation();\n// };\n// node.appendChild(elem);\n// (prim.children || []).forEach((p) => buildDomTree(p, elem));\n// }\nfunction composeAndRender() {\n if (scene) {\n scene.children = [];\n }\n // document.querySelector(\".tree\").innerHTML = \"\";\n if (datas.length === 0) {\n return;\n }\n let tree = null;\n let dataArray = datas.map((arr) => arr[1]);\n tree = compose3(dataArray);\n if (!tree) {\n console.error(\"No result from composition\");\n return;\n }\n traverseTree(tree, scene || init(), tree);\n if (autoCamera) {\n const boundingBox = new THREE.Box3();\n boundingBox.setFromObject(scene);\n if (!boundingBox.isEmpty()) {\n let avg = boundingBox.min.clone().add(boundingBox.max).multiplyScalar(0.5);\n let ext = boundingBox.max.clone().sub(boundingBox.min).length();\n camera.position.copy(avg.clone().add(new THREE.Vector3(1, 1, 1).normalize().multiplyScalar(ext)));\n camera.far = ext * 3;\n camera.updateProjectionMatrix();\n // controls.target.copy(avg);\n // controls.update();\n autoCamera = false;\n }\n }\n // buildDomTree(tree, document.querySelector(\".tree\"));\n // animate();\n}\n// function createLayerDom() {\n// document.querySelector(\".layers div\").innerHTML = \"\";\n// datas.forEach(([name, _], index) => {\n// const elem = document.createElement(\"div\");\n// elem.appendChild(document.createTextNode(name));\n// [\"\\u25B3\", \"\\u25BD\", \"\\xD7\"].reverse().forEach((lbl, cmd) => {\n// const btn = document.createElement(\"span\");\n// btn.onclick = (evt) => {\n// evt.stopPropagation();\n// if (cmd === 2) {\n// if (index > 0) {\n// [datas[index], datas[index - 1]] = [datas[index - 1], datas[index]];\n// }\n// } else if (cmd === 1) {\n// if (index < datas.length - 1) {\n// [datas[index], datas[index + 1]] = [datas[index + 1], datas[index]];\n// }\n// } else if (cmd === 0) {\n// datas.splice(index, 1);\n// }\n// composeAndRender();\n// createLayerDom();\n// };\n// btn.appendChild(document.createTextNode(lbl));\n// elem.appendChild(btn);\n// });\n// document.querySelector(\".layers div\").appendChild(elem);\n// });\n// }\n// function addModel(name, m) {\n// datas.push([name, m]);\n// createLayerDom();\n// composeAndRender();\n// }\n// function animate() {\n// requestAnimationFrame(animate);\n// controls.update();\n// renderer.render(scene, camera);\n// }\n// export { composeAndRender, addModel as default };\n\nexport function parse(m, name) {\n datas.push([name, m]);\n composeAndRender();\n return scene;\n}\nexport function clear() {\n scene = undefined;\n datas.length = 0;\n autoCamera = true;\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 { FileLoader, Loader, Scene } from \"three\";\nimport { parse, clear } from \"./render.js\";\n\nclass IFCXLoader extends Loader<Scene> {\n override load(\n url: string,\n onLoad: (data: Scene) => void,\n onProgress?: (event: ProgressEvent) => void,\n onError?: (err: unknown) => void\n ) {\n const manager = this.manager;\n\n manager.itemStart(url);\n\n const _onLoad = (scene: Scene) => {\n onLoad(scene);\n manager.itemEnd(url);\n };\n\n const _onError = (e: unknown) => {\n if (onError) onError(e);\n else console.error(e);\n manager.itemError(url);\n manager.itemEnd(url);\n };\n\n const loader = new FileLoader(this.manager);\n\n loader.setPath(this.path);\n loader.setResponseType(\"json\");\n loader.setRequestHeader(this.requestHeader);\n loader.setWithCredentials(this.withCredentials);\n\n loader.load(url, (json) => this.parse(json, _onLoad, _onError), onProgress, onError);\n }\n\n parse(json: any, onLoad: (scene: Scene) => void, onError: (err: unknown) => void) {\n try {\n onLoad(parse(json));\n } catch (e) {\n onError(e);\n } finally {\n clear();\n }\n }\n}\n\nexport { IFCXLoader };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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 { GLTFLoadingManager, GLTFLoadParams, Loader, Viewer } from \"@inweb/viewer-three\";\nimport { IFCXLoader } from \"./IFCX/IFCXLoader\";\n\nexport class IFCXFileLoader extends Loader {\n public viewer: Viewer;\n\n constructor(viewer: Viewer) {\n super();\n this.viewer = viewer;\n }\n\n override isSupport(file: any, format?: string): boolean {\n return (\n (typeof file === \"string\" || file instanceof globalThis.File || file instanceof ArrayBuffer) &&\n /(ifcx)$/i.test(format)\n );\n }\n\n override async load(file: any, format?: string, params?: GLTFLoadParams): Promise<this> {\n const manager = new GLTFLoadingManager(file, params);\n\n const loader = new IFCXLoader(manager);\n loader.setPath(manager.path);\n loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);\n loader.setWithCredentials(params.withCredentials || loader.withCredentials);\n\n const progress = (event: ProgressEvent) => {\n const { lengthComputable, loaded, total } = event;\n const progress = lengthComputable ? loaded / total : 1;\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file });\n };\n\n const scene = await loader.loadAsync(manager.fileURL, progress);\n if (!this.viewer.scene) return this;\n\n let handle = 0;\n scene.traverse((object) => {\n object.userData = { handle, ...object.userData };\n handle++;\n });\n\n this.viewer.scene.add(scene);\n this.viewer.models.push(scene);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data: scene, file });\n\n return this;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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 { Loader, Viewer } from \"@inweb/viewer-three\";\nimport { parse, clear } from \"./IFCX/render.js\";\n\nexport class IFCXCloudFileLoader extends Loader {\n public viewer: Viewer;\n\n constructor(viewer: Viewer) {\n super();\n this.viewer = viewer;\n }\n\n override isSupport(file: any): boolean {\n return (\n typeof file === \"object\" &&\n typeof file.type === \"string\" &&\n typeof file.download === \"function\" &&\n /.ifcx$/i.test(file.type)\n );\n }\n\n override async load(file: any): Promise<this> {\n const progress = (progress: number) => {\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file });\n };\n\n const arrayBuffer = await file.download(progress, this.abortController.signal);\n if (!this.viewer.scene) return this;\n\n const textDecoder = new TextDecoder();\n const json = JSON.parse(textDecoder.decode(arrayBuffer));\n\n const scene = parse(json);\n clear();\n\n let handle = 0;\n scene.traverse((object: any) => {\n object.userData = { handle, ...object.userData };\n handle++;\n });\n\n this.viewer.scene.add(scene);\n this.viewer.models.push(scene);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data: scene, file });\n\n return this;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, 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-2025 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 { loaders } from \"@inweb/viewer-three\";\n\nimport { IFCXFileLoader } from \"./IFCXFileLoader\";\nimport { IFCXCloudFileLoader } from \"./IFCXCloudFileLoader\";\n\nloaders.registerLoader(\"ifcx-file\", (viewer: any) => new IFCXFileLoader(viewer));\nloaders.registerLoader(\"ifcx-cloud-file\", (viewer: any) => new IFCXCloudFileLoader(viewer));\n"],"names":["THREE","Box3","BufferAttribute","BufferGeometry","Color","Group","Line","LineBasicMaterial","Matrix4","Mesh","MeshBasicMaterial","PerspectiveCamera","Scene","Vector3","getChildByName","root","childName","skip","fragments","replace","split","i","shift","start","length","children","f","find","name","reverse","GetNode","node","path","parts","child","get","GetTail","GetHead","join","MakeNode","Map","attributes","ConvertToCompositionNode","inputNodes","compositionNode","inherits","forEach","Object","keys","inheritName","ih","attrName","MMSet","map","key","value","has","push","set","FindRootsOrCycles","nodes","dependencies","dependents","paths","perm","temp","visit","Error","deps","dep","roots","Set","indexOf","add","e","ConvertNodes","input","compositionNodes","CycleError","ExpandFirstRootInInput","ExpandNewNode","values","CreateArtificialRoot","pseudoRoot","ExpandNode","AddDataFromInput","inherit","classNode","subnode","attrID","attr","entries","delete","MMSet2","ToInputNodes","data","ifcxNode","SchemaValidationError","ValidateAttributeValue","desc","schemas","inheritedSchemaID","inheritedSchema","dataType","found","enumRestrictions","options","filter","option","objectRestrictions","hasOwn","Array","isArray","entry","arrayRestrictions","Validate","schemaID","schema","message","LoadIfcxFile","file","checkSchemas","createArtificialRoot","Federate","files","result","header","Prune","Collapse","deleteEmpty","empty","collapsed","TreeNodeToComposedObject","co","childNode","compname","quantityKind","postfix","String","fromCodePoint","compose3","federated","tree","scene","camera","datas","autoCamera","init","window","innerWidth","innerHeight","up","position","lookAt","HasAttr","createMaterialFromParent","parent","reference","material","color","transparent","opacity","materialNode","ref","createCurveFromJson","points","Float32Array","flat","geometry","setAttribute","lineMaterial","multiplyScalar","createMeshFromJson","indices","Uint16Array","setIndex","computeVertexNormals","meshMaterial","traverseTree","parentNode","undefined","elem","matrixAutoUpdate","matrixNode","matrix","transpose","composeAndRender","dataArray","arr","console","error","boundingBox","setFromObject","isEmpty","avg","min","clone","max","ext","sub","copy","normalize","far","updateProjectionMatrix","parse","m","clear","IFCXLoader","Loader","load","url","onLoad","onProgress","onError","manager","this","itemStart","_onLoad","itemEnd","_onError","itemError","loader","FileLoader","setPath","setResponseType","setRequestHeader","requestHeader","setWithCredentials","withCredentials","json","IFCXFileLoader","constructor","viewer","super","isSupport","format","globalThis","File","ArrayBuffer","test","params","GLTFLoadingManager","setCrossOrigin","crossOrigin","progress","event","lengthComputable","loaded","total","emitEvent","type","loadAsync","fileURL","handle","traverse","object","userData","models","syncOptions","syncOverlay","update","IFCXCloudFileLoader","download","arrayBuffer","abortController","signal","textDecoder","TextDecoder","JSON","decode","loaders","registerLoader"],"mappings":"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"}
|
package/dist/viewer-three.js
CHANGED
|
@@ -66722,28 +66722,27 @@ void main() {
|
|
|
66722
66722
|
// By use of this software, its documentation or related materials, you
|
|
66723
66723
|
// acknowledge and accept the above terms.
|
|
66724
66724
|
///////////////////////////////////////////////////////////////////////////////
|
|
66725
|
-
class
|
|
66725
|
+
class GLTFFileLoader extends Loader$1 {
|
|
66726
66726
|
constructor(viewer) {
|
|
66727
66727
|
super();
|
|
66728
66728
|
this.viewer = viewer;
|
|
66729
66729
|
}
|
|
66730
|
-
isSupport(
|
|
66731
|
-
return (typeof
|
|
66732
|
-
|
|
66733
|
-
typeof model.downloadResource === "function" &&
|
|
66734
|
-
/.gltf$/i.test(model.database));
|
|
66730
|
+
isSupport(file, format) {
|
|
66731
|
+
return ((typeof file === "string" || file instanceof globalThis.File || file instanceof ArrayBuffer) &&
|
|
66732
|
+
/(gltf|glb)$/i.test(format));
|
|
66735
66733
|
}
|
|
66736
|
-
async load(
|
|
66737
|
-
const
|
|
66738
|
-
const manager = new GLTFLoadingManager(url);
|
|
66734
|
+
async load(file, format, params) {
|
|
66735
|
+
const manager = new GLTFLoadingManager(file, params);
|
|
66739
66736
|
const loader = new GLTFLoader(manager);
|
|
66740
|
-
loader.
|
|
66737
|
+
loader.setPath(manager.path);
|
|
66738
|
+
loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);
|
|
66739
|
+
loader.setWithCredentials(params.withCredentials || loader.withCredentials);
|
|
66741
66740
|
const progress = (event) => {
|
|
66742
66741
|
const { lengthComputable, loaded, total } = event;
|
|
66743
66742
|
const progress = lengthComputable ? loaded / total : 1;
|
|
66744
|
-
this.viewer.emitEvent({ type: "geometryprogress", data: progress, file
|
|
66743
|
+
this.viewer.emitEvent({ type: "geometryprogress", data: progress, file });
|
|
66745
66744
|
};
|
|
66746
|
-
const gltf = await loader.loadAsync(
|
|
66745
|
+
const gltf = await loader.loadAsync(manager.fileURL, progress);
|
|
66747
66746
|
if (!this.viewer.scene)
|
|
66748
66747
|
return this;
|
|
66749
66748
|
this.viewer.scene.add(gltf.scene);
|
|
@@ -66751,7 +66750,7 @@ void main() {
|
|
|
66751
66750
|
this.viewer.syncOptions();
|
|
66752
66751
|
this.viewer.syncOverlay();
|
|
66753
66752
|
this.viewer.update();
|
|
66754
|
-
this.viewer.emitEvent({ type: "databasechunk", data: gltf.scene, file
|
|
66753
|
+
this.viewer.emitEvent({ type: "databasechunk", data: gltf.scene, file });
|
|
66755
66754
|
return this;
|
|
66756
66755
|
}
|
|
66757
66756
|
}
|
|
@@ -66778,27 +66777,28 @@ void main() {
|
|
|
66778
66777
|
// By use of this software, its documentation or related materials, you
|
|
66779
66778
|
// acknowledge and accept the above terms.
|
|
66780
66779
|
///////////////////////////////////////////////////////////////////////////////
|
|
66781
|
-
class
|
|
66780
|
+
class GLTFCloudModelLoader extends Loader$1 {
|
|
66782
66781
|
constructor(viewer) {
|
|
66783
66782
|
super();
|
|
66784
66783
|
this.viewer = viewer;
|
|
66785
66784
|
}
|
|
66786
|
-
isSupport(
|
|
66787
|
-
return (
|
|
66788
|
-
|
|
66785
|
+
isSupport(model) {
|
|
66786
|
+
return (typeof model === "object" &&
|
|
66787
|
+
typeof model.database === "string" &&
|
|
66788
|
+
typeof model.downloadResource === "function" &&
|
|
66789
|
+
/.gltf$/i.test(model.database));
|
|
66789
66790
|
}
|
|
66790
|
-
async load(
|
|
66791
|
-
const
|
|
66791
|
+
async load(model) {
|
|
66792
|
+
const url = `${model.httpClient.serverUrl}${model.path}/${model.database}`;
|
|
66793
|
+
const manager = new GLTFLoadingManager(url);
|
|
66792
66794
|
const loader = new GLTFLoader(manager);
|
|
66793
|
-
loader.
|
|
66794
|
-
loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);
|
|
66795
|
-
loader.setWithCredentials(params.withCredentials || loader.withCredentials);
|
|
66795
|
+
loader.setRequestHeader(model.httpClient.headers);
|
|
66796
66796
|
const progress = (event) => {
|
|
66797
66797
|
const { lengthComputable, loaded, total } = event;
|
|
66798
66798
|
const progress = lengthComputable ? loaded / total : 1;
|
|
66799
|
-
this.viewer.emitEvent({ type: "geometryprogress", data: progress, file:
|
|
66799
|
+
this.viewer.emitEvent({ type: "geometryprogress", data: progress, file: model.file, model });
|
|
66800
66800
|
};
|
|
66801
|
-
const gltf = await loader.loadAsync(
|
|
66801
|
+
const gltf = await loader.loadAsync(url, progress);
|
|
66802
66802
|
if (!this.viewer.scene)
|
|
66803
66803
|
return this;
|
|
66804
66804
|
this.viewer.scene.add(gltf.scene);
|
|
@@ -66806,7 +66806,7 @@ void main() {
|
|
|
66806
66806
|
this.viewer.syncOptions();
|
|
66807
66807
|
this.viewer.syncOverlay();
|
|
66808
66808
|
this.viewer.update();
|
|
66809
|
-
this.viewer.emitEvent({ type: "databasechunk", data: gltf.scene, file:
|
|
66809
|
+
this.viewer.emitEvent({ type: "databasechunk", data: gltf.scene, file: model.file, model });
|
|
66810
66810
|
return this;
|
|
66811
66811
|
}
|
|
66812
66812
|
}
|
|
@@ -66900,8 +66900,8 @@ void main() {
|
|
|
66900
66900
|
*/
|
|
66901
66901
|
const loaders = loadersRegistry("threejs");
|
|
66902
66902
|
// build-in loaders
|
|
66903
|
-
loaders.registerLoader("gltf", (viewer) => new GLTFModelLoader(viewer));
|
|
66904
66903
|
loaders.registerLoader("gltf-file", (viewer) => new GLTFFileLoader(viewer));
|
|
66904
|
+
loaders.registerLoader("gltf-cloud-model", (viewer) => new GLTFCloudModelLoader(viewer));
|
|
66905
66905
|
|
|
66906
66906
|
class EventEmitter2 {
|
|
66907
66907
|
constructor() {
|
|
@@ -81417,12 +81417,12 @@ void main() {
|
|
|
81417
81417
|
}
|
|
81418
81418
|
dispose() {
|
|
81419
81419
|
this.cancel();
|
|
81420
|
+
this.clear();
|
|
81420
81421
|
this.emitEvent({ type: "dispose" });
|
|
81422
|
+
this.removeAllListeners();
|
|
81423
|
+
this.setActiveDragger();
|
|
81421
81424
|
this._components.forEach((component) => component.dispose());
|
|
81422
81425
|
this._components = [];
|
|
81423
|
-
this.setActiveDragger();
|
|
81424
|
-
this.removeAllListeners();
|
|
81425
|
-
this.clear();
|
|
81426
81426
|
this._markup.dispose();
|
|
81427
81427
|
if (this.canvas) {
|
|
81428
81428
|
this.canvasEvents.forEach((x) => this.canvas.removeEventListener(x, this.canvaseventlistener));
|
|
@@ -81430,10 +81430,10 @@ void main() {
|
|
|
81430
81430
|
}
|
|
81431
81431
|
if (this.renderer)
|
|
81432
81432
|
this.renderer.dispose();
|
|
81433
|
+
this.helpers = undefined;
|
|
81434
|
+
this.scene = undefined;
|
|
81433
81435
|
this.renderer = undefined;
|
|
81434
81436
|
this.camera = undefined;
|
|
81435
|
-
this.scene = undefined;
|
|
81436
|
-
this.helpers = undefined;
|
|
81437
81437
|
return this;
|
|
81438
81438
|
}
|
|
81439
81439
|
isInitialized() {
|