gs-bim-air 2.0.0-beta.16 → 2.0.0-beta.17
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/README.md +4 -0
- package/lib/BimAir.common-report.html +2 -2
- package/lib/BimAir.common.js +2 -2
- package/lib/BimAir.css +129 -129
- package/lib/BimAir.umd-report.html +2 -2
- package/lib/BimAir.umd.js +2 -2
- package/lib/BimAir.umd.min-report.html +2 -2
- package/lib/BimAir.umd.min.js +2 -2
- package/lib/undefined.gzundefined +0 -0
- package/package.json +1 -1
package/lib/BimAir.umd.js
CHANGED
|
@@ -3794,7 +3794,7 @@ eval("var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;!(__WEBPAC
|
|
|
3794
3794
|
\**************************************************************/
|
|
3795
3795
|
/***/ (function(module, exports, __webpack_require__) {
|
|
3796
3796
|
|
|
3797
|
-
eval("var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;__webpack_require__(/*! core-js/modules/es.function.name.js */ \"./node_modules/core-js/modules/es.function.name.js\");\n__webpack_require__(/*! core-js/modules/es.array.push.js */ \"./node_modules/core-js/modules/es.array.push.js\");\n__webpack_require__(/*! core-js/modules/es.array.iterator.js */ \"./node_modules/core-js/modules/es.array.iterator.js\");\n__webpack_require__(/*! core-js/modules/es.array-buffer.slice.js */ \"./node_modules/core-js/modules/es.array-buffer.slice.js\");\n__webpack_require__(/*! core-js/modules/es.object.to-string.js */ \"./node_modules/core-js/modules/es.object.to-string.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.float32-array.js */ \"./node_modules/core-js/modules/es.typed-array.float32-array.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.at.js */ \"./node_modules/core-js/modules/es.typed-array.at.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.copy-within.js */ \"./node_modules/core-js/modules/es.typed-array.copy-within.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.every.js */ \"./node_modules/core-js/modules/es.typed-array.every.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.fill.js */ \"./node_modules/core-js/modules/es.typed-array.fill.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.filter.js */ \"./node_modules/core-js/modules/es.typed-array.filter.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find.js */ \"./node_modules/core-js/modules/es.typed-array.find.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find-index.js */ \"./node_modules/core-js/modules/es.typed-array.find-index.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find-last.js */ \"./node_modules/core-js/modules/es.typed-array.find-last.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find-last-index.js */ \"./node_modules/core-js/modules/es.typed-array.find-last-index.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.for-each.js */ \"./node_modules/core-js/modules/es.typed-array.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.includes.js */ \"./node_modules/core-js/modules/es.typed-array.includes.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.index-of.js */ \"./node_modules/core-js/modules/es.typed-array.index-of.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.iterator.js */ \"./node_modules/core-js/modules/es.typed-array.iterator.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.join.js */ \"./node_modules/core-js/modules/es.typed-array.join.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.last-index-of.js */ \"./node_modules/core-js/modules/es.typed-array.last-index-of.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.map.js */ \"./node_modules/core-js/modules/es.typed-array.map.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.reduce.js */ \"./node_modules/core-js/modules/es.typed-array.reduce.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.reduce-right.js */ \"./node_modules/core-js/modules/es.typed-array.reduce-right.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.reverse.js */ \"./node_modules/core-js/modules/es.typed-array.reverse.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.set.js */ \"./node_modules/core-js/modules/es.typed-array.set.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.slice.js */ \"./node_modules/core-js/modules/es.typed-array.slice.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.some.js */ \"./node_modules/core-js/modules/es.typed-array.some.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.sort.js */ \"./node_modules/core-js/modules/es.typed-array.sort.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.subarray.js */ \"./node_modules/core-js/modules/es.typed-array.subarray.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.to-locale-string.js */ \"./node_modules/core-js/modules/es.typed-array.to-locale-string.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.to-string.js */ \"./node_modules/core-js/modules/es.typed-array.to-string.js\");\n__webpack_require__(/*! core-js/modules/esnext.typed-array.to-reversed.js */ \"./node_modules/core-js/modules/esnext.typed-array.to-reversed.js\");\n__webpack_require__(/*! core-js/modules/esnext.typed-array.to-sorted.js */ \"./node_modules/core-js/modules/esnext.typed-array.to-sorted.js\");\n__webpack_require__(/*! core-js/modules/esnext.typed-array.with.js */ \"./node_modules/core-js/modules/esnext.typed-array.with.js\");\n__webpack_require__(/*! core-js/modules/es.regexp.to-string.js */ \"./node_modules/core-js/modules/es.regexp.to-string.js\");\n__webpack_require__(/*! core-js/modules/web.dom-collections.for-each.js */ \"./node_modules/core-js/modules/web.dom-collections.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.array.concat.js */ \"./node_modules/core-js/modules/es.array.concat.js\");\n__webpack_require__(/*! core-js/modules/es.array.includes.js */ \"./node_modules/core-js/modules/es.array.includes.js\");\n__webpack_require__(/*! core-js/modules/es.string.includes.js */ \"./node_modules/core-js/modules/es.string.includes.js\");\n__webpack_require__(/*! core-js/modules/es.array.splice.js */ \"./node_modules/core-js/modules/es.array.splice.js\");\n!(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__, exports, __webpack_require__(/*! tslib */ \"./node_modules/tslib/tslib.es6.js\"), __webpack_require__(/*! gs-longan */ \"./packages/longan/src/index.ts\"), __webpack_require__(/*! gs-longan */ \"./packages/longan/src/index.ts\"), __webpack_require__(/*! ./material */ \"./packages/bimAir/src/gsDevFx/objects/material.ts\"), __webpack_require__(/*! ./cuttingOptions */ \"./packages/bimAir/src/gsDevFx/objects/cuttingOptions.ts\"), __webpack_require__(/*! gs-longan/longan/gs.viewer */ \"./packages/longan/src/longan/gs.viewer.ts\")], __WEBPACK_AMD_DEFINE_RESULT__ = (function (require, exports, tslib_1, Longan, gs_longan_1, material_1, cuttingOptions_1, gs_viewer_1) {\n \"use strict\";\n\n Object.defineProperty(exports, \"__esModule\", ({\n value: true\n }));\n exports.SegmentObject = void 0;\n Longan = tslib_1.__importStar(Longan);\n var SegmentObject = function () {\n function SegmentObject(viewer, segment) {\n this._viewer = null;\n this.matrixList = [];\n this._segment = segment;\n this._viewer = viewer;\n }\n Object.defineProperty(SegmentObject.prototype, \"treeNodeOject\", {\n get: function get() {\n if (!this._treeNodeObject) {\n this._treeNodeObject = this._viewer.structureTreeManager.getTreeNodeObjectByNodeKey(this.segment.key);\n }\n return this._treeNodeObject;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"viewer\", {\n get: function get() {\n return this._viewer;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"model\", {\n get: function get() {\n if (this.treeNodeOject) {\n return this.treeNodeOject.model;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"modelId\", {\n get: function get() {\n if (this.treeNodeOject) {\n return this.treeNodeOject.modelId;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"version\", {\n get: function get() {\n if (this.treeNodeOject && this.treeNodeOject.model) {\n return this.treeNodeOject.model.renderObject.version;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"componentId\", {\n get: function get() {\n if (this.treeNodeOject) {\n return this.treeNodeOject.componentId;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"materials\", {\n get: function get() {\n var materials = [];\n for (var i = 0; i < this._segment.styles.count(); i++) {\n var styleSegment = this._segment.styles.items[i].segment;\n if (this.viewer.styleSegment.subsegmentExists(styleSegment.name)) {\n materials.push(new material_1.Material(this.viewer, styleSegment.name, styleSegment.renderingOptions.lockFaceColor));\n }\n }\n return materials;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"name\", {\n get: function get() {\n return this._segment.name;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"key\", {\n get: function get() {\n return this.segment.key;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"localPosition\", {\n get: function get() {\n if (this.segment.modellingMatrix.matrix) {\n return Longan.Matrix4.getTranslate(new Float32Array(this.segment.modellingMatrix.matrix));\n } else {\n return [0, 0, 0];\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"worldPosition\", {\n get: function get() {\n var process = this.viewer.process;\n if (process) {\n var viewer = process.activeViewer;\n if (viewer) {\n var pathKeys = [];\n var treeNode = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(this.nodeKey);\n while (treeNode) {\n if (treeNode.obj) {\n pathKeys.push(treeNode.obj.segment.key);\n } else {\n pathKeys.push(treeNode.key);\n }\n treeNode = treeNode.parent;\n }\n var matrix = (0, gs_viewer_1.JS_Show_Path_ModellingMatrix)(pathKeys);\n return Longan.Matrix4.getTranslate(new Float32Array(matrix));\n }\n }\n return null;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"nodeKey\", {\n get: function get() {\n return this.key === undefined ? \"\" : this.key.toString();\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"segment\", {\n get: function get() {\n return this._segment;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"size\", {\n get: function get() {\n var geometries = new Longan.List();\n this.traverseSegment(this.segment, geometries);\n var result = {\n pos: 0,\n face: 0,\n geo: geometries.count()\n };\n geometries.forEach(function (geo) {\n result.pos = result.pos + geo.shellSize.pos;\n result.face = result.face + geo.shellSize.face;\n });\n return result;\n },\n enumerable: false,\n configurable: true\n });\n SegmentObject.prototype.traverseSegment = function (segment, geometries) {\n if (segment) {\n geometries.items = geometries.items.concat(segment.geometries.items);\n if (segment.includes) {\n for (var i = 0; i < segment.includes.items.length; i++) {\n var item = segment.includes.items[i].segment;\n this.traverseSegment(item, geometries);\n }\n }\n if (segment.subsegments) {\n for (var i = 0; i < segment.subsegments.items.length; i++) {\n var item = segment.subsegments.items[i];\n this.traverseSegment(item, geometries);\n }\n }\n }\n return geometries;\n };\n SegmentObject.prototype.delete = function () {\n this.segment.delete();\n };\n SegmentObject.prototype.rename = function (name) {\n this.segment.rename(name);\n };\n SegmentObject.prototype.setMaterial = function (material) {\n var components = [];\n this.viewer.structureTreeManager.getComponents(this.treeNodeOject, components);\n if (material) {\n this.viewer.materialManager.override(components, material);\n } else {\n this.viewer.materialManager.clearOverride(components);\n }\n };\n SegmentObject.prototype.setHighlight = function (isHighlight) {\n if (isHighlight) {\n this.viewer.highlightManager.highlight([this]);\n } else {\n this.viewer.highlightManager.clearHighlight([this]);\n }\n };\n SegmentObject.prototype.setVisible = function (visible) {\n if (visible) {\n this.viewer.invisibleManager.clearInvisible([this]);\n } else {\n this.viewer.invisibleManager.invisible([this]);\n }\n };\n SegmentObject.prototype.setIsolation = function (isIsolation) {\n if (isIsolation) {\n this.viewer.isolationManager.isolation([this]);\n } else {\n this.viewer.isolationManager.clearIsolation([this]);\n }\n };\n SegmentObject.prototype.setCutting = function (cuttingOptions) {\n var bb = this.viewer.computeViewBoundingBox(this._segment);\n if (bb) {\n if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxX) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[0], bb[4], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([1, 0, 0]);\n cuttingOptions.length = bb[3] - bb[0];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxY) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[1], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([0, 1, 0]);\n cuttingOptions.length = bb[4] - bb[1];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxZ) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[2]])), 2);\n cuttingOptions.direct = new Float32Array([0, 0, 1]);\n cuttingOptions.length = bb[5] - bb[2];\n }\n cuttingOptions._bb = bb;\n }\n Longan.Vector.normalize(cuttingOptions._direct);\n var xAxis = new Float32Array([1, 0, 0]);\n if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\n xAxis = new Float32Array([0, 1, 0]);\n }\n var yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\n Longan.Vector.normalize(yAxis);\n xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\n var origin = Longan.GeometryOperators.distancePoint(cuttingOptions._origin, cuttingOptions._direct, cuttingOptions._length * cuttingOptions._ratio);\n var bbLength = Longan.GeometryOperators.distance(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[5]]));\n var xPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n Longan.Vector.reverse(xAxis);\n var negXPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n var p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n var p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n Longan.Vector.reverse(yAxis);\n var p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n var p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([p1[0], p1[1], p1[2], p2[0], p2[1], p2[2], p3[0], p3[1], p3[2], p4[0], p4[1], p4[2]]);\n this._segment.visibility.setCuttingPlane(true);\n this._segment.color.setCuttingFace(cuttingOptions.color);\n };\n SegmentObject.prototype.editCutting = function (cuttingOptions) {\n var bb = cuttingOptions.bb;\n if (!bb) {\n bb = this.viewer.computeViewBoundingBox(this._segment);\n cuttingOptions._bb = bb;\n }\n if (bb) {\n if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxX) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[0], bb[4], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([1, 0, 0]);\n cuttingOptions.length = bb[3] - bb[0];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxY) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[1], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([0, 1, 0]);\n cuttingOptions.length = bb[4] - bb[1];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxZ) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[2]])), 2);\n cuttingOptions.direct = new Float32Array([0, 0, 1]);\n cuttingOptions.length = bb[5] - bb[2];\n }\n }\n Longan.Vector.normalize(cuttingOptions._direct);\n var xAxis = new Float32Array([1, 0, 0]);\n if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\n xAxis = new Float32Array([0, 1, 0]);\n }\n var yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\n Longan.Vector.normalize(yAxis);\n xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\n var origin = Longan.GeometryOperators.distancePoint(cuttingOptions._origin, cuttingOptions._direct, cuttingOptions._length * cuttingOptions._ratio);\n var bbLength = Longan.GeometryOperators.distance(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[5]]));\n var xPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n Longan.Vector.reverse(xAxis);\n var negXPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n var p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n var p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n Longan.Vector.reverse(yAxis);\n var p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n var p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n if (cuttingOptions.cuttingPlanes) {\n cuttingOptions.cuttingPlanes.edit([p1[0], p1[1], p1[2], p2[0], p2[1], p2[2], p3[0], p3[1], p3[2], p4[0], p4[1], p4[2]]);\n } else {\n cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([p1[0], p1[1], p1[2], p2[0], p2[1], p2[2], p3[0], p3[1], p3[2], p4[0], p4[1], p4[2]]);\n this._segment.visibility.setCuttingPlane(true);\n this._segment.color.setCuttingFace(cuttingOptions.color);\n }\n };\n SegmentObject.prototype.unsetCutting = function () {\n var cuttingPlanes = this._segment.findGeometry(\"CuttingPlanes\");\n if (cuttingPlanes) {\n cuttingPlanes.delete();\n }\n this._segment.visibility.unsetCuttingPlane();\n this.segment.color.unsetCuttingFace();\n };\n SegmentObject.prototype.equals = function (obj) {\n if (this.nodeKey == obj.nodeKey) {\n return true;\n } else {\n return false;\n }\n };\n SegmentObject.subtraction = function (arr, arr1) {\n var subtraction = [];\n for (var i = 0; i < arr.length; i++) {\n var exist = false;\n for (var j = 0; j < arr1.length; j++) {\n if (arr[i].equals(arr1[j])) {\n exist = true;\n break;\n }\n }\n if (!exist) {\n subtraction.push(arr[i]);\n }\n }\n return subtraction;\n };\n SegmentObject.convertToTreeNodeObjects = function (viewer, segmentObjects) {\n var treeNodeObjects = [];\n for (var i = 0; i < segmentObjects.length; i++) {\n var value = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(segmentObjects[i].nodeKey);\n if (value) {\n treeNodeObjects.push(value);\n }\n }\n return treeNodeObjects;\n };\n SegmentObject.prototype.copy = function () {\n return this.viewer.temporaryObjectManager.copy(this);\n };\n SegmentObject.prototype.translate = function (x, y, z) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var matrix = gs_longan_1.Matrix4.identity();\n gs_longan_1.Matrix4.translate(matrix, x, y, z);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.scale = function (x, y, z, origin) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var center;\n if (origin) {\n center = origin;\n } else {\n var bb = this.segment.boundingbox;\n center = [(bb[0] + bb[3]) / 2, (bb[1] + bb[4]) / 2, (bb[2] + bb[5]) / 2];\n }\n var matrix = gs_longan_1.Matrix4.identity();\n gs_longan_1.Matrix4.translate(matrix, -center[0], -center[1], -center[2]);\n gs_longan_1.Matrix4.scale(matrix, x, y, z);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.rotate = function (origin, axis, alpha) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var matrix = gs_longan_1.Matrix4.rotateByAxis(new Float32Array(origin), new Float32Array(axis), alpha);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.rotateByAxis = function (origin, axis, alpha) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var matrix = gs_longan_1.Matrix4.rotateByAxis(new Float32Array(origin), new Float32Array(axis), alpha);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.unsetMatrix = function () {\n if (this.matrixList.length > 0) {\n this.segment.modellingMatrix.set(this.matrixList[0]);\n console.log(\"this.segment.modellingMatrix.matrix\", this.matrixList);\n }\n };\n SegmentObject.prototype.undoMatrix = function () {\n if (this.matrixList.length > 0) {\n this.segment.modellingMatrix.set(this.matrixList[this.matrixList.length - 1]);\n this.matrixList.splice(this.matrixList.length - 1, 1);\n }\n };\n return SegmentObject;\n }();\n exports.SegmentObject = SegmentObject;\n}).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./packages/bimAir/src/gsDevFx/objects/segmentObject.ts.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAWA;AAMA;AALA;AAGA;AAGA;AACA;AACA;AAEA;AAAA;AACA;AACA;;AAKA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;;AAEA;;;;AAEA;AAAA;AACA;AACA;;AAEA;;;;AAEA;AAAA;AACA;AACA;;AAMA;;;;AAEA;AAAA;AACA;AACA;;AAEA;;;;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;;;AAUA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAKA;AAAA;AACA;AACA;AAGA;AACA;;AAEA;;;;AAKA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;;AAEA;;AAGA;AACA;;;AAIA;AACA;;;;AAEA;AAAA;AACA;AAEA;;;;AAEA;AAAA;AACA;AACA;;;;AAKA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAEA;AAIA;AACA;AAEA;AACA;AACA;AACA;;;AAIA;AACA;AACA;AACA;;;;AAIA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAMA;AACA;AACA;AAKA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;;AAGA;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AAMA;AAIA;AAKA;AACA;AAMA;AACA;AACA;AACA;AACA;AAEA;AAcA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;;;AAIA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AAMA;AAIA;AAKA;AACA;AAMA;AACA;AACA;AACA;AACA;AAEA;AACA;AAcA;AACA;AAcA;AACA;;AAEA;AAEA;AACA;AACA;AACA;;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AAEA;AAEA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAIA;AACA;;;AAIA;AACA;AAQA;AAIA;AACA;AACA;AAGA;AACA;;;AAGA;AACA;AAMA;AACA;AACA;AAQA;AACA;AAKA;AACA;AACA;AACA;AASA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAGA;AACA;AACA;AAQA;AACA;AAEA;AAKA;AACA;AAOA;AACA;AAEA;AAKA;AACA;AAKA;AACA;AACA;AACA;;AAEA;AAKA;AACA;AACA;AAGA;;AAEA;AACA;AAAA;AAlmBA","sources":["webpack://bimlight-platform/./packages/bimAir/src/gsDevFx/objects/segmentObject.ts?f9cb"],"sourcesContent":["import * as Longan from \"gs-longan\";\r\nimport { Matrix4, Segment } from \"gs-longan\";\r\nimport { Material } from \"./material\";\r\nimport { CuttingCreateType, CuttingOptions } from \"./cuttingOptions\";\r\nimport { Viewer } from \"../viewer\";\r\nimport { TreeNodeObject } from \"./treeNodeObject\";\r\nimport { JS_Show_Path_ModellingMatrix } from \"gs-longan/longan/gs.viewer\";\r\nimport { InstanceLightModel } from \"./instancesObjects/instanceLightModel\";\r\nimport { LightModel } from \"./lightModel\";\r\nimport { ReferenceLightModel } from \"./referenceLightModel\";\r\n\r\nexport class SegmentObject {\r\n  private _viewer: Viewer = null;\r\n  private _segment: Segment;\r\n  private _treeNodeObject: TreeNodeObject;\r\n  private matrixList = [];\r\n\r\n  constructor(viewer: Viewer, segment: Segment) {\r\n    this._segment = segment;\r\n    this._viewer = viewer;\r\n  }\r\n\r\n  public get treeNodeOject() {\r\n    if (!this._treeNodeObject) {\r\n      this._treeNodeObject =\r\n        this._viewer.structureTreeManager.getTreeNodeObjectByNodeKey(\r\n          this.segment.key\r\n        );\r\n    }\r\n    return this._treeNodeObject;\r\n  }\r\n\r\n  public get viewer(): Viewer {\r\n    return this._viewer;\r\n  }\r\n\r\n  public get model() {\r\n    if (this.treeNodeOject) {\r\n      return this.treeNodeOject.model;\r\n    }\r\n  }\r\n\r\n  public get modelId() {\r\n    if (this.treeNodeOject) {\r\n      return this.treeNodeOject.modelId;\r\n    }\r\n  }\r\n\r\n  public get version() {\r\n    if (this.treeNodeOject && this.treeNodeOject.model) {\r\n      return (\r\n        this.treeNodeOject.model.renderObject as\r\n          | LightModel\r\n          | ReferenceLightModel\r\n      ).version;\r\n    }\r\n  }\r\n\r\n  public get componentId() {\r\n    if (this.treeNodeOject) {\r\n      return this.treeNodeOject.componentId;\r\n    }\r\n  }\r\n\r\n  public get materials(): Material[] {\r\n    let materials = [];\r\n    for (let i = 0; i < this._segment.styles.count(); i++) {\r\n      let styleSegment = this._segment.styles.items[i].segment;\r\n      if (this.viewer.styleSegment.subsegmentExists(styleSegment.name)) {\r\n        materials.push(\r\n          new Material(\r\n            this.viewer,\r\n            styleSegment.name,\r\n            styleSegment.renderingOptions.lockFaceColor\r\n          )\r\n        );\r\n      }\r\n    }\r\n\r\n    return materials;\r\n  }\r\n\r\n  public get name(): string {\r\n    return this._segment.name;\r\n  }\r\n\r\n  public get key(): number {\r\n    return this.segment.key;\r\n  }\r\n\r\n  /**\r\n   * 获取局部坐标\r\n   */\r\n  get localPosition() {\r\n    if (this.segment.modellingMatrix.matrix) {\r\n      return Longan.Matrix4.getTranslate(\r\n        new Float32Array(this.segment.modellingMatrix.matrix)\r\n      );\r\n    } else {\r\n      return [0, 0, 0];\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 获取世界坐标\r\n   */\r\n  get worldPosition() {\r\n    let process = this.viewer.process;\r\n    if (process) {\r\n      let viewer = process.activeViewer as Viewer;\r\n      if (viewer) {\r\n        let pathKeys = [];\r\n        let treeNode = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(\r\n          this.nodeKey\r\n        );\r\n        while (treeNode) {\r\n          if (treeNode.obj) {\r\n            pathKeys.push(treeNode.obj.segment.key);\r\n          } else {\r\n            pathKeys.push(treeNode.key);\r\n          }\r\n          treeNode = treeNode.parent;\r\n        }\r\n\r\n        let matrix = JS_Show_Path_ModellingMatrix(pathKeys);\r\n        return Longan.Matrix4.getTranslate(new Float32Array(matrix));\r\n      }\r\n    }\r\n\r\n    return null;\r\n  }\r\n\r\n  public get nodeKey(): string {\r\n    return this.key === undefined ? \"\" : this.key.toString();\r\n    // return this.key.toString();\r\n  }\r\n\r\n  get segment() {\r\n    return this._segment;\r\n  }\r\n\r\n  /**\r\n   * 构件的尺寸，包含点数量、面数量、几何数量\r\n   */\r\n  get size() {\r\n    let geometries: Longan.List<Longan.Geometry> = new Longan.List();\r\n    this.traverseSegment(this.segment, geometries);\r\n\r\n    let result = {\r\n      pos: 0,\r\n      face: 0,\r\n      geo: geometries.count(),\r\n    };\r\n    geometries.forEach((geo) => {\r\n      result.pos = result.pos + geo.shellSize.pos;\r\n      result.face = result.face + geo.shellSize.face;\r\n    });\r\n    return result;\r\n  }\r\n\r\n  traverseSegment(\r\n    segment: Longan.Segment,\r\n    geometries: Longan.List<Longan.Geometry>\r\n  ) {\r\n    if (segment) {\r\n      geometries.items = geometries.items.concat(segment.geometries.items);\r\n\r\n      if (segment.includes) {\r\n        for (let i = 0; i < segment.includes.items.length; i++) {\r\n          const item = segment.includes.items[i].segment;\r\n          this.traverseSegment(item, geometries);\r\n        }\r\n      }\r\n\r\n      if (segment.subsegments) {\r\n        for (let i = 0; i < segment.subsegments.items.length; i++) {\r\n          const item = segment.subsegments.items[i];\r\n          this.traverseSegment(item, geometries);\r\n        }\r\n      }\r\n    }\r\n    return geometries;\r\n  }\r\n\r\n  public delete() {\r\n    this.segment.delete();\r\n  }\r\n\r\n  public rename(name) {\r\n    this.segment.rename(name);\r\n  }\r\n\r\n  /**\r\n   * 设置材质，若不传参数则清除构件上的材质\r\n   * @param material\r\n   */\r\n  public setMaterial(material?: Material) {\r\n    let components = [];\r\n    this.viewer.structureTreeManager.getComponents(\r\n      this.treeNodeOject,\r\n      components\r\n    );\r\n\r\n    if (material) {\r\n      this.viewer.materialManager.override(components, material);\r\n    } else {\r\n      this.viewer.materialManager.clearOverride(components);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 设置构件的高亮\r\n   * @param isHighlight 是否高亮\r\n   */\r\n  public setHighlight(isHighlight: boolean) {\r\n    if (isHighlight) {\r\n      this.viewer.highlightManager.highlight([this]);\r\n    } else {\r\n      this.viewer.highlightManager.clearHighlight([this]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 设置构件的可见\r\n   * @param visible 是否可见\r\n   */\r\n  public setVisible(visible: boolean) {\r\n    if (visible) {\r\n      this.viewer.invisibleManager.clearInvisible([this]);\r\n    } else {\r\n      this.viewer.invisibleManager.invisible([this]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 设置构件的隔离\r\n   * @param isIsolation 是否隔离\r\n   */\r\n  public setIsolation(isIsolation: boolean) {\r\n    if (isIsolation) {\r\n      this.viewer.isolationManager.isolation([this]);\r\n    } else {\r\n      this.viewer.isolationManager.clearIsolation([this]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 创建剖切，通过剖切选项创建剖切\r\n   * @param cuttingOptions 剖切选项\r\n   */\r\n  public setCutting(cuttingOptions: CuttingOptions) {\r\n    let bb = this.viewer.computeViewBoundingBox(this._segment);\r\n    if (bb) {\r\n      if (cuttingOptions.type == CuttingCreateType.BoundingBoxX) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[0], bb[4], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([1, 0, 0]);\r\n        cuttingOptions.length = bb[3] - bb[0];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxY) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[1], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 1, 0]);\r\n        cuttingOptions.length = bb[4] - bb[1];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxZ) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[4], bb[2]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 0, 1]);\r\n        cuttingOptions.length = bb[5] - bb[2];\r\n      }\r\n\r\n      cuttingOptions._bb = bb;\r\n    }\r\n\r\n    Longan.Vector.normalize(cuttingOptions._direct);\r\n    let xAxis = new Float32Array([1, 0, 0]);\r\n    if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\r\n      xAxis = new Float32Array([0, 1, 0]);\r\n    }\r\n    let yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\r\n    Longan.Vector.normalize(yAxis);\r\n    xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\r\n\r\n    let origin = Longan.GeometryOperators.distancePoint(\r\n      cuttingOptions._origin,\r\n      cuttingOptions._direct,\r\n      cuttingOptions._length * cuttingOptions._ratio\r\n    );\r\n\r\n    let bbLength = Longan.GeometryOperators.distance(\r\n      new Float32Array([bb[0], bb[1], bb[2]]),\r\n      new Float32Array([bb[3], bb[4], bb[5]])\r\n    );\r\n    let xPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n    Longan.Vector.reverse(xAxis);\r\n    let negXPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n\r\n    let p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n    let p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    Longan.Vector.reverse(yAxis);\r\n    let p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    let p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n\r\n    cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([\r\n      p1[0],\r\n      p1[1],\r\n      p1[2],\r\n      p2[0],\r\n      p2[1],\r\n      p2[2],\r\n      p3[0],\r\n      p3[1],\r\n      p3[2],\r\n      p4[0],\r\n      p4[1],\r\n      p4[2],\r\n    ]);\r\n    this._segment.visibility.setCuttingPlane(true);\r\n    this._segment.color.setCuttingFace(cuttingOptions.color);\r\n  }\r\n\r\n  public editCutting(cuttingOptions: CuttingOptions) {\r\n    let bb = cuttingOptions.bb;\r\n    if (!bb) {\r\n      bb = this.viewer.computeViewBoundingBox(this._segment);\r\n      cuttingOptions._bb = bb;\r\n    }\r\n    if (bb) {\r\n      if (cuttingOptions.type == CuttingCreateType.BoundingBoxX) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[0], bb[4], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([1, 0, 0]);\r\n        cuttingOptions.length = bb[3] - bb[0];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxY) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[1], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 1, 0]);\r\n        cuttingOptions.length = bb[4] - bb[1];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxZ) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[4], bb[2]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 0, 1]);\r\n        cuttingOptions.length = bb[5] - bb[2];\r\n      }\r\n    }\r\n\r\n    Longan.Vector.normalize(cuttingOptions._direct);\r\n    let xAxis = new Float32Array([1, 0, 0]);\r\n    if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\r\n      xAxis = new Float32Array([0, 1, 0]);\r\n    }\r\n    let yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\r\n    Longan.Vector.normalize(yAxis);\r\n    xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\r\n\r\n    let origin = Longan.GeometryOperators.distancePoint(\r\n      cuttingOptions._origin,\r\n      cuttingOptions._direct,\r\n      cuttingOptions._length * cuttingOptions._ratio\r\n    );\r\n\r\n    let bbLength = Longan.GeometryOperators.distance(\r\n      new Float32Array([bb[0], bb[1], bb[2]]),\r\n      new Float32Array([bb[3], bb[4], bb[5]])\r\n    );\r\n    let xPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n    Longan.Vector.reverse(xAxis);\r\n    let negXPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n\r\n    let p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n    let p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    Longan.Vector.reverse(yAxis);\r\n    let p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    let p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n\r\n    if (cuttingOptions.cuttingPlanes) {\r\n      cuttingOptions.cuttingPlanes.edit([\r\n        p1[0],\r\n        p1[1],\r\n        p1[2],\r\n        p2[0],\r\n        p2[1],\r\n        p2[2],\r\n        p3[0],\r\n        p3[1],\r\n        p3[2],\r\n        p4[0],\r\n        p4[1],\r\n        p4[2],\r\n      ]);\r\n    } else {\r\n      cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([\r\n        p1[0],\r\n        p1[1],\r\n        p1[2],\r\n        p2[0],\r\n        p2[1],\r\n        p2[2],\r\n        p3[0],\r\n        p3[1],\r\n        p3[2],\r\n        p4[0],\r\n        p4[1],\r\n        p4[2],\r\n      ]);\r\n      this._segment.visibility.setCuttingPlane(true);\r\n      this._segment.color.setCuttingFace(cuttingOptions.color);\r\n    }\r\n  }\r\n\r\n  public unsetCutting() {\r\n    let cuttingPlanes = this._segment.findGeometry(\"CuttingPlanes\");\r\n    if (cuttingPlanes) {\r\n      cuttingPlanes.delete();\r\n    }\r\n\r\n    this._segment.visibility.unsetCuttingPlane();\r\n    this.segment.color.unsetCuttingFace();\r\n  }\r\n\r\n  equals(obj: SegmentObject): boolean {\r\n    if (this.nodeKey == obj.nodeKey) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public static subtraction(\r\n    arr: SegmentObject[],\r\n    arr1: SegmentObject[]\r\n  ): SegmentObject[] {\r\n    let subtraction = [];\r\n    for (let i = 0; i < arr.length; i++) {\r\n      let exist = false;\r\n      for (let j = 0; j < arr1.length; j++) {\r\n        if (arr[i].equals(arr1[j])) {\r\n          exist = true;\r\n          break;\r\n        }\r\n      }\r\n\r\n      if (!exist) {\r\n        subtraction.push(arr[i]);\r\n      }\r\n    }\r\n\r\n    return subtraction;\r\n  }\r\n\r\n  /**\r\n   * SegmentObject 转成 TreeNodeObject\r\n   * @param viewer\r\n   * @param segmentObjects\r\n   * @returns\r\n   */\r\n  public static convertToTreeNodeObjects(\r\n    viewer,\r\n    segmentObjects: SegmentObject[]\r\n  ): TreeNodeObject[] {\r\n    let treeNodeObjects = [];\r\n    for (let i = 0; i < segmentObjects.length; i++) {\r\n      let value = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(\r\n        segmentObjects[i].nodeKey\r\n      );\r\n      if (value) {\r\n        treeNodeObjects.push(value);\r\n      }\r\n    }\r\n    return treeNodeObjects;\r\n  }\r\n\r\n  /**\r\n   * 构件复制\r\n   * @returns\r\n   */\r\n  public copy(): SegmentObject {\r\n    return this.viewer.temporaryObjectManager.copy(this);\r\n  }\r\n\r\n  /**\r\n   * 构件平移\r\n   * @param x\r\n   * @param y\r\n   * @param z\r\n   */\r\n  translate(x: number, y: number, z: number) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n    // console.log(\r\n    //   \"this.segment.modellingMatrix.matrix\",\r\n    //   this.segment.modellingMatrix.matrix\r\n    // );\r\n    let matrix = Matrix4.identity();\r\n    Matrix4.translate(matrix, x, y, z);\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 构件放缩\r\n   * @param x\r\n   * @param y\r\n   * @param z\r\n   * @param origin 放缩原点，默认是包围盒中心\r\n   */\r\n  scale(x: number, y: number, z: number, origin?: number[]) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n\r\n    let center: number[];\r\n    if (origin) {\r\n      center = origin;\r\n    } else {\r\n      let bb = this.segment.boundingbox;\r\n      center = [(bb[0] + bb[3]) / 2, (bb[1] + bb[4]) / 2, (bb[2] + bb[5]) / 2];\r\n    }\r\n    let matrix = Matrix4.identity();\r\n    Matrix4.translate(matrix, -center[0], -center[1], -center[2]);\r\n    // this.segment.modellingMatrix.append(matrix);\r\n\r\n    Matrix4.scale(matrix, x, y, z);\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 构件旋转\r\n   * @param origin 旋转原点\r\n   * @param axis 旋转轴\r\n   * @param alpha 弧度\r\n   */\r\n  rotate(origin: number[], axis: number[], alpha: number) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n\r\n    let matrix = Matrix4.rotateByAxis(\r\n      new Float32Array(origin),\r\n      new Float32Array(axis),\r\n      alpha\r\n    );\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 构件旋转\r\n   * @param axis 旋转轴\r\n   * @param alpha 弧度\r\n   */\r\n  rotateByAxis(origin: number[], axis: number[], alpha: number) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n\r\n    let matrix = Matrix4.rotateByAxis(\r\n      new Float32Array(origin),\r\n      new Float32Array(axis),\r\n      alpha\r\n    );\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 取消构件变换\r\n   */\r\n  unsetMatrix() {\r\n    if (this.matrixList.length > 0) {\r\n      this.segment.modellingMatrix.set(this.matrixList[0]);\r\n      console.log(\"this.segment.modellingMatrix.matrix\", this.matrixList);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 返回上一个构件变换\r\n   */\r\n  undoMatrix() {\r\n    if (this.matrixList.length > 0) {\r\n      this.segment.modellingMatrix.set(\r\n        this.matrixList[this.matrixList.length - 1]\r\n      );\r\n      this.matrixList.splice(this.matrixList.length - 1, 1);\r\n    }\r\n  }\r\n}\r\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./packages/bimAir/src/gsDevFx/objects/segmentObject.ts\n");
|
|
3797
|
+
eval("var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;__webpack_require__(/*! core-js/modules/es.function.name.js */ \"./node_modules/core-js/modules/es.function.name.js\");\n__webpack_require__(/*! core-js/modules/es.array.push.js */ \"./node_modules/core-js/modules/es.array.push.js\");\n__webpack_require__(/*! core-js/modules/es.array.iterator.js */ \"./node_modules/core-js/modules/es.array.iterator.js\");\n__webpack_require__(/*! core-js/modules/es.array-buffer.slice.js */ \"./node_modules/core-js/modules/es.array-buffer.slice.js\");\n__webpack_require__(/*! core-js/modules/es.object.to-string.js */ \"./node_modules/core-js/modules/es.object.to-string.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.float32-array.js */ \"./node_modules/core-js/modules/es.typed-array.float32-array.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.at.js */ \"./node_modules/core-js/modules/es.typed-array.at.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.copy-within.js */ \"./node_modules/core-js/modules/es.typed-array.copy-within.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.every.js */ \"./node_modules/core-js/modules/es.typed-array.every.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.fill.js */ \"./node_modules/core-js/modules/es.typed-array.fill.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.filter.js */ \"./node_modules/core-js/modules/es.typed-array.filter.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find.js */ \"./node_modules/core-js/modules/es.typed-array.find.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find-index.js */ \"./node_modules/core-js/modules/es.typed-array.find-index.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find-last.js */ \"./node_modules/core-js/modules/es.typed-array.find-last.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.find-last-index.js */ \"./node_modules/core-js/modules/es.typed-array.find-last-index.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.for-each.js */ \"./node_modules/core-js/modules/es.typed-array.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.includes.js */ \"./node_modules/core-js/modules/es.typed-array.includes.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.index-of.js */ \"./node_modules/core-js/modules/es.typed-array.index-of.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.iterator.js */ \"./node_modules/core-js/modules/es.typed-array.iterator.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.join.js */ \"./node_modules/core-js/modules/es.typed-array.join.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.last-index-of.js */ \"./node_modules/core-js/modules/es.typed-array.last-index-of.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.map.js */ \"./node_modules/core-js/modules/es.typed-array.map.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.reduce.js */ \"./node_modules/core-js/modules/es.typed-array.reduce.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.reduce-right.js */ \"./node_modules/core-js/modules/es.typed-array.reduce-right.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.reverse.js */ \"./node_modules/core-js/modules/es.typed-array.reverse.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.set.js */ \"./node_modules/core-js/modules/es.typed-array.set.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.slice.js */ \"./node_modules/core-js/modules/es.typed-array.slice.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.some.js */ \"./node_modules/core-js/modules/es.typed-array.some.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.sort.js */ \"./node_modules/core-js/modules/es.typed-array.sort.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.subarray.js */ \"./node_modules/core-js/modules/es.typed-array.subarray.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.to-locale-string.js */ \"./node_modules/core-js/modules/es.typed-array.to-locale-string.js\");\n__webpack_require__(/*! core-js/modules/es.typed-array.to-string.js */ \"./node_modules/core-js/modules/es.typed-array.to-string.js\");\n__webpack_require__(/*! core-js/modules/esnext.typed-array.to-reversed.js */ \"./node_modules/core-js/modules/esnext.typed-array.to-reversed.js\");\n__webpack_require__(/*! core-js/modules/esnext.typed-array.to-sorted.js */ \"./node_modules/core-js/modules/esnext.typed-array.to-sorted.js\");\n__webpack_require__(/*! core-js/modules/esnext.typed-array.with.js */ \"./node_modules/core-js/modules/esnext.typed-array.with.js\");\n__webpack_require__(/*! core-js/modules/es.regexp.to-string.js */ \"./node_modules/core-js/modules/es.regexp.to-string.js\");\n__webpack_require__(/*! core-js/modules/web.dom-collections.for-each.js */ \"./node_modules/core-js/modules/web.dom-collections.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.array.concat.js */ \"./node_modules/core-js/modules/es.array.concat.js\");\n__webpack_require__(/*! core-js/modules/es.array.includes.js */ \"./node_modules/core-js/modules/es.array.includes.js\");\n__webpack_require__(/*! core-js/modules/es.string.includes.js */ \"./node_modules/core-js/modules/es.string.includes.js\");\n__webpack_require__(/*! core-js/modules/es.array.splice.js */ \"./node_modules/core-js/modules/es.array.splice.js\");\n!(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__, exports, __webpack_require__(/*! tslib */ \"./node_modules/tslib/tslib.es6.js\"), __webpack_require__(/*! gs-longan */ \"./packages/longan/src/index.ts\"), __webpack_require__(/*! gs-longan */ \"./packages/longan/src/index.ts\"), __webpack_require__(/*! ./material */ \"./packages/bimAir/src/gsDevFx/objects/material.ts\"), __webpack_require__(/*! ./cuttingOptions */ \"./packages/bimAir/src/gsDevFx/objects/cuttingOptions.ts\"), __webpack_require__(/*! gs-longan/longan/gs.viewer */ \"./packages/longan/src/longan/gs.viewer.ts\")], __WEBPACK_AMD_DEFINE_RESULT__ = (function (require, exports, tslib_1, Longan, gs_longan_1, material_1, cuttingOptions_1, gs_viewer_1) {\n \"use strict\";\n\n Object.defineProperty(exports, \"__esModule\", ({\n value: true\n }));\n exports.SegmentObject = void 0;\n Longan = tslib_1.__importStar(Longan);\n var SegmentObject = function () {\n function SegmentObject(viewer, segment) {\n this._viewer = null;\n this.matrixList = [];\n this._segment = segment;\n this._viewer = viewer;\n }\n Object.defineProperty(SegmentObject.prototype, \"treeNodeOject\", {\n get: function get() {\n if (!this._treeNodeObject) {\n this._treeNodeObject = this._viewer.structureTreeManager.getTreeNodeObjectByNodeKey(this.segment.key);\n }\n return this._treeNodeObject;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"viewer\", {\n get: function get() {\n return this._viewer;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"model\", {\n get: function get() {\n if (this.treeNodeOject) {\n return this.treeNodeOject.model;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"modelId\", {\n get: function get() {\n if (this.treeNodeOject) {\n return this.treeNodeOject.modelId;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"version\", {\n get: function get() {\n if (this.treeNodeOject && this.treeNodeOject.model) {\n return this.treeNodeOject.model.renderObject.version;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"componentId\", {\n get: function get() {\n if (this.treeNodeOject) {\n return this.treeNodeOject.componentId;\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"materials\", {\n get: function get() {\n var materials = [];\n for (var i = 0; i < this._segment.styles.count(); i++) {\n var styleSegment = this._segment.styles.items[i].segment;\n if (this.viewer.styleSegment.subsegmentExists(styleSegment.name)) {\n materials.push(new material_1.Material(this.viewer, styleSegment.name, styleSegment.renderingOptions.lockFaceColor));\n }\n }\n return materials;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"name\", {\n get: function get() {\n return this._segment.name;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"key\", {\n get: function get() {\n return this.segment.key;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"localPosition\", {\n get: function get() {\n if (this.segment.modellingMatrix.matrix) {\n return Longan.Matrix4.getTranslate(new Float32Array(this.segment.modellingMatrix.matrix));\n } else {\n return [0, 0, 0];\n }\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"worldPosition\", {\n get: function get() {\n var process = this.viewer.process;\n if (process) {\n var viewer = process.activeViewer;\n if (viewer) {\n var pathKeys = [];\n var treeNode = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(this.nodeKey);\n while (treeNode) {\n if (treeNode.obj) {\n pathKeys.push(treeNode.obj.segment.key);\n } else {\n pathKeys.push(treeNode.key);\n }\n treeNode = treeNode.parent;\n }\n var matrix = (0, gs_viewer_1.JS_Show_Path_ModellingMatrix)(pathKeys);\n return Longan.Matrix4.getTranslate(new Float32Array(matrix));\n }\n }\n return null;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"nodeKey\", {\n get: function get() {\n return this.key === undefined ? \"\" : this.key.toString();\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"segment\", {\n get: function get() {\n return this._segment;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(SegmentObject.prototype, \"size\", {\n get: function get() {\n if (this.segment) {\n var geometries = new Longan.List();\n this.traverseSegment(this.segment, geometries);\n var result_1 = {\n pos: 0,\n face: 0,\n geo: geometries.count()\n };\n geometries.forEach(function (geo) {\n result_1.pos = result_1.pos + geo.shellSize.pos;\n result_1.face = result_1.face + geo.shellSize.face;\n });\n return result_1;\n }\n return null;\n },\n enumerable: false,\n configurable: true\n });\n SegmentObject.prototype.traverseSegment = function (segment, geometries) {\n if (segment) {\n geometries.items = geometries.items.concat(segment.geometries.items);\n if (segment.includes) {\n for (var i = 0; i < segment.includes.items.length; i++) {\n var item = segment.includes.items[i].segment;\n this.traverseSegment(item, geometries);\n }\n }\n if (segment.subsegments) {\n for (var i = 0; i < segment.subsegments.items.length; i++) {\n var item = segment.subsegments.items[i];\n this.traverseSegment(item, geometries);\n }\n }\n }\n return geometries;\n };\n SegmentObject.prototype.delete = function () {\n this.segment.delete();\n };\n SegmentObject.prototype.rename = function (name) {\n this.segment.rename(name);\n };\n SegmentObject.prototype.setMaterial = function (material) {\n var components = [];\n this.viewer.structureTreeManager.getComponents(this.treeNodeOject, components);\n if (material) {\n this.viewer.materialManager.override(components, material);\n } else {\n this.viewer.materialManager.clearOverride(components);\n }\n };\n SegmentObject.prototype.setHighlight = function (isHighlight) {\n if (isHighlight) {\n this.viewer.highlightManager.highlight([this]);\n } else {\n this.viewer.highlightManager.clearHighlight([this]);\n }\n };\n SegmentObject.prototype.setVisible = function (visible) {\n if (visible) {\n this.viewer.invisibleManager.clearInvisible([this]);\n } else {\n this.viewer.invisibleManager.invisible([this]);\n }\n };\n SegmentObject.prototype.setIsolation = function (isIsolation) {\n if (isIsolation) {\n this.viewer.isolationManager.isolation([this]);\n } else {\n this.viewer.isolationManager.clearIsolation([this]);\n }\n };\n SegmentObject.prototype.setCutting = function (cuttingOptions) {\n var bb = this.viewer.computeViewBoundingBox(this._segment);\n if (bb) {\n if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxX) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[0], bb[4], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([1, 0, 0]);\n cuttingOptions.length = bb[3] - bb[0];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxY) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[1], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([0, 1, 0]);\n cuttingOptions.length = bb[4] - bb[1];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxZ) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[2]])), 2);\n cuttingOptions.direct = new Float32Array([0, 0, 1]);\n cuttingOptions.length = bb[5] - bb[2];\n }\n cuttingOptions._bb = bb;\n }\n Longan.Vector.normalize(cuttingOptions._direct);\n var xAxis = new Float32Array([1, 0, 0]);\n if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\n xAxis = new Float32Array([0, 1, 0]);\n }\n var yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\n Longan.Vector.normalize(yAxis);\n xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\n var origin = Longan.GeometryOperators.distancePoint(cuttingOptions._origin, cuttingOptions._direct, cuttingOptions._length * cuttingOptions._ratio);\n var bbLength = Longan.GeometryOperators.distance(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[5]]));\n var xPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n Longan.Vector.reverse(xAxis);\n var negXPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n var p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n var p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n Longan.Vector.reverse(yAxis);\n var p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n var p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([p1[0], p1[1], p1[2], p2[0], p2[1], p2[2], p3[0], p3[1], p3[2], p4[0], p4[1], p4[2]]);\n this._segment.visibility.setCuttingPlane(true);\n this._segment.color.setCuttingFace(cuttingOptions.color);\n };\n SegmentObject.prototype.editCutting = function (cuttingOptions) {\n var bb = cuttingOptions.bb;\n if (!bb) {\n bb = this.viewer.computeViewBoundingBox(this._segment);\n cuttingOptions._bb = bb;\n }\n if (bb) {\n if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxX) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[0], bb[4], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([1, 0, 0]);\n cuttingOptions.length = bb[3] - bb[0];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxY) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[1], bb[5]])), 2);\n cuttingOptions.direct = new Float32Array([0, 1, 0]);\n cuttingOptions.length = bb[4] - bb[1];\n } else if (cuttingOptions.type == cuttingOptions_1.CuttingCreateType.BoundingBoxZ) {\n cuttingOptions.origin = Longan.Vector.divide(Longan.Point.add(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[2]])), 2);\n cuttingOptions.direct = new Float32Array([0, 0, 1]);\n cuttingOptions.length = bb[5] - bb[2];\n }\n }\n Longan.Vector.normalize(cuttingOptions._direct);\n var xAxis = new Float32Array([1, 0, 0]);\n if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\n xAxis = new Float32Array([0, 1, 0]);\n }\n var yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\n Longan.Vector.normalize(yAxis);\n xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\n var origin = Longan.GeometryOperators.distancePoint(cuttingOptions._origin, cuttingOptions._direct, cuttingOptions._length * cuttingOptions._ratio);\n var bbLength = Longan.GeometryOperators.distance(new Float32Array([bb[0], bb[1], bb[2]]), new Float32Array([bb[3], bb[4], bb[5]]));\n var xPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n Longan.Vector.reverse(xAxis);\n var negXPoint = Longan.GeometryOperators.distancePoint(origin, xAxis, bbLength);\n var p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n var p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n Longan.Vector.reverse(yAxis);\n var p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\n var p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\n if (cuttingOptions.cuttingPlanes) {\n cuttingOptions.cuttingPlanes.edit([p1[0], p1[1], p1[2], p2[0], p2[1], p2[2], p3[0], p3[1], p3[2], p4[0], p4[1], p4[2]]);\n } else {\n cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([p1[0], p1[1], p1[2], p2[0], p2[1], p2[2], p3[0], p3[1], p3[2], p4[0], p4[1], p4[2]]);\n this._segment.visibility.setCuttingPlane(true);\n this._segment.color.setCuttingFace(cuttingOptions.color);\n }\n };\n SegmentObject.prototype.unsetCutting = function () {\n var cuttingPlanes = this._segment.findGeometry(\"CuttingPlanes\");\n if (cuttingPlanes) {\n cuttingPlanes.delete();\n }\n this._segment.visibility.unsetCuttingPlane();\n this.segment.color.unsetCuttingFace();\n };\n SegmentObject.prototype.equals = function (obj) {\n if (this.nodeKey == obj.nodeKey) {\n return true;\n } else {\n return false;\n }\n };\n SegmentObject.subtraction = function (arr, arr1) {\n var subtraction = [];\n for (var i = 0; i < arr.length; i++) {\n var exist = false;\n for (var j = 0; j < arr1.length; j++) {\n if (arr[i].equals(arr1[j])) {\n exist = true;\n break;\n }\n }\n if (!exist) {\n subtraction.push(arr[i]);\n }\n }\n return subtraction;\n };\n SegmentObject.convertToTreeNodeObjects = function (viewer, segmentObjects) {\n var treeNodeObjects = [];\n for (var i = 0; i < segmentObjects.length; i++) {\n var value = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(segmentObjects[i].nodeKey);\n if (value) {\n treeNodeObjects.push(value);\n }\n }\n return treeNodeObjects;\n };\n SegmentObject.prototype.copy = function () {\n return this.viewer.temporaryObjectManager.copy(this);\n };\n SegmentObject.prototype.translate = function (x, y, z) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var matrix = gs_longan_1.Matrix4.identity();\n gs_longan_1.Matrix4.translate(matrix, x, y, z);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.scale = function (x, y, z, origin) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var center;\n if (origin) {\n center = origin;\n } else {\n var bb = this.segment.boundingbox;\n center = [(bb[0] + bb[3]) / 2, (bb[1] + bb[4]) / 2, (bb[2] + bb[5]) / 2];\n }\n var matrix = gs_longan_1.Matrix4.identity();\n gs_longan_1.Matrix4.translate(matrix, -center[0], -center[1], -center[2]);\n gs_longan_1.Matrix4.scale(matrix, x, y, z);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.rotate = function (origin, axis, alpha) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var matrix = gs_longan_1.Matrix4.rotateByAxis(new Float32Array(origin), new Float32Array(axis), alpha);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.rotateByAxis = function (origin, axis, alpha) {\n this.matrixList.push(this.segment.modellingMatrix.matrix);\n var matrix = gs_longan_1.Matrix4.rotateByAxis(new Float32Array(origin), new Float32Array(axis), alpha);\n this.segment.modellingMatrix.append(matrix);\n };\n SegmentObject.prototype.unsetMatrix = function () {\n if (this.matrixList.length > 0) {\n this.segment.modellingMatrix.set(this.matrixList[0]);\n console.log(\"this.segment.modellingMatrix.matrix\", this.matrixList);\n }\n };\n SegmentObject.prototype.undoMatrix = function () {\n if (this.matrixList.length > 0) {\n this.segment.modellingMatrix.set(this.matrixList[this.matrixList.length - 1]);\n this.matrixList.splice(this.matrixList.length - 1, 1);\n }\n };\n return SegmentObject;\n }();\n exports.SegmentObject = SegmentObject;\n}).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./packages/bimAir/src/gsDevFx/objects/segmentObject.ts.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAWA;AAMA;AALA;AAGA;AAGA;AACA;AACA;AAEA;AAAA;AACA;AACA;;AAKA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;;AAEA;;;;AAEA;AAAA;AACA;AACA;;AAEA;;;;AAEA;AAAA;AACA;AACA;;AAMA;;;;AAEA;AAAA;AACA;AACA;;AAEA;;;;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;;;AAUA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAKA;AAAA;AACA;AACA;AAGA;AACA;;AAEA;;;;AAKA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;;AAEA;;AAGA;AACA;;;AAIA;AACA;;;;AAEA;AAAA;AACA;AAEA;;;;AAEA;AAAA;AACA;AACA;;;;AAKA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;;AAEA;AAIA;AACA;AAEA;AACA;AACA;AACA;;;AAIA;AACA;AACA;AACA;;;;AAIA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAMA;AACA;AACA;AAKA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;;AAEA;AAMA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;;AAGA;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AAMA;AAIA;AAKA;AACA;AAMA;AACA;AACA;AACA;AACA;AAEA;AAcA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAOA;AACA;;;AAIA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AAMA;AAIA;AAKA;AACA;AAMA;AACA;AACA;AACA;AACA;AAEA;AACA;AAcA;AACA;AAcA;AACA;;AAEA;AAEA;AACA;AACA;AACA;;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AAEA;AAEA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAIA;AACA;;;AAIA;AACA;AAQA;AAIA;AACA;AACA;AAGA;AACA;;;AAGA;AACA;AAMA;AACA;AACA;AAQA;AACA;AAKA;AACA;AACA;AACA;AASA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAGA;AACA;AACA;AAQA;AACA;AAEA;AAKA;AACA;AAOA;AACA;AAEA;AAKA;AACA;AAKA;AACA;AACA;AACA;;AAEA;AAKA;AACA;AACA;AAGA;;AAEA;AACA;AAAA;AArmBA","sources":["webpack://bimlight-platform/./packages/bimAir/src/gsDevFx/objects/segmentObject.ts?f9cb"],"sourcesContent":["import * as Longan from \"gs-longan\";\r\nimport { Matrix4, Segment } from \"gs-longan\";\r\nimport { Material } from \"./material\";\r\nimport { CuttingCreateType, CuttingOptions } from \"./cuttingOptions\";\r\nimport { Viewer } from \"../viewer\";\r\nimport { TreeNodeObject } from \"./treeNodeObject\";\r\nimport { JS_Show_Path_ModellingMatrix } from \"gs-longan/longan/gs.viewer\";\r\nimport { InstanceLightModel } from \"./instancesObjects/instanceLightModel\";\r\nimport { LightModel } from \"./lightModel\";\r\nimport { ReferenceLightModel } from \"./referenceLightModel\";\r\n\r\nexport class SegmentObject {\r\n  private _viewer: Viewer = null;\r\n  private _segment: Segment;\r\n  private _treeNodeObject: TreeNodeObject;\r\n  private matrixList = [];\r\n\r\n  constructor(viewer: Viewer, segment: Segment) {\r\n    this._segment = segment;\r\n    this._viewer = viewer;\r\n  }\r\n\r\n  public get treeNodeOject() {\r\n    if (!this._treeNodeObject) {\r\n      this._treeNodeObject =\r\n        this._viewer.structureTreeManager.getTreeNodeObjectByNodeKey(\r\n          this.segment.key\r\n        );\r\n    }\r\n    return this._treeNodeObject;\r\n  }\r\n\r\n  public get viewer(): Viewer {\r\n    return this._viewer;\r\n  }\r\n\r\n  public get model() {\r\n    if (this.treeNodeOject) {\r\n      return this.treeNodeOject.model;\r\n    }\r\n  }\r\n\r\n  public get modelId() {\r\n    if (this.treeNodeOject) {\r\n      return this.treeNodeOject.modelId;\r\n    }\r\n  }\r\n\r\n  public get version() {\r\n    if (this.treeNodeOject && this.treeNodeOject.model) {\r\n      return (\r\n        this.treeNodeOject.model.renderObject as\r\n          | LightModel\r\n          | ReferenceLightModel\r\n      ).version;\r\n    }\r\n  }\r\n\r\n  public get componentId() {\r\n    if (this.treeNodeOject) {\r\n      return this.treeNodeOject.componentId;\r\n    }\r\n  }\r\n\r\n  public get materials(): Material[] {\r\n    let materials = [];\r\n    for (let i = 0; i < this._segment.styles.count(); i++) {\r\n      let styleSegment = this._segment.styles.items[i].segment;\r\n      if (this.viewer.styleSegment.subsegmentExists(styleSegment.name)) {\r\n        materials.push(\r\n          new Material(\r\n            this.viewer,\r\n            styleSegment.name,\r\n            styleSegment.renderingOptions.lockFaceColor\r\n          )\r\n        );\r\n      }\r\n    }\r\n\r\n    return materials;\r\n  }\r\n\r\n  public get name(): string {\r\n    return this._segment.name;\r\n  }\r\n\r\n  public get key(): number {\r\n    return this.segment.key;\r\n  }\r\n\r\n  /**\r\n   * 获取局部坐标\r\n   */\r\n  get localPosition() {\r\n    if (this.segment.modellingMatrix.matrix) {\r\n      return Longan.Matrix4.getTranslate(\r\n        new Float32Array(this.segment.modellingMatrix.matrix)\r\n      );\r\n    } else {\r\n      return [0, 0, 0];\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 获取世界坐标\r\n   */\r\n  get worldPosition() {\r\n    let process = this.viewer.process;\r\n    if (process) {\r\n      let viewer = process.activeViewer as Viewer;\r\n      if (viewer) {\r\n        let pathKeys = [];\r\n        let treeNode = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(\r\n          this.nodeKey\r\n        );\r\n        while (treeNode) {\r\n          if (treeNode.obj) {\r\n            pathKeys.push(treeNode.obj.segment.key);\r\n          } else {\r\n            pathKeys.push(treeNode.key);\r\n          }\r\n          treeNode = treeNode.parent;\r\n        }\r\n\r\n        let matrix = JS_Show_Path_ModellingMatrix(pathKeys);\r\n        return Longan.Matrix4.getTranslate(new Float32Array(matrix));\r\n      }\r\n    }\r\n\r\n    return null;\r\n  }\r\n\r\n  public get nodeKey(): string {\r\n    return this.key === undefined ? \"\" : this.key.toString();\r\n    // return this.key.toString();\r\n  }\r\n\r\n  get segment() {\r\n    return this._segment;\r\n  }\r\n\r\n  /**\r\n   * 构件的尺寸，包含点数量、面数量、几何数量\r\n   */\r\n  get size() {\r\n    if (this.segment) {\r\n      let geometries: Longan.List<Longan.Geometry> = new Longan.List();\r\n      this.traverseSegment(this.segment, geometries);\r\n\r\n      let result = {\r\n        pos: 0,\r\n        face: 0,\r\n        geo: geometries.count(),\r\n      };\r\n      geometries.forEach((geo) => {\r\n        result.pos = result.pos + geo.shellSize.pos;\r\n        result.face = result.face + geo.shellSize.face;\r\n      });\r\n      return result;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  traverseSegment(\r\n    segment: Longan.Segment,\r\n    geometries: Longan.List<Longan.Geometry>\r\n  ) {\r\n    if (segment) {\r\n      geometries.items = geometries.items.concat(segment.geometries.items);\r\n\r\n      if (segment.includes) {\r\n        for (let i = 0; i < segment.includes.items.length; i++) {\r\n          const item = segment.includes.items[i].segment;\r\n          this.traverseSegment(item, geometries);\r\n        }\r\n      }\r\n\r\n      if (segment.subsegments) {\r\n        for (let i = 0; i < segment.subsegments.items.length; i++) {\r\n          const item = segment.subsegments.items[i];\r\n          this.traverseSegment(item, geometries);\r\n        }\r\n      }\r\n    }\r\n    return geometries;\r\n  }\r\n\r\n  public delete() {\r\n    this.segment.delete();\r\n  }\r\n\r\n  public rename(name) {\r\n    this.segment.rename(name);\r\n  }\r\n\r\n  /**\r\n   * 设置材质，若不传参数则清除构件上的材质\r\n   * @param material\r\n   */\r\n  public setMaterial(material?: Material) {\r\n    let components = [];\r\n    this.viewer.structureTreeManager.getComponents(\r\n      this.treeNodeOject,\r\n      components\r\n    );\r\n\r\n    if (material) {\r\n      this.viewer.materialManager.override(components, material);\r\n    } else {\r\n      this.viewer.materialManager.clearOverride(components);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 设置构件的高亮\r\n   * @param isHighlight 是否高亮\r\n   */\r\n  public setHighlight(isHighlight: boolean) {\r\n    if (isHighlight) {\r\n      this.viewer.highlightManager.highlight([this]);\r\n    } else {\r\n      this.viewer.highlightManager.clearHighlight([this]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 设置构件的可见\r\n   * @param visible 是否可见\r\n   */\r\n  public setVisible(visible: boolean) {\r\n    if (visible) {\r\n      this.viewer.invisibleManager.clearInvisible([this]);\r\n    } else {\r\n      this.viewer.invisibleManager.invisible([this]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 设置构件的隔离\r\n   * @param isIsolation 是否隔离\r\n   */\r\n  public setIsolation(isIsolation: boolean) {\r\n    if (isIsolation) {\r\n      this.viewer.isolationManager.isolation([this]);\r\n    } else {\r\n      this.viewer.isolationManager.clearIsolation([this]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 创建剖切，通过剖切选项创建剖切\r\n   * @param cuttingOptions 剖切选项\r\n   */\r\n  public setCutting(cuttingOptions: CuttingOptions) {\r\n    let bb = this.viewer.computeViewBoundingBox(this._segment);\r\n    if (bb) {\r\n      if (cuttingOptions.type == CuttingCreateType.BoundingBoxX) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[0], bb[4], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([1, 0, 0]);\r\n        cuttingOptions.length = bb[3] - bb[0];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxY) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[1], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 1, 0]);\r\n        cuttingOptions.length = bb[4] - bb[1];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxZ) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[4], bb[2]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 0, 1]);\r\n        cuttingOptions.length = bb[5] - bb[2];\r\n      }\r\n\r\n      cuttingOptions._bb = bb;\r\n    }\r\n\r\n    Longan.Vector.normalize(cuttingOptions._direct);\r\n    let xAxis = new Float32Array([1, 0, 0]);\r\n    if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\r\n      xAxis = new Float32Array([0, 1, 0]);\r\n    }\r\n    let yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\r\n    Longan.Vector.normalize(yAxis);\r\n    xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\r\n\r\n    let origin = Longan.GeometryOperators.distancePoint(\r\n      cuttingOptions._origin,\r\n      cuttingOptions._direct,\r\n      cuttingOptions._length * cuttingOptions._ratio\r\n    );\r\n\r\n    let bbLength = Longan.GeometryOperators.distance(\r\n      new Float32Array([bb[0], bb[1], bb[2]]),\r\n      new Float32Array([bb[3], bb[4], bb[5]])\r\n    );\r\n    let xPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n    Longan.Vector.reverse(xAxis);\r\n    let negXPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n\r\n    let p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n    let p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    Longan.Vector.reverse(yAxis);\r\n    let p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    let p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n\r\n    cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([\r\n      p1[0],\r\n      p1[1],\r\n      p1[2],\r\n      p2[0],\r\n      p2[1],\r\n      p2[2],\r\n      p3[0],\r\n      p3[1],\r\n      p3[2],\r\n      p4[0],\r\n      p4[1],\r\n      p4[2],\r\n    ]);\r\n    this._segment.visibility.setCuttingPlane(true);\r\n    this._segment.color.setCuttingFace(cuttingOptions.color);\r\n  }\r\n\r\n  public editCutting(cuttingOptions: CuttingOptions) {\r\n    let bb = cuttingOptions.bb;\r\n    if (!bb) {\r\n      bb = this.viewer.computeViewBoundingBox(this._segment);\r\n      cuttingOptions._bb = bb;\r\n    }\r\n    if (bb) {\r\n      if (cuttingOptions.type == CuttingCreateType.BoundingBoxX) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[0], bb[4], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([1, 0, 0]);\r\n        cuttingOptions.length = bb[3] - bb[0];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxY) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[1], bb[5]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 1, 0]);\r\n        cuttingOptions.length = bb[4] - bb[1];\r\n      } else if (cuttingOptions.type == CuttingCreateType.BoundingBoxZ) {\r\n        cuttingOptions.origin = Longan.Vector.divide(\r\n          Longan.Point.add(\r\n            new Float32Array([bb[0], bb[1], bb[2]]),\r\n            new Float32Array([bb[3], bb[4], bb[2]])\r\n          ),\r\n          2\r\n        );\r\n        cuttingOptions.direct = new Float32Array([0, 0, 1]);\r\n        cuttingOptions.length = bb[5] - bb[2];\r\n      }\r\n    }\r\n\r\n    Longan.Vector.normalize(cuttingOptions._direct);\r\n    let xAxis = new Float32Array([1, 0, 0]);\r\n    if (Longan.GeometryOperators.isParallel(cuttingOptions._direct, xAxis)) {\r\n      xAxis = new Float32Array([0, 1, 0]);\r\n    }\r\n    let yAxis = Longan.Vector.cross(cuttingOptions._direct, xAxis);\r\n    Longan.Vector.normalize(yAxis);\r\n    xAxis = Longan.Vector.cross(yAxis, cuttingOptions._direct);\r\n\r\n    let origin = Longan.GeometryOperators.distancePoint(\r\n      cuttingOptions._origin,\r\n      cuttingOptions._direct,\r\n      cuttingOptions._length * cuttingOptions._ratio\r\n    );\r\n\r\n    let bbLength = Longan.GeometryOperators.distance(\r\n      new Float32Array([bb[0], bb[1], bb[2]]),\r\n      new Float32Array([bb[3], bb[4], bb[5]])\r\n    );\r\n    let xPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n    Longan.Vector.reverse(xAxis);\r\n    let negXPoint = Longan.GeometryOperators.distancePoint(\r\n      origin,\r\n      xAxis,\r\n      bbLength\r\n    );\r\n\r\n    let p1 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n    let p2 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    Longan.Vector.reverse(yAxis);\r\n    let p3 = Longan.GeometryOperators.distancePoint(negXPoint, yAxis, bbLength);\r\n    let p4 = Longan.GeometryOperators.distancePoint(xPoint, yAxis, bbLength);\r\n\r\n    if (cuttingOptions.cuttingPlanes) {\r\n      cuttingOptions.cuttingPlanes.edit([\r\n        p1[0],\r\n        p1[1],\r\n        p1[2],\r\n        p2[0],\r\n        p2[1],\r\n        p2[2],\r\n        p3[0],\r\n        p3[1],\r\n        p3[2],\r\n        p4[0],\r\n        p4[1],\r\n        p4[2],\r\n      ]);\r\n    } else {\r\n      cuttingOptions._cuttingPlanes = this._segment.insertCuttingPlanes([\r\n        p1[0],\r\n        p1[1],\r\n        p1[2],\r\n        p2[0],\r\n        p2[1],\r\n        p2[2],\r\n        p3[0],\r\n        p3[1],\r\n        p3[2],\r\n        p4[0],\r\n        p4[1],\r\n        p4[2],\r\n      ]);\r\n      this._segment.visibility.setCuttingPlane(true);\r\n      this._segment.color.setCuttingFace(cuttingOptions.color);\r\n    }\r\n  }\r\n\r\n  public unsetCutting() {\r\n    let cuttingPlanes = this._segment.findGeometry(\"CuttingPlanes\");\r\n    if (cuttingPlanes) {\r\n      cuttingPlanes.delete();\r\n    }\r\n\r\n    this._segment.visibility.unsetCuttingPlane();\r\n    this.segment.color.unsetCuttingFace();\r\n  }\r\n\r\n  equals(obj: SegmentObject): boolean {\r\n    if (this.nodeKey == obj.nodeKey) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public static subtraction(\r\n    arr: SegmentObject[],\r\n    arr1: SegmentObject[]\r\n  ): SegmentObject[] {\r\n    let subtraction = [];\r\n    for (let i = 0; i < arr.length; i++) {\r\n      let exist = false;\r\n      for (let j = 0; j < arr1.length; j++) {\r\n        if (arr[i].equals(arr1[j])) {\r\n          exist = true;\r\n          break;\r\n        }\r\n      }\r\n\r\n      if (!exist) {\r\n        subtraction.push(arr[i]);\r\n      }\r\n    }\r\n\r\n    return subtraction;\r\n  }\r\n\r\n  /**\r\n   * SegmentObject 转成 TreeNodeObject\r\n   * @param viewer\r\n   * @param segmentObjects\r\n   * @returns\r\n   */\r\n  public static convertToTreeNodeObjects(\r\n    viewer,\r\n    segmentObjects: SegmentObject[]\r\n  ): TreeNodeObject[] {\r\n    let treeNodeObjects = [];\r\n    for (let i = 0; i < segmentObjects.length; i++) {\r\n      let value = viewer.structureTreeManager.getTreeNodeObjectByNodeKey(\r\n        segmentObjects[i].nodeKey\r\n      );\r\n      if (value) {\r\n        treeNodeObjects.push(value);\r\n      }\r\n    }\r\n    return treeNodeObjects;\r\n  }\r\n\r\n  /**\r\n   * 构件复制\r\n   * @returns\r\n   */\r\n  public copy(): SegmentObject {\r\n    return this.viewer.temporaryObjectManager.copy(this);\r\n  }\r\n\r\n  /**\r\n   * 构件平移\r\n   * @param x\r\n   * @param y\r\n   * @param z\r\n   */\r\n  translate(x: number, y: number, z: number) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n    // console.log(\r\n    //   \"this.segment.modellingMatrix.matrix\",\r\n    //   this.segment.modellingMatrix.matrix\r\n    // );\r\n    let matrix = Matrix4.identity();\r\n    Matrix4.translate(matrix, x, y, z);\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 构件放缩\r\n   * @param x\r\n   * @param y\r\n   * @param z\r\n   * @param origin 放缩原点，默认是包围盒中心\r\n   */\r\n  scale(x: number, y: number, z: number, origin?: number[]) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n\r\n    let center: number[];\r\n    if (origin) {\r\n      center = origin;\r\n    } else {\r\n      let bb = this.segment.boundingbox;\r\n      center = [(bb[0] + bb[3]) / 2, (bb[1] + bb[4]) / 2, (bb[2] + bb[5]) / 2];\r\n    }\r\n    let matrix = Matrix4.identity();\r\n    Matrix4.translate(matrix, -center[0], -center[1], -center[2]);\r\n    // this.segment.modellingMatrix.append(matrix);\r\n\r\n    Matrix4.scale(matrix, x, y, z);\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 构件旋转\r\n   * @param origin 旋转原点\r\n   * @param axis 旋转轴\r\n   * @param alpha 弧度\r\n   */\r\n  rotate(origin: number[], axis: number[], alpha: number) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n\r\n    let matrix = Matrix4.rotateByAxis(\r\n      new Float32Array(origin),\r\n      new Float32Array(axis),\r\n      alpha\r\n    );\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 构件旋转\r\n   * @param axis 旋转轴\r\n   * @param alpha 弧度\r\n   */\r\n  rotateByAxis(origin: number[], axis: number[], alpha: number) {\r\n    this.matrixList.push(this.segment.modellingMatrix.matrix);\r\n\r\n    let matrix = Matrix4.rotateByAxis(\r\n      new Float32Array(origin),\r\n      new Float32Array(axis),\r\n      alpha\r\n    );\r\n    this.segment.modellingMatrix.append(matrix);\r\n  }\r\n\r\n  /**\r\n   * 取消构件变换\r\n   */\r\n  unsetMatrix() {\r\n    if (this.matrixList.length > 0) {\r\n      this.segment.modellingMatrix.set(this.matrixList[0]);\r\n      console.log(\"this.segment.modellingMatrix.matrix\", this.matrixList);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 返回上一个构件变换\r\n   */\r\n  undoMatrix() {\r\n    if (this.matrixList.length > 0) {\r\n      this.segment.modellingMatrix.set(\r\n        this.matrixList[this.matrixList.length - 1]\r\n      );\r\n      this.matrixList.splice(this.matrixList.length - 1, 1);\r\n    }\r\n  }\r\n}\r\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./packages/bimAir/src/gsDevFx/objects/segmentObject.ts\n");
|
|
3798
3798
|
|
|
3799
3799
|
/***/ }),
|
|
3800
3800
|
|
|
@@ -7402,7 +7402,7 @@ eval("var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;__webpack_
|
|
|
7402
7402
|
\*******************************************************************************************************************************************************************************************************************************************************************************************************************************/
|
|
7403
7403
|
/***/ (function(module, exports, __webpack_require__) {
|
|
7404
7404
|
|
|
7405
|
-
eval("var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;__webpack_require__(/*! core-js/modules/es.object.to-string.js */ \"./node_modules/core-js/modules/es.object.to-string.js\");\n__webpack_require__(/*! core-js/modules/web.dom-collections.for-each.js */ \"./node_modules/core-js/modules/web.dom-collections.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.array.push.js */ \"./node_modules/core-js/modules/es.array.push.js\");\n__webpack_require__(/*! core-js/modules/es.function.name.js */ \"./node_modules/core-js/modules/es.function.name.js\");\n__webpack_require__(/*! core-js/modules/es.array.filter.js */ \"./node_modules/core-js/modules/es.array.filter.js\");\n__webpack_require__(/*! core-js/modules/es.array.map.js */ \"./node_modules/core-js/modules/es.array.map.js\");\n__webpack_require__(/*! core-js/modules/es.array.splice.js */ \"./node_modules/core-js/modules/es.array.splice.js\");\n__webpack_require__(/*! core-js/modules/es.array.concat.js */ \"./node_modules/core-js/modules/es.array.concat.js\");\n__webpack_require__(/*! core-js/modules/es.array.find-index.js */ \"./node_modules/core-js/modules/es.array.find-index.js\");\n__webpack_require__(/*! core-js/modules/es.object.to-string.js */ \"./node_modules/core-js/modules/es.object.to-string.js\");\n__webpack_require__(/*! core-js/modules/web.dom-collections.for-each.js */ \"./node_modules/core-js/modules/web.dom-collections.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.array.push.js */ \"./node_modules/core-js/modules/es.array.push.js\");\n__webpack_require__(/*! core-js/modules/es.function.name.js */ \"./node_modules/core-js/modules/es.function.name.js\");\n__webpack_require__(/*! core-js/modules/es.array.filter.js */ \"./node_modules/core-js/modules/es.array.filter.js\");\n__webpack_require__(/*! core-js/modules/es.array.map.js */ \"./node_modules/core-js/modules/es.array.map.js\");\n__webpack_require__(/*! core-js/modules/es.array.splice.js */ \"./node_modules/core-js/modules/es.array.splice.js\");\n__webpack_require__(/*! core-js/modules/es.array.concat.js */ \"./node_modules/core-js/modules/es.array.concat.js\");\n__webpack_require__(/*! core-js/modules/es.array.find-index.js */ \"./node_modules/core-js/modules/es.array.find-index.js\");\n!(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__, exports, __webpack_require__(/*! tslib */ \"./node_modules/tslib/tslib.es6.js\"), __webpack_require__(/*! vue-property-decorator */ \"./node_modules/vue-property-decorator/lib/vue-property-decorator.js\"), __webpack_require__(/*! gs-longan */ \"./packages/longan/src/index.ts\"), __webpack_require__(/*! ../../../../gsDevFx/api */ \"./packages/bimAir/src/gsDevFx/api/index.ts\"), __webpack_require__(/*! ../../../../components/gs/gsDivider/gs-divider.vue */ \"./packages/bimAir/src/components/gs/gsDivider/gs-divider.vue\"), __webpack_require__(/*! ../../../../components/el/tree */ \"./packages/bimAir/src/components/el/tree/index.js\"), __webpack_require__(/*! element-ui */ \"./node_modules/element-ui/lib/element-ui.common.js\"), __webpack_require__(/*! ../../../module/createMenu */ \"./packages/bimAir/src/viewerWrapper/module/createMenu.tsx\"), __webpack_require__(/*! ../../../../store/structureTree */ \"./packages/bimAir/src/store/structureTree.ts\"), __webpack_require__(/*! gs-longan/longan/idb */ \"./packages/longan/src/longan/idb.ts\"), __webpack_require__(/*! ../structureTreeBus */ \"./packages/bimAir/src/viewerWrapper/panels/structureTree/structureTreeBus.ts\")], __WEBPACK_AMD_DEFINE_RESULT__ = (function (require, exports, tslib_1, vue_property_decorator_1, Longan, LonganApi, gs_divider_vue_1, tree_1, element_ui_1, createMenu_1, structureTree_1, idb_1, structureTreeBus_1) {\n \"use strict\";\n\n Object.defineProperty(exports, \"__esModule\", ({\n value: true\n }));\n Longan = tslib_1.__importStar(Longan);\n LonganApi = tslib_1.__importStar(LonganApi);\n gs_divider_vue_1 = tslib_1.__importDefault(gs_divider_vue_1);\n tree_1 = tslib_1.__importDefault(tree_1);\n structureTree_1 = tslib_1.__importDefault(structureTree_1);\n idb_1 = tslib_1.__importDefault(idb_1);\n structureTreeBus_1 = tslib_1.__importDefault(structureTreeBus_1);\n vue_property_decorator_1.Vue.use(tree_1.default);\n vue_property_decorator_1.Vue.use(element_ui_1.Button);\n vue_property_decorator_1.Vue.use(element_ui_1.Input);\n vue_property_decorator_1.Vue.use(element_ui_1.Form);\n vue_property_decorator_1.Vue.use(element_ui_1.FormItem);\n var InterfaceStructureTree = function (_super) {\n tslib_1.__extends(InterfaceStructureTree, _super);\n function InterfaceStructureTree() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.searchValue = \"\";\n _this.treeProps = {\n label: \"name\",\n children: \"childNodes\",\n isLeaf: \"isLeaf\",\n expaned: \"expaned\"\n };\n _this.treeCheckedNos = [];\n _this.treeExpandAll = true;\n _this.draggingNode = null;\n _this.treeModelStructure = null;\n _this.selectedKey = -1;\n _this.selectedPath = \"\";\n _this.checkKeys = [];\n _this.invisibleKeys = [];\n _this.expandedKeys = [];\n _this.currentTreeKey = null;\n _this.isEditingKey = null;\n _this.nameValue = \"\";\n _this.modelObjectsClone = [];\n _this.parentSegmentKey = null;\n _this.treeNodeHoverKey = null;\n _this.isTreeEditing = false;\n _this.operatorList = [];\n _this.isolationIds = [];\n _this.levelOneData = [];\n _this.loopFlag = false;\n _this.selectedGslNode = null;\n _this.nodePath = [];\n _this.chooseNode = null;\n _this.rootNode = null;\n _this.lastNoCheckedRootNodes = [];\n _this.count = 0;\n _this.end = false;\n _this.isolationKeys = [];\n _this.isTreeLocate = localStorage.getItem(\"isTreeLocate\") !== \"false\";\n _this.checkStrictly = false;\n _this.draggingNodeChecked = true;\n _this.buttonList = [{\n name: \"编辑\",\n children: [{\n name: \"添加\",\n clickFun: function clickFun() {\n _this.addRenderObjectClick();\n }\n }, {\n name: \"重命名\",\n clickFun: function clickFun() {\n _this.renameRenderObjectClick();\n }\n }, {\n name: \"删除\",\n clickFun: function clickFun() {\n _this.deleteRenderObjectClick();\n }\n }]\n }, {\n name: \"隐藏\",\n children: [{\n name: \"隐藏选中对象\",\n clickFun: function clickFun() {\n _this.hideObject();\n }\n }, {\n name: \"隐藏其他对象\",\n clickFun: function clickFun() {\n _this.reHideObject();\n }\n }, {\n name: \"显示全部对象\",\n clickFun: function clickFun() {\n _this.clearHideObject();\n }\n }]\n }, {\n name: \"隔离\",\n children: [{\n name: \"隔离选中对象\",\n clickFun: function clickFun() {\n _this.isolateObject();\n }\n }, {\n name: \"隔离其他对象\",\n clickFun: function clickFun() {\n _this.isolateOtherObjects();\n }\n }, {\n name: \"取消隔离\",\n clickFun: function clickFun() {\n _this.clearIsolateObjects();\n }\n }]\n }, {\n name: \"展开\",\n children: [{\n name: \"展开一层\",\n clickFun: function clickFun() {\n _this.showLevel(1);\n }\n }, {\n name: \"展开二层\",\n clickFun: function clickFun() {\n _this.showLevel(2);\n }\n }, {\n name: \"展开三层\",\n clickFun: function clickFun() {\n _this.showLevel(3);\n }\n }, {\n name: \"全部收起\",\n clickFun: function clickFun() {\n _this.setAllExpand(false);\n }\n }]\n }];\n _this.structureTree = structureTree_1.default;\n _this.heighLight = function () {\n var segObj = _this.viewer.selectionManager.segmentObject;\n console.log(\"选中的对象:\", segObj, segObj.size);\n if (segObj) {\n var treeNodeObject = _this.viewer.structureTreeManager.treeNodes[segObj.nodeKey];\n var pathKeys = new Longan.List();\n if (treeNodeObject) {\n _this.getPathKeys(treeNodeObject, pathKeys);\n }\n var tree_2 = _this.$refs.structureTree;\n pathKeys.items.reverse().forEach(function (nodeKey) {\n setTimeout(function () {\n var node = tree_2.getNode(nodeKey);\n if (node) {\n node.expand();\n }\n }, 0);\n });\n setTimeout(function () {\n _this.locateCurrentNode(segObj.nodeKey);\n tree_2.setCurrentKey(segObj.nodeKey);\n }, 10);\n }\n };\n return _this;\n }\n Object.defineProperty(InterfaceStructureTree.prototype, \"viewer\", {\n get: function get() {\n return this.getViewer();\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(InterfaceStructureTree.prototype, \"tabs\", {\n get: function get() {\n var tabs = this.viewer.options.components.property.tabs;\n return tabs;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(InterfaceStructureTree.prototype, \"viewerType\", {\n get: function get() {\n return this.viewer.options.viewerType;\n },\n enumerable: false,\n configurable: true\n });\n InterfaceStructureTree.prototype.loadNode = function (node, resolve) {\n var _this = this;\n var _a, _b;\n if (!this.viewer) {\n resolve([]);\n }\n this.checkStrictly = true;\n if ((_b = (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.structureTreeManager) === null || _b === void 0 ? void 0 : _b.rootNode) {\n this.$nextTick(function () {\n var _a;\n _this.currentNode = node;\n _this.currentNodeResolve = resolve;\n if (node.level === 0) {\n var result = void 0;\n _this.level0Node = node;\n _this.level0NodeResolve = resolve;\n if (_this.viewer.renderObject && _this.viewer.renderObject.showTreeNode) {\n result = _this.getNodes([_this.viewer.structureTreeManager.rootNode]);\n if (_this.invisibleKeys.indexOf(result[0].nodeKey) === -1) {\n _this.checkKeys.push(result[0].nodeKey);\n }\n } else {\n result = _this.getNodes(_this.viewer.structureTreeManager.rootNode.childNodes);\n result.forEach(function (item) {\n if (_this.invisibleKeys.indexOf(item.nodeKey) === -1) {\n _this.checkKeys.push(item.nodeKey);\n }\n });\n }\n resolve(result);\n } else {\n var treeNode = (_a = _this.viewer.structureTreeManager) === null || _a === void 0 ? void 0 : _a.treeNodes[node.data.nodeKey];\n if (treeNode) {\n var childNodes = treeNode.childNodes;\n var result = _this.getNodes(childNodes);\n result.forEach(function (item) {\n if (_this.invisibleKeys.indexOf(item.nodeKey) === -1) {\n _this.checkKeys.push(item.nodeKey);\n }\n });\n return resolve(result);\n } else {\n return resolve([]);\n }\n }\n });\n setTimeout(function () {\n _this.checkStrictly = false;\n }, 20);\n }\n };\n InterfaceStructureTree.prototype.getNodes = function (treeNodeObjects) {\n var _this = this;\n var result = [];\n treeNodeObjects.forEach(function (item) {\n result.push({\n name: item.name,\n nodeKey: item.nodeKey,\n isShow: item.isShow,\n isLeaf: item.childNodes.length === 0,\n expaned: _this.expandedKeys.indexOf(item.nodeKey) !== -1\n });\n });\n return result;\n };\n InterfaceStructureTree.prototype.isTreeLocateChange = function (val) {\n localStorage.setItem(\"isTreeLocate\", val);\n this.isTreeLocate = val;\n };\n InterfaceStructureTree.prototype.locateCurrentNode = function (nodeKey) {\n if (!this.isTreeLocate) {\n return;\n }\n this.count = 0;\n this.end = false;\n var tree = document.getElementById(\"structureTree\");\n var node = this.$refs.structureTree.store.root;\n this.countExpandNode(node, nodeKey);\n var count = this.count;\n var parentElement = tree.parentElement;\n parentElement.scrollTo(0, count * 26 - 60);\n };\n InterfaceStructureTree.prototype.countExpandNode = function (node, nodeKey) {\n if (!this.end) {\n if (node.expanded || this.count === 0 || node.data.nodeKey === nodeKey) {\n this.count += 1;\n if (node.data && node.data.nodeKey === nodeKey) {\n this.end = true;\n return this.count;\n }\n if (node.childNodes) {\n for (var i = 0, len = node.childNodes.length; i < len; i++) {\n this.countExpandNode(node.childNodes[i], nodeKey);\n }\n }\n } else {\n this.count += 1;\n }\n }\n };\n InterfaceStructureTree.prototype.findRoVisible = function (insObj, checkedNos) {\n if (insObj.renderObject.visible) {\n checkedNos.push(insObj.no);\n }\n for (var i = 0; i < insObj.childObjects.length; i++) {\n this.findRoVisible(insObj.childObjects[i], checkedNos);\n }\n };\n InterfaceStructureTree.prototype.getModelObjects = function () {\n var viewer = this.viewer;\n if (viewer && viewer.instanceObject) {\n var insObj = viewer.instanceObject;\n var treeCheckedNos = [];\n this.findRoVisible(insObj, treeCheckedNos);\n this.treeCheckedNos = treeCheckedNos;\n var rootNode = this.componentData && this.componentData.structureTree ? this.componentData.structureTree[0] : this.viewer.structureTreeManager.rootNode;\n if (this.viewer.renderObject.showTreeNode) {\n this.currentTreeNodeData = rootNode;\n } else {\n this.currentTreeNodeData = rootNode.childNodes[0];\n }\n this.showLevel(1);\n } else {\n this.treeCheckedNos = [];\n }\n };\n InterfaceStructureTree.prototype.searchValueChange = function (val) {\n if (val) {\n var treeNodes = this.viewer.structureTreeManager.treeNodes;\n var tree_3 = this.$refs.structureTree;\n for (var key in treeNodes) {\n if (treeNodes[key].name.indexOf(this.searchValue) !== -1) {\n var treeNodeObject = treeNodes[key];\n var pathKeys = new Longan.List();\n if (treeNodeObject) {\n this.getPathKeys(treeNodeObject, pathKeys);\n }\n pathKeys.items.reverse().forEach(function (nodeKey) {\n var node = tree_3.getNode(nodeKey);\n if (node) {\n node.expand();\n }\n });\n }\n }\n }\n this.$refs.structureTree.filter(this.searchValue);\n };\n InterfaceStructureTree.prototype.filterNode = function (value, data) {\n if (!value) {\n return true;\n }\n return data.name.indexOf(value) !== -1;\n };\n InterfaceStructureTree.prototype.treeCheck = function (data, _a) {\n var checkedNodes = _a.checkedNodes,\n checkedKeys = _a.checkedKeys,\n halfCheckedNodes = _a.halfCheckedNodes,\n halfCheckedKeys = _a.halfCheckedKeys;\n var treeNodeObject = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n if (checkedNodes.map(function (item) {\n return item.nodeKey;\n }).indexOf(treeNodeObject.nodeKey) === -1) {\n this.viewer.invisibleManager.invisible([treeNodeObject]);\n this.invisibleKeys.push(treeNodeObject.nodeKey);\n console.log(\"隐藏节点keys\", this.invisibleKeys);\n } else {\n this.viewer.invisibleManager.clearInvisible([treeNodeObject]);\n var index = this.invisibleKeys.indexOf(treeNodeObject.nodeKey);\n if (index !== -1) {\n this.invisibleKeys.splice(index, 1);\n }\n }\n this.viewer.updateDisplay();\n if (this.viewer.options.components.structureTree.defaultTab.checkFun) {\n this.viewer.options.components.structureTree.defaultTab.checkFun(treeNodeObject, {\n checkedNodes: checkedNodes,\n checkedKeys: checkedKeys,\n halfCheckedNodes: halfCheckedNodes,\n halfCheckedKeys: halfCheckedKeys\n });\n }\n };\n InterfaceStructureTree.prototype.findInvisibleRootNodes = function (rootNode, halfCheckedNodes, invisibleRootNodes) {\n if (rootNode.checked === false) {\n if (halfCheckedNodes.indexOf(rootNode.data) === -1) {\n invisibleRootNodes.push(rootNode.data);\n } else {\n var childNodes = rootNode.childNodes;\n for (var i = 0; i < childNodes.length; i++) {\n this.findInvisibleRootNodes(childNodes[i], halfCheckedNodes, invisibleRootNodes);\n }\n }\n }\n };\n InterfaceStructureTree.prototype.treeNodeClick = function (data, node) {\n var treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n console.log(\"treeNodeClick\", node, treeNode);\n this.currentTreeNodeData = treeNode;\n this.viewer.selectionManager.clearAllSelectionAndHighlight();\n this.viewer.selectionManager.selectAndHighlight([treeNode]);\n this.viewer.locateObject(treeNode);\n this.viewer.panelManager.propertyPanel.getProperty(treeNode.segmentObject);\n if (this.viewer.options.components.structureTree.clickFun) {\n this.viewer.options.components.structureTree.clickFun(treeNode);\n }\n if (this.viewer.options.components.structureTree.defaultTab.clickFun) {\n this.viewer.options.components.structureTree.defaultTab.clickFun(treeNode);\n }\n this.viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.createTree = function (newTree, node) {\n var newNode = null;\n if (node.data) {\n newNode = {\n key: node.data.key,\n name: node.data.name,\n items: []\n };\n if (newTree.items) {\n newTree.items.push(newNode);\n } else {\n newTree.push(newNode);\n }\n }\n if (!newNode) {\n newNode = newTree;\n }\n for (var i = 0; i < node.childNodes.length; i++) {\n this.createTree(newNode, node.childNodes[i]);\n }\n };\n InterfaceStructureTree.prototype.getProperties = function (key) {\n var segment = new Longan.Segment(key);\n var jsonString = segment.property.showString(\"Properties\");\n var showParentProperty = segment.property.showBoolean(\"showParentProperties\");\n if (showParentProperty) {\n var key_1 = segment.owner.key;\n jsonString = this.getParentProperties(key_1);\n }\n return JSON.parse(jsonString);\n };\n InterfaceStructureTree.prototype.getParentProperties = function (key) {\n var segment = new Longan.Segment(key);\n var properties = segment.property.showString(\"Properties\");\n if (properties) {\n return properties;\n } else {\n return this.getParentProperties(segment.owner.key);\n }\n };\n InterfaceStructureTree.prototype.treeNodeDragStart = function (node, ev) {\n this.draggingNode = node;\n this.currentTreeNode = node;\n this.currentTreeNodeData = this.viewer.structureTreeManager.treeNodes[node.data.nodeKey];\n this.draggingNodeChecked = node.checked;\n console.log(\"this.draggingNodeChecked \", this.draggingNodeChecked);\n };\n InterfaceStructureTree.prototype.treeNodeDragEnter = function (draggingNode, overNode, ev) {\n console.log(\"this.treeNodeDragEnterTimer\");\n };\n InterfaceStructureTree.prototype.treeNodeDragEnd = function (draggingNode, dropNode, dropType) {};\n InterfaceStructureTree.prototype.treeNodeDrop = function (draggingNode, dropNode, dropType, ev) {\n var _this = this;\n console.log(\"dropNode.expend\", dropNode);\n this.$confirm(\"\\u662F\\u5426\\u5C06\\u8282\\u70B9\".concat(draggingNode.label, \"\\u79FB\\u52A8\\u5230\").concat(dropNode.label).concat(dropType == \"before\" ? \"之前\" : dropType == \"after\" ? \"之后\" : \"下\", \"?\"), \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\"\n }).then(function () {\n _this.dropConfirm(draggingNode, dropNode, dropType).then(function () {\n _this.$message({\n type: \"success\",\n message: \"移动成功!\"\n });\n if (dropNode === \"inner\") {\n structureTreeBus_1.default.$emit(\"updateTree\", dropNode.key);\n } else {\n structureTreeBus_1.default.$emit(\"updateTree\", dropNode.parent.key);\n }\n });\n }).catch(function () {\n _this.$message({\n type: \"info\",\n message: \"取消移动\"\n });\n structureTreeBus_1.default.$emit(\"updateTree\", dropNode.parent.key);\n });\n };\n InterfaceStructureTree.prototype.dropConfirm = function (draggingNode, dropNode, dropType) {\n var _this = this;\n function getIndex(parent, child) {\n for (var i = 0, len = parent.childNodes.length; i < len; i++) {\n var item = parent.childNodes[i];\n if (item.key === child.key) {\n return i;\n }\n }\n return -1;\n }\n var index = -1;\n var dropSegment;\n var draggingTreeNode = this.viewer.structureTreeManager.treeNodes[draggingNode.data.nodeKey];\n var dropTreeNode;\n var targetSegIndex;\n switch (dropType) {\n case \"inner\":\n dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.key];\n dropSegment = dropTreeNode.segment;\n targetSegIndex = dropTreeNode.childNodes.length;\n this.expandedKeys.push(dropNode.data.key);\n break;\n case \"before\":\n index = getIndex(dropNode.parent, dropNode);\n dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\n dropSegment = this.viewer.structureTreeManager.treeNodes[dropNode.key].segment.owner;\n targetSegIndex = index - 1;\n break;\n case \"after\":\n index = getIndex(dropNode.parent, dropNode);\n dropSegment = this.viewer.structureTreeManager.treeNodes[dropNode.key].segment.owner;\n dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\n targetSegIndex = index + 1;\n break;\n }\n var draggingNodeChecked = this.draggingNodeChecked;\n return draggingTreeNode.moveToIndexWithRequestApi(dropTreeNode, dropSegment, targetSegIndex).then(function () {\n console.log(\"this.$refs.structureTree \", _this.$refs.structureTree, draggingNode, draggingNode.key, draggingNodeChecked);\n _this.$refs.structureTree.setChecked(draggingNode.key, draggingNodeChecked, true);\n return _this.updateIndexedDB();\n });\n };\n InterfaceStructureTree.prototype.addRenderObjectClick = function () {\n var _this = this;\n var data = this.currentTreeNodeData;\n if (data.childNodes) {\n for (var i = 0; i < data.childNodes.length; i++) {\n if (data.childNodes[i].nodeKey === \"-1\") {\n return;\n }\n }\n }\n this.parentSegmentKey = data.key;\n this.nameValue = \"\";\n var parent = this.currentTreeNode;\n parent.expand();\n this.$refs.structureTree.append({\n name: \" \",\n nodeKey: \"-1\",\n isShow: true\n }, parent);\n this.isEditingKey = \"-1\";\n setTimeout(function () {\n _this.locateCurrentNode(\"-1\");\n var input = _this.$refs.editingTreeNodeInput;\n if (input) {\n input.focus();\n }\n }, 10);\n };\n InterfaceStructureTree.prototype.renameRenderObjectClick = function () {\n var _this = this;\n var data = this.currentTreeNodeData;\n this.isEditingKey = data.nodeKey;\n this.nameValue = data.name;\n setTimeout(function () {\n _this.$refs.editingTreeNodeInput.focus();\n }, 10);\n };\n InterfaceStructureTree.prototype.deleteRenderObjectClick = function () {\n var _this = this;\n var data = this.currentTreeNodeData;\n var node = this.currentTreeNode;\n element_ui_1.MessageBox.confirm(\"\\u786E\\u5B9A\\u5220\\u9664\".concat(data.name, \"\\u8282\\u70B9\\uFF1F\"), \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\"\n }).then(function () {\n _this.updateIndexedDB();\n _this.currentTreeNodeData.deleteWithRequestApi(true).then(function () {\n var children = node.parent.childNodes;\n var index = children.findIndex(function (d) {\n return d.data.nodeKey === node.data.nodeKey;\n });\n if (index >= 0) {\n children.splice(index, 1);\n } else {\n _this.$message.warning(\"节点删除出错\");\n }\n });\n });\n };\n InterfaceStructureTree.prototype.editRenderObjectConfirm = function (node, data) {\n var _this = this;\n var treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n if (data.nodeKey === \"-1\") {\n var segment = new LonganApi.Segment(this.parentSegmentKey);\n if (!this.nameValue) {\n element_ui_1.Message.warning(\"节点名不能为空\");\n return;\n }\n if (segment.subsegmentExists(this.nameValue)) {\n element_ui_1.Message.warning(\"此节点已存在,请重命名\");\n } else {\n var parent_1 = node.parent;\n var children = parent_1.childNodes;\n var index = children.findIndex(function (d) {\n return d.nodeKey === data.nodeKey;\n });\n children.splice(index, 1);\n var parentTreeNode = this.viewer.structureTreeManager.treeNodes[parent_1.data.nodeKey];\n console.log(\"parentTreeNode\", parentTreeNode);\n if (parentTreeNode) {\n parentTreeNode.addWithRequestApi(this.nameValue, true).then(function (treeNodeObject) {\n data.nodeKey = treeNodeObject.nodeKey;\n data.name = treeNodeObject.name;\n _this.isEditingKey = null;\n _this.nameValue = \"\";\n _this.$refs.structureTree.append({\n name: treeNodeObject.name,\n nodeKey: treeNodeObject.nodeKey,\n isShow: true\n }, parent_1);\n _this.$refs.structureTree.setChecked(data.nodeKey, true, true);\n _this.$refs.structureTree.setChecked(treeNodeObject.nodeKey, true, true);\n _this.updateIndexedDB();\n });\n }\n }\n } else {\n if (this.nameValue) {\n this.currentTreeNodeData.renameWithRequestApi(this.nameValue).then(function () {\n _this.updateIndexedDB();\n });\n data.name = this.nameValue;\n this.isEditingKey = null;\n this.nameValue = \"\";\n } else {\n element_ui_1.Message.warning(\"名字不能为空\");\n }\n }\n };\n InterfaceStructureTree.prototype.editRenderObjectCancel = function (node, data) {\n if (data.nodeKey === \"-1\") {\n var parent = node.parent;\n var children = parent.childNodes;\n var index = children.findIndex(function (d) {\n return d.nodeKey === data.nodeKey;\n });\n children.splice(index, 1);\n } else {\n this.isEditingKey = null;\n }\n };\n InterfaceStructureTree.prototype.updateIndexedDB = function () {\n var treeNode = this.currentTreeNodeData;\n idb_1.default.getInstance(treeNode.modelId).del(treeNode.modelId + \"?v=\" + treeNode.model.renderObject.version);\n };\n InterfaceStructureTree.prototype.treeNodeMouseOver = function (data) {\n this.treeNodeHoverKey = data.key;\n };\n InterfaceStructureTree.prototype.treeNodeMouseLeave = function (data) {\n this.treeNodeHoverKey = null;\n };\n InterfaceStructureTree.prototype.isBindModelExist = function (modelId) {\n return false;\n };\n InterfaceStructureTree.prototype.treeNodeContextMenuClick = function (e, data, node, nodeElement) {\n var treeNodeObject = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n console.log(\"treeNodeContextMenuClick\", e);\n this.currentTreeNodeData = treeNodeObject;\n this.currentTreeNode = node;\n (0, createMenu_1.createMenu)(e.pageX, e.pageY, this.buttonList);\n };\n InterfaceStructureTree.prototype.treeNodeExpand = function (data, node, e) {\n console.log(data, node, e);\n this.expandedKeys.push(data.nodeKey);\n };\n InterfaceStructureTree.prototype.treeNodeCollapse = function (data, node, e) {\n var index = this.expandedKeys.indexOf(data.nodeKey);\n if (index !== -1) {\n this.expandedKeys.splice(index, 1);\n }\n };\n InterfaceStructureTree.prototype.showLevel = function (level) {\n var _this = this;\n setTimeout(function () {\n var node = _this.currentTreeNodeData;\n _this.expandLevel(node, level);\n }, 10);\n };\n InterfaceStructureTree.prototype.expandLevel = function (node, level) {\n var _this = this;\n var _a;\n if (node) {\n node.loaded = false;\n var nodeDom = (_a = this.$refs.structureTree) === null || _a === void 0 ? void 0 : _a.getNode(node.nodeKey);\n if (nodeDom) {\n nodeDom.expand();\n }\n }\n setTimeout(function () {\n var currentLevel = level - 1;\n if (currentLevel > 0) {\n for (var i = 0; i < node.childNodes.length; i++) {\n var item = node.childNodes[i];\n if (item.childNodes && item.childNodes.length > 0) {\n _this.expandLevel(item, currentLevel);\n }\n }\n }\n }, 10);\n };\n InterfaceStructureTree.prototype.setAllExpand = function (state) {\n var nodes = this.$refs.structureTree.store.root;\n this.expandNode(nodes, state);\n };\n InterfaceStructureTree.prototype.expandNode = function (node, state) {\n node.expanded = state;\n for (var i = 0, len = node.childNodes.length; i < len; i++) {\n if (node.childNodes[i].childNodes.length > 0) {\n this.expandNode(node.childNodes[i], state);\n }\n }\n };\n InterfaceStructureTree.prototype.hideObject = function () {\n console.log(\"hideObject\");\n this.$refs.structureTree.setChecked(this.currentTreeNodeData, false, true);\n var viewer = this.viewer;\n viewer.invisibleManager.invisible([this.currentTreeNodeData]);\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.reHideObject = function () {\n var _this = this;\n var root = this.$refs.structureTree.root;\n console.log(\"root-------------\", root);\n root.childNodes.forEach(function (item) {\n _this.$refs.structureTree.setChecked(item.data.nodeKey, false, true);\n });\n this.$refs.structureTree.setChecked(this.currentTreeNodeData, true, true);\n var viewer = this.viewer;\n this.viewer.invisibleManager.invisibleInvert([this.currentTreeNodeData]);\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.clearHideObject = function () {\n var _this = this;\n var root = this.$refs.structureTree.root;\n root.childNodes.forEach(function (item) {\n _this.$refs.structureTree.setChecked(item.data.nodeKey, true, true);\n });\n var viewer = this.viewer;\n viewer.invisibleManager.clearAllInvisible();\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.checkChange = function (data) {\n var checkedNodes;\n var checkedKeys = this.$refs.structureTree.getCheckedKeys();\n var halfCheckedNodes = this.$refs.structureTree.getHalfCheckedNodes();\n var halfCheckedKeys;\n this.treeCheck(data, {\n checkedNodes: checkedNodes,\n checkedKeys: checkedKeys,\n halfCheckedNodes: halfCheckedNodes,\n halfCheckedKeys: halfCheckedKeys\n });\n };\n InterfaceStructureTree.prototype.isolateObject = function () {\n this.viewer.isolationManager.isolation([this.currentTreeNodeData.segmentObject]);\n this.viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.isolateOtherObjects = function () {\n var viewer = this.viewer;\n viewer.isolationManager.isolationInvert([this.currentTreeNodeData]);\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.clearIsolateObjects = function () {\n this.viewer.isolationManager.clearAllIsolation();\n this.viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.openEditAllRenderObjectClick = function (node, data) {};\n InterfaceStructureTree.prototype.editAllRenderObjectConfirm = function (data) {\n this.isTreeEditing = false;\n this.treeNodeHoverKey = null;\n };\n InterfaceStructureTree.prototype.editAllRenderObjectCancel = function (data) {};\n InterfaceStructureTree.prototype.setData = function () {\n this.$emit(\"setData\", {\n title: \"模型结构树\",\n top: \"20px\",\n left: \"20px\",\n height: \"600px\",\n width: \"300px\"\n });\n };\n InterfaceStructureTree.prototype.findTreeNodePath = function (node, targetKey, nodePath) {\n if (!this.loopFlag) {\n return;\n }\n var childNodes = node.childNodes;\n for (var i = 0; i < childNodes.length; i++) {\n var childNode = childNodes[i];\n var data = childNode.data;\n var deepCloneNodePath = tslib_1.__spreadArray([], tslib_1.__read(nodePath), false);\n deepCloneNodePath.push(childNode);\n if (data.key !== targetKey) {\n this.findTreeNodePath(childNode, targetKey, deepCloneNodePath);\n } else {\n this.nodePath.push(this.rootNode);\n for (var j = 0; j < deepCloneNodePath.length; j++) {\n this.nodePath.push(deepCloneNodePath[j]);\n }\n this.selectedGslNode = childNode;\n this.loopFlag = false;\n return deepCloneNodePath;\n }\n }\n };\n InterfaceStructureTree.prototype.getPathKeys = function (treeNodeObject, pathKeys) {\n if (treeNodeObject.nodeKey) {\n pathKeys.add(treeNodeObject.nodeKey);\n }\n if (treeNodeObject.parent) {\n this.getPathKeys(treeNodeObject.parent, pathKeys);\n }\n };\n InterfaceStructureTree.prototype.updateNode = function (treeNodeObject) {\n var _this = this;\n var pathKeys = new Longan.List();\n if (treeNodeObject) {\n this.getPathKeys(treeNodeObject, pathKeys);\n }\n pathKeys.items.reverse().forEach(function (nodeKey) {\n if (nodeKey === _this.level0Node.key) {\n _this.loadNode(_this.level0Node, _this.level0NodeResolve);\n } else {\n _this.loadNode(_this.currentNode, _this.currentNodeResolve);\n }\n });\n };\n InterfaceStructureTree.prototype.mounted = function () {\n var _this = this;\n this.setData();\n console.time(\"interfaceStructureTree getModelObjects\");\n this.getModelObjects();\n console.timeEnd(\"interfaceStructureTree getModelObjects\");\n structureTreeBus_1.default.$on(\"updateTree\", function (key) {\n var _a;\n console.log(\"structureTreeBus\");\n var tree = _this.$refs.structureTree;\n if (tree) {\n var keys = tree.getCheckedKeys();\n var expandedKeys = tree.getCheckedKeys();\n if (key !== undefined) {\n var treeNode = (_a = _this.viewer.structureTreeManager) === null || _a === void 0 ? void 0 : _a.treeNodes[key];\n _this.updateNode(treeNode);\n } else {\n _this.level0Node.childNodes = [];\n _this.checkKeys = [];\n _this.loadNode(_this.level0Node, _this.level0NodeResolve);\n _this.showLevel(1);\n }\n tree.setCheckedKeys(expandedKeys);\n }\n });\n this.$nextTick(function () {\n _this.viewer.onLButtonUp.add(_this.heighLight);\n });\n };\n InterfaceStructureTree.prototype.beforeDestroy = function () {\n if (this.viewer) {\n this.viewer.onLButtonUp.remove(this.heighLight);\n }\n };\n tslib_1.__decorate([(0, vue_property_decorator_1.Prop)()], InterfaceStructureTree.prototype, \"componentData\", void 0);\n tslib_1.__decorate([(0, vue_property_decorator_1.Inject)()], InterfaceStructureTree.prototype, \"getViewer\", void 0);\n InterfaceStructureTree = tslib_1.__decorate([(0, vue_property_decorator_1.Component)({\n components: {\n GsDivider: gs_divider_vue_1.default\n }\n })], InterfaceStructureTree);\n return InterfaceStructureTree;\n }(vue_property_decorator_1.Vue);\n exports[\"default\"] = InterfaceStructureTree;\n}).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/babel-loader/lib/index.js??clonedRuleSet-86.use[0]!./node_modules/babel-loader/lib/index.js!./node_modules/@vue/cli-plugin-typescript/node_modules/ts-loader/index.js??clonedRuleSet-88.use[1]!./packages/bimAir/src/viewerWrapper/panels/structureTree/panes/structureTree.tsx?vue&type=script&lang=js&.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBA;AACA;AACA;AACA;AACA;AAKA;AAAA;AAAA;AAAA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAMA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAQA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AASA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AAEA;AAGA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAGA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AACA;AACA;AACA;;AAEA;;AAw9BA;AAt9BA;AAAA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAEA;AAAA;;AACA;AACA;;AAEA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;;AAEA;AACA;AAGA;AACA;AACA;;AAEA;;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;;AAGA;AAEA;AACA;AAEA;;AAEA;AAEA;AAAA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAEA;;;AAGA;AACA;;;AAGA;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAKA;AACA;AACA;AACA;;AAGA;AACA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAGA;AACA;AACA;AACA;;AAEA;;;;AAKA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AAEA;AAEA;AAAA;AAAA;AAAA;AAIA;AAEA;AAEA;AAAA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAIA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;;AAGA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAQA;AAcA;AACA;AAKA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;;AAEA;AACA;;AAIA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;;;AAIA;AACA;;AAGA;AACA;;AAEA;AAEA;AACA;AACA;AAEA;AAGA;AACA;AACA;;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AASA;AAEA;AAQA;AAAA;AACA;AAEA;AAMA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAGA;AAEA;AACA;AACA;AAEA;AAIA;AAGA;AACA;AAAA;AAGA;AACA;AAGA;AAQA;AAKA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;;;;AAKA;AACA;AAaA;AACA;AAGA;AAEA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AAAA;AACA;AAGA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAKA;AACA;AACA;AAAA;AAAA;AACA;AAEA;AAEA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AAKA;AAKA;AACA;;;AAGA;AAEA;AACA;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;;;AAGA;AAEA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;;AAEA;AAEA;AACA;AACA;AAMA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAMA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AAEA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;;AAEA;AACA;AAEA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAIA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;;;AAGA;AAEA;AACA;AACA;AAKA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AAKA;AACA;AAKA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AASA;AACA;AACA;AACA;AAEA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;;AAGA;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AAEA;AAAA;AACA;AACA;AACA;;AAIA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AAEA;;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AASA;AAMA;AACA;AACA;AACA;AAWA;;AAKA;;AAEA;AAEA;AAGA;AAEA;AACA;AAEA;AACA;AAEA;;AAEA;AArqCA;AACA;AAFA;AAFA;AAAA;AAAA;AACA;AAwqCA;AAAA;AAvqCA","sources":["webpack://bimlight-platform/./packages/bimAir/src/viewerWrapper/panels/structureTree/panes/structureTree.tsx?6e16"],"sourcesContent":["import { Component, Inject, Prop, Vue, Watch } from \"vue-property-decorator\";\r\nimport * as Longan from \"gs-longan\";\r\nimport * as LonganApi from \"../../../../gsDevFx/api\";\r\nimport GsDivider from \"../../../../components/gs/gsDivider/gs-divider.vue\";\r\n\r\nimport Tree from \"../../../../components/el/tree\";\r\nimport { Button, Input, Form, FormItem, Message, MessageBox } from \"element-ui\";\r\nimport { ButtonConfig, createMenu } from \"../../../module/createMenu\";\r\nimport structureTree from \"../../../../store/structureTree\";\r\nimport { ComponentSelector } from \"../../../../gsDevFx/operators/componentSelector\";\r\nimport { TreeNodeObject } from \"../../../../gsDevFx/objects/treeNodeObject\";\r\nimport { Viewer } from \"../../../../gsDevFx/viewer\";\r\nimport IDB from \"gs-longan/longan/idb\";\r\nimport { LightModel } from \"../../../../gsDevFx/objects/lightModel\";\r\nimport { ReferenceLightModel } from \"../../../../gsDevFx/objects/referenceLightModel\";\r\nimport structureTreeBus from \"../structureTreeBus\";\r\n\r\nVue.use(Tree);\r\nVue.use(Button);\r\nVue.use(Input);\r\nVue.use(Form);\r\nVue.use(FormItem);\r\n\r\n@Component({\r\n  components: { GsDivider },\r\n})\r\nexport default class InterfaceStructureTree extends Vue {\r\n  @Prop() componentData;\r\n  @Inject() getViewer;\r\n  searchValue = \"\";\r\n  treeProps = {\r\n    label: \"name\",\r\n    children: \"childNodes\",\r\n    isLeaf: \"isLeaf\",\r\n    expaned: \"expaned\",\r\n  };\r\n  treeCheckedNos = [];\r\n  treeExpandAll = true;\r\n  draggingNode = null;\r\n\r\n  treeModelStructure = null;\r\n\r\n  selectedKey = -1;\r\n  selectedPath = \"\";\r\n  // 勾选的keys\r\n  checkKeys = [];\r\n  // 隐藏的keys\r\n  invisibleKeys = [];\r\n  // 展开的keys\r\n  expandedKeys = [];\r\n  currentTreeKey = null;\r\n  isEditingKey: string = null;\r\n  nameValue = \"\";\r\n  // modelObjects: TreeNodeObject[] = [];\r\n  modelObjectsClone = [];\r\n\r\n  parentSegmentKey: number = null;\r\n  treeNodeHoverKey = null;\r\n  isTreeEditing = false;\r\n  operatorList = [];\r\n  contextMenu;\r\n  currentTreeNodeData: TreeNodeObject;\r\n  currentTreeNode;\r\n\r\n  // 隔离id列表\r\n  isolationIds = [];\r\n  levelOneData = [];\r\n\r\n  loopFlag = false;\r\n  selectedGslNode = null;\r\n  nodePath = [];\r\n  chooseNode = null;\r\n  rootNode = null;\r\n  lastNoCheckedRootNodes = [];\r\n\r\n  count = 0;\r\n  end = false;\r\n  isolationKeys = [];\r\n\r\n  isTreeLocate = localStorage.getItem(\"isTreeLocate\") !== \"false\";\r\n\r\n  level0Node;\r\n  level0NodeResolve;\r\n\r\n  currentNode;\r\n  currentNodeResolve;\r\n\r\n  checkStrictly = false;\r\n  draggingNodeChecked = true;\r\n\r\n  buttonList: ButtonConfig[] = [\r\n    {\r\n      name: \"编辑\",\r\n      children: [\r\n        {\r\n          name: \"添加\",\r\n          clickFun: () => {\r\n            this.addRenderObjectClick();\r\n          },\r\n        },\r\n        {\r\n          name: \"重命名\",\r\n          clickFun: () => {\r\n            this.renameRenderObjectClick();\r\n          },\r\n        },\r\n        {\r\n          name: \"删除\",\r\n          clickFun: () => {\r\n            this.deleteRenderObjectClick();\r\n          },\r\n        },\r\n      ],\r\n    },\r\n    // {\r\n    //   name: \"高亮选中对象\",\r\n    //   key: \"highlight\",\r\n    //   clickFun: () => {\r\n    //     //this.componentSelectAndHeighlight();\r\n    //   },\r\n    // },\r\n    {\r\n      name: \"隐藏\",\r\n      children: [\r\n        {\r\n          name: \"隐藏选中对象\",\r\n          clickFun: () => {\r\n            this.hideObject();\r\n          },\r\n        },\r\n        {\r\n          name: \"隐藏其他对象\",\r\n          clickFun: () => {\r\n            this.reHideObject();\r\n          },\r\n        },\r\n        {\r\n          name: \"显示全部对象\",\r\n          clickFun: () => {\r\n            this.clearHideObject();\r\n          },\r\n        },\r\n      ],\r\n    },\r\n    {\r\n      name: \"隔离\",\r\n      children: [\r\n        {\r\n          name: \"隔离选中对象\",\r\n          clickFun: () => {\r\n            this.isolateObject();\r\n          },\r\n        },\r\n        {\r\n          name: \"隔离其他对象\",\r\n          clickFun: () => {\r\n            this.isolateOtherObjects();\r\n          },\r\n        },\r\n        {\r\n          name: \"取消隔离\",\r\n          clickFun: () => {\r\n            this.clearIsolateObjects();\r\n          },\r\n        },\r\n      ],\r\n    },\r\n    {\r\n      name: \"展开\",\r\n      children: [\r\n        {\r\n          name: \"展开一层\",\r\n          clickFun: () => {\r\n            this.showLevel(1);\r\n          },\r\n        },\r\n        {\r\n          name: \"展开二层\",\r\n          clickFun: () => {\r\n            this.showLevel(2);\r\n          },\r\n        },\r\n        {\r\n          name: \"展开三层\",\r\n          clickFun: () => {\r\n            this.showLevel(3);\r\n          },\r\n        },\r\n        // {\r\n        //   name: \"全部展开\", key: \"showAll\", clickFun: () => {\r\n        //     this.setAllExpand(true)\r\n        //   }\r\n        // },\r\n        {\r\n          name: \"全部收起\",\r\n          clickFun: () => {\r\n            this.setAllExpand(false);\r\n          },\r\n        },\r\n      ],\r\n    },\r\n  ];\r\n\r\n  structureTree = structureTree;\r\n  treeNodeDragEnterTimer;\r\n\r\n  heighLight = () => {\r\n    let segObj = this.viewer.selectionManager.segmentObject;\r\n    console.log(\"选中的对象：\", segObj, segObj.size);\r\n    if (segObj) {\r\n      let treeNodeObject =\r\n        this.viewer.structureTreeManager.treeNodes[segObj.nodeKey];\r\n      let pathKeys: Longan.List<string> = new Longan.List();\r\n      if (treeNodeObject) {\r\n        this.getPathKeys(treeNodeObject, pathKeys);\r\n      }\r\n\r\n      let tree = this.$refs.structureTree as any;\r\n      pathKeys.items.reverse().forEach((nodeKey) => {\r\n        // 节点加载完后再展开\r\n        setTimeout(() => {\r\n          let node = tree.getNode(nodeKey);\r\n          if (node) {\r\n            node.expand();\r\n          }\r\n        }, 0);\r\n      });\r\n      // this.expandedKeys.push(segObj.nodeKey);\r\n      setTimeout(() => {\r\n        this.locateCurrentNode(segObj.nodeKey);\r\n        tree.setCurrentKey(segObj.nodeKey);\r\n      }, 10);\r\n    }\r\n  };\r\n\r\n  get viewer(): Viewer {\r\n    return this.getViewer();\r\n  }\r\n\r\n  get tabs() {\r\n    let tabs = this.viewer.options.components.property.tabs;\r\n    return tabs;\r\n  }\r\n\r\n  get viewerType() {\r\n    return this.viewer.options.viewerType;\r\n  }\r\n\r\n  loadNode(node, resolve) {\r\n    if (!this.viewer) {\r\n      resolve([]);\r\n    }\r\n    this.checkStrictly = true;\r\n    if (this.viewer?.structureTreeManager?.rootNode) {\r\n      this.$nextTick(() => {\r\n        this.currentNode = node;\r\n        this.currentNodeResolve = resolve;\r\n        if (node.level === 0) {\r\n          let result;\r\n          this.level0Node = node; //这里是关键！在data里面定义一个变量，将node.level == 0的node存起来\r\n          this.level0NodeResolve = resolve; //同\r\n          if (\r\n            this.viewer.renderObject &&\r\n            this.viewer.renderObject.showTreeNode\r\n          ) {\r\n            result = this.getNodes([this.viewer.structureTreeManager.rootNode]);\r\n            if (this.invisibleKeys.indexOf(result[0].nodeKey) === -1) {\r\n              this.checkKeys.push(result[0].nodeKey);\r\n            }\r\n          } else {\r\n            result = this.getNodes(\r\n              this.viewer.structureTreeManager.rootNode.childNodes\r\n            );\r\n            result.forEach((item) => {\r\n              if (this.invisibleKeys.indexOf(item.nodeKey) === -1) {\r\n                this.checkKeys.push(item.nodeKey);\r\n              }\r\n            });\r\n          }\r\n\r\n          resolve(result);\r\n        } else {\r\n          let treeNode =\r\n            this.viewer.structureTreeManager?.treeNodes[node.data.nodeKey];\r\n          if (treeNode) {\r\n            let childNodes = treeNode.childNodes;\r\n            let result = this.getNodes(childNodes);\r\n            result.forEach((item) => {\r\n              if (this.invisibleKeys.indexOf(item.nodeKey) === -1) {\r\n                this.checkKeys.push(item.nodeKey);\r\n              }\r\n            });\r\n            return resolve(result);\r\n          } else {\r\n            return resolve([]);\r\n          }\r\n        }\r\n      });\r\n\r\n      setTimeout(() => {\r\n        this.checkStrictly = false;\r\n        // console.log(\"树结构父子节点重新关联\");\r\n      }, 20);\r\n    }\r\n  }\r\n\r\n  getNodes(treeNodeObjects: TreeNodeObject[]): {\r\n    name: string;\r\n    nodeKey: string;\r\n    isShow: boolean;\r\n    isLeaf: boolean;\r\n    expaned: boolean;\r\n  }[] {\r\n    let result = [];\r\n    treeNodeObjects.forEach((item) => {\r\n      result.push({\r\n        name: item.name,\r\n        nodeKey: item.nodeKey,\r\n        isShow: item.isShow,\r\n        isLeaf: item.childNodes.length === 0,\r\n        expaned: this.expandedKeys.indexOf(item.nodeKey) !== -1,\r\n      });\r\n    });\r\n    return result;\r\n  }\r\n\r\n  isTreeLocateChange(val) {\r\n    localStorage.setItem(\"isTreeLocate\", val);\r\n    this.isTreeLocate = val;\r\n  }\r\n\r\n  locateCurrentNode(nodeKey) {\r\n    if (!this.isTreeLocate) {\r\n      return;\r\n    }\r\n    this.count = 0;\r\n    this.end = false;\r\n    let tree = document.getElementById(\"structureTree\");\r\n    let node = (this.$refs.structureTree as any).store.root;\r\n\r\n    this.countExpandNode(node, nodeKey);\r\n    let count = this.count;\r\n    let parentElement = tree.parentElement;\r\n    parentElement.scrollTo(0, count * 26 - 60);\r\n  }\r\n\r\n  // TODO：递归待优化，找到目标节点应该中断递归\r\n  countExpandNode(node, nodeKey) {\r\n    if (!this.end) {\r\n      if (node.expanded || this.count === 0 || node.data.nodeKey === nodeKey) {\r\n        this.count += 1;\r\n        if (node.data && node.data.nodeKey === nodeKey) {\r\n          this.end = true;\r\n          return this.count;\r\n        }\r\n        if (node.childNodes) {\r\n          for (let i = 0, len = node.childNodes.length; i < len; i++) {\r\n            // 遍历子节点\r\n            this.countExpandNode(node.childNodes[i], nodeKey);\r\n          }\r\n        }\r\n      } else {\r\n        this.count += 1;\r\n      }\r\n    }\r\n  }\r\n\r\n  findRoVisible(insObj: Longan.RenderInstanceObject, checkedNos: number[]) {\r\n    if (insObj.renderObject.visible) {\r\n      checkedNos.push(insObj.no);\r\n    }\r\n    for (let i = 0; i < insObj.childObjects.length; i++) {\r\n      this.findRoVisible(insObj.childObjects[i], checkedNos);\r\n    }\r\n  }\r\n\r\n  getModelObjects() {\r\n    let viewer = this.viewer;\r\n    if (viewer && viewer.instanceObject) {\r\n      let insObj = viewer.instanceObject;\r\n      let treeCheckedNos = [];\r\n      this.findRoVisible(insObj, treeCheckedNos);\r\n      this.treeCheckedNos = treeCheckedNos;\r\n\r\n      let rootNode =\r\n        this.componentData && this.componentData.structureTree\r\n          ? this.componentData.structureTree[0]\r\n          : this.viewer.structureTreeManager.rootNode;\r\n\r\n      if (this.viewer.renderObject.showTreeNode) {\r\n        this.currentTreeNodeData = rootNode;\r\n      } else {\r\n        this.currentTreeNodeData = rootNode.childNodes[0];\r\n      }\r\n\r\n      this.showLevel(1);\r\n    } else {\r\n      this.treeCheckedNos = [];\r\n    }\r\n  }\r\n\r\n  searchValueChange(val) {\r\n    if (val) {\r\n      let treeNodes = this.viewer.structureTreeManager.treeNodes;\r\n      let tree = this.$refs.structureTree as any;\r\n\r\n      for (let key in treeNodes) {\r\n        if (treeNodes[key].name.indexOf(this.searchValue) !== -1) {\r\n          let treeNodeObject = treeNodes[key];\r\n          let pathKeys: Longan.List<string> = new Longan.List();\r\n          if (treeNodeObject) {\r\n            this.getPathKeys(treeNodeObject, pathKeys);\r\n          }\r\n\r\n          pathKeys.items.reverse().forEach((nodeKey) => {\r\n            let node = tree.getNode(nodeKey);\r\n            if (node) {\r\n              node.expand();\r\n            }\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n    (this.$refs.structureTree as any).filter(this.searchValue);\r\n  }\r\n\r\n  filterNode(value, data): boolean {\r\n    if (!value) {\r\n      return true;\r\n    }\r\n    return data.name.indexOf(value) !== -1;\r\n  }\r\n\r\n  treeCheck(\r\n    data: TreeNodeObject,\r\n    { checkedNodes, checkedKeys, halfCheckedNodes, halfCheckedKeys }\r\n  ) {\r\n    // this.checkKeys = checkedKeys;\r\n    // console.log(\"this.checkKeys\", this.checkKeys);\r\n    let treeNodeObject =\r\n      this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n    if (\r\n      checkedNodes\r\n        .map((item) => item.nodeKey)\r\n        .indexOf(treeNodeObject.nodeKey) === -1\r\n    ) {\r\n      this.viewer.invisibleManager.invisible([treeNodeObject]);\r\n      this.invisibleKeys.push(treeNodeObject.nodeKey);\r\n      console.log(\"隐藏节点keys\", this.invisibleKeys);\r\n    } else {\r\n      this.viewer.invisibleManager.clearInvisible([treeNodeObject]);\r\n      let index = this.invisibleKeys.indexOf(treeNodeObject.nodeKey);\r\n      if (index !== -1) {\r\n        this.invisibleKeys.splice(index, 1);\r\n      }\r\n    }\r\n\r\n    this.viewer.updateDisplay();\r\n\r\n    if (this.viewer.options.components.structureTree.defaultTab.checkFun) {\r\n      this.viewer.options.components.structureTree.defaultTab.checkFun(\r\n        treeNodeObject,\r\n        {\r\n          checkedNodes,\r\n          checkedKeys,\r\n          halfCheckedNodes,\r\n          halfCheckedKeys,\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  findInvisibleRootNodes(rootNode, halfCheckedNodes, invisibleRootNodes) {\r\n    if (rootNode.checked === false) {\r\n      if (halfCheckedNodes.indexOf(rootNode.data) === -1) {\r\n        invisibleRootNodes.push(rootNode.data);\r\n      } else {\r\n        let childNodes = rootNode.childNodes;\r\n        for (let i = 0; i < childNodes.length; i++) {\r\n          this.findInvisibleRootNodes(\r\n            childNodes[i],\r\n            halfCheckedNodes,\r\n            invisibleRootNodes\r\n          );\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  // findNoObjTreeNodeObject(treeNodeObject: TreeNodeObject) {\r\n  //   if (treeNodeObject.obj) {\r\n  //     if (treeNodeObject.childNodes) {\r\n  //       return this.findNoObjTreeNodeObject(treeNodeObject.childNodes[0]);\r\n  //     } else {\r\n  //       return null;\r\n  //     }\r\n  //   } else {\r\n  //     return treeNodeObject;\r\n  //   }\r\n  // }\r\n\r\n  treeNodeClick(data, node) {\r\n    let treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n\r\n    // let noObjTreeNodeObject = this.findNoObjTreeNodeObject(treeNode);\r\n    // this.viewer.ensureSegmentAsynGeometry(noObjTreeNodeObject.segment.key);\r\n\r\n    console.log(\"treeNodeClick\", node, treeNode);\r\n    this.currentTreeNodeData = treeNode;\r\n    this.viewer.selectionManager.clearAllSelectionAndHighlight();\r\n    this.viewer.selectionManager.selectAndHighlight([treeNode]);\r\n    this.viewer.locateObject(treeNode);\r\n\r\n    this.viewer.panelManager.propertyPanel.getProperty(treeNode.segmentObject);\r\n\r\n    if (this.viewer.options.components.structureTree.clickFun) {\r\n      this.viewer.options.components.structureTree.clickFun(treeNode);\r\n    }\r\n    if (this.viewer.options.components.structureTree.defaultTab.clickFun) {\r\n      this.viewer.options.components.structureTree.defaultTab.clickFun(\r\n        treeNode\r\n      );\r\n    }\r\n    this.viewer.updateDisplay();\r\n  }\r\n\r\n  createTree(newTree, node) {\r\n    let newNode = null;\r\n    if (node.data) {\r\n      newNode = { key: node.data.key, name: node.data.name, items: [] };\r\n      if (newTree.items) {\r\n        newTree.items.push(newNode);\r\n      } else {\r\n        newTree.push(newNode);\r\n      }\r\n    }\r\n\r\n    if (!newNode) {\r\n      newNode = newTree;\r\n    }\r\n\r\n    for (let i = 0; i < node.childNodes.length; i++) {\r\n      this.createTree(newNode, node.childNodes[i]);\r\n    }\r\n  }\r\n\r\n  getProperties(key) {\r\n    let segment = new Longan.Segment(key);\r\n    let jsonString = segment.property.showString(\"Properties\");\r\n\r\n    let showParentProperty = segment.property.showBoolean(\r\n      \"showParentProperties\"\r\n    );\r\n    if (showParentProperty) {\r\n      let key = segment.owner.key;\r\n      jsonString = this.getParentProperties(key);\r\n    }\r\n\r\n    return JSON.parse(jsonString);\r\n  }\r\n\r\n  getParentProperties(key) {\r\n    let segment = new Longan.Segment(key);\r\n    let properties = segment.property.showString(\"Properties\");\r\n    if (properties) {\r\n      return properties;\r\n    } else {\r\n      return this.getParentProperties(segment.owner.key);\r\n    }\r\n  }\r\n\r\n  treeNodeDragStart(node, ev) {\r\n    this.draggingNode = node;\r\n    this.currentTreeNode = node;\r\n    this.currentTreeNodeData =\r\n      this.viewer.structureTreeManager.treeNodes[node.data.nodeKey];\r\n    this.draggingNodeChecked = node.checked;\r\n\r\n    console.log(\"this.draggingNodeChecked \", this.draggingNodeChecked);\r\n  }\r\n\r\n  treeNodeDragEnter(draggingNode, overNode, ev) {\r\n    // this.loadNode(overNode, this.level0NodeResolve);\r\n    console.log(\"this.treeNodeDragEnterTimer\");\r\n    // if (this.treeNodeDragEnterTimer) {\r\n    //   clearTimeout(this.treeNodeDragEnterTimer);\r\n    // }\r\n    // this.treeNodeDragEnterTimer = setTimeout(() => {\r\n    //   this.expandedKeys.push(overNode.data.nodeKey);\r\n    //   clearTimeout(this.treeNodeDragEnterTimer);\r\n    //   this.treeNodeDragEnterTimer = null;\r\n    // }, 500);\r\n  }\r\n\r\n  treeNodeDragEnd(draggingNode, dropNode, dropType) {\r\n    // if (dropType === \"inner\" && !dropNode.expanded) {\r\n    //   this.$message.warning(dropNode.label + \"节点未展开，无法移入\");\r\n    //   return false;\r\n    // }\r\n    // return true;\r\n  }\r\n\r\n  treeNodeDrop(draggingNode, dropNode, dropType, ev) {\r\n    console.log(\"dropNode.expend\", dropNode);\r\n\r\n    this.$confirm(\r\n      `是否将节点${draggingNode.label}移动到${dropNode.label}${\r\n        dropType == \"before\" ? \"之前\" : dropType == \"after\" ? \"之后\" : \"下\"\r\n      }?`,\r\n      \"提示\",\r\n      {\r\n        confirmButtonText: \"确定\",\r\n        cancelButtonText: \"取消\",\r\n        type: \"warning\",\r\n      }\r\n    )\r\n      .then(() => {\r\n        this.dropConfirm(draggingNode, dropNode, dropType).then(() => {\r\n          this.$message({\r\n            type: \"success\",\r\n            message: \"移动成功!\",\r\n          });\r\n          // structureTreeBus.$emit(\"updateTree\", draggingNode.key);\r\n          if (dropNode === \"inner\") {\r\n            structureTreeBus.$emit(\"updateTree\", dropNode.key);\r\n          } else {\r\n            structureTreeBus.$emit(\"updateTree\", dropNode.parent.key);\r\n          }\r\n        });\r\n      })\r\n      .catch(() => {\r\n        this.$message({\r\n          type: \"info\",\r\n          message: \"取消移动\",\r\n        });\r\n        // structureTreeBus.$emit(\"updateTree\", draggingNode.parent.key);\r\n        structureTreeBus.$emit(\"updateTree\", dropNode.parent.key);\r\n      });\r\n  }\r\n\r\n  dropConfirm(draggingNode, dropNode, dropType) {\r\n    function getIndex(parent, child) {\r\n      for (let i = 0, len = parent.childNodes.length; i < len; i++) {\r\n        const item = parent.childNodes[i];\r\n        if (item.key === child.key) {\r\n          return i;\r\n        }\r\n      }\r\n      return -1;\r\n    }\r\n\r\n    let index = -1;\r\n    // let draggingSegment = new LonganApi.Segment(draggingNode.key);\r\n    let dropSegment;\r\n\r\n    let draggingTreeNode =\r\n      this.viewer.structureTreeManager.treeNodes[draggingNode.data.nodeKey];\r\n    let dropTreeNode;\r\n\r\n    let targetSegIndex;\r\n\r\n    switch (dropType) {\r\n      case \"inner\":\r\n        // dropSegment = new LonganApi.Segment(dropNode.key);\r\n        dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.key];\r\n        dropSegment = dropTreeNode.segment;\r\n        targetSegIndex = dropTreeNode.childNodes.length;\r\n        this.expandedKeys.push(dropNode.data.key);\r\n        break;\r\n      case \"before\":\r\n        index = getIndex(dropNode.parent, dropNode);\r\n        // dropSegment = new LonganApi.Segment(dropNode.parent.key);\r\n        dropTreeNode =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\r\n        dropSegment =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.key].segment\r\n            .owner;\r\n        targetSegIndex = index - 1;\r\n\r\n        break;\r\n      case \"after\":\r\n        index = getIndex(dropNode.parent, dropNode);\r\n        // dropSegment = new LonganApi.Segment(dropNode.parent.key);\r\n        dropSegment =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.key].segment\r\n            .owner;\r\n\r\n        dropTreeNode =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\r\n\r\n        targetSegIndex = index + 1;\r\n        break;\r\n    }\r\n    // draggingSegment.moveToIndex(dropSegment, targetSegIndex);\r\n    let draggingNodeChecked = this.draggingNodeChecked;\r\n    return draggingTreeNode\r\n      .moveToIndexWithRequestApi(dropTreeNode, dropSegment, targetSegIndex)\r\n      .then(() => {\r\n        console.log(\r\n          \"this.$refs.structureTree \",\r\n          this.$refs.structureTree,\r\n          draggingNode,\r\n          draggingNode.key,\r\n          draggingNodeChecked\r\n        );\r\n\r\n        (this.$refs.structureTree as any).setChecked(\r\n          draggingNode.key,\r\n          draggingNodeChecked,\r\n          true\r\n        );\r\n        return this.updateIndexedDB();\r\n      });\r\n  }\r\n\r\n  addRenderObjectClick() {\r\n    let data = this.currentTreeNodeData;\r\n    if (data.childNodes) {\r\n      for (let i = 0; i < data.childNodes.length; i++) {\r\n        if (data.childNodes[i].nodeKey === \"-1\") {\r\n          return;\r\n        }\r\n      }\r\n    }\r\n\r\n    this.parentSegmentKey = data.key;\r\n    this.nameValue = \"\";\r\n    // let newNodeData: TreeNodeObject = new TreeNodeObject(\r\n    //   this.viewer,\r\n    //   \" \",\r\n    //   null,\r\n    //   \"\"\r\n    // );\r\n\r\n    // if (!data.childNodes) {\r\n    //   data.childNodes = [];\r\n    // }\r\n    // newNodeData.parent = data;\r\n    // data.childNodes.push(newNodeData);\r\n    const parent = this.currentTreeNode;\r\n    parent.expand();\r\n    // this.expandedKeys.push(data.nodeKey);\r\n    // this.expandedKeys.push(\"-1\");\r\n    (this.$refs.structureTree as any).append(\r\n      {\r\n        name: \" \",\r\n        nodeKey: \"-1\",\r\n        isShow: true,\r\n      },\r\n      parent\r\n    );\r\n\r\n    this.isEditingKey = \"-1\";\r\n    setTimeout(() => {\r\n      this.locateCurrentNode(\"-1\");\r\n      let input = this.$refs.editingTreeNodeInput as any;\r\n      if (input) {\r\n        input.focus();\r\n      }\r\n    }, 10);\r\n  }\r\n\r\n  renameRenderObjectClick() {\r\n    let data = this.currentTreeNodeData;\r\n    this.isEditingKey = data.nodeKey;\r\n    this.nameValue = data.name;\r\n    setTimeout(() => {\r\n      (this.$refs.editingTreeNodeInput as any).focus();\r\n    }, 10);\r\n  }\r\n\r\n  deleteRenderObjectClick() {\r\n    let data = this.currentTreeNodeData;\r\n    let node = this.currentTreeNode;\r\n    MessageBox.confirm(`确定删除${data.name}节点？`, \"提示\", {\r\n      confirmButtonText: \"确定\",\r\n      cancelButtonText: \"取消\",\r\n      type: \"warning\",\r\n    }).then(() => {\r\n      this.updateIndexedDB();\r\n\r\n      this.currentTreeNodeData.deleteWithRequestApi(true).then(() => {\r\n        let children: any[] = node.parent.childNodes;\r\n        const index = children.findIndex(\r\n          (d) => d.data.nodeKey === node.data.nodeKey\r\n        );\r\n\r\n        if (index >= 0) {\r\n          children.splice(index, 1);\r\n        } else {\r\n          this.$message.warning(\"节点删除出错\");\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  editRenderObjectConfirm(node, data) {\r\n    let treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n\r\n    // 添加\r\n    if (data.nodeKey === \"-1\") {\r\n      let segment = new LonganApi.Segment(this.parentSegmentKey);\r\n      if (!this.nameValue) {\r\n        Message.warning(\"节点名不能为空\");\r\n        return;\r\n      }\r\n      if (segment.subsegmentExists(this.nameValue)) {\r\n        Message.warning(\"此节点已存在，请重命名\");\r\n      } else {\r\n        // let parent = data.parent;\r\n        //删除临时的\r\n        // parent.removeChildNode(treeNode);\r\n        // treeNode.delete();\r\n        const parent = node.parent;\r\n        const children = parent.childNodes;\r\n        const index = children.findIndex((d) => d.nodeKey === data.nodeKey);\r\n        children.splice(index, 1);\r\n\r\n        let parentTreeNode =\r\n          this.viewer.structureTreeManager.treeNodes[parent.data.nodeKey];\r\n        console.log(\"parentTreeNode\", parentTreeNode);\r\n        if (parentTreeNode) {\r\n          parentTreeNode\r\n            .addWithRequestApi(this.nameValue, true)\r\n            .then((treeNodeObject) => {\r\n              // treeNode = treeNodeObject;\r\n              data.nodeKey = treeNodeObject.nodeKey;\r\n              data.name = treeNodeObject.name;\r\n              this.isEditingKey = null;\r\n              this.nameValue = \"\";\r\n              (this.$refs.structureTree as any).append(\r\n                {\r\n                  name: treeNodeObject.name,\r\n                  nodeKey: treeNodeObject.nodeKey,\r\n                  isShow: true,\r\n                },\r\n                parent\r\n              );\r\n              (this.$refs.structureTree as any).setChecked(\r\n                data.nodeKey,\r\n                true,\r\n                true\r\n              );\r\n              (this.$refs.structureTree as any).setChecked(\r\n                treeNodeObject.nodeKey,\r\n                true,\r\n                true\r\n              );\r\n              this.updateIndexedDB();\r\n            });\r\n        }\r\n      }\r\n    } else {\r\n      // 编辑\r\n      if (this.nameValue) {\r\n        this.currentTreeNodeData\r\n          .renameWithRequestApi(this.nameValue)\r\n          .then(() => {\r\n            this.updateIndexedDB();\r\n          });\r\n\r\n        data.name = this.nameValue;\r\n        this.isEditingKey = null;\r\n        this.nameValue = \"\";\r\n      } else {\r\n        Message.warning(\"名字不能为空\");\r\n      }\r\n    }\r\n  }\r\n\r\n  editRenderObjectCancel(node, data) {\r\n    // 添加\r\n    if (data.nodeKey === \"-1\") {\r\n      const parent = node.parent;\r\n      const children = parent.childNodes;\r\n      const index = children.findIndex((d) => d.nodeKey === data.nodeKey);\r\n      children.splice(index, 1);\r\n    } else {\r\n      // 编辑\r\n      this.isEditingKey = null;\r\n    }\r\n  }\r\n\r\n  updateIndexedDB() {\r\n    let treeNode = this.currentTreeNodeData;\r\n    IDB.getInstance(treeNode.modelId).del(\r\n      treeNode.modelId +\r\n        \"?v=\" +\r\n        (treeNode.model.renderObject as LightModel | ReferenceLightModel)\r\n          .version\r\n    );\r\n  }\r\n\r\n  treeNodeMouseOver(data) {\r\n    // if (this.isTreeEditing) {\r\n    this.treeNodeHoverKey = data.key;\r\n    // }\r\n  }\r\n\r\n  treeNodeMouseLeave(data) {\r\n    // if (this.isTreeEditing) {\r\n    this.treeNodeHoverKey = null;\r\n    // }\r\n  }\r\n\r\n  isBindModelExist(modelId) {\r\n    // for (let i = 0; i < this.modelList.length; i++) {\r\n    //     if (this.modelList[i].lightModelId === modelId) {\r\n    //         return true\r\n    //     }\r\n    // }\r\n    return false;\r\n  }\r\n\r\n  treeNodeContextMenuClick(e, data, node, nodeElement) {\r\n    let treeNodeObject =\r\n      this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n    console.log(\"treeNodeContextMenuClick\", e);\r\n    this.currentTreeNodeData = treeNodeObject;\r\n    this.currentTreeNode = node;\r\n    createMenu(e.pageX, e.pageY, this.buttonList);\r\n  }\r\n\r\n  treeNodeExpand(data, node, e) {\r\n    console.log(data, node, e);\r\n    this.expandedKeys.push(data.nodeKey);\r\n  }\r\n\r\n  treeNodeCollapse(data, node, e) {\r\n    let index = this.expandedKeys.indexOf(data.nodeKey);\r\n    if (index !== -1) {\r\n      this.expandedKeys.splice(index, 1);\r\n    }\r\n  }\r\n\r\n  showLevel(level: number) {\r\n    setTimeout(() => {\r\n      // this.expandedKeys = [];\r\n      let node = this.currentTreeNodeData;\r\n      this.expandLevel(node, level);\r\n    }, 10);\r\n  }\r\n\r\n  expandLevel(node, level: number) {\r\n    // node.expanded = true;\r\n    if (node) {\r\n      node.loaded = false;\r\n\r\n      let nodeDom = (this.$refs.structureTree as any)?.getNode(node.nodeKey);\r\n      if (nodeDom) {\r\n        nodeDom.expand();\r\n      }\r\n    }\r\n    setTimeout(() => {\r\n      let currentLevel = level - 1;\r\n      if (currentLevel > 0) {\r\n        for (let i = 0; i < node.childNodes.length; i++) {\r\n          const item = node.childNodes[i];\r\n          if (item.childNodes && item.childNodes.length > 0) {\r\n            this.expandLevel(item, currentLevel);\r\n          }\r\n        }\r\n      }\r\n    }, 10);\r\n    // this.expandedKeys.push(node.key);\r\n  }\r\n\r\n  setAllExpand(state) {\r\n    let nodes = (this.$refs.structureTree as any).store.root;\r\n    this.expandNode(nodes, state);\r\n  }\r\n\r\n  expandNode(node, state) {\r\n    // 改变节点的自身expanded状态\r\n    node.expanded = state;\r\n    for (let i = 0, len = node.childNodes.length; i < len; i++) {\r\n      // 遍历子节点\r\n      if (node.childNodes[i].childNodes.length > 0) {\r\n        this.expandNode(node.childNodes[i], state);\r\n      }\r\n    }\r\n  }\r\n\r\n  hideObject() {\r\n    console.log(\"hideObject\");\r\n    (this.$refs.structureTree as any).setChecked(\r\n      this.currentTreeNodeData,\r\n      false,\r\n      true\r\n    );\r\n    let viewer = this.viewer;\r\n    viewer.invisibleManager.invisible([this.currentTreeNodeData]);\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  reHideObject() {\r\n    let root = (this.$refs.structureTree as any).root;\r\n    console.log(\"root-------------\", root);\r\n    root.childNodes.forEach((item) => {\r\n      (this.$refs.structureTree as any).setChecked(\r\n        item.data.nodeKey,\r\n        false,\r\n        true\r\n      );\r\n    });\r\n    (this.$refs.structureTree as any).setChecked(\r\n      this.currentTreeNodeData,\r\n      true,\r\n      true\r\n    );\r\n    let viewer = this.viewer;\r\n    this.viewer.invisibleManager.invisibleInvert([this.currentTreeNodeData]);\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  clearHideObject() {\r\n    let root = (this.$refs.structureTree as any).root;\r\n    root.childNodes.forEach((item) => {\r\n      (this.$refs.structureTree as any).setChecked(\r\n        item.data.nodeKey,\r\n        true,\r\n        true\r\n      );\r\n    });\r\n    let viewer = this.viewer;\r\n    viewer.invisibleManager.clearAllInvisible();\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  checkChange(data) {\r\n    let checkedNodes;\r\n    let checkedKeys = (this.$refs.structureTree as any).getCheckedKeys();\r\n    let halfCheckedNodes = (\r\n      this.$refs.structureTree as any\r\n    ).getHalfCheckedNodes();\r\n    let halfCheckedKeys;\r\n    this.treeCheck(data, {\r\n      checkedNodes,\r\n      checkedKeys,\r\n      halfCheckedNodes,\r\n      halfCheckedKeys,\r\n    });\r\n  }\r\n\r\n  isolateObject() {\r\n    this.viewer.isolationManager.isolation([\r\n      this.currentTreeNodeData.segmentObject,\r\n    ]);\r\n\r\n    this.viewer.updateDisplay();\r\n  }\r\n\r\n  isolateOtherObjects() {\r\n    let viewer = this.viewer;\r\n    viewer.isolationManager.isolationInvert([this.currentTreeNodeData]);\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  clearIsolateObjects() {\r\n    this.viewer.isolationManager.clearAllIsolation();\r\n    this.viewer.updateDisplay();\r\n  }\r\n\r\n  openEditAllRenderObjectClick(node, data) {\r\n    // this.modelObjectsClone = [...this.modelObjects];\r\n    // this.isTreeEditing = true;\r\n    // setTimeout(() => {\r\n    //   this.expandedKeys.push(data.childNodes[0].key);\r\n    //   this.treeNodeHoverKey = data.childNodes[0].key;\r\n    // }, 100);\r\n  }\r\n\r\n  editAllRenderObjectConfirm(data) {\r\n    this.isTreeEditing = false;\r\n    this.treeNodeHoverKey = null;\r\n  }\r\n\r\n  editAllRenderObjectCancel(data) {\r\n    // this.isTreeEditing = false;\r\n    // this.treeNodeHoverKey = null;\r\n    // this.modelObjects = [...this.modelObjectsClone];\r\n    // this.getModelObjects();\r\n    // this.modelObjects = [];\r\n    // this.createTree(this.modelObjects, (this.$refs.structureTree as any).root);\r\n  }\r\n\r\n  setData() {\r\n    this.$emit(\"setData\", {\r\n      title: \"模型结构树\",\r\n      top: \"20px\",\r\n      left: \"20px\",\r\n      height: \"600px\",\r\n      width: \"300px\",\r\n    });\r\n  }\r\n\r\n  findTreeNodePath(node, targetKey, nodePath: any[]) {\r\n    if (!this.loopFlag) {\r\n      return;\r\n    }\r\n    let childNodes = node.childNodes;\r\n    for (let i = 0; i < childNodes.length; i++) {\r\n      let childNode = childNodes[i];\r\n      let data = childNode.data;\r\n\r\n      let deepCloneNodePath = [...nodePath];\r\n\r\n      deepCloneNodePath.push(childNode);\r\n      if (data.key !== targetKey) {\r\n        this.findTreeNodePath(childNode, targetKey, deepCloneNodePath);\r\n      } else {\r\n        this.nodePath.push(this.rootNode);\r\n        for (let j = 0; j < deepCloneNodePath.length; j++) {\r\n          this.nodePath.push(deepCloneNodePath[j]);\r\n        }\r\n        this.selectedGslNode = childNode;\r\n        this.loopFlag = false;\r\n        return deepCloneNodePath;\r\n      }\r\n    }\r\n  }\r\n\r\n  getPathKeys(treeNodeObject: TreeNodeObject, pathKeys: Longan.List<string>) {\r\n    if (treeNodeObject.nodeKey) {\r\n      pathKeys.add(treeNodeObject.nodeKey);\r\n    }\r\n    if (treeNodeObject.parent) {\r\n      this.getPathKeys(treeNodeObject.parent, pathKeys);\r\n    }\r\n  }\r\n\r\n  updateNode(treeNodeObject: TreeNodeObject) {\r\n    let pathKeys: Longan.List<string> = new Longan.List();\r\n    if (treeNodeObject) {\r\n      this.getPathKeys(treeNodeObject, pathKeys);\r\n    }\r\n\r\n    // let tree = this.$refs.structureTree as any;\r\n    pathKeys.items.reverse().forEach((nodeKey) => {\r\n      if (nodeKey === this.level0Node.key) {\r\n        this.loadNode(this.level0Node, this.level0NodeResolve);\r\n      } else {\r\n        this.loadNode(this.currentNode, this.currentNodeResolve);\r\n      }\r\n    });\r\n  }\r\n\r\n  mounted() {\r\n    this.setData();\r\n    console.time(\"interfaceStructureTree getModelObjects\");\r\n    this.getModelObjects();\r\n    console.timeEnd(\"interfaceStructureTree getModelObjects\");\r\n\r\n    structureTreeBus.$on(\"updateTree\", (key?) => {\r\n      console.log(\"structureTreeBus\");\r\n\r\n      let tree: any = this.$refs.structureTree;\r\n      if (tree) {\r\n        // 获取当前选中节点的key值\r\n        let keys = tree.getCheckedKeys();\r\n        // 获取当前展开节点的key值\r\n        let expandedKeys = tree.getCheckedKeys();\r\n        // 更新数据\r\n        if (key !== undefined) {\r\n          let treeNode = this.viewer.structureTreeManager?.treeNodes[key];\r\n\r\n          // if (treeNode) {\r\n          //   let data = this.getNodes([treeNode])[0];\r\n          //   if (data) {\r\n          //     tree.updateKeyChildren(key, data);\r\n          //   }\r\n          // }\r\n\r\n          this.updateNode(treeNode);\r\n\r\n          // // 获取当前节点\r\n          // const node = tree.getNode(key);\r\n          // // 更新子节点数据\r\n          // node.children = this.getNodes(treeNode.childNodes);\r\n        } else {\r\n          this.level0Node.childNodes = []; //把存起来的node的子节点清空，不然会界面会出现重复树！\r\n          this.checkKeys = [];\r\n          this.loadNode(this.level0Node, this.level0NodeResolve);\r\n          // this.checkStrictly = true;\r\n          // this.invisibleKeys.forEach((key) => {\r\n          //   let node = (this.$refs.structureTree as any).getNode(key);\r\n          //   node.checked = null;\r\n          //   node.parent.checked = null;\r\n          //   // node.parent.indeterminate = true;\r\n          //   console.log(\"(this.$refs.structureTree as any).getNode(key)\", node);\r\n          // });\r\n          // this.checkStrictly = false;\r\n\r\n          this.showLevel(1);\r\n        }\r\n        // 重新勾选节点\r\n        // tree.setCheckedKeys(keys);\r\n        // 重新展开节点\r\n        tree.setCheckedKeys(expandedKeys);\r\n      }\r\n    });\r\n\r\n    this.$nextTick(() => {\r\n      // let componentSelector = this.viewer.operatorManager.find(\"ComponentSelector\") as ComponentSelector;\r\n      // if (componentSelector) {\r\n      this.viewer.onLButtonUp.add(this.heighLight);\r\n      // }\r\n    });\r\n  }\r\n\r\n  beforeDestroy() {\r\n    if (this.viewer) {\r\n      // \tlet componentSelector = this.viewer.operatorManager.find(\"ComponentSelector\") as ComponentSelector;\r\n      this.viewer.onLButtonUp.remove(this.heighLight);\r\n    }\r\n  }\r\n}\r\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedRuleSet-86.use[0]!./node_modules/babel-loader/lib/index.js!./node_modules/@vue/cli-plugin-typescript/node_modules/ts-loader/index.js??clonedRuleSet-88.use[1]!./packages/bimAir/src/viewerWrapper/panels/structureTree/panes/structureTree.tsx?vue&type=script&lang=js&\n");
|
|
7405
|
+
eval("var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;__webpack_require__(/*! core-js/modules/es.object.to-string.js */ \"./node_modules/core-js/modules/es.object.to-string.js\");\n__webpack_require__(/*! core-js/modules/web.dom-collections.for-each.js */ \"./node_modules/core-js/modules/web.dom-collections.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.array.push.js */ \"./node_modules/core-js/modules/es.array.push.js\");\n__webpack_require__(/*! core-js/modules/es.function.name.js */ \"./node_modules/core-js/modules/es.function.name.js\");\n__webpack_require__(/*! core-js/modules/es.array.filter.js */ \"./node_modules/core-js/modules/es.array.filter.js\");\n__webpack_require__(/*! core-js/modules/es.array.map.js */ \"./node_modules/core-js/modules/es.array.map.js\");\n__webpack_require__(/*! core-js/modules/es.array.splice.js */ \"./node_modules/core-js/modules/es.array.splice.js\");\n__webpack_require__(/*! core-js/modules/es.array.concat.js */ \"./node_modules/core-js/modules/es.array.concat.js\");\n__webpack_require__(/*! core-js/modules/es.array.find-index.js */ \"./node_modules/core-js/modules/es.array.find-index.js\");\n__webpack_require__(/*! core-js/modules/es.object.to-string.js */ \"./node_modules/core-js/modules/es.object.to-string.js\");\n__webpack_require__(/*! core-js/modules/web.dom-collections.for-each.js */ \"./node_modules/core-js/modules/web.dom-collections.for-each.js\");\n__webpack_require__(/*! core-js/modules/es.array.push.js */ \"./node_modules/core-js/modules/es.array.push.js\");\n__webpack_require__(/*! core-js/modules/es.function.name.js */ \"./node_modules/core-js/modules/es.function.name.js\");\n__webpack_require__(/*! core-js/modules/es.array.filter.js */ \"./node_modules/core-js/modules/es.array.filter.js\");\n__webpack_require__(/*! core-js/modules/es.array.map.js */ \"./node_modules/core-js/modules/es.array.map.js\");\n__webpack_require__(/*! core-js/modules/es.array.splice.js */ \"./node_modules/core-js/modules/es.array.splice.js\");\n__webpack_require__(/*! core-js/modules/es.array.concat.js */ \"./node_modules/core-js/modules/es.array.concat.js\");\n__webpack_require__(/*! core-js/modules/es.array.find-index.js */ \"./node_modules/core-js/modules/es.array.find-index.js\");\n!(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__, exports, __webpack_require__(/*! tslib */ \"./node_modules/tslib/tslib.es6.js\"), __webpack_require__(/*! vue-property-decorator */ \"./node_modules/vue-property-decorator/lib/vue-property-decorator.js\"), __webpack_require__(/*! gs-longan */ \"./packages/longan/src/index.ts\"), __webpack_require__(/*! ../../../../gsDevFx/api */ \"./packages/bimAir/src/gsDevFx/api/index.ts\"), __webpack_require__(/*! ../../../../components/gs/gsDivider/gs-divider.vue */ \"./packages/bimAir/src/components/gs/gsDivider/gs-divider.vue\"), __webpack_require__(/*! ../../../../components/el/tree */ \"./packages/bimAir/src/components/el/tree/index.js\"), __webpack_require__(/*! element-ui */ \"./node_modules/element-ui/lib/element-ui.common.js\"), __webpack_require__(/*! ../../../module/createMenu */ \"./packages/bimAir/src/viewerWrapper/module/createMenu.tsx\"), __webpack_require__(/*! ../../../../store/structureTree */ \"./packages/bimAir/src/store/structureTree.ts\"), __webpack_require__(/*! gs-longan/longan/idb */ \"./packages/longan/src/longan/idb.ts\"), __webpack_require__(/*! ../structureTreeBus */ \"./packages/bimAir/src/viewerWrapper/panels/structureTree/structureTreeBus.ts\")], __WEBPACK_AMD_DEFINE_RESULT__ = (function (require, exports, tslib_1, vue_property_decorator_1, Longan, LonganApi, gs_divider_vue_1, tree_1, element_ui_1, createMenu_1, structureTree_1, idb_1, structureTreeBus_1) {\n \"use strict\";\n\n Object.defineProperty(exports, \"__esModule\", ({\n value: true\n }));\n Longan = tslib_1.__importStar(Longan);\n LonganApi = tslib_1.__importStar(LonganApi);\n gs_divider_vue_1 = tslib_1.__importDefault(gs_divider_vue_1);\n tree_1 = tslib_1.__importDefault(tree_1);\n structureTree_1 = tslib_1.__importDefault(structureTree_1);\n idb_1 = tslib_1.__importDefault(idb_1);\n structureTreeBus_1 = tslib_1.__importDefault(structureTreeBus_1);\n vue_property_decorator_1.Vue.use(tree_1.default);\n vue_property_decorator_1.Vue.use(element_ui_1.Button);\n vue_property_decorator_1.Vue.use(element_ui_1.Input);\n vue_property_decorator_1.Vue.use(element_ui_1.Form);\n vue_property_decorator_1.Vue.use(element_ui_1.FormItem);\n var InterfaceStructureTree = function (_super) {\n tslib_1.__extends(InterfaceStructureTree, _super);\n function InterfaceStructureTree() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.searchValue = \"\";\n _this.treeProps = {\n label: \"name\",\n children: \"childNodes\",\n isLeaf: \"isLeaf\",\n expaned: \"expaned\"\n };\n _this.treeCheckedNos = [];\n _this.treeExpandAll = true;\n _this.draggingNode = null;\n _this.treeModelStructure = null;\n _this.selectedKey = -1;\n _this.selectedPath = \"\";\n _this.checkKeys = [];\n _this.invisibleKeys = [];\n _this.expandedKeys = [];\n _this.currentTreeKey = null;\n _this.isEditingKey = null;\n _this.nameValue = \"\";\n _this.modelObjectsClone = [];\n _this.parentSegmentKey = null;\n _this.treeNodeHoverKey = null;\n _this.isTreeEditing = false;\n _this.operatorList = [];\n _this.isolationIds = [];\n _this.levelOneData = [];\n _this.loopFlag = false;\n _this.selectedGslNode = null;\n _this.nodePath = [];\n _this.chooseNode = null;\n _this.rootNode = null;\n _this.lastNoCheckedRootNodes = [];\n _this.count = 0;\n _this.end = false;\n _this.isolationKeys = [];\n _this.isTreeLocate = localStorage.getItem(\"isTreeLocate\") !== \"false\";\n _this.checkStrictly = false;\n _this.draggingNodeChecked = true;\n _this.buttonList = [{\n name: \"编辑\",\n children: [{\n name: \"添加\",\n clickFun: function clickFun() {\n _this.addRenderObjectClick();\n }\n }, {\n name: \"重命名\",\n clickFun: function clickFun() {\n _this.renameRenderObjectClick();\n }\n }, {\n name: \"删除\",\n clickFun: function clickFun() {\n _this.deleteRenderObjectClick();\n }\n }]\n }, {\n name: \"隐藏\",\n children: [{\n name: \"隐藏选中对象\",\n clickFun: function clickFun() {\n _this.hideObject();\n }\n }, {\n name: \"隐藏其他对象\",\n clickFun: function clickFun() {\n _this.reHideObject();\n }\n }, {\n name: \"显示全部对象\",\n clickFun: function clickFun() {\n _this.clearHideObject();\n }\n }]\n }, {\n name: \"隔离\",\n children: [{\n name: \"隔离选中对象\",\n clickFun: function clickFun() {\n _this.isolateObject();\n }\n }, {\n name: \"隔离其他对象\",\n clickFun: function clickFun() {\n _this.isolateOtherObjects();\n }\n }, {\n name: \"取消隔离\",\n clickFun: function clickFun() {\n _this.clearIsolateObjects();\n }\n }]\n }, {\n name: \"展开\",\n children: [{\n name: \"展开一层\",\n clickFun: function clickFun() {\n _this.showLevel(1);\n }\n }, {\n name: \"展开二层\",\n clickFun: function clickFun() {\n _this.showLevel(2);\n }\n }, {\n name: \"展开三层\",\n clickFun: function clickFun() {\n _this.showLevel(3);\n }\n }, {\n name: \"全部收起\",\n clickFun: function clickFun() {\n _this.setAllExpand(false);\n }\n }]\n }];\n _this.structureTree = structureTree_1.default;\n _this.heighLight = function () {\n var segObj = _this.viewer.selectionManager.segmentObject;\n console.log(\"选中的对象:\", segObj);\n if (segObj) {\n var treeNodeObject = _this.viewer.structureTreeManager.treeNodes[segObj.nodeKey];\n var pathKeys = new Longan.List();\n if (treeNodeObject) {\n _this.getPathKeys(treeNodeObject, pathKeys);\n }\n var tree_2 = _this.$refs.structureTree;\n pathKeys.items.reverse().forEach(function (nodeKey) {\n setTimeout(function () {\n var node = tree_2.getNode(nodeKey);\n if (node) {\n node.expand();\n }\n }, 0);\n });\n setTimeout(function () {\n _this.locateCurrentNode(segObj.nodeKey);\n tree_2.setCurrentKey(segObj.nodeKey);\n }, 10);\n }\n };\n return _this;\n }\n Object.defineProperty(InterfaceStructureTree.prototype, \"viewer\", {\n get: function get() {\n return this.getViewer();\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(InterfaceStructureTree.prototype, \"tabs\", {\n get: function get() {\n var tabs = this.viewer.options.components.property.tabs;\n return tabs;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(InterfaceStructureTree.prototype, \"viewerType\", {\n get: function get() {\n return this.viewer.options.viewerType;\n },\n enumerable: false,\n configurable: true\n });\n InterfaceStructureTree.prototype.loadNode = function (node, resolve) {\n var _this = this;\n var _a, _b;\n if (!this.viewer) {\n resolve([]);\n }\n this.checkStrictly = true;\n if ((_b = (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.structureTreeManager) === null || _b === void 0 ? void 0 : _b.rootNode) {\n this.$nextTick(function () {\n var _a;\n _this.currentNode = node;\n _this.currentNodeResolve = resolve;\n if (node.level === 0) {\n var result = void 0;\n _this.level0Node = node;\n _this.level0NodeResolve = resolve;\n if (_this.viewer.renderObject && _this.viewer.renderObject.showTreeNode) {\n result = _this.getNodes([_this.viewer.structureTreeManager.rootNode]);\n if (_this.invisibleKeys.indexOf(result[0].nodeKey) === -1) {\n _this.checkKeys.push(result[0].nodeKey);\n }\n } else {\n result = _this.getNodes(_this.viewer.structureTreeManager.rootNode.childNodes);\n result.forEach(function (item) {\n if (_this.invisibleKeys.indexOf(item.nodeKey) === -1) {\n _this.checkKeys.push(item.nodeKey);\n }\n });\n }\n resolve(result);\n } else {\n var treeNode = (_a = _this.viewer.structureTreeManager) === null || _a === void 0 ? void 0 : _a.treeNodes[node.data.nodeKey];\n if (treeNode) {\n var childNodes = treeNode.childNodes;\n var result = _this.getNodes(childNodes);\n result.forEach(function (item) {\n if (_this.invisibleKeys.indexOf(item.nodeKey) === -1) {\n _this.checkKeys.push(item.nodeKey);\n }\n });\n return resolve(result);\n } else {\n return resolve([]);\n }\n }\n });\n setTimeout(function () {\n _this.checkStrictly = false;\n }, 20);\n }\n };\n InterfaceStructureTree.prototype.getNodes = function (treeNodeObjects) {\n var _this = this;\n var result = [];\n treeNodeObjects.forEach(function (item) {\n result.push({\n name: item.name,\n nodeKey: item.nodeKey,\n isShow: item.isShow,\n isLeaf: item.childNodes.length === 0,\n expaned: _this.expandedKeys.indexOf(item.nodeKey) !== -1\n });\n });\n return result;\n };\n InterfaceStructureTree.prototype.isTreeLocateChange = function (val) {\n localStorage.setItem(\"isTreeLocate\", val);\n this.isTreeLocate = val;\n };\n InterfaceStructureTree.prototype.locateCurrentNode = function (nodeKey) {\n if (!this.isTreeLocate) {\n return;\n }\n this.count = 0;\n this.end = false;\n var tree = document.getElementById(\"structureTree\");\n var node = this.$refs.structureTree.store.root;\n this.countExpandNode(node, nodeKey);\n var count = this.count;\n var parentElement = tree.parentElement;\n parentElement.scrollTo(0, count * 26 - 60);\n };\n InterfaceStructureTree.prototype.countExpandNode = function (node, nodeKey) {\n if (!this.end) {\n if (node.expanded || this.count === 0 || node.data.nodeKey === nodeKey) {\n this.count += 1;\n if (node.data && node.data.nodeKey === nodeKey) {\n this.end = true;\n return this.count;\n }\n if (node.childNodes) {\n for (var i = 0, len = node.childNodes.length; i < len; i++) {\n this.countExpandNode(node.childNodes[i], nodeKey);\n }\n }\n } else {\n this.count += 1;\n }\n }\n };\n InterfaceStructureTree.prototype.findRoVisible = function (insObj, checkedNos) {\n if (insObj.renderObject.visible) {\n checkedNos.push(insObj.no);\n }\n for (var i = 0; i < insObj.childObjects.length; i++) {\n this.findRoVisible(insObj.childObjects[i], checkedNos);\n }\n };\n InterfaceStructureTree.prototype.getModelObjects = function () {\n var viewer = this.viewer;\n if (viewer && viewer.instanceObject) {\n var insObj = viewer.instanceObject;\n var treeCheckedNos = [];\n this.findRoVisible(insObj, treeCheckedNos);\n this.treeCheckedNos = treeCheckedNos;\n var rootNode = this.componentData && this.componentData.structureTree ? this.componentData.structureTree[0] : this.viewer.structureTreeManager.rootNode;\n if (this.viewer.renderObject.showTreeNode) {\n this.currentTreeNodeData = rootNode;\n } else {\n this.currentTreeNodeData = rootNode.childNodes[0];\n }\n this.showLevel(1);\n } else {\n this.treeCheckedNos = [];\n }\n };\n InterfaceStructureTree.prototype.searchValueChange = function (val) {\n if (val) {\n var treeNodes = this.viewer.structureTreeManager.treeNodes;\n var tree_3 = this.$refs.structureTree;\n for (var key in treeNodes) {\n if (treeNodes[key].name.indexOf(this.searchValue) !== -1) {\n var treeNodeObject = treeNodes[key];\n var pathKeys = new Longan.List();\n if (treeNodeObject) {\n this.getPathKeys(treeNodeObject, pathKeys);\n }\n pathKeys.items.reverse().forEach(function (nodeKey) {\n var node = tree_3.getNode(nodeKey);\n if (node) {\n node.expand();\n }\n });\n }\n }\n }\n this.$refs.structureTree.filter(this.searchValue);\n };\n InterfaceStructureTree.prototype.filterNode = function (value, data) {\n if (!value) {\n return true;\n }\n return data.name.indexOf(value) !== -1;\n };\n InterfaceStructureTree.prototype.treeCheck = function (data, _a) {\n var checkedNodes = _a.checkedNodes,\n checkedKeys = _a.checkedKeys,\n halfCheckedNodes = _a.halfCheckedNodes,\n halfCheckedKeys = _a.halfCheckedKeys;\n var treeNodeObject = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n if (checkedNodes.map(function (item) {\n return item.nodeKey;\n }).indexOf(treeNodeObject.nodeKey) === -1) {\n this.viewer.invisibleManager.invisible([treeNodeObject]);\n this.invisibleKeys.push(treeNodeObject.nodeKey);\n console.log(\"隐藏节点keys\", this.invisibleKeys);\n } else {\n this.viewer.invisibleManager.clearInvisible([treeNodeObject]);\n var index = this.invisibleKeys.indexOf(treeNodeObject.nodeKey);\n if (index !== -1) {\n this.invisibleKeys.splice(index, 1);\n }\n }\n this.viewer.updateDisplay();\n if (this.viewer.options.components.structureTree.defaultTab.checkFun) {\n this.viewer.options.components.structureTree.defaultTab.checkFun(treeNodeObject, {\n checkedNodes: checkedNodes,\n checkedKeys: checkedKeys,\n halfCheckedNodes: halfCheckedNodes,\n halfCheckedKeys: halfCheckedKeys\n });\n }\n };\n InterfaceStructureTree.prototype.findInvisibleRootNodes = function (rootNode, halfCheckedNodes, invisibleRootNodes) {\n if (rootNode.checked === false) {\n if (halfCheckedNodes.indexOf(rootNode.data) === -1) {\n invisibleRootNodes.push(rootNode.data);\n } else {\n var childNodes = rootNode.childNodes;\n for (var i = 0; i < childNodes.length; i++) {\n this.findInvisibleRootNodes(childNodes[i], halfCheckedNodes, invisibleRootNodes);\n }\n }\n }\n };\n InterfaceStructureTree.prototype.treeNodeClick = function (data, node) {\n var treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n console.log(\"treeNodeClick\", node, treeNode);\n this.currentTreeNodeData = treeNode;\n this.viewer.selectionManager.clearAllSelectionAndHighlight();\n this.viewer.selectionManager.selectAndHighlight([treeNode]);\n this.viewer.locateObject(treeNode);\n this.viewer.panelManager.propertyPanel.getProperty(treeNode.segmentObject);\n if (this.viewer.options.components.structureTree.clickFun) {\n this.viewer.options.components.structureTree.clickFun(treeNode);\n }\n if (this.viewer.options.components.structureTree.defaultTab.clickFun) {\n this.viewer.options.components.structureTree.defaultTab.clickFun(treeNode);\n }\n this.viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.createTree = function (newTree, node) {\n var newNode = null;\n if (node.data) {\n newNode = {\n key: node.data.key,\n name: node.data.name,\n items: []\n };\n if (newTree.items) {\n newTree.items.push(newNode);\n } else {\n newTree.push(newNode);\n }\n }\n if (!newNode) {\n newNode = newTree;\n }\n for (var i = 0; i < node.childNodes.length; i++) {\n this.createTree(newNode, node.childNodes[i]);\n }\n };\n InterfaceStructureTree.prototype.getProperties = function (key) {\n var segment = new Longan.Segment(key);\n var jsonString = segment.property.showString(\"Properties\");\n var showParentProperty = segment.property.showBoolean(\"showParentProperties\");\n if (showParentProperty) {\n var key_1 = segment.owner.key;\n jsonString = this.getParentProperties(key_1);\n }\n return JSON.parse(jsonString);\n };\n InterfaceStructureTree.prototype.getParentProperties = function (key) {\n var segment = new Longan.Segment(key);\n var properties = segment.property.showString(\"Properties\");\n if (properties) {\n return properties;\n } else {\n return this.getParentProperties(segment.owner.key);\n }\n };\n InterfaceStructureTree.prototype.treeNodeDragStart = function (node, ev) {\n this.draggingNode = node;\n this.currentTreeNode = node;\n this.currentTreeNodeData = this.viewer.structureTreeManager.treeNodes[node.data.nodeKey];\n this.draggingNodeChecked = node.checked;\n console.log(\"this.draggingNodeChecked \", this.draggingNodeChecked);\n };\n InterfaceStructureTree.prototype.treeNodeDragEnter = function (draggingNode, overNode, ev) {\n console.log(\"this.treeNodeDragEnterTimer\");\n };\n InterfaceStructureTree.prototype.treeNodeDragEnd = function (draggingNode, dropNode, dropType) {};\n InterfaceStructureTree.prototype.treeNodeDrop = function (draggingNode, dropNode, dropType, ev) {\n var _this = this;\n console.log(\"dropNode.expend\", dropNode);\n this.$confirm(\"\\u662F\\u5426\\u5C06\\u8282\\u70B9\".concat(draggingNode.label, \"\\u79FB\\u52A8\\u5230\").concat(dropNode.label).concat(dropType == \"before\" ? \"之前\" : dropType == \"after\" ? \"之后\" : \"下\", \"?\"), \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\"\n }).then(function () {\n _this.dropConfirm(draggingNode, dropNode, dropType).then(function () {\n _this.$message({\n type: \"success\",\n message: \"移动成功!\"\n });\n if (dropNode === \"inner\") {\n structureTreeBus_1.default.$emit(\"updateTree\", dropNode.key);\n } else {\n structureTreeBus_1.default.$emit(\"updateTree\", dropNode.parent.key);\n }\n });\n }).catch(function () {\n _this.$message({\n type: \"info\",\n message: \"取消移动\"\n });\n structureTreeBus_1.default.$emit(\"updateTree\", dropNode.parent.key);\n });\n };\n InterfaceStructureTree.prototype.dropConfirm = function (draggingNode, dropNode, dropType) {\n var _this = this;\n function getIndex(parent, child) {\n for (var i = 0, len = parent.childNodes.length; i < len; i++) {\n var item = parent.childNodes[i];\n if (item.key === child.key) {\n return i;\n }\n }\n return -1;\n }\n var index = -1;\n var dropSegment;\n var draggingTreeNode = this.viewer.structureTreeManager.treeNodes[draggingNode.data.nodeKey];\n var dropTreeNode;\n var targetSegIndex;\n switch (dropType) {\n case \"inner\":\n dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.key];\n dropSegment = dropTreeNode.segment;\n targetSegIndex = dropTreeNode.childNodes.length;\n this.expandedKeys.push(dropNode.data.key);\n break;\n case \"before\":\n index = getIndex(dropNode.parent, dropNode);\n dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\n dropSegment = this.viewer.structureTreeManager.treeNodes[dropNode.key].segment.owner;\n targetSegIndex = index - 1;\n break;\n case \"after\":\n index = getIndex(dropNode.parent, dropNode);\n dropSegment = this.viewer.structureTreeManager.treeNodes[dropNode.key].segment.owner;\n dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\n targetSegIndex = index + 1;\n break;\n }\n var draggingNodeChecked = this.draggingNodeChecked;\n return draggingTreeNode.moveToIndexWithRequestApi(dropTreeNode, dropSegment, targetSegIndex).then(function () {\n console.log(\"this.$refs.structureTree \", _this.$refs.structureTree, draggingNode, draggingNode.key, draggingNodeChecked);\n _this.$refs.structureTree.setChecked(draggingNode.key, draggingNodeChecked, true);\n return _this.updateIndexedDB();\n });\n };\n InterfaceStructureTree.prototype.addRenderObjectClick = function () {\n var _this = this;\n var data = this.currentTreeNodeData;\n if (data.childNodes) {\n for (var i = 0; i < data.childNodes.length; i++) {\n if (data.childNodes[i].nodeKey === \"-1\") {\n return;\n }\n }\n }\n this.parentSegmentKey = data.key;\n this.nameValue = \"\";\n var parent = this.currentTreeNode;\n parent.expand();\n this.$refs.structureTree.append({\n name: \" \",\n nodeKey: \"-1\",\n isShow: true\n }, parent);\n this.isEditingKey = \"-1\";\n setTimeout(function () {\n _this.locateCurrentNode(\"-1\");\n var input = _this.$refs.editingTreeNodeInput;\n if (input) {\n input.focus();\n }\n }, 10);\n };\n InterfaceStructureTree.prototype.renameRenderObjectClick = function () {\n var _this = this;\n var data = this.currentTreeNodeData;\n this.isEditingKey = data.nodeKey;\n this.nameValue = data.name;\n setTimeout(function () {\n _this.$refs.editingTreeNodeInput.focus();\n }, 10);\n };\n InterfaceStructureTree.prototype.deleteRenderObjectClick = function () {\n var _this = this;\n var data = this.currentTreeNodeData;\n var node = this.currentTreeNode;\n element_ui_1.MessageBox.confirm(\"\\u786E\\u5B9A\\u5220\\u9664\".concat(data.name, \"\\u8282\\u70B9\\uFF1F\"), \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\"\n }).then(function () {\n _this.updateIndexedDB();\n _this.currentTreeNodeData.deleteWithRequestApi(true).then(function () {\n var children = node.parent.childNodes;\n var index = children.findIndex(function (d) {\n return d.data.nodeKey === node.data.nodeKey;\n });\n if (index >= 0) {\n children.splice(index, 1);\n } else {\n _this.$message.warning(\"节点删除出错\");\n }\n });\n });\n };\n InterfaceStructureTree.prototype.editRenderObjectConfirm = function (node, data) {\n var _this = this;\n var treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n if (data.nodeKey === \"-1\") {\n var segment = new LonganApi.Segment(this.parentSegmentKey);\n if (!this.nameValue) {\n element_ui_1.Message.warning(\"节点名不能为空\");\n return;\n }\n if (segment.subsegmentExists(this.nameValue)) {\n element_ui_1.Message.warning(\"此节点已存在,请重命名\");\n } else {\n var parent_1 = node.parent;\n var children = parent_1.childNodes;\n var index = children.findIndex(function (d) {\n return d.nodeKey === data.nodeKey;\n });\n children.splice(index, 1);\n var parentTreeNode = this.viewer.structureTreeManager.treeNodes[parent_1.data.nodeKey];\n console.log(\"parentTreeNode\", parentTreeNode);\n if (parentTreeNode) {\n parentTreeNode.addWithRequestApi(this.nameValue, true).then(function (treeNodeObject) {\n data.nodeKey = treeNodeObject.nodeKey;\n data.name = treeNodeObject.name;\n _this.isEditingKey = null;\n _this.nameValue = \"\";\n _this.$refs.structureTree.append({\n name: treeNodeObject.name,\n nodeKey: treeNodeObject.nodeKey,\n isShow: true\n }, parent_1);\n _this.$refs.structureTree.setChecked(data.nodeKey, true, true);\n _this.$refs.structureTree.setChecked(treeNodeObject.nodeKey, true, true);\n _this.updateIndexedDB();\n });\n }\n }\n } else {\n if (this.nameValue) {\n this.currentTreeNodeData.renameWithRequestApi(this.nameValue).then(function () {\n _this.updateIndexedDB();\n });\n data.name = this.nameValue;\n this.isEditingKey = null;\n this.nameValue = \"\";\n } else {\n element_ui_1.Message.warning(\"名字不能为空\");\n }\n }\n };\n InterfaceStructureTree.prototype.editRenderObjectCancel = function (node, data) {\n if (data.nodeKey === \"-1\") {\n var parent = node.parent;\n var children = parent.childNodes;\n var index = children.findIndex(function (d) {\n return d.nodeKey === data.nodeKey;\n });\n children.splice(index, 1);\n } else {\n this.isEditingKey = null;\n }\n };\n InterfaceStructureTree.prototype.updateIndexedDB = function () {\n var treeNode = this.currentTreeNodeData;\n idb_1.default.getInstance(treeNode.modelId).del(treeNode.modelId + \"?v=\" + treeNode.model.renderObject.version);\n };\n InterfaceStructureTree.prototype.treeNodeMouseOver = function (data) {\n this.treeNodeHoverKey = data.key;\n };\n InterfaceStructureTree.prototype.treeNodeMouseLeave = function (data) {\n this.treeNodeHoverKey = null;\n };\n InterfaceStructureTree.prototype.isBindModelExist = function (modelId) {\n return false;\n };\n InterfaceStructureTree.prototype.treeNodeContextMenuClick = function (e, data, node, nodeElement) {\n var treeNodeObject = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\n console.log(\"treeNodeContextMenuClick\", e);\n this.currentTreeNodeData = treeNodeObject;\n this.currentTreeNode = node;\n (0, createMenu_1.createMenu)(e.pageX, e.pageY, this.buttonList);\n };\n InterfaceStructureTree.prototype.treeNodeExpand = function (data, node, e) {\n console.log(data, node, e);\n this.expandedKeys.push(data.nodeKey);\n };\n InterfaceStructureTree.prototype.treeNodeCollapse = function (data, node, e) {\n var index = this.expandedKeys.indexOf(data.nodeKey);\n if (index !== -1) {\n this.expandedKeys.splice(index, 1);\n }\n };\n InterfaceStructureTree.prototype.showLevel = function (level) {\n var _this = this;\n setTimeout(function () {\n var node = _this.currentTreeNodeData;\n _this.expandLevel(node, level);\n }, 10);\n };\n InterfaceStructureTree.prototype.expandLevel = function (node, level) {\n var _this = this;\n var _a;\n if (node) {\n node.loaded = false;\n var nodeDom = (_a = this.$refs.structureTree) === null || _a === void 0 ? void 0 : _a.getNode(node.nodeKey);\n if (nodeDom) {\n nodeDom.expand();\n }\n }\n setTimeout(function () {\n var currentLevel = level - 1;\n if (currentLevel > 0) {\n for (var i = 0; i < node.childNodes.length; i++) {\n var item = node.childNodes[i];\n if (item.childNodes && item.childNodes.length > 0) {\n _this.expandLevel(item, currentLevel);\n }\n }\n }\n }, 10);\n };\n InterfaceStructureTree.prototype.setAllExpand = function (state) {\n var nodes = this.$refs.structureTree.store.root;\n this.expandNode(nodes, state);\n };\n InterfaceStructureTree.prototype.expandNode = function (node, state) {\n node.expanded = state;\n for (var i = 0, len = node.childNodes.length; i < len; i++) {\n if (node.childNodes[i].childNodes.length > 0) {\n this.expandNode(node.childNodes[i], state);\n }\n }\n };\n InterfaceStructureTree.prototype.hideObject = function () {\n console.log(\"hideObject\");\n this.$refs.structureTree.setChecked(this.currentTreeNodeData, false, true);\n var viewer = this.viewer;\n viewer.invisibleManager.invisible([this.currentTreeNodeData]);\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.reHideObject = function () {\n var _this = this;\n var root = this.$refs.structureTree.root;\n console.log(\"root-------------\", root);\n root.childNodes.forEach(function (item) {\n _this.$refs.structureTree.setChecked(item.data.nodeKey, false, true);\n });\n this.$refs.structureTree.setChecked(this.currentTreeNodeData, true, true);\n var viewer = this.viewer;\n this.viewer.invisibleManager.invisibleInvert([this.currentTreeNodeData]);\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.clearHideObject = function () {\n var _this = this;\n var root = this.$refs.structureTree.root;\n root.childNodes.forEach(function (item) {\n _this.$refs.structureTree.setChecked(item.data.nodeKey, true, true);\n });\n var viewer = this.viewer;\n viewer.invisibleManager.clearAllInvisible();\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.checkChange = function (data) {\n var checkedNodes;\n var checkedKeys = this.$refs.structureTree.getCheckedKeys();\n var halfCheckedNodes = this.$refs.structureTree.getHalfCheckedNodes();\n var halfCheckedKeys;\n this.treeCheck(data, {\n checkedNodes: checkedNodes,\n checkedKeys: checkedKeys,\n halfCheckedNodes: halfCheckedNodes,\n halfCheckedKeys: halfCheckedKeys\n });\n };\n InterfaceStructureTree.prototype.isolateObject = function () {\n this.viewer.isolationManager.isolation([this.currentTreeNodeData.segmentObject]);\n this.viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.isolateOtherObjects = function () {\n var viewer = this.viewer;\n viewer.isolationManager.isolationInvert([this.currentTreeNodeData]);\n viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.clearIsolateObjects = function () {\n this.viewer.isolationManager.clearAllIsolation();\n this.viewer.updateDisplay();\n };\n InterfaceStructureTree.prototype.openEditAllRenderObjectClick = function (node, data) {};\n InterfaceStructureTree.prototype.editAllRenderObjectConfirm = function (data) {\n this.isTreeEditing = false;\n this.treeNodeHoverKey = null;\n };\n InterfaceStructureTree.prototype.editAllRenderObjectCancel = function (data) {};\n InterfaceStructureTree.prototype.setData = function () {\n this.$emit(\"setData\", {\n title: \"模型结构树\",\n top: \"20px\",\n left: \"20px\",\n height: \"600px\",\n width: \"300px\"\n });\n };\n InterfaceStructureTree.prototype.findTreeNodePath = function (node, targetKey, nodePath) {\n if (!this.loopFlag) {\n return;\n }\n var childNodes = node.childNodes;\n for (var i = 0; i < childNodes.length; i++) {\n var childNode = childNodes[i];\n var data = childNode.data;\n var deepCloneNodePath = tslib_1.__spreadArray([], tslib_1.__read(nodePath), false);\n deepCloneNodePath.push(childNode);\n if (data.key !== targetKey) {\n this.findTreeNodePath(childNode, targetKey, deepCloneNodePath);\n } else {\n this.nodePath.push(this.rootNode);\n for (var j = 0; j < deepCloneNodePath.length; j++) {\n this.nodePath.push(deepCloneNodePath[j]);\n }\n this.selectedGslNode = childNode;\n this.loopFlag = false;\n return deepCloneNodePath;\n }\n }\n };\n InterfaceStructureTree.prototype.getPathKeys = function (treeNodeObject, pathKeys) {\n if (treeNodeObject.nodeKey) {\n pathKeys.add(treeNodeObject.nodeKey);\n }\n if (treeNodeObject.parent) {\n this.getPathKeys(treeNodeObject.parent, pathKeys);\n }\n };\n InterfaceStructureTree.prototype.updateNode = function (treeNodeObject) {\n var _this = this;\n var pathKeys = new Longan.List();\n if (treeNodeObject) {\n this.getPathKeys(treeNodeObject, pathKeys);\n }\n pathKeys.items.reverse().forEach(function (nodeKey) {\n if (nodeKey === _this.level0Node.key) {\n _this.loadNode(_this.level0Node, _this.level0NodeResolve);\n } else {\n _this.loadNode(_this.currentNode, _this.currentNodeResolve);\n }\n });\n };\n InterfaceStructureTree.prototype.mounted = function () {\n var _this = this;\n this.setData();\n console.time(\"interfaceStructureTree getModelObjects\");\n this.getModelObjects();\n console.timeEnd(\"interfaceStructureTree getModelObjects\");\n structureTreeBus_1.default.$on(\"updateTree\", function (key) {\n var _a;\n console.log(\"structureTreeBus\");\n var tree = _this.$refs.structureTree;\n if (tree) {\n var keys = tree.getCheckedKeys();\n var expandedKeys = tree.getCheckedKeys();\n if (key !== undefined) {\n var treeNode = (_a = _this.viewer.structureTreeManager) === null || _a === void 0 ? void 0 : _a.treeNodes[key];\n _this.updateNode(treeNode);\n } else {\n _this.level0Node.childNodes = [];\n _this.checkKeys = [];\n _this.loadNode(_this.level0Node, _this.level0NodeResolve);\n _this.showLevel(1);\n }\n tree.setCheckedKeys(expandedKeys);\n }\n });\n this.$nextTick(function () {\n _this.viewer.onLButtonUp.add(_this.heighLight);\n });\n };\n InterfaceStructureTree.prototype.beforeDestroy = function () {\n if (this.viewer) {\n this.viewer.onLButtonUp.remove(this.heighLight);\n }\n };\n tslib_1.__decorate([(0, vue_property_decorator_1.Prop)()], InterfaceStructureTree.prototype, \"componentData\", void 0);\n tslib_1.__decorate([(0, vue_property_decorator_1.Inject)()], InterfaceStructureTree.prototype, \"getViewer\", void 0);\n InterfaceStructureTree = tslib_1.__decorate([(0, vue_property_decorator_1.Component)({\n components: {\n GsDivider: gs_divider_vue_1.default\n }\n })], InterfaceStructureTree);\n return InterfaceStructureTree;\n }(vue_property_decorator_1.Vue);\n exports[\"default\"] = InterfaceStructureTree;\n}).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/babel-loader/lib/index.js??clonedRuleSet-86.use[0]!./node_modules/babel-loader/lib/index.js!./node_modules/@vue/cli-plugin-typescript/node_modules/ts-loader/index.js??clonedRuleSet-88.use[1]!./packages/bimAir/src/viewerWrapper/panels/structureTree/panes/structureTree.tsx?vue&type=script&lang=js&.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBA;AACA;AACA;AACA;AACA;AAKA;AAAA;AAAA;AAAA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAMA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAQA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AASA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AAEA;AAGA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAGA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AACA;AACA;AACA;;AAEA;;AAw9BA;AAt9BA;AAAA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;AACA;;;;AAEA;AAAA;AACA;AACA;;;;AAEA;AAAA;;AACA;AACA;;AAEA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;;AAEA;AACA;AAGA;AACA;AACA;;AAEA;;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;;AAGA;AAEA;AACA;AAEA;;AAEA;AAEA;AAAA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAEA;;;AAGA;AACA;;;AAGA;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAKA;AACA;AACA;AACA;;AAGA;AACA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAGA;AACA;AACA;AACA;;AAEA;;;;AAKA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AAEA;AAEA;AAAA;AAAA;AAAA;AAIA;AAEA;AAEA;AAAA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAIA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;;AAGA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAQA;AAcA;AACA;AAKA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;;AAEA;AACA;;AAIA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;;;AAIA;AACA;;AAGA;AACA;;AAEA;AAEA;AACA;AACA;AAEA;AAGA;AACA;AACA;;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AASA;AAEA;AAQA;AAAA;AACA;AAEA;AAMA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAGA;AAEA;AACA;AACA;AAEA;AAIA;AAGA;AACA;AAAA;AAGA;AACA;AAGA;AAQA;AAKA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;;;;AAKA;AACA;AAaA;AACA;AAGA;AAEA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AAAA;AACA;AAGA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAKA;AACA;AACA;AAAA;AAAA;AACA;AAEA;AAEA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AAKA;AAKA;AACA;;;AAGA;AAEA;AACA;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;;;AAGA;AAEA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;;AAEA;AAEA;AACA;AACA;AAMA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAMA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AAEA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;;AAEA;AACA;AAEA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AAIA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;;;AAGA;AAEA;AACA;AACA;AAKA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AAKA;AACA;AAKA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AASA;AACA;AACA;AACA;AAEA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;;AAGA;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AAEA;AAAA;AACA;AACA;AACA;;AAIA;AACA;AACA;AACA;AACA;;AAEA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AAEA;;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AASA;AAMA;AACA;AACA;AACA;AAWA;;AAKA;;AAEA;AAEA;AAGA;AAEA;AACA;AAEA;AACA;AAEA;;AAEA;AArqCA;AACA;AAFA;AAFA;AAAA;AAAA;AACA;AAwqCA;AAAA;AAvqCA","sources":["webpack://bimlight-platform/./packages/bimAir/src/viewerWrapper/panels/structureTree/panes/structureTree.tsx?6e16"],"sourcesContent":["import { Component, Inject, Prop, Vue, Watch } from \"vue-property-decorator\";\r\nimport * as Longan from \"gs-longan\";\r\nimport * as LonganApi from \"../../../../gsDevFx/api\";\r\nimport GsDivider from \"../../../../components/gs/gsDivider/gs-divider.vue\";\r\n\r\nimport Tree from \"../../../../components/el/tree\";\r\nimport { Button, Input, Form, FormItem, Message, MessageBox } from \"element-ui\";\r\nimport { ButtonConfig, createMenu } from \"../../../module/createMenu\";\r\nimport structureTree from \"../../../../store/structureTree\";\r\nimport { ComponentSelector } from \"../../../../gsDevFx/operators/componentSelector\";\r\nimport { TreeNodeObject } from \"../../../../gsDevFx/objects/treeNodeObject\";\r\nimport { Viewer } from \"../../../../gsDevFx/viewer\";\r\nimport IDB from \"gs-longan/longan/idb\";\r\nimport { LightModel } from \"../../../../gsDevFx/objects/lightModel\";\r\nimport { ReferenceLightModel } from \"../../../../gsDevFx/objects/referenceLightModel\";\r\nimport structureTreeBus from \"../structureTreeBus\";\r\n\r\nVue.use(Tree);\r\nVue.use(Button);\r\nVue.use(Input);\r\nVue.use(Form);\r\nVue.use(FormItem);\r\n\r\n@Component({\r\n  components: { GsDivider },\r\n})\r\nexport default class InterfaceStructureTree extends Vue {\r\n  @Prop() componentData;\r\n  @Inject() getViewer;\r\n  searchValue = \"\";\r\n  treeProps = {\r\n    label: \"name\",\r\n    children: \"childNodes\",\r\n    isLeaf: \"isLeaf\",\r\n    expaned: \"expaned\",\r\n  };\r\n  treeCheckedNos = [];\r\n  treeExpandAll = true;\r\n  draggingNode = null;\r\n\r\n  treeModelStructure = null;\r\n\r\n  selectedKey = -1;\r\n  selectedPath = \"\";\r\n  // 勾选的keys\r\n  checkKeys = [];\r\n  // 隐藏的keys\r\n  invisibleKeys = [];\r\n  // 展开的keys\r\n  expandedKeys = [];\r\n  currentTreeKey = null;\r\n  isEditingKey: string = null;\r\n  nameValue = \"\";\r\n  // modelObjects: TreeNodeObject[] = [];\r\n  modelObjectsClone = [];\r\n\r\n  parentSegmentKey: number = null;\r\n  treeNodeHoverKey = null;\r\n  isTreeEditing = false;\r\n  operatorList = [];\r\n  contextMenu;\r\n  currentTreeNodeData: TreeNodeObject;\r\n  currentTreeNode;\r\n\r\n  // 隔离id列表\r\n  isolationIds = [];\r\n  levelOneData = [];\r\n\r\n  loopFlag = false;\r\n  selectedGslNode = null;\r\n  nodePath = [];\r\n  chooseNode = null;\r\n  rootNode = null;\r\n  lastNoCheckedRootNodes = [];\r\n\r\n  count = 0;\r\n  end = false;\r\n  isolationKeys = [];\r\n\r\n  isTreeLocate = localStorage.getItem(\"isTreeLocate\") !== \"false\";\r\n\r\n  level0Node;\r\n  level0NodeResolve;\r\n\r\n  currentNode;\r\n  currentNodeResolve;\r\n\r\n  checkStrictly = false;\r\n  draggingNodeChecked = true;\r\n\r\n  buttonList: ButtonConfig[] = [\r\n    {\r\n      name: \"编辑\",\r\n      children: [\r\n        {\r\n          name: \"添加\",\r\n          clickFun: () => {\r\n            this.addRenderObjectClick();\r\n          },\r\n        },\r\n        {\r\n          name: \"重命名\",\r\n          clickFun: () => {\r\n            this.renameRenderObjectClick();\r\n          },\r\n        },\r\n        {\r\n          name: \"删除\",\r\n          clickFun: () => {\r\n            this.deleteRenderObjectClick();\r\n          },\r\n        },\r\n      ],\r\n    },\r\n    // {\r\n    //   name: \"高亮选中对象\",\r\n    //   key: \"highlight\",\r\n    //   clickFun: () => {\r\n    //     //this.componentSelectAndHeighlight();\r\n    //   },\r\n    // },\r\n    {\r\n      name: \"隐藏\",\r\n      children: [\r\n        {\r\n          name: \"隐藏选中对象\",\r\n          clickFun: () => {\r\n            this.hideObject();\r\n          },\r\n        },\r\n        {\r\n          name: \"隐藏其他对象\",\r\n          clickFun: () => {\r\n            this.reHideObject();\r\n          },\r\n        },\r\n        {\r\n          name: \"显示全部对象\",\r\n          clickFun: () => {\r\n            this.clearHideObject();\r\n          },\r\n        },\r\n      ],\r\n    },\r\n    {\r\n      name: \"隔离\",\r\n      children: [\r\n        {\r\n          name: \"隔离选中对象\",\r\n          clickFun: () => {\r\n            this.isolateObject();\r\n          },\r\n        },\r\n        {\r\n          name: \"隔离其他对象\",\r\n          clickFun: () => {\r\n            this.isolateOtherObjects();\r\n          },\r\n        },\r\n        {\r\n          name: \"取消隔离\",\r\n          clickFun: () => {\r\n            this.clearIsolateObjects();\r\n          },\r\n        },\r\n      ],\r\n    },\r\n    {\r\n      name: \"展开\",\r\n      children: [\r\n        {\r\n          name: \"展开一层\",\r\n          clickFun: () => {\r\n            this.showLevel(1);\r\n          },\r\n        },\r\n        {\r\n          name: \"展开二层\",\r\n          clickFun: () => {\r\n            this.showLevel(2);\r\n          },\r\n        },\r\n        {\r\n          name: \"展开三层\",\r\n          clickFun: () => {\r\n            this.showLevel(3);\r\n          },\r\n        },\r\n        // {\r\n        //   name: \"全部展开\", key: \"showAll\", clickFun: () => {\r\n        //     this.setAllExpand(true)\r\n        //   }\r\n        // },\r\n        {\r\n          name: \"全部收起\",\r\n          clickFun: () => {\r\n            this.setAllExpand(false);\r\n          },\r\n        },\r\n      ],\r\n    },\r\n  ];\r\n\r\n  structureTree = structureTree;\r\n  treeNodeDragEnterTimer;\r\n\r\n  heighLight = () => {\r\n    let segObj = this.viewer.selectionManager.segmentObject;\r\n    console.log(\"选中的对象：\", segObj);\r\n    if (segObj) {\r\n      let treeNodeObject =\r\n        this.viewer.structureTreeManager.treeNodes[segObj.nodeKey];\r\n      let pathKeys: Longan.List<string> = new Longan.List();\r\n      if (treeNodeObject) {\r\n        this.getPathKeys(treeNodeObject, pathKeys);\r\n      }\r\n\r\n      let tree = this.$refs.structureTree as any;\r\n      pathKeys.items.reverse().forEach((nodeKey) => {\r\n        // 节点加载完后再展开\r\n        setTimeout(() => {\r\n          let node = tree.getNode(nodeKey);\r\n          if (node) {\r\n            node.expand();\r\n          }\r\n        }, 0);\r\n      });\r\n      // this.expandedKeys.push(segObj.nodeKey);\r\n      setTimeout(() => {\r\n        this.locateCurrentNode(segObj.nodeKey);\r\n        tree.setCurrentKey(segObj.nodeKey);\r\n      }, 10);\r\n    }\r\n  };\r\n\r\n  get viewer(): Viewer {\r\n    return this.getViewer();\r\n  }\r\n\r\n  get tabs() {\r\n    let tabs = this.viewer.options.components.property.tabs;\r\n    return tabs;\r\n  }\r\n\r\n  get viewerType() {\r\n    return this.viewer.options.viewerType;\r\n  }\r\n\r\n  loadNode(node, resolve) {\r\n    if (!this.viewer) {\r\n      resolve([]);\r\n    }\r\n    this.checkStrictly = true;\r\n    if (this.viewer?.structureTreeManager?.rootNode) {\r\n      this.$nextTick(() => {\r\n        this.currentNode = node;\r\n        this.currentNodeResolve = resolve;\r\n        if (node.level === 0) {\r\n          let result;\r\n          this.level0Node = node; //这里是关键！在data里面定义一个变量，将node.level == 0的node存起来\r\n          this.level0NodeResolve = resolve; //同\r\n          if (\r\n            this.viewer.renderObject &&\r\n            this.viewer.renderObject.showTreeNode\r\n          ) {\r\n            result = this.getNodes([this.viewer.structureTreeManager.rootNode]);\r\n            if (this.invisibleKeys.indexOf(result[0].nodeKey) === -1) {\r\n              this.checkKeys.push(result[0].nodeKey);\r\n            }\r\n          } else {\r\n            result = this.getNodes(\r\n              this.viewer.structureTreeManager.rootNode.childNodes\r\n            );\r\n            result.forEach((item) => {\r\n              if (this.invisibleKeys.indexOf(item.nodeKey) === -1) {\r\n                this.checkKeys.push(item.nodeKey);\r\n              }\r\n            });\r\n          }\r\n\r\n          resolve(result);\r\n        } else {\r\n          let treeNode =\r\n            this.viewer.structureTreeManager?.treeNodes[node.data.nodeKey];\r\n          if (treeNode) {\r\n            let childNodes = treeNode.childNodes;\r\n            let result = this.getNodes(childNodes);\r\n            result.forEach((item) => {\r\n              if (this.invisibleKeys.indexOf(item.nodeKey) === -1) {\r\n                this.checkKeys.push(item.nodeKey);\r\n              }\r\n            });\r\n            return resolve(result);\r\n          } else {\r\n            return resolve([]);\r\n          }\r\n        }\r\n      });\r\n\r\n      setTimeout(() => {\r\n        this.checkStrictly = false;\r\n        // console.log(\"树结构父子节点重新关联\");\r\n      }, 20);\r\n    }\r\n  }\r\n\r\n  getNodes(treeNodeObjects: TreeNodeObject[]): {\r\n    name: string;\r\n    nodeKey: string;\r\n    isShow: boolean;\r\n    isLeaf: boolean;\r\n    expaned: boolean;\r\n  }[] {\r\n    let result = [];\r\n    treeNodeObjects.forEach((item) => {\r\n      result.push({\r\n        name: item.name,\r\n        nodeKey: item.nodeKey,\r\n        isShow: item.isShow,\r\n        isLeaf: item.childNodes.length === 0,\r\n        expaned: this.expandedKeys.indexOf(item.nodeKey) !== -1,\r\n      });\r\n    });\r\n    return result;\r\n  }\r\n\r\n  isTreeLocateChange(val) {\r\n    localStorage.setItem(\"isTreeLocate\", val);\r\n    this.isTreeLocate = val;\r\n  }\r\n\r\n  locateCurrentNode(nodeKey) {\r\n    if (!this.isTreeLocate) {\r\n      return;\r\n    }\r\n    this.count = 0;\r\n    this.end = false;\r\n    let tree = document.getElementById(\"structureTree\");\r\n    let node = (this.$refs.structureTree as any).store.root;\r\n\r\n    this.countExpandNode(node, nodeKey);\r\n    let count = this.count;\r\n    let parentElement = tree.parentElement;\r\n    parentElement.scrollTo(0, count * 26 - 60);\r\n  }\r\n\r\n  // TODO：递归待优化，找到目标节点应该中断递归\r\n  countExpandNode(node, nodeKey) {\r\n    if (!this.end) {\r\n      if (node.expanded || this.count === 0 || node.data.nodeKey === nodeKey) {\r\n        this.count += 1;\r\n        if (node.data && node.data.nodeKey === nodeKey) {\r\n          this.end = true;\r\n          return this.count;\r\n        }\r\n        if (node.childNodes) {\r\n          for (let i = 0, len = node.childNodes.length; i < len; i++) {\r\n            // 遍历子节点\r\n            this.countExpandNode(node.childNodes[i], nodeKey);\r\n          }\r\n        }\r\n      } else {\r\n        this.count += 1;\r\n      }\r\n    }\r\n  }\r\n\r\n  findRoVisible(insObj: Longan.RenderInstanceObject, checkedNos: number[]) {\r\n    if (insObj.renderObject.visible) {\r\n      checkedNos.push(insObj.no);\r\n    }\r\n    for (let i = 0; i < insObj.childObjects.length; i++) {\r\n      this.findRoVisible(insObj.childObjects[i], checkedNos);\r\n    }\r\n  }\r\n\r\n  getModelObjects() {\r\n    let viewer = this.viewer;\r\n    if (viewer && viewer.instanceObject) {\r\n      let insObj = viewer.instanceObject;\r\n      let treeCheckedNos = [];\r\n      this.findRoVisible(insObj, treeCheckedNos);\r\n      this.treeCheckedNos = treeCheckedNos;\r\n\r\n      let rootNode =\r\n        this.componentData && this.componentData.structureTree\r\n          ? this.componentData.structureTree[0]\r\n          : this.viewer.structureTreeManager.rootNode;\r\n\r\n      if (this.viewer.renderObject.showTreeNode) {\r\n        this.currentTreeNodeData = rootNode;\r\n      } else {\r\n        this.currentTreeNodeData = rootNode.childNodes[0];\r\n      }\r\n\r\n      this.showLevel(1);\r\n    } else {\r\n      this.treeCheckedNos = [];\r\n    }\r\n  }\r\n\r\n  searchValueChange(val) {\r\n    if (val) {\r\n      let treeNodes = this.viewer.structureTreeManager.treeNodes;\r\n      let tree = this.$refs.structureTree as any;\r\n\r\n      for (let key in treeNodes) {\r\n        if (treeNodes[key].name.indexOf(this.searchValue) !== -1) {\r\n          let treeNodeObject = treeNodes[key];\r\n          let pathKeys: Longan.List<string> = new Longan.List();\r\n          if (treeNodeObject) {\r\n            this.getPathKeys(treeNodeObject, pathKeys);\r\n          }\r\n\r\n          pathKeys.items.reverse().forEach((nodeKey) => {\r\n            let node = tree.getNode(nodeKey);\r\n            if (node) {\r\n              node.expand();\r\n            }\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n    (this.$refs.structureTree as any).filter(this.searchValue);\r\n  }\r\n\r\n  filterNode(value, data): boolean {\r\n    if (!value) {\r\n      return true;\r\n    }\r\n    return data.name.indexOf(value) !== -1;\r\n  }\r\n\r\n  treeCheck(\r\n    data: TreeNodeObject,\r\n    { checkedNodes, checkedKeys, halfCheckedNodes, halfCheckedKeys }\r\n  ) {\r\n    // this.checkKeys = checkedKeys;\r\n    // console.log(\"this.checkKeys\", this.checkKeys);\r\n    let treeNodeObject =\r\n      this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n    if (\r\n      checkedNodes\r\n        .map((item) => item.nodeKey)\r\n        .indexOf(treeNodeObject.nodeKey) === -1\r\n    ) {\r\n      this.viewer.invisibleManager.invisible([treeNodeObject]);\r\n      this.invisibleKeys.push(treeNodeObject.nodeKey);\r\n      console.log(\"隐藏节点keys\", this.invisibleKeys);\r\n    } else {\r\n      this.viewer.invisibleManager.clearInvisible([treeNodeObject]);\r\n      let index = this.invisibleKeys.indexOf(treeNodeObject.nodeKey);\r\n      if (index !== -1) {\r\n        this.invisibleKeys.splice(index, 1);\r\n      }\r\n    }\r\n\r\n    this.viewer.updateDisplay();\r\n\r\n    if (this.viewer.options.components.structureTree.defaultTab.checkFun) {\r\n      this.viewer.options.components.structureTree.defaultTab.checkFun(\r\n        treeNodeObject,\r\n        {\r\n          checkedNodes,\r\n          checkedKeys,\r\n          halfCheckedNodes,\r\n          halfCheckedKeys,\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  findInvisibleRootNodes(rootNode, halfCheckedNodes, invisibleRootNodes) {\r\n    if (rootNode.checked === false) {\r\n      if (halfCheckedNodes.indexOf(rootNode.data) === -1) {\r\n        invisibleRootNodes.push(rootNode.data);\r\n      } else {\r\n        let childNodes = rootNode.childNodes;\r\n        for (let i = 0; i < childNodes.length; i++) {\r\n          this.findInvisibleRootNodes(\r\n            childNodes[i],\r\n            halfCheckedNodes,\r\n            invisibleRootNodes\r\n          );\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  // findNoObjTreeNodeObject(treeNodeObject: TreeNodeObject) {\r\n  //   if (treeNodeObject.obj) {\r\n  //     if (treeNodeObject.childNodes) {\r\n  //       return this.findNoObjTreeNodeObject(treeNodeObject.childNodes[0]);\r\n  //     } else {\r\n  //       return null;\r\n  //     }\r\n  //   } else {\r\n  //     return treeNodeObject;\r\n  //   }\r\n  // }\r\n\r\n  treeNodeClick(data, node) {\r\n    let treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n\r\n    // let noObjTreeNodeObject = this.findNoObjTreeNodeObject(treeNode);\r\n    // this.viewer.ensureSegmentAsynGeometry(noObjTreeNodeObject.segment.key);\r\n\r\n    console.log(\"treeNodeClick\", node, treeNode);\r\n    this.currentTreeNodeData = treeNode;\r\n    this.viewer.selectionManager.clearAllSelectionAndHighlight();\r\n    this.viewer.selectionManager.selectAndHighlight([treeNode]);\r\n    this.viewer.locateObject(treeNode);\r\n\r\n    this.viewer.panelManager.propertyPanel.getProperty(treeNode.segmentObject);\r\n\r\n    if (this.viewer.options.components.structureTree.clickFun) {\r\n      this.viewer.options.components.structureTree.clickFun(treeNode);\r\n    }\r\n    if (this.viewer.options.components.structureTree.defaultTab.clickFun) {\r\n      this.viewer.options.components.structureTree.defaultTab.clickFun(\r\n        treeNode\r\n      );\r\n    }\r\n    this.viewer.updateDisplay();\r\n  }\r\n\r\n  createTree(newTree, node) {\r\n    let newNode = null;\r\n    if (node.data) {\r\n      newNode = { key: node.data.key, name: node.data.name, items: [] };\r\n      if (newTree.items) {\r\n        newTree.items.push(newNode);\r\n      } else {\r\n        newTree.push(newNode);\r\n      }\r\n    }\r\n\r\n    if (!newNode) {\r\n      newNode = newTree;\r\n    }\r\n\r\n    for (let i = 0; i < node.childNodes.length; i++) {\r\n      this.createTree(newNode, node.childNodes[i]);\r\n    }\r\n  }\r\n\r\n  getProperties(key) {\r\n    let segment = new Longan.Segment(key);\r\n    let jsonString = segment.property.showString(\"Properties\");\r\n\r\n    let showParentProperty = segment.property.showBoolean(\r\n      \"showParentProperties\"\r\n    );\r\n    if (showParentProperty) {\r\n      let key = segment.owner.key;\r\n      jsonString = this.getParentProperties(key);\r\n    }\r\n\r\n    return JSON.parse(jsonString);\r\n  }\r\n\r\n  getParentProperties(key) {\r\n    let segment = new Longan.Segment(key);\r\n    let properties = segment.property.showString(\"Properties\");\r\n    if (properties) {\r\n      return properties;\r\n    } else {\r\n      return this.getParentProperties(segment.owner.key);\r\n    }\r\n  }\r\n\r\n  treeNodeDragStart(node, ev) {\r\n    this.draggingNode = node;\r\n    this.currentTreeNode = node;\r\n    this.currentTreeNodeData =\r\n      this.viewer.structureTreeManager.treeNodes[node.data.nodeKey];\r\n    this.draggingNodeChecked = node.checked;\r\n\r\n    console.log(\"this.draggingNodeChecked \", this.draggingNodeChecked);\r\n  }\r\n\r\n  treeNodeDragEnter(draggingNode, overNode, ev) {\r\n    // this.loadNode(overNode, this.level0NodeResolve);\r\n    console.log(\"this.treeNodeDragEnterTimer\");\r\n    // if (this.treeNodeDragEnterTimer) {\r\n    //   clearTimeout(this.treeNodeDragEnterTimer);\r\n    // }\r\n    // this.treeNodeDragEnterTimer = setTimeout(() => {\r\n    //   this.expandedKeys.push(overNode.data.nodeKey);\r\n    //   clearTimeout(this.treeNodeDragEnterTimer);\r\n    //   this.treeNodeDragEnterTimer = null;\r\n    // }, 500);\r\n  }\r\n\r\n  treeNodeDragEnd(draggingNode, dropNode, dropType) {\r\n    // if (dropType === \"inner\" && !dropNode.expanded) {\r\n    //   this.$message.warning(dropNode.label + \"节点未展开，无法移入\");\r\n    //   return false;\r\n    // }\r\n    // return true;\r\n  }\r\n\r\n  treeNodeDrop(draggingNode, dropNode, dropType, ev) {\r\n    console.log(\"dropNode.expend\", dropNode);\r\n\r\n    this.$confirm(\r\n      `是否将节点${draggingNode.label}移动到${dropNode.label}${\r\n        dropType == \"before\" ? \"之前\" : dropType == \"after\" ? \"之后\" : \"下\"\r\n      }?`,\r\n      \"提示\",\r\n      {\r\n        confirmButtonText: \"确定\",\r\n        cancelButtonText: \"取消\",\r\n        type: \"warning\",\r\n      }\r\n    )\r\n      .then(() => {\r\n        this.dropConfirm(draggingNode, dropNode, dropType).then(() => {\r\n          this.$message({\r\n            type: \"success\",\r\n            message: \"移动成功!\",\r\n          });\r\n          // structureTreeBus.$emit(\"updateTree\", draggingNode.key);\r\n          if (dropNode === \"inner\") {\r\n            structureTreeBus.$emit(\"updateTree\", dropNode.key);\r\n          } else {\r\n            structureTreeBus.$emit(\"updateTree\", dropNode.parent.key);\r\n          }\r\n        });\r\n      })\r\n      .catch(() => {\r\n        this.$message({\r\n          type: \"info\",\r\n          message: \"取消移动\",\r\n        });\r\n        // structureTreeBus.$emit(\"updateTree\", draggingNode.parent.key);\r\n        structureTreeBus.$emit(\"updateTree\", dropNode.parent.key);\r\n      });\r\n  }\r\n\r\n  dropConfirm(draggingNode, dropNode, dropType) {\r\n    function getIndex(parent, child) {\r\n      for (let i = 0, len = parent.childNodes.length; i < len; i++) {\r\n        const item = parent.childNodes[i];\r\n        if (item.key === child.key) {\r\n          return i;\r\n        }\r\n      }\r\n      return -1;\r\n    }\r\n\r\n    let index = -1;\r\n    // let draggingSegment = new LonganApi.Segment(draggingNode.key);\r\n    let dropSegment;\r\n\r\n    let draggingTreeNode =\r\n      this.viewer.structureTreeManager.treeNodes[draggingNode.data.nodeKey];\r\n    let dropTreeNode;\r\n\r\n    let targetSegIndex;\r\n\r\n    switch (dropType) {\r\n      case \"inner\":\r\n        // dropSegment = new LonganApi.Segment(dropNode.key);\r\n        dropTreeNode = this.viewer.structureTreeManager.treeNodes[dropNode.key];\r\n        dropSegment = dropTreeNode.segment;\r\n        targetSegIndex = dropTreeNode.childNodes.length;\r\n        this.expandedKeys.push(dropNode.data.key);\r\n        break;\r\n      case \"before\":\r\n        index = getIndex(dropNode.parent, dropNode);\r\n        // dropSegment = new LonganApi.Segment(dropNode.parent.key);\r\n        dropTreeNode =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\r\n        dropSegment =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.key].segment\r\n            .owner;\r\n        targetSegIndex = index - 1;\r\n\r\n        break;\r\n      case \"after\":\r\n        index = getIndex(dropNode.parent, dropNode);\r\n        // dropSegment = new LonganApi.Segment(dropNode.parent.key);\r\n        dropSegment =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.key].segment\r\n            .owner;\r\n\r\n        dropTreeNode =\r\n          this.viewer.structureTreeManager.treeNodes[dropNode.parent.key];\r\n\r\n        targetSegIndex = index + 1;\r\n        break;\r\n    }\r\n    // draggingSegment.moveToIndex(dropSegment, targetSegIndex);\r\n    let draggingNodeChecked = this.draggingNodeChecked;\r\n    return draggingTreeNode\r\n      .moveToIndexWithRequestApi(dropTreeNode, dropSegment, targetSegIndex)\r\n      .then(() => {\r\n        console.log(\r\n          \"this.$refs.structureTree \",\r\n          this.$refs.structureTree,\r\n          draggingNode,\r\n          draggingNode.key,\r\n          draggingNodeChecked\r\n        );\r\n\r\n        (this.$refs.structureTree as any).setChecked(\r\n          draggingNode.key,\r\n          draggingNodeChecked,\r\n          true\r\n        );\r\n        return this.updateIndexedDB();\r\n      });\r\n  }\r\n\r\n  addRenderObjectClick() {\r\n    let data = this.currentTreeNodeData;\r\n    if (data.childNodes) {\r\n      for (let i = 0; i < data.childNodes.length; i++) {\r\n        if (data.childNodes[i].nodeKey === \"-1\") {\r\n          return;\r\n        }\r\n      }\r\n    }\r\n\r\n    this.parentSegmentKey = data.key;\r\n    this.nameValue = \"\";\r\n    // let newNodeData: TreeNodeObject = new TreeNodeObject(\r\n    //   this.viewer,\r\n    //   \" \",\r\n    //   null,\r\n    //   \"\"\r\n    // );\r\n\r\n    // if (!data.childNodes) {\r\n    //   data.childNodes = [];\r\n    // }\r\n    // newNodeData.parent = data;\r\n    // data.childNodes.push(newNodeData);\r\n    const parent = this.currentTreeNode;\r\n    parent.expand();\r\n    // this.expandedKeys.push(data.nodeKey);\r\n    // this.expandedKeys.push(\"-1\");\r\n    (this.$refs.structureTree as any).append(\r\n      {\r\n        name: \" \",\r\n        nodeKey: \"-1\",\r\n        isShow: true,\r\n      },\r\n      parent\r\n    );\r\n\r\n    this.isEditingKey = \"-1\";\r\n    setTimeout(() => {\r\n      this.locateCurrentNode(\"-1\");\r\n      let input = this.$refs.editingTreeNodeInput as any;\r\n      if (input) {\r\n        input.focus();\r\n      }\r\n    }, 10);\r\n  }\r\n\r\n  renameRenderObjectClick() {\r\n    let data = this.currentTreeNodeData;\r\n    this.isEditingKey = data.nodeKey;\r\n    this.nameValue = data.name;\r\n    setTimeout(() => {\r\n      (this.$refs.editingTreeNodeInput as any).focus();\r\n    }, 10);\r\n  }\r\n\r\n  deleteRenderObjectClick() {\r\n    let data = this.currentTreeNodeData;\r\n    let node = this.currentTreeNode;\r\n    MessageBox.confirm(`确定删除${data.name}节点？`, \"提示\", {\r\n      confirmButtonText: \"确定\",\r\n      cancelButtonText: \"取消\",\r\n      type: \"warning\",\r\n    }).then(() => {\r\n      this.updateIndexedDB();\r\n\r\n      this.currentTreeNodeData.deleteWithRequestApi(true).then(() => {\r\n        let children: any[] = node.parent.childNodes;\r\n        const index = children.findIndex(\r\n          (d) => d.data.nodeKey === node.data.nodeKey\r\n        );\r\n\r\n        if (index >= 0) {\r\n          children.splice(index, 1);\r\n        } else {\r\n          this.$message.warning(\"节点删除出错\");\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  editRenderObjectConfirm(node, data) {\r\n    let treeNode = this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n\r\n    // 添加\r\n    if (data.nodeKey === \"-1\") {\r\n      let segment = new LonganApi.Segment(this.parentSegmentKey);\r\n      if (!this.nameValue) {\r\n        Message.warning(\"节点名不能为空\");\r\n        return;\r\n      }\r\n      if (segment.subsegmentExists(this.nameValue)) {\r\n        Message.warning(\"此节点已存在，请重命名\");\r\n      } else {\r\n        // let parent = data.parent;\r\n        //删除临时的\r\n        // parent.removeChildNode(treeNode);\r\n        // treeNode.delete();\r\n        const parent = node.parent;\r\n        const children = parent.childNodes;\r\n        const index = children.findIndex((d) => d.nodeKey === data.nodeKey);\r\n        children.splice(index, 1);\r\n\r\n        let parentTreeNode =\r\n          this.viewer.structureTreeManager.treeNodes[parent.data.nodeKey];\r\n        console.log(\"parentTreeNode\", parentTreeNode);\r\n        if (parentTreeNode) {\r\n          parentTreeNode\r\n            .addWithRequestApi(this.nameValue, true)\r\n            .then((treeNodeObject) => {\r\n              // treeNode = treeNodeObject;\r\n              data.nodeKey = treeNodeObject.nodeKey;\r\n              data.name = treeNodeObject.name;\r\n              this.isEditingKey = null;\r\n              this.nameValue = \"\";\r\n              (this.$refs.structureTree as any).append(\r\n                {\r\n                  name: treeNodeObject.name,\r\n                  nodeKey: treeNodeObject.nodeKey,\r\n                  isShow: true,\r\n                },\r\n                parent\r\n              );\r\n              (this.$refs.structureTree as any).setChecked(\r\n                data.nodeKey,\r\n                true,\r\n                true\r\n              );\r\n              (this.$refs.structureTree as any).setChecked(\r\n                treeNodeObject.nodeKey,\r\n                true,\r\n                true\r\n              );\r\n              this.updateIndexedDB();\r\n            });\r\n        }\r\n      }\r\n    } else {\r\n      // 编辑\r\n      if (this.nameValue) {\r\n        this.currentTreeNodeData\r\n          .renameWithRequestApi(this.nameValue)\r\n          .then(() => {\r\n            this.updateIndexedDB();\r\n          });\r\n\r\n        data.name = this.nameValue;\r\n        this.isEditingKey = null;\r\n        this.nameValue = \"\";\r\n      } else {\r\n        Message.warning(\"名字不能为空\");\r\n      }\r\n    }\r\n  }\r\n\r\n  editRenderObjectCancel(node, data) {\r\n    // 添加\r\n    if (data.nodeKey === \"-1\") {\r\n      const parent = node.parent;\r\n      const children = parent.childNodes;\r\n      const index = children.findIndex((d) => d.nodeKey === data.nodeKey);\r\n      children.splice(index, 1);\r\n    } else {\r\n      // 编辑\r\n      this.isEditingKey = null;\r\n    }\r\n  }\r\n\r\n  updateIndexedDB() {\r\n    let treeNode = this.currentTreeNodeData;\r\n    IDB.getInstance(treeNode.modelId).del(\r\n      treeNode.modelId +\r\n        \"?v=\" +\r\n        (treeNode.model.renderObject as LightModel | ReferenceLightModel)\r\n          .version\r\n    );\r\n  }\r\n\r\n  treeNodeMouseOver(data) {\r\n    // if (this.isTreeEditing) {\r\n    this.treeNodeHoverKey = data.key;\r\n    // }\r\n  }\r\n\r\n  treeNodeMouseLeave(data) {\r\n    // if (this.isTreeEditing) {\r\n    this.treeNodeHoverKey = null;\r\n    // }\r\n  }\r\n\r\n  isBindModelExist(modelId) {\r\n    // for (let i = 0; i < this.modelList.length; i++) {\r\n    //     if (this.modelList[i].lightModelId === modelId) {\r\n    //         return true\r\n    //     }\r\n    // }\r\n    return false;\r\n  }\r\n\r\n  treeNodeContextMenuClick(e, data, node, nodeElement) {\r\n    let treeNodeObject =\r\n      this.viewer.structureTreeManager.treeNodes[data.nodeKey];\r\n    console.log(\"treeNodeContextMenuClick\", e);\r\n    this.currentTreeNodeData = treeNodeObject;\r\n    this.currentTreeNode = node;\r\n    createMenu(e.pageX, e.pageY, this.buttonList);\r\n  }\r\n\r\n  treeNodeExpand(data, node, e) {\r\n    console.log(data, node, e);\r\n    this.expandedKeys.push(data.nodeKey);\r\n  }\r\n\r\n  treeNodeCollapse(data, node, e) {\r\n    let index = this.expandedKeys.indexOf(data.nodeKey);\r\n    if (index !== -1) {\r\n      this.expandedKeys.splice(index, 1);\r\n    }\r\n  }\r\n\r\n  showLevel(level: number) {\r\n    setTimeout(() => {\r\n      // this.expandedKeys = [];\r\n      let node = this.currentTreeNodeData;\r\n      this.expandLevel(node, level);\r\n    }, 10);\r\n  }\r\n\r\n  expandLevel(node, level: number) {\r\n    // node.expanded = true;\r\n    if (node) {\r\n      node.loaded = false;\r\n\r\n      let nodeDom = (this.$refs.structureTree as any)?.getNode(node.nodeKey);\r\n      if (nodeDom) {\r\n        nodeDom.expand();\r\n      }\r\n    }\r\n    setTimeout(() => {\r\n      let currentLevel = level - 1;\r\n      if (currentLevel > 0) {\r\n        for (let i = 0; i < node.childNodes.length; i++) {\r\n          const item = node.childNodes[i];\r\n          if (item.childNodes && item.childNodes.length > 0) {\r\n            this.expandLevel(item, currentLevel);\r\n          }\r\n        }\r\n      }\r\n    }, 10);\r\n    // this.expandedKeys.push(node.key);\r\n  }\r\n\r\n  setAllExpand(state) {\r\n    let nodes = (this.$refs.structureTree as any).store.root;\r\n    this.expandNode(nodes, state);\r\n  }\r\n\r\n  expandNode(node, state) {\r\n    // 改变节点的自身expanded状态\r\n    node.expanded = state;\r\n    for (let i = 0, len = node.childNodes.length; i < len; i++) {\r\n      // 遍历子节点\r\n      if (node.childNodes[i].childNodes.length > 0) {\r\n        this.expandNode(node.childNodes[i], state);\r\n      }\r\n    }\r\n  }\r\n\r\n  hideObject() {\r\n    console.log(\"hideObject\");\r\n    (this.$refs.structureTree as any).setChecked(\r\n      this.currentTreeNodeData,\r\n      false,\r\n      true\r\n    );\r\n    let viewer = this.viewer;\r\n    viewer.invisibleManager.invisible([this.currentTreeNodeData]);\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  reHideObject() {\r\n    let root = (this.$refs.structureTree as any).root;\r\n    console.log(\"root-------------\", root);\r\n    root.childNodes.forEach((item) => {\r\n      (this.$refs.structureTree as any).setChecked(\r\n        item.data.nodeKey,\r\n        false,\r\n        true\r\n      );\r\n    });\r\n    (this.$refs.structureTree as any).setChecked(\r\n      this.currentTreeNodeData,\r\n      true,\r\n      true\r\n    );\r\n    let viewer = this.viewer;\r\n    this.viewer.invisibleManager.invisibleInvert([this.currentTreeNodeData]);\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  clearHideObject() {\r\n    let root = (this.$refs.structureTree as any).root;\r\n    root.childNodes.forEach((item) => {\r\n      (this.$refs.structureTree as any).setChecked(\r\n        item.data.nodeKey,\r\n        true,\r\n        true\r\n      );\r\n    });\r\n    let viewer = this.viewer;\r\n    viewer.invisibleManager.clearAllInvisible();\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  checkChange(data) {\r\n    let checkedNodes;\r\n    let checkedKeys = (this.$refs.structureTree as any).getCheckedKeys();\r\n    let halfCheckedNodes = (\r\n      this.$refs.structureTree as any\r\n    ).getHalfCheckedNodes();\r\n    let halfCheckedKeys;\r\n    this.treeCheck(data, {\r\n      checkedNodes,\r\n      checkedKeys,\r\n      halfCheckedNodes,\r\n      halfCheckedKeys,\r\n    });\r\n  }\r\n\r\n  isolateObject() {\r\n    this.viewer.isolationManager.isolation([\r\n      this.currentTreeNodeData.segmentObject,\r\n    ]);\r\n\r\n    this.viewer.updateDisplay();\r\n  }\r\n\r\n  isolateOtherObjects() {\r\n    let viewer = this.viewer;\r\n    viewer.isolationManager.isolationInvert([this.currentTreeNodeData]);\r\n    viewer.updateDisplay();\r\n  }\r\n\r\n  clearIsolateObjects() {\r\n    this.viewer.isolationManager.clearAllIsolation();\r\n    this.viewer.updateDisplay();\r\n  }\r\n\r\n  openEditAllRenderObjectClick(node, data) {\r\n    // this.modelObjectsClone = [...this.modelObjects];\r\n    // this.isTreeEditing = true;\r\n    // setTimeout(() => {\r\n    //   this.expandedKeys.push(data.childNodes[0].key);\r\n    //   this.treeNodeHoverKey = data.childNodes[0].key;\r\n    // }, 100);\r\n  }\r\n\r\n  editAllRenderObjectConfirm(data) {\r\n    this.isTreeEditing = false;\r\n    this.treeNodeHoverKey = null;\r\n  }\r\n\r\n  editAllRenderObjectCancel(data) {\r\n    // this.isTreeEditing = false;\r\n    // this.treeNodeHoverKey = null;\r\n    // this.modelObjects = [...this.modelObjectsClone];\r\n    // this.getModelObjects();\r\n    // this.modelObjects = [];\r\n    // this.createTree(this.modelObjects, (this.$refs.structureTree as any).root);\r\n  }\r\n\r\n  setData() {\r\n    this.$emit(\"setData\", {\r\n      title: \"模型结构树\",\r\n      top: \"20px\",\r\n      left: \"20px\",\r\n      height: \"600px\",\r\n      width: \"300px\",\r\n    });\r\n  }\r\n\r\n  findTreeNodePath(node, targetKey, nodePath: any[]) {\r\n    if (!this.loopFlag) {\r\n      return;\r\n    }\r\n    let childNodes = node.childNodes;\r\n    for (let i = 0; i < childNodes.length; i++) {\r\n      let childNode = childNodes[i];\r\n      let data = childNode.data;\r\n\r\n      let deepCloneNodePath = [...nodePath];\r\n\r\n      deepCloneNodePath.push(childNode);\r\n      if (data.key !== targetKey) {\r\n        this.findTreeNodePath(childNode, targetKey, deepCloneNodePath);\r\n      } else {\r\n        this.nodePath.push(this.rootNode);\r\n        for (let j = 0; j < deepCloneNodePath.length; j++) {\r\n          this.nodePath.push(deepCloneNodePath[j]);\r\n        }\r\n        this.selectedGslNode = childNode;\r\n        this.loopFlag = false;\r\n        return deepCloneNodePath;\r\n      }\r\n    }\r\n  }\r\n\r\n  getPathKeys(treeNodeObject: TreeNodeObject, pathKeys: Longan.List<string>) {\r\n    if (treeNodeObject.nodeKey) {\r\n      pathKeys.add(treeNodeObject.nodeKey);\r\n    }\r\n    if (treeNodeObject.parent) {\r\n      this.getPathKeys(treeNodeObject.parent, pathKeys);\r\n    }\r\n  }\r\n\r\n  updateNode(treeNodeObject: TreeNodeObject) {\r\n    let pathKeys: Longan.List<string> = new Longan.List();\r\n    if (treeNodeObject) {\r\n      this.getPathKeys(treeNodeObject, pathKeys);\r\n    }\r\n\r\n    // let tree = this.$refs.structureTree as any;\r\n    pathKeys.items.reverse().forEach((nodeKey) => {\r\n      if (nodeKey === this.level0Node.key) {\r\n        this.loadNode(this.level0Node, this.level0NodeResolve);\r\n      } else {\r\n        this.loadNode(this.currentNode, this.currentNodeResolve);\r\n      }\r\n    });\r\n  }\r\n\r\n  mounted() {\r\n    this.setData();\r\n    console.time(\"interfaceStructureTree getModelObjects\");\r\n    this.getModelObjects();\r\n    console.timeEnd(\"interfaceStructureTree getModelObjects\");\r\n\r\n    structureTreeBus.$on(\"updateTree\", (key?) => {\r\n      console.log(\"structureTreeBus\");\r\n\r\n      let tree: any = this.$refs.structureTree;\r\n      if (tree) {\r\n        // 获取当前选中节点的key值\r\n        let keys = tree.getCheckedKeys();\r\n        // 获取当前展开节点的key值\r\n        let expandedKeys = tree.getCheckedKeys();\r\n        // 更新数据\r\n        if (key !== undefined) {\r\n          let treeNode = this.viewer.structureTreeManager?.treeNodes[key];\r\n\r\n          // if (treeNode) {\r\n          //   let data = this.getNodes([treeNode])[0];\r\n          //   if (data) {\r\n          //     tree.updateKeyChildren(key, data);\r\n          //   }\r\n          // }\r\n\r\n          this.updateNode(treeNode);\r\n\r\n          // // 获取当前节点\r\n          // const node = tree.getNode(key);\r\n          // // 更新子节点数据\r\n          // node.children = this.getNodes(treeNode.childNodes);\r\n        } else {\r\n          this.level0Node.childNodes = []; //把存起来的node的子节点清空，不然会界面会出现重复树！\r\n          this.checkKeys = [];\r\n          this.loadNode(this.level0Node, this.level0NodeResolve);\r\n          // this.checkStrictly = true;\r\n          // this.invisibleKeys.forEach((key) => {\r\n          //   let node = (this.$refs.structureTree as any).getNode(key);\r\n          //   node.checked = null;\r\n          //   node.parent.checked = null;\r\n          //   // node.parent.indeterminate = true;\r\n          //   console.log(\"(this.$refs.structureTree as any).getNode(key)\", node);\r\n          // });\r\n          // this.checkStrictly = false;\r\n\r\n          this.showLevel(1);\r\n        }\r\n        // 重新勾选节点\r\n        // tree.setCheckedKeys(keys);\r\n        // 重新展开节点\r\n        tree.setCheckedKeys(expandedKeys);\r\n      }\r\n    });\r\n\r\n    this.$nextTick(() => {\r\n      // let componentSelector = this.viewer.operatorManager.find(\"ComponentSelector\") as ComponentSelector;\r\n      // if (componentSelector) {\r\n      this.viewer.onLButtonUp.add(this.heighLight);\r\n      // }\r\n    });\r\n  }\r\n\r\n  beforeDestroy() {\r\n    if (this.viewer) {\r\n      // \tlet componentSelector = this.viewer.operatorManager.find(\"ComponentSelector\") as ComponentSelector;\r\n      this.viewer.onLButtonUp.remove(this.heighLight);\r\n    }\r\n  }\r\n}\r\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedRuleSet-86.use[0]!./node_modules/babel-loader/lib/index.js!./node_modules/@vue/cli-plugin-typescript/node_modules/ts-loader/index.js??clonedRuleSet-88.use[1]!./packages/bimAir/src/viewerWrapper/panels/structureTree/panes/structureTree.tsx?vue&type=script&lang=js&\n");
|
|
7406
7406
|
|
|
7407
7407
|
/***/ }),
|
|
7408
7408
|
|