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,54 @@
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, label } from "chili-controls";
5
+ import { Config, I18n, type I18nKeys, Navigation3D, PubSub } from "chili-core";
6
+ import { SnapConfig } from "./snapConfig";
7
+ import style from "./statusbar.module.css";
8
+
9
+ export class Statusbar extends HTMLElement {
10
+ private _isDefaultTip = true;
11
+
12
+ readonly tip = label({
13
+ textContent: "",
14
+ className: style.tip,
15
+ });
16
+
17
+ constructor(className: string) {
18
+ super();
19
+ this.className = `${style.panel} ${className}`;
20
+
21
+ this.setDefaultTip();
22
+ this.render();
23
+
24
+ PubSub.default.sub("statusBarTip", this.statusBarTip);
25
+ PubSub.default.sub("clearStatusBarTip", this.setDefaultTip);
26
+ Config.instance.onPropertyChanged(this.handleConfigChanged);
27
+ }
28
+
29
+ private readonly handleConfigChanged = (prop: keyof Config) => {
30
+ if (prop === "navigation3DIndex" && this._isDefaultTip) {
31
+ this.setDefaultTip();
32
+ }
33
+ };
34
+
35
+ private render() {
36
+ this.append(
37
+ div({ className: style.left }, this.tip),
38
+ div({ className: style.right }, new SnapConfig()),
39
+ );
40
+ }
41
+
42
+ private readonly statusBarTip = (tip: I18nKeys) => {
43
+ this._isDefaultTip = false;
44
+ I18n.set(this.tip, "textContent", tip);
45
+ };
46
+
47
+ private readonly setDefaultTip = () => {
48
+ this._isDefaultTip = true;
49
+ const { pan, rotate } = Navigation3D.navigationKeyMap();
50
+ I18n.set(this.tip, "textContent", "prompt.default{0}{1}", pan, rotate);
51
+ };
52
+ }
53
+
54
+ customElements.define("chili-statusbar", Statusbar);
@@ -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 "./toast";
@@ -0,0 +1,27 @@
1
+ .toast {
2
+ position: absolute;
3
+ left: 50%;
4
+ top: 30%;
5
+ transform: translate(-50%, 0%);
6
+ z-index: 10000;
7
+ border-radius: 0.8em;
8
+ background-color: var(--background-color);
9
+ backdrop-filter: blur(10px);
10
+ font-size: 1.2em;
11
+ padding: 1em;
12
+ opacity: 0.85;
13
+ color: var(--foreground-color);
14
+ border: 1px solid var(--border-color);
15
+ }
16
+
17
+ .info {
18
+ color: var(--foreground-color);
19
+ }
20
+
21
+ .error {
22
+ color: var(--error-color);
23
+ }
24
+
25
+ .warning {
26
+ color: var(--warning-color);
27
+ }
@@ -0,0 +1,39 @@
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 } from "chili-controls";
5
+ import { I18n, type I18nKeys } from "chili-core";
6
+ import style from "./toast.module.css";
7
+
8
+ export class Toast {
9
+ private static _lastToast: [number, HTMLElement] | undefined;
10
+
11
+ static readonly info = (message: I18nKeys, ...args: any[]) => {
12
+ Toast.display(style.info, I18n.translate(message, ...args));
13
+ };
14
+
15
+ static readonly error = (message: string) => {
16
+ Toast.display(style.error, message);
17
+ };
18
+
19
+ static readonly warn = (message: string) => {
20
+ Toast.display(style.warning, message);
21
+ };
22
+
23
+ private static display(type: string, message: string) {
24
+ if (Toast._lastToast) {
25
+ clearTimeout(Toast._lastToast[0]);
26
+ Toast._lastToast[1].remove();
27
+ }
28
+
29
+ const toast = label({ className: `${style.toast} ${type}`, textContent: message });
30
+ document.body.appendChild(toast);
31
+ Toast._lastToast = [
32
+ window.setTimeout(() => {
33
+ toast.remove();
34
+ Toast._lastToast = undefined;
35
+ }, 2000),
36
+ toast,
37
+ ];
38
+ }
39
+ }
@@ -0,0 +1,9 @@
1
+ .root {
2
+ position: absolute;
3
+ display: flex;
4
+ flex-direction: column;
5
+ margin-top: 15px;
6
+ margin-left: 15px;
7
+ opacity: 0.75;
8
+ z-index: 888;
9
+ }
@@ -0,0 +1,77 @@
1
+ // Part of the Chili3d Project, under the AGPL-3.0 License.
2
+ // See LICENSE file in the project root for full license information.
3
+
4
+ import { type I18nKeys, type MessageType, PubSub, type Result } from "chili-core";
5
+ import style from "./flyout.module.css";
6
+ import { Input } from "./input";
7
+ import { Tip } from "./tip";
8
+
9
+ export class Flyout extends HTMLElement {
10
+ private _tip: HTMLElement | undefined;
11
+ private _input: Input | undefined;
12
+ private lastFocus: HTMLElement | null = null;
13
+
14
+ constructor() {
15
+ super();
16
+ this.className = style.root;
17
+ }
18
+
19
+ connectedCallback(): void {
20
+ PubSub.default.sub("showFloatTip", this.showTip);
21
+ PubSub.default.sub("clearFloatTip", this.clearTip);
22
+ PubSub.default.sub("showInput", this.displayInput);
23
+ PubSub.default.sub("clearInput", this.clearInput);
24
+ }
25
+
26
+ disconnectedCallback(): void {
27
+ PubSub.default.remove("showFloatTip", this.showTip);
28
+ PubSub.default.remove("clearFloatTip", this.clearTip);
29
+ PubSub.default.remove("showInput", this.displayInput);
30
+ PubSub.default.remove("clearInput", this.clearInput);
31
+ }
32
+
33
+ private readonly showTip = (dom: HTMLElement | { level: MessageType; msg: string }) => {
34
+ if (dom instanceof HTMLElement) {
35
+ this._tip?.remove();
36
+
37
+ this._tip = dom;
38
+ this.append(this._tip);
39
+ } else if (this._tip instanceof Tip) {
40
+ this._tip.set(dom.msg, dom.level);
41
+ } else {
42
+ this._tip?.remove();
43
+
44
+ this._tip = new Tip(dom.msg, dom.level);
45
+ this.append(this._tip);
46
+ }
47
+ };
48
+
49
+ private readonly clearTip = () => {
50
+ if (this._tip !== undefined) {
51
+ this._tip.remove();
52
+ this._tip = undefined;
53
+ }
54
+ };
55
+
56
+ private readonly displayInput = (text: string, handler: (text: string) => Result<string, I18nKeys>) => {
57
+ if (this._input === undefined) {
58
+ this.lastFocus = document.activeElement as HTMLElement;
59
+ this._input = new Input(text, handler);
60
+ this._input.onCancelled(this.clearInput);
61
+ this._input.onCompleted(this.clearInput);
62
+ this.append(this._input);
63
+ this._input.focus();
64
+ }
65
+ };
66
+
67
+ private readonly clearInput = () => {
68
+ if (this._input !== undefined) {
69
+ this.removeChild(this._input);
70
+ this._input.dispose();
71
+ this._input = undefined;
72
+ this.lastFocus?.focus();
73
+ }
74
+ };
75
+ }
76
+
77
+ customElements.define("chili-flyout", Flyout);
@@ -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
+ export * from "./flyout";
5
+ export * from "./input";
6
+ export * from "./tip";
@@ -0,0 +1,21 @@
1
+ .panel {
2
+ font-size: 13px;
3
+ background-color: var(--panel-background-color);
4
+ color: var(--foreground-color);
5
+ opacity: 0.85;
6
+ display: flex;
7
+ flex-direction: column;
8
+ border-radius: 4px;
9
+ margin: 2px 0px;
10
+
11
+ input {
12
+ background-color: var(--control-background-color);
13
+ color: var(--input-text-color);
14
+ border: 1px solid var(--input-border-color);
15
+ }
16
+ }
17
+
18
+ .error {
19
+ color: red;
20
+ font-size: 11px;
21
+ }
@@ -0,0 +1,89 @@
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 { input, label } from "chili-controls";
5
+ import { I18n, type I18nKeys, type IDisposable, Localize, type Result } from "chili-core";
6
+ import style from "./input.module.css";
7
+
8
+ export class Input extends HTMLElement implements IDisposable {
9
+ private readonly _cancelledCallbacks: (() => void)[] = [];
10
+ private readonly _completedCallbacks: (() => void)[] = [];
11
+ private readonly textbox: HTMLInputElement;
12
+ private tip?: HTMLLabelElement;
13
+
14
+ constructor(
15
+ text: string,
16
+ readonly handler: (text: string) => Result<string, I18nKeys>,
17
+ ) {
18
+ super();
19
+ this.className = style.panel;
20
+ this.textbox = input({
21
+ value: text,
22
+ onkeydown: this.handleKeyDown,
23
+ });
24
+ this.append(this.textbox);
25
+ }
26
+
27
+ onCancelled(callback: () => void) {
28
+ this._cancelledCallbacks.push(callback);
29
+ }
30
+
31
+ onCompleted(callback: () => void) {
32
+ this._completedCallbacks.push(callback);
33
+ }
34
+
35
+ get text(): string {
36
+ return this.textbox.value;
37
+ }
38
+
39
+ override focus() {
40
+ this.textbox.focus();
41
+ }
42
+
43
+ dispose() {
44
+ this._cancelledCallbacks.length = 0;
45
+ this._completedCallbacks.length = 0;
46
+ }
47
+
48
+ private showTip(tip: I18nKeys) {
49
+ if (this.tip === undefined) {
50
+ this.tip = label({
51
+ textContent: new Localize(tip),
52
+ className: style.error,
53
+ });
54
+ this.append(this.tip);
55
+ } else {
56
+ I18n.set(this.tip, "textContent", tip);
57
+ }
58
+ }
59
+
60
+ private removeTip() {
61
+ if (this.tip === undefined) return;
62
+ this.removeChild(this.tip);
63
+ this.tip = undefined;
64
+ }
65
+
66
+ private readonly handleKeyDown = (e: KeyboardEvent) => {
67
+ e.stopPropagation();
68
+ if (e.key === "Enter") {
69
+ this.processEnterKey();
70
+ } else if (e.key === "Escape") {
71
+ this._cancelledCallbacks.forEach((callback) => callback());
72
+ } else {
73
+ this.removeTip();
74
+ }
75
+ };
76
+
77
+ private processEnterKey() {
78
+ this.textbox.readOnly = true;
79
+ const error = this.handler(this.textbox.value);
80
+ if (error.isOk) {
81
+ this._completedCallbacks.forEach((callback) => callback());
82
+ } else {
83
+ this.textbox.readOnly = false;
84
+ this.showTip(error.error);
85
+ }
86
+ }
87
+ }
88
+
89
+ customElements.define("chili-input", Input);
@@ -0,0 +1,21 @@
1
+ .tip {
2
+ font-size: 13px;
3
+ background-color: var(--panel-background-color);
4
+ opacity: 0.85;
5
+ border: 1px solid var(--border-color);
6
+ border-radius: 4px;
7
+ padding: 1px 4px;
8
+ margin: 2px 0px;
9
+ }
10
+
11
+ .info {
12
+ color: var(--foreground-color);
13
+ }
14
+
15
+ .warn {
16
+ color: yellow;
17
+ }
18
+
19
+ .error {
20
+ color: red;
21
+ }
@@ -0,0 +1,45 @@
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 { MessageType } from "chili-core";
5
+ import style from "./tip.module.css";
6
+
7
+ export class Tip extends HTMLElement {
8
+ private color?: string;
9
+
10
+ constructor(msg: string, type: MessageType) {
11
+ super();
12
+ this.className = style.tip;
13
+ this.set(msg, type);
14
+ }
15
+
16
+ set(msg: string, type: MessageType) {
17
+ if (this.textContent !== msg) {
18
+ this.textContent = msg;
19
+ }
20
+
21
+ const newStyle = this.getStyle(type);
22
+ this.setStyle(newStyle);
23
+ }
24
+
25
+ private setStyle(newStyle: string) {
26
+ if (this.color !== newStyle && newStyle !== undefined) {
27
+ if (this.color !== undefined) this.classList.remove(this.color);
28
+ this.classList.add(newStyle);
29
+ this.color = newStyle;
30
+ }
31
+ }
32
+
33
+ private getStyle(type: MessageType) {
34
+ switch (type) {
35
+ case MessageType.error:
36
+ return style.error;
37
+ case MessageType.warn:
38
+ return style.warn;
39
+ default:
40
+ return style.info;
41
+ }
42
+ }
43
+ }
44
+
45
+ customElements.define("chili-tip", Tip);
@@ -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 "./layoutViewport";
@@ -0,0 +1,21 @@
1
+ .root {
2
+ display: flex;
3
+ flex-direction: row;
4
+ background: var(--viewport-background-color);
5
+ position: relative;
6
+ }
7
+
8
+ .viewports {
9
+ width: 100%;
10
+ height: 100%;
11
+ position: relative;
12
+ }
13
+
14
+ .viewport {
15
+ width: 100%;
16
+ height: 100%;
17
+ }
18
+
19
+ .hidden {
20
+ display: none;
21
+ }
@@ -0,0 +1,76 @@
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
+ CollectionAction,
6
+ type CollectionChangedArgs,
7
+ type CursorType,
8
+ type IApplication,
9
+ type IView,
10
+ PubSub,
11
+ } from "chili-core";
12
+ import { Cursor } from "../cursor";
13
+ import style from "./layoutViewport.module.css";
14
+ import { Viewport } from "./viewport";
15
+
16
+ export class LayoutViewport extends HTMLElement {
17
+ private readonly _viewports: Map<IView, Viewport> = new Map();
18
+
19
+ constructor(
20
+ readonly app: IApplication,
21
+ readonly showViewControls: boolean = true,
22
+ ) {
23
+ super();
24
+ this.className = style.root;
25
+ app.views.onCollectionChanged(this._handleViewCollectionChanged);
26
+ }
27
+
28
+ private readonly _handleViewCollectionChanged = (args: CollectionChangedArgs) => {
29
+ if (args.action === CollectionAction.add) {
30
+ args.items.forEach((view) => {
31
+ this.createViewport(view);
32
+ });
33
+ } else if (args.action === CollectionAction.remove) {
34
+ args.items.forEach((view) => {
35
+ const viewport = this._viewports.get(view);
36
+ viewport?.remove();
37
+ viewport?.dispose();
38
+ this._viewports.delete(view);
39
+ });
40
+ }
41
+ };
42
+
43
+ connectedCallback(): void {
44
+ PubSub.default.sub("activeViewChanged", this._handleActiveViewChanged);
45
+ PubSub.default.sub("viewCursor", this._handleCursor);
46
+ }
47
+
48
+ disconnectedCallback(): void {
49
+ PubSub.default.remove("activeViewChanged", this._handleActiveViewChanged);
50
+ PubSub.default.remove("viewCursor", this._handleCursor);
51
+ }
52
+
53
+ private readonly _handleCursor = (type: CursorType) => {
54
+ this.style.cursor = Cursor.get(type);
55
+ };
56
+
57
+ private createViewport(view: IView) {
58
+ const viewport = new Viewport(view, this.showViewControls);
59
+ viewport.classList.add(style.viewport, style.hidden);
60
+ this.appendChild(viewport);
61
+ this._viewports.set(view, viewport);
62
+ return viewport;
63
+ }
64
+
65
+ private readonly _handleActiveViewChanged = (view: IView | undefined) => {
66
+ this._viewports.forEach((v) => {
67
+ if (v.view === view) {
68
+ v.classList.remove(style.hidden);
69
+ } else {
70
+ v.classList.add(style.hidden);
71
+ }
72
+ });
73
+ };
74
+ }
75
+
76
+ customElements.define("chili-viewport", LayoutViewport);
@@ -0,0 +1,179 @@
1
+ .root {
2
+ position: relative;
3
+ }
4
+
5
+ .actsContainer {
6
+ position: absolute;
7
+ bottom: 12px;
8
+ z-index: 99999;
9
+ width: 100%;
10
+ pointer-events: all;
11
+
12
+ .border {
13
+ display: inline-block;
14
+ position: relative;
15
+ margin: auto;
16
+ width: fit-content;
17
+ max-width: 75%;
18
+
19
+ &::before {
20
+ position: absolute;
21
+ bottom: 0;
22
+ left: 1px;
23
+ height: 50px;
24
+ width: calc(100% - 2px);
25
+ margin-top: 40px;
26
+ content: "";
27
+ border-radius: 16px;
28
+ border: 1px solid var(--border-color);
29
+ background-color: var(--panel-background-color);
30
+ backdrop-filter: blur(10px);
31
+ }
32
+
33
+ .acts {
34
+ display: flex;
35
+ align-items: center;
36
+ flex-direction: row;
37
+ gap: 6px;
38
+ cursor: pointer;
39
+ height: 96px;
40
+ margin: 0px 8px;
41
+ overflow-y: hidden;
42
+ overflow-x: auto;
43
+ pointer-events: all;
44
+ --floatControlVisible: none;
45
+
46
+ &::-webkit-scrollbar {
47
+ height: 6px;
48
+ }
49
+
50
+ &::-webkit-scrollbar-thumb {
51
+ background-color: var(--foreground-muted-color);
52
+ border-radius: 3px;
53
+ }
54
+
55
+ &::-webkit-scrollbar-track {
56
+ background-color: transparent;
57
+ }
58
+
59
+ div {
60
+ position: relative;
61
+ flex: 0 0 auto;
62
+ padding: 8px;
63
+ margin-top: 43px;
64
+ width: 72px;
65
+ border-radius: 8px;
66
+ user-select: none;
67
+ background-color: var(--panel-background-color);
68
+ border: 1px solid var(--border-color);
69
+ color: var(--foreground-color);
70
+ font-size: 14px;
71
+ justify-content: center;
72
+ opacity: 0.75;
73
+ height: 18px;
74
+
75
+ span {
76
+ display: block;
77
+ max-width: 64px;
78
+ text-overflow: ellipsis;
79
+ overflow: hidden;
80
+ white-space: nowrap;
81
+ text-align: center;
82
+ }
83
+
84
+ &:hover {
85
+ opacity: 1;
86
+ --floatControlVisible: flex;
87
+ }
88
+
89
+ .tools {
90
+ display: var(--floatControlVisible);
91
+ background-color: transparent;
92
+ border: none;
93
+ position: absolute;
94
+ margin: 0;
95
+ padding: 8px;
96
+ top: -34px;
97
+ left: 0px;
98
+ gap: 4px;
99
+
100
+ svg {
101
+ width: 14px;
102
+ height: 14px;
103
+ padding: 4px;
104
+ border-radius: 100%;
105
+ background-color: var(--panel-background-color);
106
+ opacity: 0.75;
107
+
108
+ &:hover {
109
+ opacity: 1;
110
+ }
111
+ }
112
+ }
113
+ }
114
+ }
115
+ }
116
+ }
117
+
118
+ .viewControls {
119
+ position: absolute;
120
+ height: 100%;
121
+ top: 0;
122
+ right: 16px;
123
+ z-index: 999;
124
+ pointer-events: none;
125
+ padding-top: 160px;
126
+ color: var(--foreground-color);
127
+
128
+ svg {
129
+ border: none;
130
+ background: transparent;
131
+ width: 22px;
132
+ height: 22px;
133
+ padding: 8px;
134
+ border-radius: 7.5px;
135
+ color: inherit;
136
+ fill: currentColor;
137
+
138
+ &:hover {
139
+ background: var(--hover-background-color);
140
+ }
141
+
142
+ &:active {
143
+ background: var(--active-background-color);
144
+ }
145
+ }
146
+
147
+ .actived {
148
+ background: var(--checked-color);
149
+ }
150
+
151
+ .border {
152
+ border: 1px solid var(--border-color);
153
+ background: var(--panel-background-color);
154
+ border-radius: 10px;
155
+ margin: 1px 0px;
156
+ padding: 2px;
157
+ pointer-events: all;
158
+ display: flex;
159
+ flex-direction: column;
160
+ overflow: hidden;
161
+ color: var(--foreground-color);
162
+
163
+ div {
164
+ padding: 0;
165
+ margin: 0;
166
+ display: flex;
167
+ flex-direction: column;
168
+ overflow: hidden;
169
+ border-radius: 7.5px;
170
+ color: inherit;
171
+ }
172
+ }
173
+ }
174
+
175
+ @media (max-width: 680px) {
176
+ .viewControls {
177
+ display: none;
178
+ }
179
+ }