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,147 @@
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 { button, ColorConverter, collection, div, span, svg } from "chili-controls";
5
+ import { UrlStringConverter } from "chili-controls/src/converters/urlConverter";
6
+ import {
7
+ Binding,
8
+ type IConverter,
9
+ Localize,
10
+ type Material,
11
+ PathBinding,
12
+ Property,
13
+ PubSub,
14
+ Result,
15
+ Texture,
16
+ } from "chili-core";
17
+ import { findPropertyControl } from "../utils";
18
+ import type { MaterialDataContent } from "./materialDataContent";
19
+ import style from "./materialEditor.module.css";
20
+
21
+ class ActiveStyleConverter implements IConverter<Material> {
22
+ constructor(readonly material: Material) {}
23
+
24
+ convert(value: Material): Result<string> {
25
+ return Result.ok(this.material === value ? `${style.material} ${style.active}` : style.material);
26
+ }
27
+ }
28
+
29
+ export class MaterialEditor extends HTMLElement {
30
+ private readonly editingControl: HTMLElement;
31
+ private readonly colorConverter = new ColorConverter();
32
+
33
+ constructor(readonly dataContent: MaterialDataContent) {
34
+ super();
35
+ this.editingControl = div({ className: style.properties });
36
+ this.initEditingControl(dataContent.editingMaterial);
37
+ this.append(this.createEditorUI());
38
+ }
39
+
40
+ private createEditorUI() {
41
+ return div(
42
+ { className: style.root },
43
+ this.titleSection(),
44
+ this.materialsCollection(),
45
+ this.editingControl,
46
+ this.buttons(),
47
+ );
48
+ }
49
+
50
+ private titleSection() {
51
+ return div(
52
+ { className: style.title },
53
+ span({ textContent: new Localize("common.material") }),
54
+ this.iconButton("icon-plus", () => this.dataContent.addMaterial()),
55
+ this.iconButton("icon-clone", () => this.dataContent.copyMaterial()),
56
+ this.iconButton("icon-trash", () => this.dataContent.deleteMaterial()),
57
+ );
58
+ }
59
+
60
+ private iconButton(icon: string, onclick: () => void) {
61
+ return svg({ icon, onclick });
62
+ }
63
+
64
+ private materialsCollection() {
65
+ return collection({
66
+ className: style.materials,
67
+ sources: this.dataContent.document.modelManager.materials,
68
+ template: (material: Material) => this.material(material),
69
+ });
70
+ }
71
+
72
+ private material(material: Material) {
73
+ return span({
74
+ className: new Binding(this.dataContent, "editingMaterial", new ActiveStyleConverter(material)),
75
+ title: material.name,
76
+ style: {
77
+ backgroundColor: new Binding(material, "color", this.colorConverter),
78
+ backgroundImage: new PathBinding(material, "map.image", new UrlStringConverter()),
79
+ backgroundBlendMode: "multiply",
80
+ backgroundSize: "contain",
81
+ },
82
+ onclick: () => {
83
+ this.dataContent.editingMaterial = material;
84
+ },
85
+ ondblclick: () => {
86
+ this.dataContent.callback(material);
87
+ this.remove();
88
+ },
89
+ });
90
+ }
91
+
92
+ private buttons() {
93
+ return div(
94
+ { className: style.bottom },
95
+ button({
96
+ textContent: new Localize("common.confirm"),
97
+ onclick: () => {
98
+ this.dataContent.callback(this.dataContent.editingMaterial);
99
+ this.remove();
100
+ },
101
+ }),
102
+ button({
103
+ textContent: new Localize("common.cancel"),
104
+ onclick: () => this.remove(),
105
+ }),
106
+ );
107
+ }
108
+
109
+ connectedCallback() {
110
+ this.dataContent.onPropertyChanged(this._onEditingMaterialChanged);
111
+ PubSub.default.sub("showProperties", this._handleShowProperty);
112
+ }
113
+
114
+ disconnectedCallback() {
115
+ PubSub.default.remove("showProperties", this._handleShowProperty);
116
+ }
117
+
118
+ private readonly _handleShowProperty = () => {
119
+ this.remove();
120
+ };
121
+
122
+ private readonly _onEditingMaterialChanged = (property: keyof MaterialDataContent) => {
123
+ if (property !== "editingMaterial") return;
124
+ this.editingControl.firstChild?.remove();
125
+ this.initEditingControl(this.dataContent.editingMaterial);
126
+ };
127
+
128
+ private initEditingControl(material: Material) {
129
+ this.editingControl.innerHTML = "";
130
+
131
+ const isTexture = (p: Property) => {
132
+ return (material as any)[p.name] instanceof Texture;
133
+ };
134
+
135
+ const properties = Property.getProperties(material);
136
+ this.editingControl.append(
137
+ ...properties
138
+ .filter((x) => !isTexture(x))
139
+ .map((x) => findPropertyControl(this.dataContent.document, [material], x)),
140
+ ...properties
141
+ .filter(isTexture)
142
+ .map((x) => findPropertyControl(this.dataContent.document, [material], x)),
143
+ );
144
+ }
145
+ }
146
+
147
+ customElements.define("material-editor", MaterialEditor);
@@ -0,0 +1,46 @@
1
+ .root {
2
+ margin-top: 8px;
3
+ }
4
+
5
+ .expander {
6
+ display: flex;
7
+ flex-direction: row;
8
+ }
9
+
10
+ .properties {
11
+ display: flex;
12
+ flex-direction: column;
13
+ justify-content: space-around;
14
+ }
15
+
16
+ .image {
17
+ display: flex;
18
+ flex-direction: column;
19
+ align-items: center;
20
+ margin-top: 4px;
21
+ border-radius: 8px;
22
+ position: relative;
23
+ margin-left: 16px;
24
+
25
+ &:hover {
26
+ --delete-visiblity: visible;
27
+ }
28
+
29
+ img {
30
+ width: 96px;
31
+ height: 96px;
32
+ border-radius: 4px;
33
+ }
34
+
35
+ svg {
36
+ position: absolute;
37
+ background-color: rgba(255, 0, 0, 0.45);
38
+ border-radius: 50%;
39
+ padding: 4px;
40
+ top: 2px;
41
+ right: 2px;
42
+ width: 16px;
43
+ height: 16px;
44
+ visibility: var(--delete-visiblity);
45
+ }
46
+ }
@@ -0,0 +1,61 @@
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, Expander, img, svg } from "chili-controls";
5
+ import { UrlStringConverter } from "chili-controls/src/converters/urlConverter";
6
+ import {
7
+ type I18nKeys,
8
+ type IDocument,
9
+ PathBinding,
10
+ Property,
11
+ readFileAsync,
12
+ type Texture,
13
+ } from "chili-core";
14
+ import { findPropertyControl } from "../utils";
15
+ import style from "./textureEditor.module.css";
16
+
17
+ export class TextureProperty extends Expander {
18
+ constructor(
19
+ readonly document: IDocument,
20
+ display: I18nKeys,
21
+ readonly texture: Texture,
22
+ ) {
23
+ super(display);
24
+ this.classList.add(style.root);
25
+ this.append(this.render());
26
+ }
27
+
28
+ private render() {
29
+ const properties = Property.getProperties(this.texture)
30
+ .filter((x) => (x.name as keyof Texture) !== "image")
31
+ .map((x) => findPropertyControl(this.document, [this.texture], x));
32
+
33
+ return div(
34
+ { className: style.expander },
35
+ div({ className: style.properties }, ...properties),
36
+ div(
37
+ { className: style.image },
38
+ img({
39
+ style: {
40
+ backgroundImage: new PathBinding(this.texture, "image", new UrlStringConverter()),
41
+ backgroundSize: "contain",
42
+ },
43
+ onclick: this.selectTexture,
44
+ }),
45
+ svg({
46
+ icon: "icon-times",
47
+ onclick: () => {
48
+ this.texture.image = "";
49
+ },
50
+ }),
51
+ ),
52
+ );
53
+ }
54
+
55
+ private readonly selectTexture = async () => {
56
+ const file = await readFileAsync(".png, .jpg, .jpeg", false, "readAsDataURL");
57
+ this.texture.image = file.value[0].data;
58
+ };
59
+ }
60
+
61
+ customElements.define("texture-editor", TextureProperty);
@@ -0,0 +1,30 @@
1
+ .material {
2
+ display: flex;
3
+ flex-direction: row;
4
+ align-items: center;
5
+ margin-top: 4px;
6
+
7
+ div {
8
+ font-size: 14px;
9
+ opacity: 0.75;
10
+ color: var(--color);
11
+ min-width: 72px;
12
+ flex: 0 1 auto;
13
+ }
14
+
15
+ button {
16
+ flex: 1 1 auto;
17
+ font-size: 1rem;
18
+ padding: 4px;
19
+ outline: none;
20
+ background-color: transparent;
21
+
22
+ border: 1px solid var(--border-color);
23
+ border-radius: 4px;
24
+ margin: 0px;
25
+
26
+ &:hover {
27
+ background-color: var(--hover-background-color);
28
+ }
29
+ }
30
+ }
@@ -0,0 +1,86 @@
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 { button, ColorConverter, collection, div, span, UrlStringConverter } from "chili-controls";
5
+ import {
6
+ Binding,
7
+ type IDocument,
8
+ Localize,
9
+ type Material,
10
+ ObservableCollection,
11
+ PathBinding,
12
+ type Property,
13
+ PubSub,
14
+ Transaction,
15
+ } from "chili-core";
16
+ import style from "./materialProperty.module.css";
17
+ import { PropertyBase } from "./propertyBase";
18
+
19
+ export class MaterialProperty extends PropertyBase {
20
+ private readonly materials: ObservableCollection<Material>;
21
+
22
+ constructor(
23
+ readonly document: IDocument,
24
+ objects: { materialId: string | string[] }[],
25
+ readonly property: Property,
26
+ ) {
27
+ super(objects);
28
+ this.materials = this.materialCollection(objects[0].materialId);
29
+ this.append(
30
+ collection({
31
+ sources: this.materials,
32
+ template: (material, index) => this.materialControl(document, material, index),
33
+ }),
34
+ );
35
+ }
36
+
37
+ private materialControl(document: IDocument, material: Material, index: number) {
38
+ return div(
39
+ { className: style.material },
40
+ div(
41
+ span({ textContent: new Localize("common.material") }),
42
+ this.materials.length > 1 ? span({ textContent: ` ${index + 1}` }) : "",
43
+ ),
44
+ button({
45
+ textContent: material.name,
46
+ style: {
47
+ backgroundColor: new Binding(material, "color", new ColorConverter()),
48
+ backgroundImage: new PathBinding(material, "map.image", new UrlStringConverter()),
49
+ backgroundBlendMode: "multiply",
50
+ backgroundSize: "cover",
51
+ cursor: "pointer",
52
+ },
53
+ onclick: (e) => {
54
+ PubSub.default.pub("editMaterial", document, material, (material) => {
55
+ this.setMaterial(e, material, index);
56
+ });
57
+ },
58
+ }),
59
+ );
60
+ }
61
+
62
+ private setMaterial(e: MouseEvent, material: Material, index: number) {
63
+ Transaction.execute(this.document, "change material", () => {
64
+ this.materials.replace(index, material);
65
+ this.objects.forEach((x) => {
66
+ if (this.property.name in x) {
67
+ x.materialId =
68
+ this.materials.length > 1
69
+ ? x.materialId.toSpliced(index, 1, material.id)
70
+ : material.id;
71
+ }
72
+ });
73
+ });
74
+ this.document.visual.update();
75
+ }
76
+
77
+ private materialCollection(id: string | string[]) {
78
+ const findMaterial = (id: string) => this.document.modelManager.materials.find((m) => m.id === id);
79
+ const materials = Array.isArray(id)
80
+ ? id.map(findMaterial).filter(Boolean)
81
+ : [findMaterial(id)].filter(Boolean);
82
+ return new ObservableCollection(...materials) as ObservableCollection<Material>;
83
+ }
84
+ }
85
+
86
+ customElements.define("chili-material-property", MaterialProperty);
@@ -0,0 +1,147 @@
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 GroupNode,
6
+ type IConverter,
7
+ type IDocument,
8
+ Matrix4,
9
+ Result,
10
+ type VisualNode,
11
+ type XYZLike,
12
+ } from "chili-core";
13
+ import { InputProperty } from "./input";
14
+ import { PropertyBase } from "./propertyBase";
15
+
16
+ export class MatrixProperty extends PropertyBase {
17
+ readonly first: VisualNode | GroupNode;
18
+
19
+ constructor(
20
+ readonly document: IDocument,
21
+ geometries: (VisualNode | GroupNode)[],
22
+ className: string,
23
+ ) {
24
+ super(geometries);
25
+ this.first = geometries[0];
26
+ this.className = className;
27
+ this.append(
28
+ new InputProperty(
29
+ document,
30
+ [this.first],
31
+ {
32
+ name: "transform",
33
+ display: "transform.translation",
34
+ },
35
+ new TranslationConverter(this.first),
36
+ ),
37
+ new InputProperty(
38
+ document,
39
+ [this.first],
40
+ {
41
+ name: "transform",
42
+ display: "transform.scale",
43
+ },
44
+ new ScalingConverter(this.first),
45
+ ),
46
+ new InputProperty(
47
+ document,
48
+ [this.first],
49
+ {
50
+ name: "transform",
51
+ display: "transform.rotation",
52
+ },
53
+ new RotateConverter(this.first),
54
+ ),
55
+ );
56
+ }
57
+
58
+ private readonly onPropertyChanged = (property: keyof (VisualNode | GroupNode)) => {
59
+ if (property === "transform") {
60
+ this.objects.forEach((obj) => {
61
+ if (obj === this.first) return;
62
+ obj.transform = this.first.transform;
63
+ });
64
+ }
65
+ };
66
+
67
+ connectedCallback() {
68
+ (this.first as VisualNode).onPropertyChanged(this.onPropertyChanged);
69
+ }
70
+
71
+ disconnectedCallback() {
72
+ (this.first as VisualNode).removePropertyChanged(this.onPropertyChanged);
73
+ }
74
+ }
75
+
76
+ customElements.define("matrix-property", MatrixProperty);
77
+
78
+ export abstract class MatrixConverter implements IConverter<Matrix4, string> {
79
+ constructor(readonly geometry: VisualNode | GroupNode) {}
80
+
81
+ convert(value: Matrix4): Result<string, string> {
82
+ const [x, y, z] = this.convertFrom(value);
83
+ return Result.ok(`${x.toFixed(6)}, ${y.toFixed(6)}, ${z.toFixed(6)}`);
84
+ }
85
+
86
+ protected abstract convertFrom(value: Matrix4): [number, number, number];
87
+ protected abstract convertTo(values: XYZLike): Matrix4;
88
+
89
+ convertBack(value: string): Result<Matrix4, string> {
90
+ const values = value
91
+ .split(",")
92
+ .map(Number)
93
+ .filter((x) => !isNaN(x));
94
+ if (values.length !== 3) return Result.err("invalid number of values");
95
+ const newValue = {
96
+ x: values[0],
97
+ y: values[1],
98
+ z: values[2],
99
+ };
100
+ const matrix = this.convertTo(newValue);
101
+ return Result.ok(matrix);
102
+ }
103
+ }
104
+
105
+ export class TranslationConverter extends MatrixConverter {
106
+ protected convertFrom(matrix: Matrix4): [number, number, number] {
107
+ const position = matrix.translationPart();
108
+ return [position.x, position.y, position.z];
109
+ }
110
+ protected convertTo(values: XYZLike): Matrix4 {
111
+ const rotation = this.geometry.transform.getEulerAngles();
112
+ const scale = this.geometry.transform.getScale();
113
+ return Matrix4.createFromTRS(values, rotation, scale);
114
+ }
115
+ }
116
+
117
+ export class ScalingConverter extends MatrixConverter {
118
+ protected convertFrom(matrix: Matrix4): [number, number, number] {
119
+ const s = matrix.getScale();
120
+ return [s.x, s.y, s.z];
121
+ }
122
+ protected convertTo(values: XYZLike): Matrix4 {
123
+ const rotation = this.geometry.transform.getEulerAngles();
124
+ const translation = this.geometry.transform.translationPart();
125
+ return Matrix4.createFromTRS(translation, rotation, values);
126
+ }
127
+ }
128
+
129
+ export class RotateConverter extends MatrixConverter {
130
+ protected convertFrom(matrix: Matrix4): [number, number, number] {
131
+ const s = matrix.getEulerAngles();
132
+ return [(s.pitch * 180) / Math.PI, (s.yaw * 180) / Math.PI, (s.roll * 180) / Math.PI];
133
+ }
134
+ protected convertTo(values: XYZLike): Matrix4 {
135
+ const scale = this.geometry.transform.getScale();
136
+ const translation = this.geometry.transform.translationPart();
137
+ return Matrix4.createFromTRS(
138
+ translation,
139
+ {
140
+ pitch: (values.x * Math.PI) / 180,
141
+ yaw: (values.y * Math.PI) / 180,
142
+ roll: (values.z * Math.PI) / 180,
143
+ },
144
+ scale,
145
+ );
146
+ }
147
+ }
@@ -0,0 +1,3 @@
1
+ .panel {
2
+ margin: 3px 0;
3
+ }
@@ -0,0 +1,14 @@
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 style from "./propertyBase.module.css";
5
+
6
+ export abstract class PropertyBase extends HTMLElement {
7
+ constructor(readonly objects: any[]) {
8
+ super();
9
+ this.className = style.panel;
10
+ if (objects.length === 0) {
11
+ throw new Error(`there are no objects`);
12
+ }
13
+ }
14
+ }
@@ -0,0 +1,36 @@
1
+ .root {
2
+ display: flex;
3
+ flex-direction: column;
4
+ }
5
+
6
+ .header {
7
+ margin: 2px 18px;
8
+ font-size: 1.15rem;
9
+ font-weight: bold;
10
+ flex: 0;
11
+ }
12
+
13
+ .panel {
14
+ flex: 1;
15
+ padding: 10px;
16
+ display: flex;
17
+ flex-direction: column;
18
+ gap: 6px;
19
+ overflow-y: auto;
20
+ border-top: 2px solid transparent;
21
+ border-bottom: 2px solid transparent;
22
+ background-color: var(--panel-background-color);
23
+ }
24
+
25
+ .properties {
26
+ display: flex;
27
+ flex-direction: column;
28
+ gap: 3px;
29
+ }
30
+
31
+ .name {
32
+ display: grid;
33
+ grid-template-columns: auto 1fr;
34
+ grid-gap: 10px;
35
+ align-items: center;
36
+ }
@@ -0,0 +1,115 @@
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, Expander, label } from "chili-controls";
5
+ import {
6
+ FolderNode,
7
+ GroupNode,
8
+ type IDocument,
9
+ type INode,
10
+ type IView,
11
+ Localize,
12
+ Node,
13
+ Property,
14
+ PubSub,
15
+ VisualNode,
16
+ } from "chili-core";
17
+ import { MatrixProperty } from "./matrixProperty";
18
+ import style from "./propertyView.module.css";
19
+ import { findPropertyControl } from "./utils";
20
+
21
+ export class PropertyView extends HTMLElement {
22
+ private readonly panel = div({ className: style.panel });
23
+
24
+ constructor(props: { className: string }) {
25
+ super();
26
+ this.classList.add(props.className, style.root);
27
+ this.append(
28
+ label({
29
+ className: style.header,
30
+ textContent: new Localize("properties.header"),
31
+ }),
32
+ this.panel,
33
+ );
34
+ PubSub.default.sub("showProperties", this.handleShowProperties);
35
+ PubSub.default.sub("activeViewChanged", this.handleActiveViewChanged);
36
+ }
37
+
38
+ private readonly handleActiveViewChanged = (view: IView | undefined) => {
39
+ if (view) {
40
+ const nodes = view.document.selection.getSelectedNodes();
41
+ this.handleShowProperties(view.document, nodes);
42
+ }
43
+ };
44
+
45
+ private readonly handleShowProperties = (document: IDocument, nodes: INode[]) => {
46
+ this.removeProperties();
47
+ if (nodes.length === 0) return;
48
+ this.addModel(document, nodes);
49
+ this.addGeometry(nodes, document);
50
+ };
51
+
52
+ private removeProperties() {
53
+ while (this.panel.lastElementChild) {
54
+ this.panel.removeChild(this.panel.lastElementChild);
55
+ }
56
+ }
57
+
58
+ private addModel(document: IDocument, nodes: INode[]) {
59
+ if (nodes.length === 0) return;
60
+
61
+ let controls: (HTMLElement | string)[] = [];
62
+ if (nodes[0] instanceof FolderNode) {
63
+ controls = Property.getProperties(Object.getPrototypeOf(nodes[0])).map((x) =>
64
+ findPropertyControl(document, nodes, x),
65
+ );
66
+ } else if (nodes[0] instanceof Node) {
67
+ controls = Property.getOwnProperties(Node.prototype).map((x) =>
68
+ findPropertyControl(document, nodes, x),
69
+ );
70
+ }
71
+
72
+ this.panel.append(div({ className: style.properties }, ...controls));
73
+ }
74
+
75
+ private addGeometry(nodes: INode[], document: IDocument) {
76
+ const geometries = nodes.filter((x) => x instanceof VisualNode || x instanceof GroupNode);
77
+ if (geometries.length === 0 || !this.isAllElementsOfTypeFirstElement(geometries)) return;
78
+ this.addTransform(document, geometries);
79
+ this.addParameters(geometries, document);
80
+ }
81
+
82
+ private addTransform(document: IDocument, geometries: (VisualNode | GroupNode)[]) {
83
+ const matrix = new Expander("common.matrix");
84
+ this.panel.append(matrix);
85
+
86
+ matrix.contenxtPanel.append(new MatrixProperty(document, geometries, style.properties));
87
+ }
88
+
89
+ private addParameters(geometries: (VisualNode | GroupNode)[], document: IDocument) {
90
+ const entities = geometries.filter((x) => x instanceof VisualNode);
91
+ if (entities.length === 0 || !this.isAllElementsOfTypeFirstElement(entities)) return;
92
+ const parameters = new Expander(entities[0].display());
93
+ parameters.contenxtPanel.append(
94
+ ...Property.getProperties(Object.getPrototypeOf(entities[0]), Node.prototype).map((x) =>
95
+ findPropertyControl(document, entities, x),
96
+ ),
97
+ );
98
+ this.panel.append(parameters);
99
+ }
100
+
101
+ private isAllElementsOfTypeFirstElement(arr: any[]): boolean {
102
+ if (arr.length <= 1) {
103
+ return true;
104
+ }
105
+ const firstElementType = Object.getPrototypeOf(arr[0]).constructor;
106
+ for (let i = 1; i < arr.length; i++) {
107
+ if (Object.getPrototypeOf(arr[i]).constructor !== firstElementType) {
108
+ return false;
109
+ }
110
+ }
111
+ return true;
112
+ }
113
+ }
114
+
115
+ customElements.define("chili-property-view", PropertyView);