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,48 @@
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 IConverter, type IDocument, Logger, type Property, Texture } from "chili-core";
5
+ import { CheckProperty } from "./check";
6
+ import { ColorProperty } from "./colorProperty";
7
+ import { InputProperty } from "./input";
8
+ import { TextureProperty } from "./material/textureEditor";
9
+ import { MaterialProperty } from "./materialProperty";
10
+
11
+ export function findPropertyControl(
12
+ document: IDocument,
13
+ objs: any[],
14
+ prop: Property,
15
+ converter?: IConverter,
16
+ ) {
17
+ if (prop === undefined || objs.length === 0) return "";
18
+
19
+ if (prop.type === "color") {
20
+ return new ColorProperty(document, objs, prop);
21
+ }
22
+
23
+ if (prop.type === "materialId" && canShowMaterialProperty(objs, prop)) {
24
+ return new MaterialProperty(document, objs, prop);
25
+ }
26
+
27
+ const value = objs[0][prop.name];
28
+ if (value instanceof Texture) {
29
+ return new TextureProperty(document, prop.display, value);
30
+ }
31
+
32
+ if (["object", "string", "number"].includes(typeof value)) {
33
+ return new InputProperty(document, objs, prop, converter);
34
+ }
35
+
36
+ if (typeof value === "boolean") {
37
+ return new CheckProperty(document, objs, prop);
38
+ }
39
+
40
+ Logger.warn(`Property ${prop.name} not found in ${Object.getPrototypeOf(objs[0]).constructor.name}`);
41
+ return "";
42
+ }
43
+
44
+ function canShowMaterialProperty(objs: any[], prop: Property) {
45
+ if (objs.length === 0) return false;
46
+ if (objs.length === 1) return true;
47
+ return objs.every((obj) => obj[prop.name] === objs[0][prop.name]);
48
+ }
@@ -0,0 +1,73 @@
1
+ .panel {
2
+ display: flex;
3
+ flex-direction: row;
4
+ justify-content: center;
5
+ align-items: center;
6
+ margin: 2px 8px;
7
+ gap: 12px;
8
+ }
9
+
10
+ .title {
11
+ font-weight: bold;
12
+ }
13
+
14
+ .group {
15
+ display: flex;
16
+ margin-left: 6px;
17
+ flex-direction: row;
18
+ justify-content: center;
19
+ align-items: center;
20
+ gap: 12px;
21
+ }
22
+
23
+ .button {
24
+ padding: 2px 12px;
25
+ font-size: 1em;
26
+ border-radius: 6px;
27
+ color: var(--foreground-color);
28
+ border: 1px solid var(--border-color);
29
+ background-color: var(--control-background-color);
30
+
31
+ &:hover {
32
+ background-color: var(--hover-background-color);
33
+ }
34
+ }
35
+
36
+ .icon {
37
+ width: 14px;
38
+ height: 14px;
39
+ }
40
+
41
+ .input {
42
+ margin-left: 8px;
43
+ width: 64px;
44
+ background-color: var(--input-background-color);
45
+ border: 1px solid var(--input-border-color);
46
+ color: var(--input-text-color);
47
+ }
48
+
49
+ .select {
50
+ margin-left: 8px;
51
+ padding: 2px 12px;
52
+ font-size: 1em;
53
+ border-radius: 6px;
54
+ color: var(--foreground-color);
55
+ border: 1px solid var(--border-color);
56
+ background-color: var(--control-background-color);
57
+ }
58
+
59
+ .materialButton {
60
+ flex: 1 1 auto;
61
+ font-size: 1rem;
62
+ padding: 2px 24px;
63
+ outline: none;
64
+ background-color: transparent;
65
+
66
+ border: 1px solid var(--border-color);
67
+ border-radius: 4px;
68
+ margin: 0px;
69
+
70
+ &:hover {
71
+ background-color: var(--hover-background-color);
72
+ }
73
+ }
@@ -0,0 +1,239 @@
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 { MultistepCommand } from "chili";
5
+ import {
6
+ button,
7
+ ColorConverter,
8
+ div,
9
+ input,
10
+ label,
11
+ option,
12
+ select,
13
+ svg,
14
+ UrlStringConverter,
15
+ } from "chili-controls";
16
+ import {
17
+ Binding,
18
+ CancelableCommand,
19
+ Combobox,
20
+ Command,
21
+ I18n,
22
+ type I18nKeys,
23
+ type ICommand,
24
+ type IDisposable,
25
+ Localize,
26
+ Observable,
27
+ PathBinding,
28
+ Property,
29
+ PubSub,
30
+ } from "chili-core";
31
+ import style from "./commandContext.module.css";
32
+
33
+ export class CommandContext extends HTMLElement implements IDisposable {
34
+ private readonly propMap: Map<string | number | symbol, [Property, HTMLElement][]> = new Map();
35
+
36
+ constructor(readonly command: ICommand) {
37
+ super();
38
+ this.className = style.panel;
39
+ const data = Command.getData(command);
40
+ this.append(
41
+ svg({ className: style.icon, icon: data!.icon }),
42
+ label({ className: style.title, textContent: new Localize(`command.${data!.key}`) }, `: `),
43
+ );
44
+ this.initContext();
45
+ }
46
+
47
+ connectedCallback(): void {
48
+ if (this.command instanceof Observable) {
49
+ this.command.onPropertyChanged(this.onPropertyChanged);
50
+ }
51
+ }
52
+
53
+ disconnectedCallback(): void {
54
+ if (this.command instanceof Observable) {
55
+ this.command.removePropertyChanged(this.onPropertyChanged);
56
+ }
57
+ }
58
+
59
+ dispose() {
60
+ this.propMap.clear();
61
+ }
62
+
63
+ private readonly onPropertyChanged = (property: string | number | symbol) => {
64
+ if (this.propMap.has(property)) {
65
+ const items = this.propMap.get(property)!;
66
+ for (const [prop, control] of items) {
67
+ this.setVisible(control, prop);
68
+ }
69
+ }
70
+ };
71
+
72
+ private initContext() {
73
+ const groupMap = new Map<I18nKeys, HTMLDivElement>();
74
+ Property.getProperties(this.command).forEach((property) => {
75
+ const group = this.findGroup(groupMap, property);
76
+ const item = this.createItem(this.command, property);
77
+ this.setVisible(item, property);
78
+ this.cacheDependencies(item, property);
79
+ group.append(item);
80
+ });
81
+ }
82
+
83
+ private cacheDependencies(item: HTMLElement, g: Property) {
84
+ if (g.dependencies) {
85
+ for (const d of g.dependencies) {
86
+ const items = this.propMap.get(d.property);
87
+ this.propMap.set(d.property, [...(items ?? []), [g, item]]);
88
+ }
89
+ }
90
+ }
91
+
92
+ private setVisible(control: HTMLElement, property: Property) {
93
+ let visible = true;
94
+ if (property.dependencies) {
95
+ for (const d of property.dependencies) {
96
+ if ((this.command as any)[d.property] !== d.value) {
97
+ visible = false;
98
+ break;
99
+ }
100
+ }
101
+ }
102
+ control.style.display = visible ? "inherit" : "none";
103
+ }
104
+
105
+ private findGroup(groupMap: Map<I18nKeys, HTMLDivElement>, prop: Property) {
106
+ let group = groupMap.get(prop.group!);
107
+ if (group === undefined) {
108
+ group = div({ className: style.group });
109
+ groupMap.set(prop.group!, group);
110
+ this.append(group);
111
+ }
112
+ return group;
113
+ }
114
+
115
+ private createItem(command: ICommand, g: Property) {
116
+ const noType = command as any;
117
+ const type = typeof noType[g.name];
118
+
119
+ if (g.type === "materialId") {
120
+ return this.materialEditor(g, noType);
121
+ }
122
+
123
+ switch (type) {
124
+ case "function":
125
+ return this.newButton(g, noType);
126
+ case "boolean":
127
+ return this.newCheckbox(g, noType);
128
+ case "number":
129
+ return this.newInput(g, noType, parseFloat);
130
+ case "string":
131
+ return this.newInput(g, noType);
132
+ default:
133
+ if (noType[g.name] instanceof Combobox) {
134
+ return this.newCombobox(noType, g);
135
+ }
136
+ throw new Error("暂不支持的类型");
137
+ }
138
+ }
139
+
140
+ private newCombobox(noType: any, g: Property) {
141
+ const combobox = noType[g.name] as Combobox<any>;
142
+ const options = combobox.items.map((item, index) => {
143
+ return option({
144
+ selected: index === combobox.selectedIndex,
145
+ textContent: I18n.isI18nKey(item)
146
+ ? new Localize(item)
147
+ : (combobox.converter?.convert(item).unchecked() ?? String(item)),
148
+ });
149
+ });
150
+
151
+ return div(
152
+ label({ textContent: new Localize(g.display) }),
153
+ select(
154
+ {
155
+ className: style.select,
156
+ onchange: (e) => {
157
+ combobox.selectedIndex = (e.target as HTMLSelectElement).selectedIndex;
158
+ },
159
+ },
160
+ ...options,
161
+ ),
162
+ );
163
+ }
164
+
165
+ private newInput(g: Property, noType: any, converter?: (v: string) => any) {
166
+ return div(
167
+ label({ textContent: new Localize(g.display) }),
168
+ input({
169
+ type: "text",
170
+ className: style.input,
171
+ value: new Binding(noType, g.name),
172
+ onblur: (e) => {
173
+ const input = e.target as HTMLInputElement;
174
+ noType[g.name] = converter ? converter(input.value) : input.value;
175
+ },
176
+ onkeydown: (e) => {
177
+ e.stopPropagation();
178
+ if (e.key === "Enter") {
179
+ const input = e.target as HTMLInputElement;
180
+ input.blur();
181
+ }
182
+ },
183
+ }),
184
+ );
185
+ }
186
+
187
+ private newCheckbox(g: Property, noType: any) {
188
+ return div(
189
+ label({ textContent: new Localize(g.display) }),
190
+ input({
191
+ type: "checkbox",
192
+ checked: new Binding(noType, g.name),
193
+ onclick: () => {
194
+ noType[g.name] = !noType[g.name];
195
+ },
196
+ }),
197
+ );
198
+ }
199
+
200
+ private newButton(g: Property, noType: any) {
201
+ return button({
202
+ className: style.button,
203
+ textContent: new Localize(g.display),
204
+ onclick: () => noType[g.name](),
205
+ });
206
+ }
207
+
208
+ private materialEditor(g: Property, noType: any) {
209
+ if (!(this.command instanceof CancelableCommand)) {
210
+ throw new Error("MaterialEditor only support CancelableCommand");
211
+ }
212
+
213
+ const material = this.command.document.modelManager.materials.find((x) => x.id === noType[g.name])!;
214
+ const display = material.clone();
215
+
216
+ return button({
217
+ className: style.materialButton,
218
+ style: {
219
+ backgroundColor: new Binding(display, "color", new ColorConverter()),
220
+ backgroundImage: new PathBinding(display, "map.image", new UrlStringConverter()),
221
+ backgroundBlendMode: "multiply",
222
+ backgroundSize: "cover",
223
+ cursor: "pointer",
224
+ },
225
+ textContent: new Localize(g.display),
226
+ onclick: () => {
227
+ if (this.command instanceof MultistepCommand) {
228
+ PubSub.default.pub("editMaterial", this.command.document, material, (newMaterial) => {
229
+ noType[g.name] = newMaterial.id;
230
+ display.color = newMaterial.color;
231
+ display.map = newMaterial.map;
232
+ });
233
+ }
234
+ },
235
+ });
236
+ }
237
+ }
238
+
239
+ customElements.define("command-context", CommandContext);
@@ -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 "./ribbon";
@@ -0,0 +1,286 @@
1
+ .root {
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: 100%;
5
+ }
6
+
7
+ .split {
8
+ width: 1px;
9
+ height: 14px;
10
+ margin: 0px 8px;
11
+ background-color: rgba(128, 128, 128, 0.45);
12
+ }
13
+
14
+ .titleBar {
15
+ display: flex;
16
+ flex-direction: row;
17
+ align-items: center;
18
+ margin: 2px 4px;
19
+
20
+ .left {
21
+ display: flex;
22
+ flex-direction: row;
23
+ align-items: center;
24
+ justify-self: center;
25
+
26
+ .appIcon {
27
+ display: flex;
28
+ flex-direction: row;
29
+ align-items: center;
30
+ justify-self: center;
31
+ border-radius: 8px;
32
+ padding: 4px 8px;
33
+ margin: 2px;
34
+ cursor: pointer;
35
+
36
+ &:hover {
37
+ background-color: var(--hover-background-color);
38
+ }
39
+
40
+ .icon {
41
+ width: 24px;
42
+ height: 24px;
43
+ padding: 2px;
44
+ }
45
+
46
+ span {
47
+ margin-left: 16px;
48
+ font-weight: bolder;
49
+ text-wrap: nowrap;
50
+ }
51
+ }
52
+ }
53
+
54
+ .center {
55
+ display: flex;
56
+ flex-direction: row;
57
+ align-items: center;
58
+ margin: auto;
59
+ flex: 0 1 auto;
60
+ overflow: auto;
61
+
62
+ .views {
63
+ display: flex;
64
+ flex-direction: row;
65
+ align-items: center;
66
+ border-radius: 8px;
67
+ padding: 2px 0px;
68
+ overflow: hidden;
69
+
70
+ .tab {
71
+ display: flex;
72
+ flex-direction: row;
73
+ align-items: center;
74
+ border-radius: 6px;
75
+ height: 26px;
76
+ background-color: var(--title-background);
77
+ padding: 2px;
78
+ width: 220px;
79
+ overflow: hidden;
80
+ margin: 0px 2px;
81
+ cursor: default;
82
+ transition: width 0.2s ease-out;
83
+
84
+ &:hover {
85
+ background-color: var(--hover-background-color);
86
+ }
87
+
88
+ .name {
89
+ display: flex;
90
+ flex-direction: row;
91
+ align-items: center;
92
+ margin-right: auto;
93
+ margin-left: 8px;
94
+ text-wrap: nowrap;
95
+ user-select: none;
96
+ text-decoration: dashed;
97
+ overflow: hidden;
98
+
99
+ .split {
100
+ padding: 0px 4px;
101
+ }
102
+
103
+ span {
104
+ font-size: 12px;
105
+ }
106
+ }
107
+
108
+ .close {
109
+ width: 12px;
110
+ height: 12px;
111
+ margin: 4px;
112
+ padding: 6px;
113
+ border-radius: 6px;
114
+ flex-shrink: 0;
115
+
116
+ &:hover {
117
+ background-color: var(--hover-background-color);
118
+ }
119
+ }
120
+ }
121
+
122
+ .active {
123
+ width: 260px;
124
+ background-color: var(--title-checked);
125
+ }
126
+ }
127
+
128
+ .new {
129
+ width: 16px;
130
+ height: 16px;
131
+ margin-left: 2px;
132
+ padding: 6px;
133
+ border-radius: 6px;
134
+
135
+ &:hover {
136
+ background-color: var(--hover-background-color);
137
+ }
138
+ }
139
+ }
140
+
141
+ .right {
142
+ display: flex;
143
+ flex-direction: row;
144
+ align-items: center;
145
+ margin: 2px 8px;
146
+ flex: 0 0 auto;
147
+
148
+ .icon {
149
+ width: 24px;
150
+ height: 24px;
151
+ padding: 4px;
152
+ border-radius: 4px;
153
+
154
+ &:hover {
155
+ background-color: var(--hover-background-color);
156
+ }
157
+ }
158
+ }
159
+ }
160
+
161
+ .ribbonTitlePanel {
162
+ display: flex;
163
+ flex-direction: row;
164
+ align-items: center;
165
+ margin: 0px 4px;
166
+ flex: 0 0 auto;
167
+
168
+ .home {
169
+ width: 14px;
170
+ height: 14px;
171
+ padding: 6px;
172
+ border-radius: 4px;
173
+ margin: 0px 4px;
174
+
175
+ &:hover {
176
+ background-color: var(--hover-background-color);
177
+ }
178
+ }
179
+
180
+ & .quickCommands {
181
+ display: flex;
182
+ flex-direction: row;
183
+
184
+ svg {
185
+ width: 14px;
186
+ height: 14px;
187
+ padding: 6px;
188
+ border-radius: 4px;
189
+ margin: 0px 6px;
190
+
191
+ &:hover {
192
+ background-color: var(--hover-background-color);
193
+ }
194
+ }
195
+ }
196
+
197
+ .tabHeader {
198
+ color: var(--titlebar-forground-color);
199
+ padding: 5px 15px;
200
+
201
+ &:hover {
202
+ -webkit-text-stroke: 0.65px var(--foreground-color);
203
+ background-color: var(--hover-background-color);
204
+ }
205
+ }
206
+
207
+ .activedTab {
208
+ position: relative;
209
+
210
+ &::after {
211
+ content: "";
212
+ position: absolute;
213
+ bottom: -2px;
214
+ left: 8px;
215
+ right: 8px;
216
+ height: 3px;
217
+ background-color: var(--primary-color);
218
+ }
219
+ }
220
+ }
221
+
222
+ .tabContentPanel {
223
+ display: flex;
224
+ flex-direction: row;
225
+ background-color: var(--panel-background-color);
226
+ border-bottom: 1px solid var(--border-color);
227
+ overflow-x: auto;
228
+
229
+ &::-webkit-scrollbar {
230
+ height: 6px;
231
+ }
232
+
233
+ &::-webkit-scrollbar-thumb {
234
+ background: var(--foreground-muted-color);
235
+ border-radius: 5px;
236
+ }
237
+
238
+ & .groupPanel {
239
+ display: flex;
240
+ flex-direction: row;
241
+ }
242
+ }
243
+
244
+ .commandContextPanel {
245
+ display: flex;
246
+ flex-direction: row;
247
+ justify-content: stretch;
248
+ flex: 1 1 auto;
249
+ height: 32px;
250
+ background-color: var(--panel-background-color);
251
+ border-bottom: 1px solid var(--border-color);
252
+ }
253
+
254
+ .ribbonGroup {
255
+ position: relative;
256
+ display: grid;
257
+ grid-template-rows: 1fr auto;
258
+ justify-items: center;
259
+ flex-shrink: 0;
260
+
261
+ .header {
262
+ color: var(--foreground-color);
263
+ font-size: 12px;
264
+ }
265
+
266
+ .content {
267
+ height: 72px;
268
+ flex-shrink: 0;
269
+ display: flex;
270
+ flex-direction: row;
271
+ align-items: center;
272
+ justify-items: center;
273
+ overflow: hidden;
274
+ }
275
+ }
276
+
277
+ .ribbonGroup::after {
278
+ content: "";
279
+ position: absolute;
280
+ display: grid;
281
+ right: 0px;
282
+ top: 6px;
283
+ bottom: 6px;
284
+ width: 1px;
285
+ background-color: var(--border-color);
286
+ }