chili3d 0.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (472) hide show
  1. package/.github/workflows/main.yml +26 -0
  2. package/.vscode/c_cpp_properties.json +30 -0
  3. package/.vscode/launch.json +21 -0
  4. package/.vscode/settings.json +8 -0
  5. package/Dockerfile +7 -0
  6. package/LICENSE +661 -0
  7. package/README.md +184 -0
  8. package/biome.json +67 -0
  9. package/compose.yml +7 -0
  10. package/cpp/CMakeLists.txt +96 -0
  11. package/cpp/CMakePresets.json +43 -0
  12. package/cpp/README.md +21 -0
  13. package/cpp/src/converter.cpp +413 -0
  14. package/cpp/src/factory.cpp +612 -0
  15. package/cpp/src/geometry.cpp +204 -0
  16. package/cpp/src/mesher.cpp +330 -0
  17. package/cpp/src/opencascade.cpp +414 -0
  18. package/cpp/src/shape.cpp +447 -0
  19. package/cpp/src/shared.cpp +83 -0
  20. package/cpp/src/shared.hpp +211 -0
  21. package/cpp/src/transient.cpp +29 -0
  22. package/cpp/src/utils.cpp +114 -0
  23. package/cpp/src/utils.hpp +25 -0
  24. package/cpp/test/index.html +146 -0
  25. package/package.json +49 -0
  26. package/packages/chili/package.json +11 -0
  27. package/packages/chili/src/application.ts +200 -0
  28. package/packages/chili/src/bodys/arc.ts +61 -0
  29. package/packages/chili/src/bodys/boolean.ts +32 -0
  30. package/packages/chili/src/bodys/box.ts +73 -0
  31. package/packages/chili/src/bodys/circle.ts +57 -0
  32. package/packages/chili/src/bodys/cone.ts +64 -0
  33. package/packages/chili/src/bodys/cylinder.ts +69 -0
  34. package/packages/chili/src/bodys/ellipse.ts +85 -0
  35. package/packages/chili/src/bodys/face.ts +72 -0
  36. package/packages/chili/src/bodys/fuse.ts +44 -0
  37. package/packages/chili/src/bodys/index.ts +16 -0
  38. package/packages/chili/src/bodys/line.ts +48 -0
  39. package/packages/chili/src/bodys/polygon.ts +40 -0
  40. package/packages/chili/src/bodys/prism.ts +49 -0
  41. package/packages/chili/src/bodys/pyramid.ts +64 -0
  42. package/packages/chili/src/bodys/rect.ts +69 -0
  43. package/packages/chili/src/bodys/revolve.ts +54 -0
  44. package/packages/chili/src/bodys/sphere.ts +48 -0
  45. package/packages/chili/src/bodys/sweep.ts +67 -0
  46. package/packages/chili/src/bodys/wire.ts +36 -0
  47. package/packages/chili/src/commands/application/index.ts +10 -0
  48. package/packages/chili/src/commands/application/newDocument.ts +17 -0
  49. package/packages/chili/src/commands/application/openDocument.ts +35 -0
  50. package/packages/chili/src/commands/application/performanceTest.ts +64 -0
  51. package/packages/chili/src/commands/application/saveDocument.ts +24 -0
  52. package/packages/chili/src/commands/application/toFile.ts +35 -0
  53. package/packages/chili/src/commands/application/toggleDynamicWorkplane.ts +15 -0
  54. package/packages/chili/src/commands/application/wechatGroup.ts +42 -0
  55. package/packages/chili/src/commands/boolean.ts +109 -0
  56. package/packages/chili/src/commands/create/arc.ts +110 -0
  57. package/packages/chili/src/commands/create/bezier.ts +116 -0
  58. package/packages/chili/src/commands/create/box.ts +59 -0
  59. package/packages/chili/src/commands/create/circle.ts +54 -0
  60. package/packages/chili/src/commands/create/cone.ts +104 -0
  61. package/packages/chili/src/commands/create/converter.ts +159 -0
  62. package/packages/chili/src/commands/create/copySubShape.ts +37 -0
  63. package/packages/chili/src/commands/create/curveProjection.ts +61 -0
  64. package/packages/chili/src/commands/create/cylinder.ts +96 -0
  65. package/packages/chili/src/commands/create/ellipse.ts +95 -0
  66. package/packages/chili/src/commands/create/group.ts +205 -0
  67. package/packages/chili/src/commands/create/index.ts +26 -0
  68. package/packages/chili/src/commands/create/line.ts +61 -0
  69. package/packages/chili/src/commands/create/loft.ts +149 -0
  70. package/packages/chili/src/commands/create/offset.ts +131 -0
  71. package/packages/chili/src/commands/create/polygon.ts +104 -0
  72. package/packages/chili/src/commands/create/prism.ts +52 -0
  73. package/packages/chili/src/commands/create/pyramid.ts +56 -0
  74. package/packages/chili/src/commands/create/rect.ts +105 -0
  75. package/packages/chili/src/commands/create/revolve.ts +62 -0
  76. package/packages/chili/src/commands/create/section.ts +31 -0
  77. package/packages/chili/src/commands/create/sphere.ts +48 -0
  78. package/packages/chili/src/commands/create/sweep.ts +39 -0
  79. package/packages/chili/src/commands/create/thickSolid.ts +50 -0
  80. package/packages/chili/src/commands/createActCommand.ts +26 -0
  81. package/packages/chili/src/commands/createCommand.ts +41 -0
  82. package/packages/chili/src/commands/delete.ts +38 -0
  83. package/packages/chili/src/commands/folder.ts +18 -0
  84. package/packages/chili/src/commands/importExport.ts +97 -0
  85. package/packages/chili/src/commands/index.ts +17 -0
  86. package/packages/chili/src/commands/measure/angle.ts +130 -0
  87. package/packages/chili/src/commands/measure/index.ts +6 -0
  88. package/packages/chili/src/commands/measure/length.ts +57 -0
  89. package/packages/chili/src/commands/measure/select.module.css +68 -0
  90. package/packages/chili/src/commands/measure/select.ts +228 -0
  91. package/packages/chili/src/commands/modify/array.ts +447 -0
  92. package/packages/chili/src/commands/modify/break.ts +78 -0
  93. package/packages/chili/src/commands/modify/brush.ts +100 -0
  94. package/packages/chili/src/commands/modify/chamfer.ts +70 -0
  95. package/packages/chili/src/commands/modify/explode.ts +91 -0
  96. package/packages/chili/src/commands/modify/fillet.ts +69 -0
  97. package/packages/chili/src/commands/modify/index.ts +16 -0
  98. package/packages/chili/src/commands/modify/mirror.ts +49 -0
  99. package/packages/chili/src/commands/modify/move.ts +39 -0
  100. package/packages/chili/src/commands/modify/removeFeature.ts +56 -0
  101. package/packages/chili/src/commands/modify/removeSubShapes.ts +44 -0
  102. package/packages/chili/src/commands/modify/rotate.ts +112 -0
  103. package/packages/chili/src/commands/modify/split.ts +81 -0
  104. package/packages/chili/src/commands/modify/transformedCommand.ts +100 -0
  105. package/packages/chili/src/commands/modify/trim.ts +254 -0
  106. package/packages/chili/src/commands/multistepCommand.ts +125 -0
  107. package/packages/chili/src/commands/redo.ts +16 -0
  108. package/packages/chili/src/commands/undo.ts +16 -0
  109. package/packages/chili/src/commands/workingPlane.ts +150 -0
  110. package/packages/chili/src/comparers/NumberEqualityComparer.ts +12 -0
  111. package/packages/chili/src/comparers/XYZEqualityComparer.ts +12 -0
  112. package/packages/chili/src/comparers/index.ts +5 -0
  113. package/packages/chili/src/document.ts +145 -0
  114. package/packages/chili/src/editEventHandler.ts +20 -0
  115. package/packages/chili/src/index.ts +12 -0
  116. package/packages/chili/src/selection.ts +178 -0
  117. package/packages/chili/src/services/commandService.ts +105 -0
  118. package/packages/chili/src/services/editorService.ts +46 -0
  119. package/packages/chili/src/services/hotkeyService.ts +102 -0
  120. package/packages/chili/src/services/index.ts +6 -0
  121. package/packages/chili/src/snap/dimension.ts +33 -0
  122. package/packages/chili/src/snap/handlers/angleSnapEventHandler.ts +60 -0
  123. package/packages/chili/src/snap/handlers/index.ts +7 -0
  124. package/packages/chili/src/snap/handlers/lengthSnapEventHandler.ts +117 -0
  125. package/packages/chili/src/snap/handlers/pointSnapEventHandler.ts +176 -0
  126. package/packages/chili/src/snap/handlers/snapEventHandler.ts +288 -0
  127. package/packages/chili/src/snap/index.ts +6 -0
  128. package/packages/chili/src/snap/snap.ts +50 -0
  129. package/packages/chili/src/snap/snaps/axisSnap.ts +57 -0
  130. package/packages/chili/src/snap/snaps/baseSnap.ts +69 -0
  131. package/packages/chili/src/snap/snaps/featurePointStrategy.ts +64 -0
  132. package/packages/chili/src/snap/snaps/index.ts +7 -0
  133. package/packages/chili/src/snap/snaps/objectSnap.ts +264 -0
  134. package/packages/chili/src/snap/snaps/planeSnap.ts +55 -0
  135. package/packages/chili/src/snap/snaps/pointOnCurveSnap.ts +24 -0
  136. package/packages/chili/src/snap/tracking/axis.ts +32 -0
  137. package/packages/chili/src/snap/tracking/axisTracking.ts +46 -0
  138. package/packages/chili/src/snap/tracking/index.ts +6 -0
  139. package/packages/chili/src/snap/tracking/objectTracking.ts +90 -0
  140. package/packages/chili/src/snap/tracking/trackingBase.ts +40 -0
  141. package/packages/chili/src/snap/tracking/trackingSnap.ts +201 -0
  142. package/packages/chili/src/step/angleStep.ts +32 -0
  143. package/packages/chili/src/step/index.ts +8 -0
  144. package/packages/chili/src/step/lengthStep.ts +32 -0
  145. package/packages/chili/src/step/pointStep.ts +87 -0
  146. package/packages/chili/src/step/selectStep.ts +130 -0
  147. package/packages/chili/src/step/step.ts +55 -0
  148. package/packages/chili/src/utils.ts +19 -0
  149. package/packages/chili/test/command.test.ts +4 -0
  150. package/packages/chili-builder/package.json +13 -0
  151. package/packages/chili-builder/src/additionalModule.ts +15 -0
  152. package/packages/chili-builder/src/appBuilder.ts +176 -0
  153. package/packages/chili-builder/src/defaultDataExchange.ts +152 -0
  154. package/packages/chili-builder/src/index.ts +5 -0
  155. package/packages/chili-builder/src/ribbon.ts +129 -0
  156. package/packages/chili-controls/package.json +9 -0
  157. package/packages/chili-controls/src/collection.ts +96 -0
  158. package/packages/chili-controls/src/controls.ts +83 -0
  159. package/packages/chili-controls/src/converters/colorConverter.ts +39 -0
  160. package/packages/chili-controls/src/converters/index.ts +8 -0
  161. package/packages/chili-controls/src/converters/numberConverter.ts +15 -0
  162. package/packages/chili-controls/src/converters/stringConverter.ts +13 -0
  163. package/packages/chili-controls/src/converters/urlConverter.ts +10 -0
  164. package/packages/chili-controls/src/converters/xyzConverter.ts +28 -0
  165. package/packages/chili-controls/src/expander/expander.module.css +38 -0
  166. package/packages/chili-controls/src/expander/expander.ts +59 -0
  167. package/packages/chili-controls/src/expander/index.ts +4 -0
  168. package/packages/chili-controls/src/htmlProps.ts +10 -0
  169. package/packages/chili-controls/src/index.ts +10 -0
  170. package/packages/chili-controls/src/radioGroup.module.css +20 -0
  171. package/packages/chili-controls/src/radioGroup.ts +54 -0
  172. package/packages/chili-controls/src/utils.ts +20 -0
  173. package/packages/chili-controls/test/converter.test.ts +70 -0
  174. package/packages/chili-controls/test/styleMock.js +4 -0
  175. package/packages/chili-core/package.json +7 -0
  176. package/packages/chili-core/src/application.ts +38 -0
  177. package/packages/chili-core/src/command/command.ts +154 -0
  178. package/packages/chili-core/src/command/commandKeys.ts +8 -0
  179. package/packages/chili-core/src/command/decarator.ts +43 -0
  180. package/packages/chili-core/src/command/index.ts +6 -0
  181. package/packages/chili-core/src/config.ts +145 -0
  182. package/packages/chili-core/src/constants.ts +8 -0
  183. package/packages/chili-core/src/dataExchange.ts +12 -0
  184. package/packages/chili-core/src/document.ts +25 -0
  185. package/packages/chili-core/src/editor.ts +12 -0
  186. package/packages/chili-core/src/foundation/asyncController.ts +55 -0
  187. package/packages/chili-core/src/foundation/binding.ts +132 -0
  188. package/packages/chili-core/src/foundation/collection.ts +208 -0
  189. package/packages/chili-core/src/foundation/converter.ts +9 -0
  190. package/packages/chili-core/src/foundation/deepObserver.ts +154 -0
  191. package/packages/chili-core/src/foundation/disposable.ts +18 -0
  192. package/packages/chili-core/src/foundation/dto/index.ts +9 -0
  193. package/packages/chili-core/src/foundation/equalityComparer.ts +6 -0
  194. package/packages/chili-core/src/foundation/gc.ts +36 -0
  195. package/packages/chili-core/src/foundation/history.ts +237 -0
  196. package/packages/chili-core/src/foundation/id.ts +25 -0
  197. package/packages/chili-core/src/foundation/index.ts +26 -0
  198. package/packages/chili-core/src/foundation/lazy.ts +18 -0
  199. package/packages/chili-core/src/foundation/linkedList.ts +141 -0
  200. package/packages/chili-core/src/foundation/logger.ts +45 -0
  201. package/packages/chili-core/src/foundation/messageType.ts +8 -0
  202. package/packages/chili-core/src/foundation/objectStorage.ts +50 -0
  203. package/packages/chili-core/src/foundation/observer.ts +147 -0
  204. package/packages/chili-core/src/foundation/precision.ts +8 -0
  205. package/packages/chili-core/src/foundation/pubsub.ts +74 -0
  206. package/packages/chili-core/src/foundation/result.ts +69 -0
  207. package/packages/chili-core/src/foundation/storage.ts +10 -0
  208. package/packages/chili-core/src/foundation/transaction.ts +77 -0
  209. package/packages/chili-core/src/foundation/utils/debounce.ts +15 -0
  210. package/packages/chili-core/src/foundation/utils/download.ts +16 -0
  211. package/packages/chili-core/src/foundation/utils/index.ts +6 -0
  212. package/packages/chili-core/src/foundation/utils/readFileAsync.ts +84 -0
  213. package/packages/chili-core/src/i18n/i18n.ts +107 -0
  214. package/packages/chili-core/src/i18n/index.ts +5 -0
  215. package/packages/chili-core/src/i18n/keys.ts +265 -0
  216. package/packages/chili-core/src/index.ts +26 -0
  217. package/packages/chili-core/src/material.ts +269 -0
  218. package/packages/chili-core/src/math/boundingBox.ts +226 -0
  219. package/packages/chili-core/src/math/index.ts +14 -0
  220. package/packages/chili-core/src/math/line.ts +55 -0
  221. package/packages/chili-core/src/math/lineSegment.ts +166 -0
  222. package/packages/chili-core/src/math/mathUtils.ts +45 -0
  223. package/packages/chili-core/src/math/matrix4.ts +414 -0
  224. package/packages/chili-core/src/math/plane.ts +96 -0
  225. package/packages/chili-core/src/math/planeAngle.ts +53 -0
  226. package/packages/chili-core/src/math/quaternion.ts +131 -0
  227. package/packages/chili-core/src/math/ray.ts +30 -0
  228. package/packages/chili-core/src/math/xy.ts +104 -0
  229. package/packages/chili-core/src/math/xyz.ts +181 -0
  230. package/packages/chili-core/src/model/component.ts +305 -0
  231. package/packages/chili-core/src/model/facebaseNode.ts +17 -0
  232. package/packages/chili-core/src/model/folderNode.ts +289 -0
  233. package/packages/chili-core/src/model/geometryNode.ts +185 -0
  234. package/packages/chili-core/src/model/groupNode.ts +19 -0
  235. package/packages/chili-core/src/model/index.ts +12 -0
  236. package/packages/chili-core/src/model/meshNode.ts +53 -0
  237. package/packages/chili-core/src/model/node.ts +315 -0
  238. package/packages/chili-core/src/model/shapeNode.ts +195 -0
  239. package/packages/chili-core/src/model/visualNode.ts +39 -0
  240. package/packages/chili-core/src/modelManager.ts +147 -0
  241. package/packages/chili-core/src/navigation.ts +58 -0
  242. package/packages/chili-core/src/property.ts +60 -0
  243. package/packages/chili-core/src/selection.ts +33 -0
  244. package/packages/chili-core/src/selectionFilter.ts +28 -0
  245. package/packages/chili-core/src/serialize/index.ts +4 -0
  246. package/packages/chili-core/src/serialize/serializer.ts +231 -0
  247. package/packages/chili-core/src/service.ts +10 -0
  248. package/packages/chili-core/src/shape/curve.ts +174 -0
  249. package/packages/chili-core/src/shape/geometry.ts +17 -0
  250. package/packages/chili-core/src/shape/index.ts +12 -0
  251. package/packages/chili-core/src/shape/lineType.ts +7 -0
  252. package/packages/chili-core/src/shape/meshData.ts +347 -0
  253. package/packages/chili-core/src/shape/shape.ts +104 -0
  254. package/packages/chili-core/src/shape/shapeConverter.ts +17 -0
  255. package/packages/chili-core/src/shape/shapeFactory.ts +58 -0
  256. package/packages/chili-core/src/shape/shapeType.ts +75 -0
  257. package/packages/chili-core/src/shape/surface.ts +154 -0
  258. package/packages/chili-core/src/snapType.ts +32 -0
  259. package/packages/chili-core/src/ui/button.ts +16 -0
  260. package/packages/chili-core/src/ui/combobox.ts +27 -0
  261. package/packages/chili-core/src/ui/dialog.ts +7 -0
  262. package/packages/chili-core/src/ui/index.ts +8 -0
  263. package/packages/chili-core/src/ui/ribbon.ts +15 -0
  264. package/packages/chili-core/src/ui/window.ts +13 -0
  265. package/packages/chili-core/src/visual/act.ts +59 -0
  266. package/packages/chili-core/src/visual/cameraController.ts +22 -0
  267. package/packages/chili-core/src/visual/cursorType.ts +4 -0
  268. package/packages/chili-core/src/visual/detectedData.ts +14 -0
  269. package/packages/chili-core/src/visual/eventHandler.ts +15 -0
  270. package/packages/chili-core/src/visual/highlighter.ts +16 -0
  271. package/packages/chili-core/src/visual/index.ts +20 -0
  272. package/packages/chili-core/src/visual/meshExporter.ts +11 -0
  273. package/packages/chili-core/src/visual/meshUtils.ts +276 -0
  274. package/packages/chili-core/src/visual/textGenerator.ts +8 -0
  275. package/packages/chili-core/src/visual/view.ts +80 -0
  276. package/packages/chili-core/src/visual/viewGizmo.ts +8 -0
  277. package/packages/chili-core/src/visual/viewport.ts +10 -0
  278. package/packages/chili-core/src/visual/visual.ts +24 -0
  279. package/packages/chili-core/src/visual/visualContext.ts +29 -0
  280. package/packages/chili-core/src/visual/visualFactory.ts +10 -0
  281. package/packages/chili-core/src/visual/visualObject.ts +25 -0
  282. package/packages/chili-core/src/visual/visualShape.ts +30 -0
  283. package/packages/chili-core/test/binding.test.ts +95 -0
  284. package/packages/chili-core/test/boundingBox.test.ts +60 -0
  285. package/packages/chili-core/test/collection.test.ts +53 -0
  286. package/packages/chili-core/test/history.test.ts +42 -0
  287. package/packages/chili-core/test/line.test.ts +75 -0
  288. package/packages/chili-core/test/linesegment.test.ts +98 -0
  289. package/packages/chili-core/test/linkedList.test.ts +82 -0
  290. package/packages/chili-core/test/math.test.ts +34 -0
  291. package/packages/chili-core/test/matrix.test.ts +129 -0
  292. package/packages/chili-core/test/node.test.ts +122 -0
  293. package/packages/chili-core/test/nodeList.test.ts +247 -0
  294. package/packages/chili-core/test/observer.test.ts +91 -0
  295. package/packages/chili-core/test/plane.test.ts +31 -0
  296. package/packages/chili-core/test/quaternion.test.ts +14 -0
  297. package/packages/chili-core/test/result.test.ts +24 -0
  298. package/packages/chili-core/test/serializer.test.ts +58 -0
  299. package/packages/chili-core/test/snapType.test.ts +10 -0
  300. package/packages/chili-core/test/task.test.ts +41 -0
  301. package/packages/chili-core/test/testDocument.ts +70 -0
  302. package/packages/chili-core/test/transaction.test.ts +42 -0
  303. package/packages/chili-core/test/visual.test.ts +42 -0
  304. package/packages/chili-core/test/xyz.test.ts +260 -0
  305. package/packages/chili-geo/package.json +9 -0
  306. package/packages/chili-geo/src/index.ts +4 -0
  307. package/packages/chili-geo/src/utils.ts +113 -0
  308. package/packages/chili-i18n/package.json +9 -0
  309. package/packages/chili-i18n/src/en.ts +270 -0
  310. package/packages/chili-i18n/src/index.ts +8 -0
  311. package/packages/chili-i18n/src/pt-br.ts +67 -0
  312. package/packages/chili-i18n/src/zh-cn.ts +269 -0
  313. package/packages/chili-storage/package.json +9 -0
  314. package/packages/chili-storage/src/index.ts +4 -0
  315. package/packages/chili-storage/src/indexedDBStorage.ts +150 -0
  316. package/packages/chili-three/package.json +13 -0
  317. package/packages/chili-three/src/cameraController.ts +335 -0
  318. package/packages/chili-three/src/common.ts +65 -0
  319. package/packages/chili-three/src/constants.ts +12 -0
  320. package/packages/chili-three/src/highlightable.ts +13 -0
  321. package/packages/chili-three/src/index.ts +4 -0
  322. package/packages/chili-three/src/meshExporter.ts +69 -0
  323. package/packages/chili-three/src/outlinePass.js +340 -0
  324. package/packages/chili-three/src/texture_points.jpg +0 -0
  325. package/packages/chili-three/src/threeGeometry.ts +207 -0
  326. package/packages/chili-three/src/threeGeometryFactory.ts +120 -0
  327. package/packages/chili-three/src/threeHelper.ts +174 -0
  328. package/packages/chili-three/src/threeHighlighter.ts +257 -0
  329. package/packages/chili-three/src/threeView.module.css +39 -0
  330. package/packages/chili-three/src/threeView.ts +669 -0
  331. package/packages/chili-three/src/threeViewEventHandler.ts +193 -0
  332. package/packages/chili-three/src/threeVisual.ts +92 -0
  333. package/packages/chili-three/src/threeVisualContext.ts +435 -0
  334. package/packages/chili-three/src/threeVisualFactory.ts +12 -0
  335. package/packages/chili-three/src/threeVisualObject.ts +442 -0
  336. package/packages/chili-three/src/viewGizmo.ts +305 -0
  337. package/packages/chili-three/test/cameraControls.ts +10 -0
  338. package/packages/chili-three/test/testDocument.ts +68 -0
  339. package/packages/chili-three/test/testEdge.ts +171 -0
  340. package/packages/chili-three/test/testView.ts +78 -0
  341. package/packages/chili-three/test/three.test.ts +44 -0
  342. package/packages/chili-three/test/viewGizmo.ts +12 -0
  343. package/packages/chili-ui/package.json +12 -0
  344. package/packages/chili-ui/src/cursor/draw.cur +0 -0
  345. package/packages/chili-ui/src/cursor/index.ts +17 -0
  346. package/packages/chili-ui/src/dialog.module.css +63 -0
  347. package/packages/chili-ui/src/dialog.ts +42 -0
  348. package/packages/chili-ui/src/editor.module.css +83 -0
  349. package/packages/chili-ui/src/editor.ts +142 -0
  350. package/packages/chili-ui/src/home/home.module.css +301 -0
  351. package/packages/chili-ui/src/home/home.ts +243 -0
  352. package/packages/chili-ui/src/home/index.ts +4 -0
  353. package/packages/chili-ui/src/home/languageSelector.ts +27 -0
  354. package/packages/chili-ui/src/home/navigation3DSelector.ts +27 -0
  355. package/packages/chili-ui/src/home/themeSelector.ts +34 -0
  356. package/packages/chili-ui/src/index.ts +5 -0
  357. package/packages/chili-ui/src/mainWindow.module.css +144 -0
  358. package/packages/chili-ui/src/mainWindow.ts +154 -0
  359. package/packages/chili-ui/src/okCancel.module.css +54 -0
  360. package/packages/chili-ui/src/okCancel.ts +58 -0
  361. package/packages/chili-ui/src/permanent.module.css +44 -0
  362. package/packages/chili-ui/src/permanent.ts +31 -0
  363. package/packages/chili-ui/src/project/index.ts +4 -0
  364. package/packages/chili-ui/src/project/projectView.module.css +37 -0
  365. package/packages/chili-ui/src/project/projectView.ts +77 -0
  366. package/packages/chili-ui/src/project/toolBar.module.css +16 -0
  367. package/packages/chili-ui/src/project/toolBar.ts +73 -0
  368. package/packages/chili-ui/src/project/tree/index.ts +5 -0
  369. package/packages/chili-ui/src/project/tree/tree.module.css +16 -0
  370. package/packages/chili-ui/src/project/tree/tree.ts +265 -0
  371. package/packages/chili-ui/src/project/tree/treeItem.module.css +21 -0
  372. package/packages/chili-ui/src/project/tree/treeItem.ts +89 -0
  373. package/packages/chili-ui/src/project/tree/treeItemGroup.module.css +33 -0
  374. package/packages/chili-ui/src/project/tree/treeItemGroup.ts +85 -0
  375. package/packages/chili-ui/src/project/tree/treeModel.module.css +11 -0
  376. package/packages/chili-ui/src/project/tree/treeModel.ts +20 -0
  377. package/packages/chili-ui/src/property/check.ts +39 -0
  378. package/packages/chili-ui/src/property/colorPorperty.module.css +6 -0
  379. package/packages/chili-ui/src/property/colorProperty.ts +63 -0
  380. package/packages/chili-ui/src/property/common.module.css +14 -0
  381. package/packages/chili-ui/src/property/index.ts +4 -0
  382. package/packages/chili-ui/src/property/input.module.css +19 -0
  383. package/packages/chili-ui/src/property/input.ts +140 -0
  384. package/packages/chili-ui/src/property/material/index.ts +5 -0
  385. package/packages/chili-ui/src/property/material/materialDataContent.ts +44 -0
  386. package/packages/chili-ui/src/property/material/materialEditor.module.css +98 -0
  387. package/packages/chili-ui/src/property/material/materialEditor.ts +147 -0
  388. package/packages/chili-ui/src/property/material/textureEditor.module.css +46 -0
  389. package/packages/chili-ui/src/property/material/textureEditor.ts +61 -0
  390. package/packages/chili-ui/src/property/materialProperty.module.css +30 -0
  391. package/packages/chili-ui/src/property/materialProperty.ts +86 -0
  392. package/packages/chili-ui/src/property/matrixProperty.ts +147 -0
  393. package/packages/chili-ui/src/property/propertyBase.module.css +3 -0
  394. package/packages/chili-ui/src/property/propertyBase.ts +14 -0
  395. package/packages/chili-ui/src/property/propertyView.module.css +36 -0
  396. package/packages/chili-ui/src/property/propertyView.ts +115 -0
  397. package/packages/chili-ui/src/property/utils.ts +48 -0
  398. package/packages/chili-ui/src/ribbon/commandContext.module.css +73 -0
  399. package/packages/chili-ui/src/ribbon/commandContext.ts +239 -0
  400. package/packages/chili-ui/src/ribbon/index.ts +4 -0
  401. package/packages/chili-ui/src/ribbon/ribbon.module.css +286 -0
  402. package/packages/chili-ui/src/ribbon/ribbon.ts +288 -0
  403. package/packages/chili-ui/src/ribbon/ribbonButton.module.css +75 -0
  404. package/packages/chili-ui/src/ribbon/ribbonButton.ts +88 -0
  405. package/packages/chili-ui/src/ribbon/ribbonData.ts +66 -0
  406. package/packages/chili-ui/src/ribbon/ribbonStack.module.css +6 -0
  407. package/packages/chili-ui/src/ribbon/ribbonStack.ts +13 -0
  408. package/packages/chili-ui/src/ribbon/ribbonToggleButton.module.css +3 -0
  409. package/packages/chili-ui/src/ribbon/ribbonToggleButton.ts +6 -0
  410. package/packages/chili-ui/src/statusbar/index.ts +4 -0
  411. package/packages/chili-ui/src/statusbar/snapConfig.module.css +25 -0
  412. package/packages/chili-ui/src/statusbar/snapConfig.ts +92 -0
  413. package/packages/chili-ui/src/statusbar/statusbar.module.css +28 -0
  414. package/packages/chili-ui/src/statusbar/statusbar.ts +54 -0
  415. package/packages/chili-ui/src/toast/index.ts +4 -0
  416. package/packages/chili-ui/src/toast/toast.module.css +27 -0
  417. package/packages/chili-ui/src/toast/toast.ts +39 -0
  418. package/packages/chili-ui/src/viewport/flyout/flyout.module.css +9 -0
  419. package/packages/chili-ui/src/viewport/flyout/flyout.ts +77 -0
  420. package/packages/chili-ui/src/viewport/flyout/index.ts +6 -0
  421. package/packages/chili-ui/src/viewport/flyout/input.module.css +21 -0
  422. package/packages/chili-ui/src/viewport/flyout/input.ts +89 -0
  423. package/packages/chili-ui/src/viewport/flyout/tip.module.css +21 -0
  424. package/packages/chili-ui/src/viewport/flyout/tip.ts +45 -0
  425. package/packages/chili-ui/src/viewport/index.ts +4 -0
  426. package/packages/chili-ui/src/viewport/layoutViewport.module.css +21 -0
  427. package/packages/chili-ui/src/viewport/layoutViewport.ts +76 -0
  428. package/packages/chili-ui/src/viewport/viewport.module.css +179 -0
  429. package/packages/chili-ui/src/viewport/viewport.ts +296 -0
  430. package/packages/chili-vis/package.json +9 -0
  431. package/packages/chili-vis/src/index.ts +7 -0
  432. package/packages/chili-vis/src/nodeSelectionEventHandler.ts +122 -0
  433. package/packages/chili-vis/src/selectionEventHandler.ts +145 -0
  434. package/packages/chili-vis/src/shapeSelectionEventHandler.ts +176 -0
  435. package/packages/chili-vis/src/viewUtils.ts +64 -0
  436. package/packages/chili-wasm/lib/chili-wasm.d.ts +827 -0
  437. package/packages/chili-wasm/lib/chili-wasm.js +5275 -0
  438. package/packages/chili-wasm/lib/chili-wasm.wasm +0 -0
  439. package/packages/chili-wasm/package.json +10 -0
  440. package/packages/chili-wasm/src/converter.ts +124 -0
  441. package/packages/chili-wasm/src/curve.ts +589 -0
  442. package/packages/chili-wasm/src/factory.ts +331 -0
  443. package/packages/chili-wasm/src/geometry.ts +51 -0
  444. package/packages/chili-wasm/src/helper.ts +435 -0
  445. package/packages/chili-wasm/src/index.ts +5 -0
  446. package/packages/chili-wasm/src/mesher.ts +114 -0
  447. package/packages/chili-wasm/src/shape.ts +481 -0
  448. package/packages/chili-wasm/src/surface.ts +510 -0
  449. package/packages/chili-wasm/src/wasm.ts +13 -0
  450. package/packages/chili-web/package.json +9 -0
  451. package/packages/chili-web/src/index.ts +33 -0
  452. package/packages/chili-web/src/loading.ts +67 -0
  453. package/packages/global.d.ts +31 -0
  454. package/public/favicon.svg +10 -0
  455. package/public/fonts/fzhei.json +46120 -0
  456. package/public/iconfont.js +1 -0
  457. package/public/images/wechat.jpg +0 -0
  458. package/public/index.css +13 -0
  459. package/public/index.html +24 -0
  460. package/rspack.config.ts +93 -0
  461. package/rstest.config.ts +27 -0
  462. package/screenshots/screenshot.png +0 -0
  463. package/scripts/add_copyright.mjs +59 -0
  464. package/scripts/build-npm.mjs +105 -0
  465. package/scripts/common.mjs +24 -0
  466. package/scripts/release.mjs +92 -0
  467. package/scripts/restore-package-json.mjs +27 -0
  468. package/scripts/setup_wasm_deps.mjs +97 -0
  469. package/scripts/update-package-json.mjs +27 -0
  470. package/tsconfig.build.json +14 -0
  471. package/tsconfig.build.tsbuildinfo +1 -0
  472. package/tsconfig.json +19 -0
