@tpitre/story-ui 3.4.0 → 3.4.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 (282) hide show
  1. package/dist/cli/index.js +0 -0
  2. package/dist/mcp-server/index.js +32 -0
  3. package/package.json +2 -1
  4. package/dist/cli/index.js.map +0 -1
  5. package/dist/cli/setup.js.map +0 -1
  6. package/dist/cloudflare-edge/src/mcp-session.js +0 -462
  7. package/dist/cloudflare-edge/src/types.js +0 -4
  8. package/dist/cloudflare-edge/src/worker.js +0 -106
  9. package/dist/cloudflare-pages/vite.config.js +0 -14
  10. package/dist/index.d.ts +0 -13
  11. package/dist/index.d.ts.map +0 -1
  12. package/dist/index.js +0 -12
  13. package/dist/index.js.map +0 -1
  14. package/dist/mcp-server/index.js.map +0 -1
  15. package/dist/mcp-server/mcp-stdio-server.js.map +0 -1
  16. package/dist/mcp-server/routes/claude.js.map +0 -1
  17. package/dist/mcp-server/routes/components.js.map +0 -1
  18. package/dist/mcp-server/routes/generateStory.js.map +0 -1
  19. package/dist/mcp-server/routes/hybridStories.d.ts +0 -18
  20. package/dist/mcp-server/routes/hybridStories.d.ts.map +0 -1
  21. package/dist/mcp-server/routes/hybridStories.js +0 -216
  22. package/dist/mcp-server/routes/hybridStories.js.map +0 -1
  23. package/dist/mcp-server/routes/memoryStories.d.ts +0 -26
  24. package/dist/mcp-server/routes/memoryStories.d.ts.map +0 -1
  25. package/dist/mcp-server/routes/memoryStories.js +0 -158
  26. package/dist/mcp-server/routes/memoryStories.js.map +0 -1
  27. package/dist/mcp-server/routes/storySync.d.ts +0 -26
  28. package/dist/mcp-server/routes/storySync.d.ts.map +0 -1
  29. package/dist/mcp-server/routes/storySync.js +0 -147
  30. package/dist/mcp-server/routes/storySync.js.map +0 -1
  31. package/dist/mcp-server/routes/updateStory.js +0 -246
  32. package/dist/mcp-server/sessionManager.d.ts +0 -50
  33. package/dist/mcp-server/sessionManager.d.ts.map +0 -1
  34. package/dist/mcp-server/sessionManager.js +0 -125
  35. package/dist/mcp-server/sessionManager.js.map +0 -1
  36. package/dist/playground/components/AIAssistant/AIAssistant.d.ts +0 -6
  37. package/dist/playground/components/AIAssistant/AIAssistant.d.ts.map +0 -1
  38. package/dist/playground/components/AIAssistant/AIAssistant.js +0 -109
  39. package/dist/playground/components/AIAssistant/AIAssistant.js.map +0 -1
  40. package/dist/playground/components/AIAssistant/AIAssistant.module.css +0 -166
  41. package/dist/playground/components/Canvas/Canvas.d.ts +0 -9
  42. package/dist/playground/components/Canvas/Canvas.d.ts.map +0 -1
  43. package/dist/playground/components/Canvas/Canvas.js +0 -58
  44. package/dist/playground/components/Canvas/Canvas.js.map +0 -1
  45. package/dist/playground/components/Canvas/Canvas.module.css +0 -189
  46. package/dist/playground/components/Canvas/CanvasWithDnd.d.ts +0 -9
  47. package/dist/playground/components/Canvas/CanvasWithDnd.d.ts.map +0 -1
  48. package/dist/playground/components/Canvas/CanvasWithDnd.js +0 -158
  49. package/dist/playground/components/Canvas/CanvasWithDnd.js.map +0 -1
  50. package/dist/playground/components/Canvas/ComponentRenderer.d.ts +0 -15
  51. package/dist/playground/components/Canvas/ComponentRenderer.d.ts.map +0 -1
  52. package/dist/playground/components/Canvas/ComponentRenderer.js +0 -177
  53. package/dist/playground/components/Canvas/ComponentRenderer.js.map +0 -1
  54. package/dist/playground/components/Canvas/DraggableComponent.d.ts +0 -15
  55. package/dist/playground/components/Canvas/DraggableComponent.d.ts.map +0 -1
  56. package/dist/playground/components/Canvas/DraggableComponent.js +0 -49
  57. package/dist/playground/components/Canvas/DraggableComponent.js.map +0 -1
  58. package/dist/playground/components/Canvas/index.d.ts +0 -9
  59. package/dist/playground/components/Canvas/index.d.ts.map +0 -1
  60. package/dist/playground/components/Canvas/index.js +0 -5
  61. package/dist/playground/components/Canvas/index.js.map +0 -1
  62. package/dist/playground/components/CodeView/CodeView.d.ts +0 -12
  63. package/dist/playground/components/CodeView/CodeView.d.ts.map +0 -1
  64. package/dist/playground/components/CodeView/CodeView.js +0 -77
  65. package/dist/playground/components/CodeView/CodeView.js.map +0 -1
  66. package/dist/playground/components/CodeView/CodeView.module.css +0 -178
  67. package/dist/playground/components/ComponentPalette/ComponentPalette.d.ts +0 -17
  68. package/dist/playground/components/ComponentPalette/ComponentPalette.d.ts.map +0 -1
  69. package/dist/playground/components/ComponentPalette/ComponentPalette.js +0 -138
  70. package/dist/playground/components/ComponentPalette/ComponentPalette.js.map +0 -1
  71. package/dist/playground/components/ComponentPalette/ComponentPalette.module.css +0 -217
  72. package/dist/playground/components/ComponentPalette/index.d.ts +0 -3
  73. package/dist/playground/components/ComponentPalette/index.d.ts.map +0 -1
  74. package/dist/playground/components/ComponentPalette/index.js +0 -2
  75. package/dist/playground/components/ComponentPalette/index.js.map +0 -1
  76. package/dist/playground/components/DropZone/DropZone.d.ts +0 -17
  77. package/dist/playground/components/DropZone/DropZone.d.ts.map +0 -1
  78. package/dist/playground/components/DropZone/DropZone.js +0 -73
  79. package/dist/playground/components/DropZone/DropZone.js.map +0 -1
  80. package/dist/playground/components/DropZone/DropZone.module.css +0 -86
  81. package/dist/playground/components/ExportDialog/ExportDialog.d.ts +0 -10
  82. package/dist/playground/components/ExportDialog/ExportDialog.d.ts.map +0 -1
  83. package/dist/playground/components/ExportDialog/ExportDialog.js +0 -57
  84. package/dist/playground/components/ExportDialog/ExportDialog.js.map +0 -1
  85. package/dist/playground/components/ExportDialog/ExportDialog.module.css +0 -328
  86. package/dist/playground/components/LayoutHelpers/LayoutHelpers.d.ts +0 -134
  87. package/dist/playground/components/LayoutHelpers/LayoutHelpers.d.ts.map +0 -1
  88. package/dist/playground/components/LayoutHelpers/LayoutHelpers.js +0 -254
  89. package/dist/playground/components/LayoutHelpers/LayoutHelpers.js.map +0 -1
  90. package/dist/playground/components/LayoutHelpers/index.d.ts +0 -3
  91. package/dist/playground/components/LayoutHelpers/index.d.ts.map +0 -1
  92. package/dist/playground/components/LayoutHelpers/index.js +0 -2
  93. package/dist/playground/components/LayoutHelpers/index.js.map +0 -1
  94. package/dist/playground/components/Playground/Playground.d.ts +0 -10
  95. package/dist/playground/components/Playground/Playground.d.ts.map +0 -1
  96. package/dist/playground/components/Playground/Playground.js +0 -128
  97. package/dist/playground/components/Playground/Playground.js.map +0 -1
  98. package/dist/playground/components/Playground/Playground.module.css +0 -308
  99. package/dist/playground/components/PropertiesPanel/PropertiesPanel.d.ts +0 -10
  100. package/dist/playground/components/PropertiesPanel/PropertiesPanel.d.ts.map +0 -1
  101. package/dist/playground/components/PropertiesPanel/PropertiesPanel.js +0 -150
  102. package/dist/playground/components/PropertiesPanel/PropertiesPanel.js.map +0 -1
  103. package/dist/playground/components/PropertiesPanel/PropertiesPanel.module.css +0 -155
  104. package/dist/playground/components/PropertiesPanel/index.d.ts +0 -3
  105. package/dist/playground/components/PropertiesPanel/index.d.ts.map +0 -1
  106. package/dist/playground/components/PropertiesPanel/index.js +0 -2
  107. package/dist/playground/components/PropertiesPanel/index.js.map +0 -1
  108. package/dist/playground/components/PropertyEditors/BooleanEditor.d.ts +0 -12
  109. package/dist/playground/components/PropertyEditors/BooleanEditor.d.ts.map +0 -1
  110. package/dist/playground/components/PropertyEditors/BooleanEditor.js +0 -14
  111. package/dist/playground/components/PropertyEditors/BooleanEditor.js.map +0 -1
  112. package/dist/playground/components/PropertyEditors/ColorEditor.d.ts +0 -12
  113. package/dist/playground/components/PropertyEditors/ColorEditor.d.ts.map +0 -1
  114. package/dist/playground/components/PropertyEditors/ColorEditor.js +0 -62
  115. package/dist/playground/components/PropertyEditors/ColorEditor.js.map +0 -1
  116. package/dist/playground/components/PropertyEditors/IconEditor.d.ts +0 -12
  117. package/dist/playground/components/PropertyEditors/IconEditor.d.ts.map +0 -1
  118. package/dist/playground/components/PropertyEditors/IconEditor.js +0 -123
  119. package/dist/playground/components/PropertyEditors/IconEditor.js.map +0 -1
  120. package/dist/playground/components/PropertyEditors/NumberEditor.d.ts +0 -15
  121. package/dist/playground/components/PropertyEditors/NumberEditor.d.ts.map +0 -1
  122. package/dist/playground/components/PropertyEditors/NumberEditor.js +0 -46
  123. package/dist/playground/components/PropertyEditors/NumberEditor.js.map +0 -1
  124. package/dist/playground/components/PropertyEditors/PropertyEditors.module.css +0 -432
  125. package/dist/playground/components/PropertyEditors/SelectEditor.d.ts +0 -19
  126. package/dist/playground/components/PropertyEditors/SelectEditor.d.ts.map +0 -1
  127. package/dist/playground/components/PropertyEditors/SelectEditor.js +0 -17
  128. package/dist/playground/components/PropertyEditors/SelectEditor.js.map +0 -1
  129. package/dist/playground/components/PropertyEditors/SpacingEditor.d.ts +0 -19
  130. package/dist/playground/components/PropertyEditors/SpacingEditor.d.ts.map +0 -1
  131. package/dist/playground/components/PropertyEditors/SpacingEditor.js +0 -162
  132. package/dist/playground/components/PropertyEditors/SpacingEditor.js.map +0 -1
  133. package/dist/playground/components/PropertyEditors/SpacingEditor.module.css +0 -214
  134. package/dist/playground/components/PropertyEditors/TextEditor.d.ts +0 -14
  135. package/dist/playground/components/PropertyEditors/TextEditor.d.ts.map +0 -1
  136. package/dist/playground/components/PropertyEditors/TextEditor.js +0 -38
  137. package/dist/playground/components/PropertyEditors/TextEditor.js.map +0 -1
  138. package/dist/playground/components/PropertyEditors/TokenEditor.d.ts +0 -23
  139. package/dist/playground/components/PropertyEditors/TokenEditor.d.ts.map +0 -1
  140. package/dist/playground/components/PropertyEditors/TokenEditor.js +0 -50
  141. package/dist/playground/components/PropertyEditors/TokenEditor.js.map +0 -1
  142. package/dist/playground/components/PropertyEditors/index.d.ts +0 -20
  143. package/dist/playground/components/PropertyEditors/index.d.ts.map +0 -1
  144. package/dist/playground/components/PropertyEditors/index.js +0 -12
  145. package/dist/playground/components/PropertyEditors/index.js.map +0 -1
  146. package/dist/playground/components/TreeView/TreeView.d.ts +0 -10
  147. package/dist/playground/components/TreeView/TreeView.d.ts.map +0 -1
  148. package/dist/playground/components/TreeView/TreeView.js +0 -146
  149. package/dist/playground/components/TreeView/TreeView.js.map +0 -1
  150. package/dist/playground/components/TreeView/TreeView.module.css +0 -214
  151. package/dist/playground/components/TreeView/index.d.ts +0 -3
  152. package/dist/playground/components/TreeView/index.d.ts.map +0 -1
  153. package/dist/playground/components/TreeView/index.js +0 -2
  154. package/dist/playground/components/TreeView/index.js.map +0 -1
  155. package/dist/playground/config/propertyDefinitions.d.ts +0 -73
  156. package/dist/playground/config/propertyDefinitions.d.ts.map +0 -1
  157. package/dist/playground/config/propertyDefinitions.js +0 -809
  158. package/dist/playground/config/propertyDefinitions.js.map +0 -1
  159. package/dist/playground/hooks/useKeyboardShortcuts.d.ts +0 -38
  160. package/dist/playground/hooks/useKeyboardShortcuts.d.ts.map +0 -1
  161. package/dist/playground/hooks/useKeyboardShortcuts.js +0 -191
  162. package/dist/playground/hooks/useKeyboardShortcuts.js.map +0 -1
  163. package/dist/playground/index.d.ts +0 -21
  164. package/dist/playground/index.d.ts.map +0 -1
  165. package/dist/playground/index.js +0 -23
  166. package/dist/playground/index.js.map +0 -1
  167. package/dist/playground/services/CodeGenerator.d.ts +0 -73
  168. package/dist/playground/services/CodeGenerator.d.ts.map +0 -1
  169. package/dist/playground/services/CodeGenerator.js +0 -359
  170. package/dist/playground/services/CodeGenerator.js.map +0 -1
  171. package/dist/playground/services/DragDropManager.d.ts +0 -95
  172. package/dist/playground/services/DragDropManager.d.ts.map +0 -1
  173. package/dist/playground/services/DragDropManager.js +0 -408
  174. package/dist/playground/services/DragDropManager.js.map +0 -1
  175. package/dist/playground/services/StoryParser.d.ts +0 -73
  176. package/dist/playground/services/StoryParser.d.ts.map +0 -1
  177. package/dist/playground/services/StoryParser.js +0 -419
  178. package/dist/playground/services/StoryParser.js.map +0 -1
  179. package/dist/playground/store/playgroundStore.d.ts +0 -86
  180. package/dist/playground/store/playgroundStore.d.ts.map +0 -1
  181. package/dist/playground/store/playgroundStore.js +0 -337
  182. package/dist/playground/store/playgroundStore.js.map +0 -1
  183. package/dist/playground/stories/PlaygroundDragDrop.stories.d.ts +0 -13
  184. package/dist/playground/stories/PlaygroundDragDrop.stories.d.ts.map +0 -1
  185. package/dist/playground/stories/PlaygroundDragDrop.stories.js +0 -227
  186. package/dist/playground/stories/PlaygroundDragDrop.stories.js.map +0 -1
  187. package/dist/playground/stories/PlaygroundPhase4.stories.d.ts +0 -13
  188. package/dist/playground/stories/PlaygroundPhase4.stories.d.ts.map +0 -1
  189. package/dist/playground/stories/PlaygroundPhase4.stories.js +0 -334
  190. package/dist/playground/stories/PlaygroundPhase4.stories.js.map +0 -1
  191. package/dist/playground/stories/PlaygroundPhase5.stories.d.ts +0 -14
  192. package/dist/playground/stories/PlaygroundPhase5.stories.d.ts.map +0 -1
  193. package/dist/playground/stories/PlaygroundPhase5.stories.js +0 -512
  194. package/dist/playground/stories/PlaygroundPhase5.stories.js.map +0 -1
  195. package/dist/playground/stories/PlaygroundProperties.stories.d.ts +0 -13
  196. package/dist/playground/stories/PlaygroundProperties.stories.d.ts.map +0 -1
  197. package/dist/playground/stories/PlaygroundProperties.stories.js +0 -342
  198. package/dist/playground/stories/PlaygroundProperties.stories.js.map +0 -1
  199. package/dist/playground/types/index.d.ts +0 -251
  200. package/dist/playground/types/index.d.ts.map +0 -1
  201. package/dist/playground/types/index.js +0 -5
  202. package/dist/playground/types/index.js.map +0 -1
  203. package/dist/scripts/verify-framework-adapters.js +0 -105
  204. package/dist/story-generator/componentBlacklist.js.map +0 -1
  205. package/dist/story-generator/componentDiscovery.js.map +0 -1
  206. package/dist/story-generator/configLoader.js.map +0 -1
  207. package/dist/story-generator/considerationsLoader.js.map +0 -1
  208. package/dist/story-generator/documentation-sources.js.map +0 -1
  209. package/dist/story-generator/documentationLoader.js.map +0 -1
  210. package/dist/story-generator/dynamicPackageDiscovery.js.map +0 -1
  211. package/dist/story-generator/enhancedComponentDiscovery.js.map +0 -1
  212. package/dist/story-generator/generateStory.js.map +0 -1
  213. package/dist/story-generator/gitignoreManager.js.map +0 -1
  214. package/dist/story-generator/inMemoryStoryService.d.ts +0 -89
  215. package/dist/story-generator/inMemoryStoryService.d.ts.map +0 -1
  216. package/dist/story-generator/inMemoryStoryService.js +0 -128
  217. package/dist/story-generator/inMemoryStoryService.js.map +0 -1
  218. package/dist/story-generator/logger.js.map +0 -1
  219. package/dist/story-generator/postProcessStory.js.map +0 -1
  220. package/dist/story-generator/postgresStoryService.d.ts +0 -56
  221. package/dist/story-generator/postgresStoryService.d.ts.map +0 -1
  222. package/dist/story-generator/postgresStoryService.js +0 -240
  223. package/dist/story-generator/productionGitignoreManager.d.ts +0 -91
  224. package/dist/story-generator/productionGitignoreManager.d.ts.map +0 -1
  225. package/dist/story-generator/productionGitignoreManager.js +0 -340
  226. package/dist/story-generator/productionGitignoreManager.js.map +0 -1
  227. package/dist/story-generator/promptGenerator.js.map +0 -1
  228. package/dist/story-generator/providerPresets.d.ts +0 -54
  229. package/dist/story-generator/providerPresets.d.ts.map +0 -1
  230. package/dist/story-generator/providerPresets.js +0 -214
  231. package/dist/story-generator/storyHistory.js.map +0 -1
  232. package/dist/story-generator/storyServiceFactory.d.ts +0 -22
  233. package/dist/story-generator/storyServiceFactory.d.ts.map +0 -1
  234. package/dist/story-generator/storyServiceFactory.js +0 -97
  235. package/dist/story-generator/storyServiceInterface.d.ts +0 -85
  236. package/dist/story-generator/storyServiceInterface.d.ts.map +0 -1
  237. package/dist/story-generator/storyServiceInterface.js +0 -5
  238. package/dist/story-generator/storySync.d.ts +0 -68
  239. package/dist/story-generator/storySync.d.ts.map +0 -1
  240. package/dist/story-generator/storySync.js +0 -201
  241. package/dist/story-generator/storySync.js.map +0 -1
  242. package/dist/story-generator/storyTracker.js.map +0 -1
  243. package/dist/story-generator/storyValidator.js.map +0 -1
  244. package/dist/story-generator/test_validation.d.ts +0 -2
  245. package/dist/story-generator/test_validation.d.ts.map +0 -1
  246. package/dist/story-generator/test_validation.js +0 -51
  247. package/dist/story-generator/universalDesignSystemAdapter.js.map +0 -1
  248. package/dist/story-generator/urlRedirectService.js.map +0 -1
  249. package/dist/story-generator/validateStory.js.map +0 -1
  250. package/dist/story-ui.config.js.map +0 -1
  251. package/dist/story-ui.config.loader.d.ts +0 -36
  252. package/dist/story-ui.config.loader.d.ts.map +0 -1
  253. package/dist/story-ui.config.loader.js +0 -205
  254. package/dist/story-ui.config.loader.js.map +0 -1
  255. package/dist/temp/package/templates/StoryUI/StoryUIPanel.js +0 -807
  256. package/dist/temp/package/templates/StoryUI/StoryUIPanel.stories.js +0 -37
  257. package/dist/temp/package/templates/StoryUI/index.js +0 -2
  258. package/dist/templates/StoryUI/StoryUIPanel.js.map +0 -1
  259. package/dist/templates/StoryUI/StoryUIPanel.stories.js.map +0 -1
  260. package/dist/templates/StoryUI/index.js.map +0 -1
  261. package/dist/templates/StoryUI/manager.d.ts +0 -14
  262. package/dist/templates/StoryUI/manager.d.ts.map +0 -1
  263. package/dist/templates/production-app/src/App.d.ts +0 -10
  264. package/dist/templates/production-app/src/App.d.ts.map +0 -1
  265. package/dist/templates/production-app/src/App.js +0 -653
  266. package/dist/templates/production-app/src/LivePreviewRenderer.d.ts +0 -24
  267. package/dist/templates/production-app/src/LivePreviewRenderer.d.ts.map +0 -1
  268. package/dist/templates/production-app/src/LivePreviewRenderer.js +0 -199
  269. package/dist/templates/production-app/src/componentRegistry.d.ts +0 -20
  270. package/dist/templates/production-app/src/componentRegistry.d.ts.map +0 -1
  271. package/dist/templates/production-app/src/componentRegistry.js +0 -316
  272. package/dist/templates/production-app/src/main.d.ts +0 -9
  273. package/dist/templates/production-app/src/main.d.ts.map +0 -1
  274. package/dist/templates/production-app/src/main.js +0 -18
  275. package/dist/templates/production-app/vite.config.d.ts +0 -3
  276. package/dist/templates/production-app/vite.config.d.ts.map +0 -1
  277. package/dist/templates/production-app/vite.config.js +0 -71
  278. package/dist/test-storybooks/angular-material-storybook/src/main.js +0 -66
  279. package/dist/test-storybooks/chakra-storybook/vite.config.js +0 -6
  280. package/dist/test-storybooks/mantine-storybook/vite.config.js +0 -93
  281. package/dist/test-storybooks/web-components-shoelace/vite.config.js +0 -9
  282. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,214 +0,0 @@
