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,288 @@
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, collection, div, label, span, svg } from "chili-controls";
5
+ import {
6
+ Binding,
7
+ ButtonSize,
8
+ Command,
9
+ type CommandKeys,
10
+ I18n,
11
+ type IApplication,
12
+ type ICommand,
13
+ type IConverter,
14
+ type IView,
15
+ Localize,
16
+ Logger,
17
+ Observable,
18
+ ObservableCollection,
19
+ PubSub,
20
+ Result,
21
+ } from "chili-core";
22
+ import { CommandContext } from "./commandContext";
23
+ import style from "./ribbon.module.css";
24
+ import { RibbonButton } from "./ribbonButton";
25
+ import type { RibbonCommandData, RibbonGroupData, RibbonTabData } from "./ribbonData";
26
+ import { RibbonStack } from "./ribbonStack";
27
+
28
+ export class RibbonDataContent extends Observable {
29
+ readonly quickCommands = new ObservableCollection<CommandKeys>();
30
+ readonly ribbonTabs = new ObservableCollection<RibbonTabData>();
31
+ private _activeTab: RibbonTabData;
32
+ private _activeView: IView | undefined;
33
+
34
+ constructor(
35
+ readonly app: IApplication,
36
+ quickCommands: CommandKeys[],
37
+ ribbonTabs: RibbonTabData[],
38
+ ) {
39
+ super();
40
+ this.quickCommands.push(...quickCommands);
41
+ this.ribbonTabs.push(...ribbonTabs);
42
+ this._activeTab = ribbonTabs[0];
43
+ PubSub.default.sub("activeViewChanged", (v) => {
44
+ this.activeView = v;
45
+ });
46
+ }
47
+
48
+ get activeTab() {
49
+ return this._activeTab;
50
+ }
51
+ set activeTab(value: RibbonTabData) {
52
+ this.setProperty("activeTab", value);
53
+ }
54
+
55
+ get activeView() {
56
+ return this._activeView;
57
+ }
58
+ set activeView(value: IView | undefined) {
59
+ this.setProperty("activeView", value);
60
+ }
61
+ }
62
+
63
+ export const QuickButton = (command: ICommand) => {
64
+ const data = Command.getData(command);
65
+ if (!data) {
66
+ Logger.warn("commandData is undefined");
67
+ return span({ textContent: "null" });
68
+ }
69
+
70
+ return svg({
71
+ icon: data.icon,
72
+ title: new Localize(`command.${data.key}`),
73
+ onclick: () => PubSub.default.pub("executeCommand", data.key),
74
+ });
75
+ };
76
+
77
+ class ViewActiveConverter implements IConverter<IView> {
78
+ constructor(
79
+ readonly target: IView,
80
+ readonly style: string,
81
+ readonly activeStyle: string,
82
+ ) {}
83
+
84
+ convert(value: IView): Result<string> {
85
+ return Result.ok(this.target === value ? `${this.style} ${this.activeStyle}` : this.style);
86
+ }
87
+ }
88
+
89
+ class ActivedRibbonTabConverter implements IConverter<RibbonTabData> {
90
+ constructor(
91
+ readonly tab: RibbonTabData,
92
+ readonly style: string,
93
+ readonly activeStyle: string,
94
+ ) {}
95
+
96
+ convert(value: RibbonTabData): Result<string> {
97
+ return Result.ok(this.tab === value ? `${this.style} ${this.activeStyle}` : this.style);
98
+ }
99
+ }
100
+
101
+ class DisplayConverter implements IConverter<RibbonTabData> {
102
+ constructor(readonly tab: RibbonTabData) {}
103
+
104
+ convert(value: RibbonTabData): Result<string> {
105
+ return Result.ok(this.tab === value ? "" : "none");
106
+ }
107
+ }
108
+
109
+ export class Ribbon extends HTMLElement {
110
+ private readonly _commandContext = div({ className: style.commandContextPanel });
111
+ private commandContext?: CommandContext;
112
+
113
+ constructor(readonly dataContent: RibbonDataContent) {
114
+ super();
115
+ this.className = style.root;
116
+ this.append(this.header(), this.ribbonTabs(), this._commandContext);
117
+ }
118
+
119
+ private header() {
120
+ return div({ className: style.titleBar }, this.leftPanel(), this.centerPanel(), this.rightPanel());
121
+ }
122
+
123
+ private leftPanel() {
124
+ return div(
125
+ { className: style.left },
126
+ div(
127
+ { className: style.appIcon, onclick: () => PubSub.default.pub("displayHome", true) },
128
+ svg({ className: style.icon, icon: "icon-chili" }),
129
+ span({ id: "appName", textContent: `Chili3D - v${__APP_VERSION__}` }),
130
+ ),
131
+ div(
132
+ { className: style.ribbonTitlePanel },
133
+ svg({
134
+ className: style.home,
135
+ icon: "icon-home",
136
+ onclick: () => PubSub.default.pub("displayHome", true),
137
+ }),
138
+ collection({
139
+ className: style.quickCommands,
140
+ sources: this.dataContent.quickCommands,
141
+ template: (command: CommandKeys) => QuickButton(command as any),
142
+ }),
143
+ span({ className: style.split }),
144
+ this.createRibbonHeader(),
145
+ ),
146
+ );
147
+ }
148
+
149
+ private createRibbonHeader() {
150
+ return collection({
151
+ sources: this.dataContent.ribbonTabs,
152
+ template: (tab: RibbonTabData) => {
153
+ const converter = new ActivedRibbonTabConverter(tab, style.tabHeader, style.activedTab);
154
+ return label({
155
+ className: new Binding(this.dataContent, "activeTab", converter),
156
+ textContent: new Localize(tab.tabName),
157
+ onclick: () => {
158
+ this.dataContent.activeTab = tab;
159
+ },
160
+ });
161
+ },
162
+ });
163
+ }
164
+
165
+ private centerPanel() {
166
+ return div(
167
+ { className: style.center },
168
+ collection({
169
+ className: style.views,
170
+ sources: this.dataContent.app.views,
171
+ template: (view) => this.createViewItem(view),
172
+ }),
173
+ svg({
174
+ className: style.new,
175
+ icon: "icon-plus",
176
+ title: I18n.translate("command.doc.new"),
177
+ onclick: () => PubSub.default.pub("executeCommand", "doc.new"),
178
+ }),
179
+ );
180
+ }
181
+
182
+ private createViewItem(view: IView) {
183
+ return div(
184
+ {
185
+ className: new Binding(
186
+ this.dataContent,
187
+ "activeView",
188
+ new ViewActiveConverter(view, style.tab, style.active),
189
+ ),
190
+ onclick: () => {
191
+ this.dataContent.app.activeView = view;
192
+ },
193
+ },
194
+ div({ className: style.name }, span({ textContent: new Binding(view.document, "name") })),
195
+ svg({
196
+ className: style.close,
197
+ icon: "icon-times",
198
+ onclick: (e) => {
199
+ e.stopPropagation();
200
+ view.close();
201
+ },
202
+ }),
203
+ );
204
+ }
205
+
206
+ private rightPanel() {
207
+ return div(
208
+ { className: style.right },
209
+ a(
210
+ { href: "https://github.com/xiangechen/chili3d", target: "_blank" },
211
+ svg({ title: "Github", className: style.icon, icon: "icon-github" }),
212
+ ),
213
+ );
214
+ }
215
+
216
+ private ribbonTabs() {
217
+ return collection({
218
+ className: style.tabContentPanel,
219
+ sources: this.dataContent.ribbonTabs,
220
+ template: (tab: RibbonTabData) => this.ribbonTab(tab),
221
+ });
222
+ }
223
+
224
+ private ribbonTab(tab: RibbonTabData) {
225
+ return collection({
226
+ className: style.groupPanel,
227
+ sources: tab.groups,
228
+ style: {
229
+ display: new Binding(this.dataContent, "activeTab", new DisplayConverter(tab)),
230
+ },
231
+ template: (group: RibbonGroupData) => this.ribbonGroup(group),
232
+ });
233
+ }
234
+
235
+ private ribbonGroup(group: RibbonGroupData) {
236
+ return div(
237
+ { className: style.ribbonGroup },
238
+ collection({
239
+ sources: group.items,
240
+ className: style.content,
241
+ template: (item) => this.ribbonButton(item),
242
+ }),
243
+ label({ className: style.header, textContent: new Localize(group.groupName) }),
244
+ );
245
+ }
246
+
247
+ private ribbonButton(item: RibbonCommandData) {
248
+ if (typeof item === "string") {
249
+ return RibbonButton.fromCommandName(item, ButtonSize.large)!;
250
+ } else if (item instanceof ObservableCollection) {
251
+ const stack = new RibbonStack();
252
+ item.forEach((b) => {
253
+ const button = RibbonButton.fromCommandName(b, ButtonSize.small);
254
+ if (button) stack.append(button);
255
+ });
256
+ return stack;
257
+ } else {
258
+ return new RibbonButton(item.display, item.icon, ButtonSize.large, item.onClick);
259
+ }
260
+ }
261
+
262
+ connectedCallback(): void {
263
+ PubSub.default.sub("openCommandContext", this.openContext);
264
+ PubSub.default.sub("closeCommandContext", this.closeContext);
265
+ }
266
+
267
+ disconnectedCallback(): void {
268
+ PubSub.default.remove("openCommandContext", this.openContext);
269
+ PubSub.default.remove("closeCommandContext", this.closeContext);
270
+ }
271
+
272
+ private readonly openContext = (command: ICommand) => {
273
+ if (this.commandContext) {
274
+ this.closeContext();
275
+ }
276
+ this.commandContext = new CommandContext(command);
277
+ this._commandContext.append(this.commandContext);
278
+ };
279
+
280
+ private readonly closeContext = () => {
281
+ this.commandContext?.remove();
282
+ this.commandContext?.dispose();
283
+ this.commandContext = undefined;
284
+ this._commandContext.innerHTML = "";
285
+ };
286
+ }
287
+
288
+ customElements.define("chili-ribbon", Ribbon);
@@ -0,0 +1,75 @@
1
+ .normal {
2
+ display: flex;
3
+ flex-direction: column;
4
+ align-items: center;
5
+ padding: 4px;
6
+ margin: 4px;
7
+ border-radius: 4px;
8
+ min-width: 42px;
9
+ max-width: 100px;
10
+ width: auto;
11
+ min-height: 48px;
12
+ height: auto;
13
+ }
14
+
15
+ .normal:hover {
16
+ opacity: 0.85;
17
+ background-color: var(--hover-background-color);
18
+ }
19
+
20
+ .normal:active {
21
+ background-color: var(--active-background-color);
22
+ }
23
+
24
+ .small {
25
+ display: flex;
26
+ flex-direction: row;
27
+ justify-items: top;
28
+ padding: 4px;
29
+ margin: 0px 4px;
30
+ }
31
+
32
+ .checked {
33
+ background-color: var(--checked-color);
34
+ }
35
+
36
+ .small:hover {
37
+ opacity: 0.85;
38
+ background-color: var(--hover-background-color);
39
+ }
40
+
41
+ .small:active {
42
+ background-color: var(--active-background-color);
43
+ }
44
+
45
+ .largeButtonText .smallButtonText {
46
+ color: var(--foreground-color);
47
+ white-space: normal;
48
+ word-break: break-word;
49
+ overflow: visible;
50
+ width: 100%;
51
+ display: block;
52
+ }
53
+
54
+ .largeButtonText {
55
+ font-size: 12px;
56
+ text-align: center;
57
+ }
58
+
59
+ .smallButtonText {
60
+ font-size: 12px;
61
+ text-align: left;
62
+ }
63
+
64
+ .icon {
65
+ width: 30px;
66
+ height: 30px;
67
+ margin-bottom: 4px;
68
+ }
69
+
70
+ .smallIcon {
71
+ width: 16px;
72
+ height: 16px;
73
+ margin-right: 8px;
74
+ flex-shrink: 0;
75
+ }
@@ -0,0 +1,88 @@
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 { label, svg } from "chili-controls";
5
+ import {
6
+ ButtonSize,
7
+ Command,
8
+ type CommandData,
9
+ type CommandKeys,
10
+ I18n,
11
+ type I18nKeys,
12
+ type IConverter,
13
+ Localize,
14
+ Logger,
15
+ PubSub,
16
+ Result,
17
+ } from "chili-core";
18
+ import style from "./ribbonButton.module.css";
19
+
20
+ export class RibbonButton extends HTMLElement {
21
+ constructor(
22
+ display: I18nKeys,
23
+ icon: string,
24
+ size: ButtonSize,
25
+ readonly onClick: () => void,
26
+ ) {
27
+ super();
28
+ this.initHTML(display, icon, size);
29
+ this.addEventListener("click", onClick);
30
+ }
31
+
32
+ static fromCommandName(commandName: CommandKeys, size: ButtonSize) {
33
+ const data = Command.getData(commandName);
34
+ if (!data) {
35
+ Logger.warn(`commandData of ${commandName} is undefined`);
36
+ return undefined;
37
+ }
38
+ if (data.toggle) {
39
+ return new RibbonToggleButton(data, size);
40
+ }
41
+ return new RibbonButton(`command.${data.key}`, data.icon, size, () => {
42
+ PubSub.default.pub("executeCommand", commandName);
43
+ });
44
+ }
45
+
46
+ dispose(): void {
47
+ this.removeEventListener("click", this.onClick);
48
+ }
49
+
50
+ private initHTML(display: I18nKeys, icon: string, size: ButtonSize) {
51
+ const image = svg({ icon });
52
+ this.className = size === ButtonSize.large ? style.normal : style.small;
53
+ image.classList.add(size === ButtonSize.large ? style.icon : style.smallIcon);
54
+ const text = label({
55
+ className: size === ButtonSize.large ? style.largeButtonText : style.smallButtonText,
56
+ textContent: new Localize(display),
57
+ });
58
+ I18n.set(this, "title", display);
59
+ this.append(image, text);
60
+ }
61
+ }
62
+
63
+ customElements.define("ribbon-button", RibbonButton);
64
+
65
+ class ToggleConverter implements IConverter {
66
+ constructor(
67
+ readonly className: string,
68
+ readonly active: string,
69
+ ) {}
70
+ convert(isChecked: boolean): Result<string, string> {
71
+ return isChecked ? Result.ok(`${this.className} ${this.active}`) : Result.ok(this.className);
72
+ }
73
+ }
74
+
75
+ export class RibbonToggleButton extends RibbonButton {
76
+ constructor(data: CommandData, size: ButtonSize) {
77
+ super(`command.${data.key}`, data.icon, size, () => {
78
+ PubSub.default.pub("executeCommand", data.key);
79
+ });
80
+
81
+ if (data.toggle) {
82
+ data.toggle.converter = new ToggleConverter(this.className, style.checked);
83
+ data.toggle.setBinding(this, "className");
84
+ }
85
+ }
86
+ }
87
+
88
+ customElements.define("ribbon-toggle-button", RibbonToggleButton);
@@ -0,0 +1,66 @@
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 Button,
6
+ type CommandKeys,
7
+ type I18nKeys,
8
+ Observable,
9
+ ObservableCollection,
10
+ type RibbonGroup,
11
+ type RibbonTab,
12
+ } from "chili-core";
13
+
14
+ export type RibbonCommandData = CommandKeys | ObservableCollection<CommandKeys> | Button;
15
+
16
+ export class RibbonGroupData extends Observable {
17
+ readonly items: ObservableCollection<RibbonCommandData>;
18
+
19
+ get groupName(): I18nKeys {
20
+ return this.getPrivateValue("groupName");
21
+ }
22
+ set groupName(value: I18nKeys) {
23
+ this.setProperty("groupName", value);
24
+ }
25
+
26
+ constructor(groupName: I18nKeys, ...items: RibbonCommandData[]) {
27
+ super();
28
+ this.setPrivateValue("groupName", groupName);
29
+ this.items = new ObservableCollection<RibbonCommandData>(...items);
30
+ }
31
+
32
+ static fromProfile(profile: RibbonGroup) {
33
+ return new RibbonGroupData(
34
+ profile.groupName,
35
+ ...profile.items.map((item) => {
36
+ return Array.isArray(item) ? new ObservableCollection(...item) : item;
37
+ }),
38
+ );
39
+ }
40
+ }
41
+
42
+ export class RibbonTabData extends Observable {
43
+ readonly groups = new ObservableCollection<RibbonGroupData>();
44
+
45
+ get tabName(): I18nKeys {
46
+ return this.getPrivateValue("tabName");
47
+ }
48
+ set tabName(value: I18nKeys) {
49
+ this.setProperty("tabName", value);
50
+ }
51
+
52
+ constructor(tabName: I18nKeys, ...groups: RibbonGroupData[]) {
53
+ super();
54
+ this.setPrivateValue("tabName", tabName);
55
+ this.groups.push(...groups);
56
+ }
57
+
58
+ static fromProfile(profile: RibbonTab) {
59
+ return new RibbonTabData(
60
+ profile.tabName,
61
+ ...profile.groups.map((group) => RibbonGroupData.fromProfile(group)),
62
+ );
63
+ }
64
+ }
65
+
66
+ export type RibbonData = RibbonTabData[];
@@ -0,0 +1,6 @@
1
+ .root {
2
+ display: flex;
3
+ flex-direction: column;
4
+ justify-content: space-between;
5
+ overflow: hidden;
6
+ }
@@ -0,0 +1,13 @@
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 "./ribbonStack.module.css";
5
+
6
+ export class RibbonStack extends HTMLElement {
7
+ constructor() {
8
+ super();
9
+ this.className = style.root;
10
+ }
11
+ }
12
+
13
+ customElements.define("ribbon-stack", RibbonStack);
@@ -0,0 +1,3 @@
1
+ .checked {
2
+ background-color: var(--secondary-color);
3
+ }
@@ -0,0 +1,6 @@
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 { ButtonSize, CommandData, IConverter, PubSub, Result } from "chili-core";
5
+ import { RibbonButton } from "./ribbonButton";
6
+ import style from "./ribbonToggleButton.module.css";
@@ -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 "./statusbar";
@@ -0,0 +1,25 @@
1
+ .container {
2
+ display: flex;
3
+ flex-direction: row;
4
+ align-items: center;
5
+ gap: 8px;
6
+ color: var(--foreground-color);
7
+
8
+ div {
9
+ display: flex;
10
+ flex-direction: row;
11
+ align-items: center;
12
+ gap: 4px;
13
+ user-select: none;
14
+
15
+ input {
16
+ width: 12px;
17
+ height: 12px;
18
+ }
19
+
20
+ label {
21
+ color: var(--foreground-color);
22
+ font-size: 12px;
23
+ }
24
+ }
25
+ }
@@ -0,0 +1,92 @@
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, input, label } from "chili-controls";
5
+ import { Config, type I18nKeys, Localize, ObjectSnapType } from "chili-core";
6
+ import style from "./snapConfig.module.css";
7
+
8
+ const SnapTypes: Array<{
9
+ type: ObjectSnapType;
10
+ display: I18nKeys;
11
+ }> = [
12
+ {
13
+ type: ObjectSnapType.endPoint,
14
+ display: "snap.end",
15
+ },
16
+ {
17
+ type: ObjectSnapType.midPoint,
18
+ display: "snap.mid",
19
+ },
20
+ {
21
+ type: ObjectSnapType.center,
22
+ display: "snap.center",
23
+ },
24
+ {
25
+ type: ObjectSnapType.perpendicular,
26
+ display: "snap.perpendicular",
27
+ },
28
+ {
29
+ type: ObjectSnapType.intersection,
30
+ display: "snap.intersection",
31
+ },
32
+ ];
33
+
34
+ export class SnapConfig extends HTMLElement {
35
+ constructor() {
36
+ super();
37
+ this.className = style.container;
38
+ Config.instance.onPropertyChanged(this.snapTypeChanged);
39
+
40
+ this.render();
41
+ }
42
+
43
+ private readonly snapTypeChanged = (property: keyof Config) => {
44
+ if (property === "snapType" || property === "enableSnap" || property === "enableSnapTracking") {
45
+ this.innerHTML = "";
46
+ this.render();
47
+ }
48
+ };
49
+
50
+ private handleSnapClick(snapType: ObjectSnapType) {
51
+ if (ObjectSnapType.has(Config.instance.snapType, snapType)) {
52
+ Config.instance.snapType = ObjectSnapType.remove(Config.instance.snapType, snapType);
53
+ } else {
54
+ Config.instance.snapType = ObjectSnapType.add(Config.instance.snapType, snapType);
55
+ }
56
+ }
57
+
58
+ private render() {
59
+ this.append(
60
+ ...SnapTypes.map((snapType) => {
61
+ return div(
62
+ input({
63
+ type: "checkbox",
64
+ id: `snap-${snapType.type}`,
65
+ checked: ObjectSnapType.has(Config.instance.snapType, snapType.type),
66
+ onclick: () => this.handleSnapClick(snapType.type),
67
+ }),
68
+ label({
69
+ htmlFor: `snap-${snapType.type}`,
70
+ textContent: new Localize(snapType.display),
71
+ }),
72
+ );
73
+ }),
74
+ div(
75
+ input({
76
+ type: "checkbox",
77
+ id: "snap-tracking",
78
+ checked: Config.instance.enableSnapTracking,
79
+ onclick: () => {
80
+ Config.instance.enableSnapTracking = !Config.instance.enableSnapTracking;
81
+ },
82
+ }),
83
+ label({
84
+ htmlFor: "snap-tracking",
85
+ textContent: new Localize("statusBar.tracking"),
86
+ }),
87
+ ),
88
+ );
89
+ }
90
+ }
91
+
92
+ customElements.define("chili-snap-config", SnapConfig);
@@ -0,0 +1,28 @@
1
+ .panel {
2
+ background: var(--statusbar-background-color);
3
+ border-top: 1px solid var(--border-color);
4
+ display: flex;
5
+ flex-direction: row;
6
+ align-items: center;
7
+ padding: 0 8px;
8
+ }
9
+
10
+ .left {
11
+ flex: 1;
12
+
13
+ .tip {
14
+ font-size: 12px;
15
+ margin: 4px 8px;
16
+ color: var(--statusbar-foreground-color);
17
+ }
18
+ }
19
+
20
+ .right {
21
+ flex: 0 1 auto;
22
+ }
23
+
24
+ @media (max-width: 680px) {
25
+ .right {
26
+ display: none;
27
+ }
28
+ }