@@ -0,0 +1,58 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ import { div, span, svg } from "chili-controls";
5
+ import { type AsyncController, type I18nKeys, Localize } from "chili-core";
6
+ import style from "./okCancel.module.css";
7
+
8
+ export class OKCancel extends HTMLElement {
9
+ private control?: AsyncController;
10
+
11
+ constructor() {
12
+ super();
13
+ this.className = style.root;
14
+ this.append(this.container());
15
+ }
16
+
17
+ private container() {
18
+ return div(
19
+ { className: style.container },
20
+ span({ textContent: new Localize("ribbon.group.selection") }),
21
+ div({ className: style.spacer }),
22
+ this.buttons(),
23
+ );
24
+ }
25
+
26
+ private buttons() {
27
+ return div(
28
+ { className: style.panel },
29
+ this._createIcon("icon-confirm", "common.confirm", this._onConfirm),
30
+ this._createIcon("icon-cancel", "common.cancel", this._onCancel),
31
+ );
32
+ }
33
+
34
+ private _createIcon(icon: string, text: I18nKeys, onClick: () => void) {
35
+ return div(
36
+ {
37
+ className: style.icon,
38
+ onclick: onClick,
39
+ },
40
+ svg({ icon }),
41
+ span({ textContent: new Localize(text) }),
42
+ );
43
+ }
44
+
45
+ setControl(control: AsyncController | undefined) {
46
+ this.control = control;
47
+ }
48
+
49
+ private readonly _onConfirm = () => {
50
+ this.control?.success();
51
+ };
52
+
53
+ private readonly _onCancel = () => {
54
+ this.control?.cancel();
55
+ };
56
+ }
57
+
58
+ customElements.define("ok-cancel", OKCancel);
@@ -0,0 +1,44 @@
1
+ dialog {
2
+ border: none;
3
+ box-shadow: 0px 1px 2px var(--foreground-muted-color);
4
+ border-radius: 16px;
5
+ padding: 0px;
6
+ }
7
+
8
+ dialog::backdrop {
9
+ background-color: var(--backdrop-color);
10
+ }
11
+
12
+ .loading {
13
+ position: relative;
14
+ width: 48px;
15
+ height: 48px;
16
+ border: 2px solid var(--foreground-color);
17
+ border-top-color: var(--loading-border-color);
18
+ border-right-color: var(--loading-border-color);
19
+ border-bottom-color: var(--loading-border-color);
20
+ border-radius: 100%;
21
+ }
22
+
23
+ @keyframes circle {
24
+ 0% {
25
+ transform: rotate(0);
26
+ }
27
+
28
+ 100% {
29
+ transform: rotate(360deg);
30
+ }
31
+ }
32
+
33
+ .container {
34
+ width: fit-content;
35
+ height: fit-content;
36
+ padding: 24px;
37
+ display: flex;
38
+ flex-direction: column;
39
+ align-items: center;
40
+ }
41
+
42
+ .message {
43
+ margin-top: 12px;
44
+ }
@@ -0,0 +1,31 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ import { div, span } from "chili-controls";
5
+ import { I18n, type I18nKeys } from "chili-core";
6
+ import style from "./permanent.module.css";
7
+
8
+ export class Permanent {
9
+ static async show(action: () => Promise<void>, message: I18nKeys, ...args: any[]) {
10
+ const dialog = document.createElement("dialog");
11
+ dialog.appendChild(
12
+ div(
13
+ { className: style.container },
14
+ div({
15
+ className: style.loading,
16
+ style: {
17
+ animation: `${style.circle} infinite 0.75s linear`,
18
+ },
19
+ }),
20
+ span({
21
+ className: style.message,
22
+ textContent: I18n.translate(message, ...args),
23
+ }),
24
+ ),
25
+ );
26
+ document.body.appendChild(dialog);
27
+ dialog.showModal();
28
+
29
+ action().finally(() => dialog.remove());
30
+ }
31
+ }
@@ -0,0 +1,4 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ export * from "./projectView";
@@ -0,0 +1,37 @@
1
+ .root {
2
+ display: flex;
3
+ flex-direction: column;
4
+ }
5
+
6
+ .headerPanel {
7
+ display: flex;
8
+ flex-direction: row;
9
+ align-items: end;
10
+ flex: 0;
11
+ margin: 0px 12px;
12
+ }
13
+
14
+ .itemsPanel {
15
+ display: flex;
16
+ flex: 1;
17
+ flex-direction: column;
18
+ overflow-y: auto;
19
+ border-top: 2px solid transparent;
20
+ border-bottom: 2px solid transparent;
21
+ background-color: var(--panel-background-color);
22
+ }
23
+
24
+ .header {
25
+ display: flex;
26
+ flex-direction: row;
27
+ font-size: 1.15rem;
28
+ font-weight: bolder;
29
+ flex: 1;
30
+ margin: 2px 6px;
31
+ }
32
+
33
+ @media (max-width: 680px) {
34
+ .root {
35
+ display: none;
36
+ }
37
+ }
@@ -0,0 +1,77 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ import { div, span } from "chili-controls";
5
+ import { type IDocument, type IView, Localize, PubSub } from "chili-core";
6
+ import style from "./projectView.module.css";
7
+ import { ToolBar } from "./toolBar";
8
+ import { Tree } from "./tree";
9
+
10
+ export class ProjectView extends HTMLElement {
11
+ private readonly _documentTreeMap = new Map<IDocument, Tree>();
12
+
13
+ private _activeDocument: IDocument | undefined;
14
+ get activeDocument() {
15
+ return this._activeDocument;
16
+ }
17
+
18
+ private readonly panel: HTMLDivElement;
19
+
20
+ constructor(props: { className: string }) {
21
+ super();
22
+ this.classList.add(style.root, props.className);
23
+ this.panel = div({
24
+ className: style.itemsPanel,
25
+ });
26
+ PubSub.default.sub("activeViewChanged", this.handleActiveViewChanged);
27
+ PubSub.default.sub("documentClosed", this.handleDocumentClosed);
28
+
29
+ this.render();
30
+ }
31
+
32
+ private render() {
33
+ this.append(
34
+ div(
35
+ { className: style.headerPanel },
36
+ span({
37
+ className: style.header,
38
+ textContent: new Localize("items.header"),
39
+ }),
40
+ new ToolBar(this),
41
+ ),
42
+ this.panel,
43
+ );
44
+ }
45
+
46
+ activeTree() {
47
+ if (!this._activeDocument) return undefined;
48
+ return this._documentTreeMap.get(this._activeDocument);
49
+ }
50
+
51
+ private readonly handleDocumentClosed = (document: IDocument) => {
52
+ const tree = this._documentTreeMap.get(document);
53
+ if (tree) {
54
+ tree.remove();
55
+ tree.dispose();
56
+ this._documentTreeMap.delete(document);
57
+ }
58
+ };
59
+
60
+ private readonly handleActiveViewChanged = (view: IView | undefined) => {
61
+ if (this._activeDocument === view?.document) return;
62
+
63
+ this._documentTreeMap.get(this._activeDocument!)?.remove();
64
+ this._activeDocument = view?.document;
65
+
66
+ if (view) {
67
+ let tree = this._documentTreeMap.get(view.document);
68
+ if (!tree) {
69
+ tree = new Tree(view.document);
70
+ this._documentTreeMap.set(view.document, tree);
71
+ }
72
+ this.panel.append(tree);
73
+ }
74
+ };
75
+ }
76
+
77
+ customElements.define("chili-project-view", ProjectView);
@@ -0,0 +1,16 @@
1
+ .panel {
2
+ display: flex;
3
+ flex-direction: row;
4
+ flex: 0;
5
+ }
6
+
7
+ .svg {
8
+ width: 16px;
9
+ height: 16px;
10
+ margin-left: 12px;
11
+ padding: 6px;
12
+ }
13
+
14
+ .svg:hover {
15
+ background-color: var(--hover-background-color);
16
+ }
@@ -0,0 +1,73 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ import { a, svg } from "chili-controls";
5
+ import { I18n, type I18nKeys, INode, PubSub } from "chili-core";
6
+ import type { ProjectView } from "./projectView";
7
+ import style from "./toolBar.module.css";
8
+ import type { Tree } from "./tree";
9
+ import { TreeGroup } from "./tree/treeItemGroup";
10
+
11
+ export class ToolBar extends HTMLElement {
12
+ constructor(readonly projectView: ProjectView) {
13
+ super();
14
+ this.className = style.panel;
15
+ this.render();
16
+ }
17
+
18
+ private render() {
19
+ const buttons = [
20
+ { icon: "icon-folder-plus", tip: "items.tool.newFolder", command: this.newGroup },
21
+ { icon: "icon-unexpand", tip: "items.tool.unexpandAll", command: this.unExpandAll },
22
+ { icon: "icon-expand", tip: "items.tool.expandAll", command: this.expandAll },
23
+ ];
24
+ buttons.forEach(({ icon, tip, command }) => this.button(icon, tip as I18nKeys, command));
25
+ }
26
+
27
+ private button(icon: string, tip: I18nKeys, command: () => void) {
28
+ this.append(
29
+ a(
30
+ { title: I18n.translate(tip) },
31
+ svg({
32
+ icon,
33
+ className: style.svg,
34
+ onclick: command,
35
+ }),
36
+ ),
37
+ );
38
+ }
39
+
40
+ private readonly newGroup = () => {
41
+ PubSub.default.pub("executeCommand", "create.folder");
42
+ };
43
+
44
+ private readonly expandAll = () => {
45
+ this.setExpand(true);
46
+ };
47
+
48
+ private readonly unExpandAll = () => {
49
+ this.setExpand(false);
50
+ };
51
+
52
+ private setExpand(expand: boolean) {
53
+ const tree = this.projectView.activeTree();
54
+ if (!tree) return;
55
+ const first = this.projectView.activeDocument?.modelManager.rootNode.firstChild;
56
+ if (first) this.setNodeExpand(tree, first, expand);
57
+ }
58
+
59
+ private setNodeExpand(tree: Tree, list: INode, expand: boolean) {
60
+ const item = tree.treeItem(list);
61
+ if (item instanceof TreeGroup) {
62
+ item.isExpanded = expand;
63
+ }
64
+ if (INode.isLinkedListNode(list) && list.firstChild) {
65
+ this.setNodeExpand(tree, list.firstChild, expand);
66
+ }
67
+ if (list.nextSibling) {
68
+ this.setNodeExpand(tree, list.nextSibling, expand);
69
+ }
70
+ }
71
+ }
72
+
73
+ customElements.define("chili-toolbar", ToolBar);
@@ -0,0 +1,5 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ export * from "./tree";
5
+ export * from "./treeModel";
@@ -0,0 +1,16 @@
1
+ .panel {
2
+ margin: 4px;
3
+ }
4
+
5
+ .selected {
6
+ background-color: var(--hover-background-color);
7
+ }
8
+
9
+ .current {
10
+ outline: 2px solid var(--primary-color);
11
+ }
12
+
13
+ .dragging {
14
+ opacity: 0.56;
15
+ pointer-events: none;
16
+ }
@@ -0,0 +1,265 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ import {
5
+ type IDocument,
6
+ INode,
7
+ type INodeLinkedList,
8
+ type NodeRecord,
9
+ PubSub,
10
+ ShapeType,
11
+ Transaction,
12
+ VisualNode,
13
+ } from "chili-core";
14
+ import { NodeSelectionHandler, ShapeSelectionHandler } from "chili-vis";
15
+ import style from "./tree.module.css";
16
+ import { TreeItem } from "./treeItem";
17
+ import { TreeGroup } from "./treeItemGroup";
18
+ import { TreeModel } from "./treeModel";
19
+
20
+ export class Tree extends HTMLElement {
21
+ private readonly nodeMap = new Map<INode, TreeItem>();
22
+ private lastClicked: INode | undefined;
23
+ private readonly selectedNodes: Set<INode> = new Set();
24
+ private dragging: INode[] | undefined;
25
+
26
+ constructor(private document: IDocument) {
27
+ super();
28
+ this.className = style.panel;
29
+ this.initializeTree(document);
30
+ }
31
+
32
+ private initializeTree(document: IDocument) {
33
+ this.addAllNodes(document, this, document.modelManager.rootNode);
34
+ this.addEvents(this);
35
+ }
36
+
37
+ connectedCallback() {
38
+ this.document.modelManager.addNodeObserver(this.handleNodeChanged);
39
+ PubSub.default.sub("selectionChanged", this.handleSelectionChanged);
40
+ }
41
+
42
+ disconnectedCallback() {
43
+ this.document.modelManager.removeNodeObserver(this.handleNodeChanged);
44
+ PubSub.default.remove("selectionChanged", this.handleSelectionChanged);
45
+ }
46
+
47
+ treeItem(node: INode): TreeItem | undefined {
48
+ return this.nodeMap.get(node);
49
+ }
50
+
51
+ dispose(): void {
52
+ this.lastClicked = undefined;
53
+ this.dragging = undefined;
54
+ this.nodeMap.forEach((x) => x.dispose());
55
+ this.nodeMap.clear();
56
+ this.selectedNodes.clear();
57
+ this.removeEvents(this);
58
+ this.document.modelManager.removeNodeObserver(this.handleNodeChanged);
59
+ PubSub.default.remove("selectionChanged", this.handleSelectionChanged);
60
+ this.document = null as any;
61
+ }
62
+
63
+ readonly handleNodeChanged = (records: NodeRecord[]) => {
64
+ this.ensureHasHTML(records);
65
+ records.forEach((record) => {
66
+ const ele = this.nodeMap.get(record.node);
67
+ ele?.remove();
68
+ if (!ele || !record.newParent) return;
69
+
70
+ const parent = this.nodeMap.get(record.newParent) || this.createAndMapParent(record.newParent);
71
+ if (parent instanceof TreeGroup) {
72
+ const pre = record.newPrevious ? this.nodeMap.get(record.newPrevious) : null;
73
+ parent.insertAfter(ele, pre ?? null);
74
+ }
75
+ });
76
+ };
77
+
78
+ private createAndMapParent(newParent: INode) {
79
+ const parent = this.createHTMLElement(this.document, newParent);
80
+ this.nodeMap.set(newParent, parent);
81
+ return parent;
82
+ }
83
+
84
+ private readonly handleSelectionChanged = (
85
+ document: IDocument,
86
+ selected: INode[],
87
+ unselected: INode[],
88
+ ) => {
89
+ unselected.forEach((x) => {
90
+ this.nodeMap.get(x)?.removeSelectedStyle(style.selected);
91
+ this.selectedNodes.delete(x);
92
+ });
93
+ this.setLastClickItem(undefined);
94
+ selected.forEach((model) => {
95
+ this.selectedNodes.add(model);
96
+ this.nodeMap.get(model)?.addSelectedStyle(style.selected);
97
+ });
98
+ this.scrollToNode(selected);
99
+ };
100
+
101
+ private ensureHasHTML(records: NodeRecord[]) {
102
+ records.forEach((record) => {
103
+ if (!this.nodeMap.has(record.node)) {
104
+ this.nodeMap.set(record.node, this.createHTMLElement(this.document, record.node));
105
+ }
106
+ });
107
+ }
108
+
109
+ private scrollToNode(selected: INode[]) {
110
+ const node = selected.at(0);
111
+ if (node) {
112
+ this.expandParents(node);
113
+ this.nodeMap.get(node)?.scrollIntoView({ block: "nearest", behavior: "smooth" });
114
+ }
115
+ }
116
+
117
+ private expandParents(node: INode) {
118
+ let parent = node.parent;
119
+ while (parent) {
120
+ const group = this.nodeMap.get(parent) as TreeGroup;
121
+ if (group && !group.isExpanded) {
122
+ group.isExpanded = true;
123
+ }
124
+ parent = parent.parent;
125
+ }
126
+ }
127
+
128
+ private addAllNodes(document: IDocument, parent: HTMLElement, node: INode) {
129
+ const element = this.createHTMLElement(document, node);
130
+ this.nodeMap.set(node, element);
131
+ parent.appendChild(element);
132
+
133
+ const firstChild = (node as INodeLinkedList).firstChild;
134
+ if (firstChild) this.addAllNodes(document, element, firstChild);
135
+ if (node.nextSibling) this.addAllNodes(document, parent, node.nextSibling);
136
+ }
137
+
138
+ private createHTMLElement(document: IDocument, node: INode): TreeItem {
139
+ let result: TreeItem;
140
+ if (INode.isLinkedListNode(node)) result = new TreeGroup(document, node);
141
+ else if (node instanceof VisualNode) result = new TreeModel(document, node);
142
+ else throw new Error("unknown node");
143
+ return result;
144
+ }
145
+
146
+ private addEvents(item: HTMLElement) {
147
+ item.addEventListener("dragstart", this.onDragStart);
148
+ item.addEventListener("dragover", this.onDragOver);
149
+ item.addEventListener("dragleave", this.onDragLeave);
150
+ item.addEventListener("drop", this.onDrop);
151
+ item.addEventListener("click", this.onClick);
152
+ }
153
+
154
+ private removeEvents(item: HTMLElement) {
155
+ item.removeEventListener("dragstart", this.onDragStart);
156
+ item.removeEventListener("dragover", this.onDragOver);
157
+ item.removeEventListener("dragleave", this.onDragLeave);
158
+ item.removeEventListener("drop", this.onDrop);
159
+ item.removeEventListener("click", this.onClick);
160
+ }
161
+
162
+ private getTreeItem(item: HTMLElement | null): TreeItem | undefined {
163
+ if (item === null) return undefined;
164
+ if (item instanceof TreeItem) return item;
165
+ return this.getTreeItem(item.parentElement);
166
+ }
167
+
168
+ private readonly onClick = (event: MouseEvent) => {
169
+ if (!this.canSelect()) return;
170
+
171
+ const item = this.getTreeItem(event.target as HTMLElement)?.node;
172
+ if (!item) return;
173
+ event.stopPropagation();
174
+
175
+ if (event.shiftKey) {
176
+ this.handleShiftClick(item);
177
+ } else {
178
+ this.document.selection.setSelection([item], event.ctrlKey);
179
+ }
180
+
181
+ this.setLastClickItem(item);
182
+ };
183
+
184
+ private handleShiftClick(item: INode) {
185
+ if (this.lastClicked) {
186
+ const nodes = INode.getNodesBetween(this.lastClicked, item);
187
+ this.document.selection.setSelection(nodes, false);
188
+ }
189
+ }
190
+
191
+ private readonly onDragLeave = (event: DragEvent) => {
192
+ if (!this.canDrop(event)) return;
193
+ };
194
+
195
+ private readonly onDragOver = (event: DragEvent) => {
196
+ if (!this.canDrop(event)) {
197
+ return;
198
+ }
199
+ event.preventDefault();
200
+ event.dataTransfer!.dropEffect = "move";
201
+ };
202
+
203
+ private canSelect() {
204
+ if (this.document.visual.eventHandler instanceof NodeSelectionHandler) {
205
+ return true;
206
+ }
207
+
208
+ if (this.document.visual.eventHandler instanceof ShapeSelectionHandler) {
209
+ return this.document.visual.eventHandler.shapeType === ShapeType.Shape;
210
+ }
211
+
212
+ return false;
213
+ }
214
+
215
+ private setLastClickItem(item: INode | undefined) {
216
+ if (this.lastClicked !== undefined) {
217
+ this.nodeMap.get(this.lastClicked)?.removeSelectedStyle(style.current);
218
+ }
219
+ this.lastClicked = item;
220
+ if (item !== undefined) {
221
+ this.nodeMap.get(item)?.addSelectedStyle(style.current);
222
+ this.document.modelManager.currentNode = INode.isLinkedListNode(item) ? item : item.parent;
223
+ }
224
+ }
225
+
226
+ private canDrop(event: DragEvent) {
227
+ const node = this.getTreeItem(event.target as HTMLElement)?.node;
228
+ if (node === undefined) return false;
229
+ if (this.dragging?.includes(node)) return false;
230
+ let parent = node.parent;
231
+ while (parent !== undefined) {
232
+ if (this.dragging?.includes(parent)) return false;
233
+ parent = parent.parent;
234
+ }
235
+ return true;
236
+ }
237
+
238
+ protected onDrop = (event: DragEvent) => {
239
+ event.preventDefault();
240
+ event.stopPropagation();
241
+
242
+ const node = this.getTreeItem(event.target as HTMLElement)?.node;
243
+ if (node === undefined) return;
244
+ Transaction.execute(this.document, "move node", () => {
245
+ const isLinkList = INode.isLinkedListNode(node);
246
+ const newParent = isLinkList ? (node as INodeLinkedList) : node.parent;
247
+ const target = isLinkList ? undefined : node;
248
+ this.dragging?.forEach((x) => {
249
+ x.parent?.move(x, newParent!, target);
250
+ });
251
+ this.dragging = undefined;
252
+ });
253
+ };
254
+
255
+ private readonly onDragStart = (event: DragEvent) => {
256
+ event.stopPropagation();
257
+ const item = this.getTreeItem(event.target as HTMLElement)?.node;
258
+ this.dragging = INode.findTopLevelNodes(this.selectedNodes);
259
+ if (item && !INode.containsDescendant(this.selectedNodes, item)) {
260
+ this.dragging.push(item);
261
+ }
262
+ };
263
+ }
264
+
265
+ customElements.define("ui-tree", Tree);
@@ -0,0 +1,21 @@
1
+ .name {
2
+ flex: 1 1 auto;
3
+ font-size: 12px;
4
+ user-select: none;
5
+ text-wrap: nowrap;
6
+ -moz-user-select: none;
7
+ -webkit-user-select: none;
8
+ -ms-user-select: none;
9
+ overflow: hidden;
10
+ }
11
+
12
+ .icon {
13
+ flex-shrink: 0;
14
+ width: 16px;
15
+ height: 16px;
16
+ padding: 0px 8px;
17
+ }
18
+
19
+ .parent-hidden {
20
+ opacity: 0.56;
21
+ }