1
- /* SpacingEditor styles */
2
-
3
- .spacingEditor {
4
- display: flex;
5
- flex-direction: column;
6
- gap: 12px;
7
- padding: 12px;
8
- background: white;
9
- border-radius: 8px;
10
- border: 1px solid #e5e7eb;
11
- }
12
-
13
- .header {
14
- display: flex;
15
- justify-content: space-between;
16
- align-items: center;
17
- }
18
-
19
- .label {
20
- font-size: 13px;
21
- font-weight: 600;
22
- color: #374151;
23
- text-transform: capitalize;
24
- }
25
-
26
- .controls {
27
- display: flex;
28
- gap: 8px;
29
- align-items: center;
30
- }
31
-
32
- .linkButton {
33
- width: 28px;
34
- height: 28px;
35
- padding: 0;
36
- background: white;
37
- border: 1px solid #e5e7eb;
38
- border-radius: 6px;
39
- cursor: pointer;
40
- display: flex;
41
- align-items: center;
42
- justify-content: center;
43
- font-size: 14px;
44
- transition: all 0.2s;
45
- }
46
-
47
- .linkButton:hover {
48
- background: #f3f4f6;
49
- border-color: #d1d5db;
50
- }
51
-
52
- .linkButton.linked {
53
- background: #3b82f6;
54
- border-color: #3b82f6;
55
- filter: grayscale(0);
56
- }
57
-
58
- .linkButton:not(.linked) {
59
- filter: grayscale(1);
60
- opacity: 0.5;
61
- }
62
-
63
- .unitSelect {
64
- padding: 4px 8px;
65
- background: white;
66
- border: 1px solid #e5e7eb;
67
- border-radius: 6px;
68
- font-size: 12px;
69
- color: #374151;
70
- cursor: pointer;
71
- outline: none;
72
- transition: all 0.2s;
73
- }
74
-
75
- .unitSelect:hover {
76
- border-color: #d1d5db;
77
- }
78
-
79
- .unitSelect:focus {
80
- border-color: #3b82f6;
81
- box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
82
- }
83
-
84
- .visualEditor {
85
- display: flex;
86
- justify-content: center;
87
- padding: 20px;
88
- }
89
-
90
- .boxModel {
91
- position: relative;
92
- width: 200px;
93
- height: 120px;
94
- background: #f9fafb;
95
- border: 2px dashed #d1d5db;
96
- border-radius: 8px;
97
- }
98
-
99
- .input {
100
- position: absolute;
101
- width: 50px;
102
- padding: 4px;
103
- background: white;
104
- border: 1px solid #e5e7eb;
105
- border-radius: 4px;
106
- font-size: 12px;
107
- text-align: center;
108
- color: #374151;
109
- outline: none;
110
- transition: all 0.2s;
111
- }
112
-
113
- .input:hover:not(:disabled) {
114
- border-color: #93c5fd;
115
- }
116
-
117
- .input:focus {
118
- border-color: #3b82f6;
119
- box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
120
- }
121
-
122
- .input:disabled {
123
- background: #f3f4f6;
124
- color: #9ca3af;
125
- cursor: not-allowed;
126
- }
127
-
128
- .inputTop {
129
- top: -14px;
130
- left: 50%;
131
- transform: translateX(-50%);
132
- }
133
-
134
- .inputRight {
135
- right: -14px;
136
- top: 50%;
137
- transform: translateY(-50%);
138
- }
139
-
140
- .inputBottom {
141
- bottom: -14px;
142
- left: 50%;
143
- transform: translateX(-50%);
144
- }
145
-
146
- .inputLeft {
147
- left: -14px;
148
- top: 50%;
149
- transform: translateY(-50%);
150
- }
151
-
152
- .centerBox {
153
- position: absolute;
154
- top: 50%;
155
- left: 50%;
156
- transform: translate(-50%, -50%);
157
- padding: 8px 16px;
158
- background: white;
159
- border: 1px solid #e5e7eb;
160
- border-radius: 6px;
161
- display: flex;
162
- align-items: center;
163
- justify-content: center;
164
- }
165
-
166
- .propertyName {
167
- font-size: 11px;
168
- font-weight: 600;
169
- color: #6b7280;
170
- text-transform: uppercase;
171
- letter-spacing: 0.5px;
172
- }
173
-
174
- .presets {
175
- display: flex;
176
- gap: 6px;
177
- justify-content: center;
178
- }
179
-
180
- .preset {
181
- flex: 1;
182
- padding: 6px 8px;
183
- background: white;
184
- border: 1px solid #e5e7eb;
185
- border-radius: 6px;
186
- font-size: 11px;
187
- font-weight: 500;
188
- color: #6b7280;
189
- cursor: pointer;
190
- transition: all 0.2s;
191
- }
192
-
193
- .preset:hover {
194
- background: #f3f4f6;
195
- border-color: #d1d5db;
196
- color: #374151;
197
- }
198
-
199
- .preset:active {
200
- background: #e5e7eb;
201
- }
202
-
203
- /* Responsive adjustments */
204
- @media (max-width: 320px) {
205
- .boxModel {
206
- width: 160px;
207
- height: 100px;
208
- }
209
-
210
- .input {
211
- width: 40px;
212
- font-size: 11px;
213
- }
214
- }
@@ -1,14 +0,0 @@
1
- /**
2
- * TextEditor - Simple text input for string properties using MUI
3
- */
4
- import React from 'react';
5
- export interface TextEditorProps {
6
- value?: string;
7
- onChange: (value: string) => void;
8
- label?: string;
9
- placeholder?: string;
10
- multiline?: boolean;
11
- rows?: number;
12
- }
13
- export declare const TextEditor: React.FC<TextEditorProps>;
14
- //# sourceMappingURL=TextEditor.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TextEditor.d.ts","sourceRoot":"","sources":["../../../../playground/components/PropertyEditors/TextEditor.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAmD,MAAM,OAAO,CAAC;AAIxE,MAAM,WAAW,eAAe;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAyDhD,CAAC"}
@@ -1,38 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- /**
3
- * TextEditor - Simple text input for string properties using MUI
4
- */
5
- import { useState, useCallback, useEffect, useRef } from 'react';
6
- import { TextField } from '@mui/material';
7
- import styles from './PropertyEditors.module.css';
8
- export const TextEditor = ({ value = '', onChange, label, placeholder, multiline = false, rows = 3 }) => {
9
- const [localValue, setLocalValue] = useState(value);
10
- const inputRef = useRef(null);
11
- const isUpdatingRef = useRef(false);
12
- useEffect(() => {
13
- if (!isUpdatingRef.current) {
14
- setLocalValue(value);
15
- }
16
- }, [value]);
17
- const handleChange = useCallback((e) => {
18
- const newValue = e.target.value;
19
- isUpdatingRef.current = true;
20
- setLocalValue(newValue);
21
- onChange(newValue);
22
- // Reset flag after a brief delay to allow for external updates
23
- setTimeout(() => {
24
- isUpdatingRef.current = false;
25
- }, 100);
26
- }, [onChange]);
27
- const handleBlur = useCallback(() => {
28
- isUpdatingRef.current = false;
29
- }, []);
30
- return (_jsx("div", { className: styles.propertyEditor, children: _jsx(TextField, { label: label, value: localValue, onChange: handleChange, onBlur: handleBlur, placeholder: placeholder, multiline: multiline, rows: multiline ? rows : undefined, size: "small", fullWidth: true, inputProps: {
31
- style: { fontSize: '13px' }
32
- }, sx: {
33
- '& .MuiInputLabel-root': {
34
- fontSize: '12px'
35
- }
36
- } }) }));
37
- };
38
- //# sourceMappingURL=TextEditor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TextEditor.js","sourceRoot":"","sources":["../../../../playground/components/PropertyEditors/TextEditor.tsx"],"names":[],"mappings":";AAAA;;GAEG;AAEH,OAAc,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,MAAM,MAAM,8BAA8B,CAAC;AAWlD,MAAM,CAAC,MAAM,UAAU,GAA8B,CAAC,EACpD,KAAK,GAAG,EAAE,EACV,QAAQ,EACR,KAAK,EACL,WAAW,EACX,SAAS,GAAG,KAAK,EACjB,IAAI,GAAG,CAAC,EACT,EAAE,EAAE;IACH,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACpD,MAAM,QAAQ,GAAG,MAAM,CAAyC,IAAI,CAAC,CAAC;IACtE,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEpC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC3B,aAAa,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;IACH,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEZ,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,CAA4D,EAAE,EAAE;QAChG,MAAM,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAChC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC;QAC7B,aAAa,CAAC,QAAQ,CAAC,CAAC;QACxB,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAEnB,+DAA+D;QAC/D,UAAU,CAAC,GAAG,EAAE;YACd,aAAa,CAAC,OAAO,GAAG,KAAK,CAAC;QAChC,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE;QAClC,aAAa,CAAC,OAAO,GAAG,KAAK,CAAC;IAChC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,cAAK,SAAS,EAAE,MAAM,CAAC,cAAc,YACnC,KAAC,SAAS,IACR,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,UAAU,EACjB,QAAQ,EAAE,YAAY,EACtB,MAAM,EAAE,UAAU,EAClB,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,SAAS,EACpB,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EAClC,IAAI,EAAC,OAAO,EACZ,SAAS,QACT,UAAU,EAAE;gBACV,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE;aAC5B,EACD,EAAE,EAAE;gBACF,uBAAuB,EAAE;oBACvB,QAAQ,EAAE,MAAM;iBACjB;aACF,GACD,GACE,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -1,23 +0,0 @@
1
- /**
2
- * TokenEditor - Design token selector for spacing, sizing, and other design system values
3
- */
4
- import React from 'react';
5
- export interface TokenOption {
6
- label: string;
7
- value: string | number;
8
- description?: string;
9
- preview?: string;
10
- }
11
- export interface TokenEditorProps {
12
- value?: string | number;
13
- onChange: (value: string | number) => void;
14
- label?: string;
15
- tokens: TokenOption[];
16
- allowCustom?: boolean;
17
- unit?: string;
18
- placeholder?: string;
19
- }
20
- export declare const SPACING_TOKENS: TokenOption[];
21
- export declare const SIZE_TOKENS: TokenOption[];
22
- export declare const TokenEditor: React.FC<TokenEditorProps>;
23
- //# sourceMappingURL=TokenEditor.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TokenEditor.d.ts","sourceRoot":"","sources":["../../../../playground/components/PropertyEditors/TokenEditor.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAA+B,MAAM,OAAO,CAAC;AAGpD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,gBAAgB;IAC/B,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,KAAK,IAAI,CAAC;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,WAAW,EAAE,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAGD,eAAO,MAAM,cAAc,EAAE,WAAW,EAavC,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,EAIpC,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CA2FlD,CAAC"}
@@ -1,50 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- /**
3
- * TokenEditor - Design token selector for spacing, sizing, and other design system values
4
- */
5
- import { useCallback, useMemo } from 'react';
6
- import styles from './PropertyEditors.module.css';
7
- // Common design tokens
8
- export const SPACING_TOKENS = [
9
- { label: 'None', value: 0, description: '0px' },
10
- { label: 'XS', value: 2, description: '2px' },
11
- { label: 'SM', value: 4, description: '4px' },
12
- { label: 'MD', value: 8, description: '8px' },
13
- { label: 'LG', value: 12, description: '12px' },
14
- { label: 'XL', value: 16, description: '16px' },
15
- { label: '2XL', value: 20, description: '20px' },
16
- { label: '3XL', value: 24, description: '24px' },
17
- { label: '4XL', value: 32, description: '32px' },
18
- { label: '5XL', value: 40, description: '40px' },
19
- { label: '6XL', value: 48, description: '48px' },
20
- { label: '7XL', value: 64, description: '64px' }
21
- ];
22
- export const SIZE_TOKENS = [
23
- { label: 'Small', value: 'small', description: 'Compact size' },
24
- { label: 'Medium', value: 'medium', description: 'Default size' },
25
- { label: 'Large', value: 'large', description: 'Larger size' }
26
- ];
27
- export const TokenEditor = ({ value, onChange, label, tokens, allowCustom = true, unit = 'px', placeholder = 'Select token...' }) => {
28
- const currentToken = useMemo(() => {
29
- return tokens.find(token => token.value === value);
30
- }, [tokens, value]);
31
- const handleTokenSelect = useCallback((selectedValue) => {
32
- onChange(selectedValue);
33
- }, [onChange]);
34
- const handleCustomChange = useCallback((e) => {
35
- const newValue = e.target.value;
36
- // Try to parse as number if it looks like one
37
- const numValue = Number(newValue);
38
- onChange(!isNaN(numValue) && newValue !== '' ? numValue : newValue);
39
- }, [onChange]);
40
- const renderTokenButton = (token) => {
41
- const isSelected = token.value === value;
42
- return (_jsxs("button", { className: `${styles.tokenButton} ${isSelected ? styles.tokenSelected : ''}`, onClick: () => handleTokenSelect(token.value), title: token.description, type: "button", children: [_jsx("span", { className: styles.tokenLabel, children: token.label }), token.preview && (_jsx("span", { className: styles.tokenPreview, style: {
43
- width: typeof token.value === 'number' ? `${Math.min(token.value, 32)}px` : '16px',
44
- height: '2px',
45
- backgroundColor: 'var(--color-primary)'
46
- } })), token.description && (_jsx("span", { className: styles.tokenDescription, children: token.description }))] }, token.value));
47
- };
48
- return (_jsxs("div", { className: styles.propertyEditor, children: [label && _jsx("label", { className: styles.label, children: label }), _jsxs("div", { className: styles.tokenEditor, children: [_jsx("div", { className: styles.tokenGrid, children: tokens.map(renderTokenButton) }), allowCustom && (_jsxs("div", { className: styles.customTokenInput, children: [_jsx("input", { type: "text", className: styles.input, value: currentToken ? '' : value || '', onChange: handleCustomChange, placeholder: placeholder }), unit && typeof value === 'number' && (_jsx("span", { className: styles.unit, children: unit }))] })), currentToken && (_jsxs("div", { className: styles.selectedToken, children: [_jsx("span", { className: styles.selectedLabel, children: "Selected:" }), _jsxs("span", { className: styles.selectedValue, children: [currentToken.label, " (", currentToken.description || currentToken.value, ")"] })] }))] })] }));
49
- };
50
- //# sourceMappingURL=TokenEditor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TokenEditor.js","sourceRoot":"","sources":["../../../../playground/components/PropertyEditors/TokenEditor.tsx"],"names":[],"mappings":";AAAA;;GAEG;AAEH,OAAc,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,MAAM,MAAM,8BAA8B,CAAC;AAmBlD,uBAAuB;AACvB,MAAM,CAAC,MAAM,cAAc,GAAkB;IAC3C,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE;IAC/C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE;IAC7C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE;IAC7C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE;IAC7C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;IAC/C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;IAC/C,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;IAChD,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;IAChD,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;IAChD,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;IAChD,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;IAChD,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;CACjD,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAkB;IACxC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE;IAC/D,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,cAAc,EAAE;IACjE,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE;CAC/D,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EACtD,KAAK,EACL,QAAQ,EACR,KAAK,EACL,MAAM,EACN,WAAW,GAAG,IAAI,EAClB,IAAI,GAAG,IAAI,EACX,WAAW,GAAG,iBAAiB,EAChC,EAAE,EAAE;IACH,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,EAAE;QAChC,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;IACrD,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;IAEpB,MAAM,iBAAiB,GAAG,WAAW,CAAC,CAAC,aAA8B,EAAE,EAAE;QACvE,QAAQ,CAAC,aAAa,CAAC,CAAC;IAC1B,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,MAAM,kBAAkB,GAAG,WAAW,CAAC,CAAC,CAAsC,EAAE,EAAE;QAChF,MAAM,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAChC,8CAA8C;QAC9C,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAClC,QAAQ,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,QAAQ,KAAK,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IACtE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,MAAM,iBAAiB,GAAG,CAAC,KAAkB,EAAE,EAAE;QAC/C,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,KAAK,KAAK,CAAC;QAEzC,OAAO,CACL,kBAEE,SAAS,EAAE,GAAG,MAAM,CAAC,WAAW,IAAI,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,EAAE,EAC5E,OAAO,EAAE,GAAG,EAAE,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,CAAC,EAC7C,KAAK,EAAE,KAAK,CAAC,WAAW,EACxB,IAAI,EAAC,QAAQ,aAEb,eAAM,SAAS,EAAE,MAAM,CAAC,UAAU,YAAG,KAAK,CAAC,KAAK,GAAQ,EACvD,KAAK,CAAC,OAAO,IAAI,CAChB,eACE,SAAS,EAAE,MAAM,CAAC,YAAY,EAC9B,KAAK,EAAE;wBACL,KAAK,EAAE,OAAO,KAAK,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM;wBAClF,MAAM,EAAE,KAAK;wBACb,eAAe,EAAE,sBAAsB;qBACxC,GACD,CACH,EACA,KAAK,CAAC,WAAW,IAAI,CACpB,eAAM,SAAS,EAAE,MAAM,CAAC,gBAAgB,YAAG,KAAK,CAAC,WAAW,GAAQ,CACrE,KAnBI,KAAK,CAAC,KAAK,CAoBT,CACV,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO,CACL,eAAK,SAAS,EAAE,MAAM,CAAC,cAAc,aAClC,KAAK,IAAI,gBAAO,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAS,EAEzD,eAAK,SAAS,EAAE,MAAM,CAAC,WAAW,aAEhC,cAAK,SAAS,EAAE,MAAM,CAAC,SAAS,YAC7B,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,GAC1B,EAGL,WAAW,IAAI,CACd,eAAK,SAAS,EAAE,MAAM,CAAC,gBAAgB,aACrC,gBACE,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,MAAM,CAAC,KAAK,EACvB,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,EACtC,QAAQ,EAAE,kBAAkB,EAC5B,WAAW,EAAE,WAAW,GACxB,EACD,IAAI,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CACpC,eAAM,SAAS,EAAE,MAAM,CAAC,IAAI,YAAG,IAAI,GAAQ,CAC5C,IACG,CACP,EAGA,YAAY,IAAI,CACf,eAAK,SAAS,EAAE,MAAM,CAAC,aAAa,aAClC,eAAM,SAAS,EAAE,MAAM,CAAC,aAAa,0BAAkB,EACvD,gBAAM,SAAS,EAAE,MAAM,CAAC,aAAa,aAClC,YAAY,CAAC,KAAK,QAAI,YAAY,CAAC,WAAW,IAAI,YAAY,CAAC,KAAK,SAChE,IACH,CACP,IACG,IACF,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -1,20 +0,0 @@
1
- /**
2
- * Property Editors - Intelligent form controls for different data types
3
- */
4
- export { BooleanEditor } from './BooleanEditor.js';
5
- export { ColorEditor } from './ColorEditor.js';
6
- export { IconEditor } from './IconEditor.js';
7
- export { NumberEditor } from './NumberEditor.js';
8
- export { SelectEditor } from './SelectEditor.js';
9
- export { SpacingEditor } from './SpacingEditor.js';
10
- export { TextEditor } from './TextEditor.js';
11
- export { TokenEditor, SPACING_TOKENS, SIZE_TOKENS } from './TokenEditor.js';
12
- export type { BooleanEditorProps } from './BooleanEditor.js';
13
- export type { ColorEditorProps } from './ColorEditor.js';
14
- export type { IconEditorProps } from './IconEditor.js';
15
- export type { NumberEditorProps } from './NumberEditor.js';
16
- export type { SelectEditorProps, SelectOption } from './SelectEditor.js';
17
- export type { SpacingEditorProps, SpacingValue } from './SpacingEditor.js';
18
- export type { TextEditorProps } from './TextEditor.js';
19
- export type { TokenEditorProps, TokenOption } from './TokenEditor.js';
20
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../playground/components/PropertyEditors/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE5E,YAAY,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAC7D,YAAY,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACzD,YAAY,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AACvD,YAAY,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAC3D,YAAY,EAAE,iBAAiB,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACzE,YAAY,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAC3E,YAAY,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AACvD,YAAY,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC"}
@@ -1,12 +0,0 @@
1
- /**
2
- * Property Editors - Intelligent form controls for different data types
3
- */
4
- export { BooleanEditor } from './BooleanEditor.js';
5
- export { ColorEditor } from './ColorEditor.js';
6
- export { IconEditor } from './IconEditor.js';
7
- export { NumberEditor } from './NumberEditor.js';
8
- export { SelectEditor } from './SelectEditor.js';
9
- export { SpacingEditor } from './SpacingEditor.js';
10
- export { TextEditor } from './TextEditor.js';
11
- export { TokenEditor, SPACING_TOKENS, SIZE_TOKENS } from './TokenEditor.js';
12
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../playground/components/PropertyEditors/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC"}
@@ -1,10 +0,0 @@
1
- /**
2
- * TreeView - Hierarchical component structure viewer
3
- */
4
- import React from 'react';
5
- export interface TreeViewProps {
6
- onComponentDoubleClick?: (id: string) => void;
7
- searchQuery?: string;
8
- }
9
- export declare const TreeView: React.FC<TreeViewProps>;
10
- //# sourceMappingURL=TreeView.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TreeView.d.ts","sourceRoot":"","sources":["../../../../playground/components/TreeView/TreeView.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAyC,MAAM,OAAO,CAAC;AA+J9D,MAAM,WAAW,aAAa;IAC5B,sBAAsB,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9C,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAsJ5C,CAAC"}
@@ -1,146 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- /**
3
- * TreeView - Hierarchical component structure viewer
4
- */
5
- import { useState, useCallback, useMemo } from 'react';
6
- import { usePlaygroundStore } from '../../store/playgroundStore';
7
- import styles from './TreeView.module.css';
8
- const TreeNode = ({ component, level, isSelected, isHovered, expandedNodes, onToggleExpand, onSelect, onHover, onDoubleClick }) => {
9
- const { components } = usePlaygroundStore();
10
- const hasChildren = component.children && component.children.length > 0;
11
- const isExpanded = expandedNodes.has(component.id);
12
- const handleClick = useCallback((e) => {
13
- e.stopPropagation();
14
- onSelect(component.id, e.metaKey || e.ctrlKey);
15
- }, [component.id, onSelect]);
16
- const handleToggle = useCallback((e) => {
17
- e.stopPropagation();
18
- onToggleExpand(component.id);
19
- }, [component.id, onToggleExpand]);
20
- const handleDoubleClick = useCallback((e) => {
21
- e.stopPropagation();
22
- onDoubleClick?.(component.id);
23
- }, [component.id, onDoubleClick]);
24
- const handleMouseEnter = useCallback(() => {
25
- onHover(component.id);
26
- }, [component.id, onHover]);
27
- const handleMouseLeave = useCallback(() => {
28
- onHover(null);
29
- }, [onHover]);
30
- // Get component icon based on type
31
- const getComponentIcon = (type) => {
32
- const iconMap = {
33
- // Layout
34
- 'Box': '📦',
35
- 'Container': '🔲',
36
- 'Stack': '📚',
37
- 'HStack': '🔗',
38
- 'Grid': '⚏',
39
- 'Flex': '↔️',
40
- 'Center': '⊡',
41
- // Form
42
- 'Button': '🔘',
43
- 'Input': '✏️',
44
- 'Select': '📝',
45
- 'Checkbox': '☑️',
46
- 'Radio': '⭕',
47
- // Display
48
- 'Text': '📝',
49
- 'Heading': '📰',
50
- 'Image': '🖼️',
51
- 'Card': '🎴',
52
- 'Badge': '🏷️',
53
- // Data
54
- 'Table': '📊',
55
- 'List': '📋',
56
- 'Avatar': '👤',
57
- // Default
58
- 'default': '🧩'
59
- };
60
- return iconMap[type] || iconMap.default;
61
- };
62
- return (_jsxs(_Fragment, { children: [_jsxs("div", { className: `
63
- ${styles.treeNode}
64
- ${isSelected ? styles.selected : ''}
65
- ${isHovered ? styles.hovered : ''}
66
- `, style: { paddingLeft: `${level * 20 + 8}px` }, onClick: handleClick, onDoubleClick: handleDoubleClick, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, children: [hasChildren && (_jsx("button", { className: `${styles.expandButton} ${isExpanded ? styles.expanded : ''}`, onClick: handleToggle, "aria-label": isExpanded ? 'Collapse' : 'Expand', children: "\u25B6" })), !hasChildren && _jsx("span", { className: styles.noExpand }), _jsx("span", { className: styles.icon, children: getComponentIcon(component.type) }), _jsxs("span", { className: styles.label, children: [_jsx("span", { className: styles.type, children: component.type }), component.displayName && component.displayName !== component.type && (_jsx("span", { className: styles.name, children: component.displayName }))] }), component.hidden && (_jsx("span", { className: styles.badge, title: "Hidden", children: "\uD83D\uDC41\uFE0F\u200D\uD83D\uDDE8\uFE0F" })), component.locked && (_jsx("span", { className: styles.badge, title: "Locked", children: "\uD83D\uDD12" }))] }), hasChildren && isExpanded && (_jsx("div", { className: styles.children, children: component.children.map((childId) => {
67
- const child = components.get(childId);
68
- if (!child)
69
- return null;
70
- // Selection/hover come from top-level props to ensure reactivity
71
- return (_jsx(TreeNode, { component: child, level: level + 1, isSelected: usePlaygroundStore.getState().selectedIds.has(child.id), isHovered: usePlaygroundStore.getState().hoveredId === child.id, expandedNodes: expandedNodes, onToggleExpand: onToggleExpand, onSelect: onSelect, onHover: onHover, onDoubleClick: onDoubleClick }, child.id));
72
- }) }))] }));
73
- };
74
- export const TreeView = ({ onComponentDoubleClick, searchQuery = '' }) => {
75
- const { components, rootId, selectedIds, hoveredId, selectComponent, setHoveredComponent } = usePlaygroundStore();
76
- const [expandedNodes, setExpandedNodes] = useState(new Set([rootId]));
77
- const [localSearchQuery, setLocalSearchQuery] = useState('');
78
- const effectiveSearchQuery = searchQuery || localSearchQuery;
79
- const rootComponent = components.get(rootId);
80
- const handleToggleExpand = useCallback((id) => {
81
- setExpandedNodes((prev) => {
82
- const next = new Set(prev);
83
- if (next.has(id)) {
84
- next.delete(id);
85
- }
86
- else {
87
- next.add(id);
88
- }
89
- return next;
90
- });
91
- }, []);
92
- const handleExpandAll = useCallback(() => {
93
- const allIds = new Set();
94
- const addIds = (comp) => {
95
- allIds.add(comp.id);
96
- comp.children?.forEach(childId => {
97
- const child = components.get(childId);
98
- if (child)
99
- addIds(child);
100
- });
101
- };
102
- if (rootComponent) {
103
- addIds(rootComponent);
104
- }
105
- setExpandedNodes(allIds);
106
- }, [rootComponent, components]);
107
- const handleCollapseAll = useCallback(() => {
108
- setExpandedNodes(new Set([rootId]));
109
- }, [rootId]);
110
- const handleDoubleClick = useCallback((id) => {
111
- // Focus on the component in the canvas
112
- selectComponent(id);
113
- onComponentDoubleClick?.(id);
114
- }, [selectComponent, onComponentDoubleClick]);
115
- // Filter components based on search
116
- const filterComponents = useCallback((component, query) => {
117
- if (!query)
118
- return component;
119
- const matchesQuery = component.type.toLowerCase().includes(query.toLowerCase()) ||
120
- component.displayName?.toLowerCase().includes(query.toLowerCase()) ||
121
- component.id.toLowerCase().includes(query.toLowerCase());
122
- const filteredChildren = component.children
123
- ?.map(childId => {
124
- const child = components.get(childId);
125
- return child ? filterComponents(child, query) : null;
126
- })
127
- .filter(Boolean);
128
- if (matchesQuery || (filteredChildren && filteredChildren.length > 0)) {
129
- return {
130
- ...component,
131
- children: filteredChildren?.map(c => c.id)
132
- };
133
- }
134
- return null;
135
- }, [components]);
136
- const filteredRoot = useMemo(() => {
137
- if (!rootComponent)
138
- return null;
139
- return filterComponents(rootComponent, effectiveSearchQuery);
140
- }, [rootComponent, effectiveSearchQuery, filterComponents]);
141
- if (!filteredRoot) {
142
- return (_jsx("div", { className: styles.treeView, children: _jsx("div", { className: styles.emptyState, children: effectiveSearchQuery ? (_jsxs("p", { children: ["No components match \"", effectiveSearchQuery, "\""] })) : (_jsx("p", { children: "No components to display" })) }) }));
143
- }
144
- return (_jsxs("div", { className: styles.treeView, children: [_jsxs("div", { className: styles.toolbar, children: [_jsx("input", { type: "text", className: styles.searchInput, placeholder: "Search components...", value: localSearchQuery, onChange: (e) => setLocalSearchQuery(e.target.value) }), _jsxs("div", { className: styles.actions, children: [_jsx("button", { className: styles.actionButton, onClick: handleExpandAll, title: "Expand all", children: "\u229E" }), _jsx("button", { className: styles.actionButton, onClick: handleCollapseAll, title: "Collapse all", children: "\u229F" })] })] }), _jsx("div", { className: styles.treeContent, children: _jsx(TreeNode, { component: filteredRoot, level: 0, isSelected: selectedIds.has(filteredRoot.id), isHovered: hoveredId === filteredRoot.id, expandedNodes: expandedNodes, onToggleExpand: handleToggleExpand, onSelect: selectComponent, onHover: setHoveredComponent, onDoubleClick: handleDoubleClick }) })] }));
145
- };
146
- //# sourceMappingURL=TreeView.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TreeView.js","sourceRoot":"","sources":["../../../../playground/components/TreeView/TreeView.tsx"],"names":[],"mappings":"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"}