@bendyline/squisq-editor-react 1.5.1 → 1.5.3

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 (405) hide show
  1. package/dist/index.d.ts +1991 -90
  2. package/dist/index.js +17162 -82
  3. package/dist/index.js.map +1 -1
  4. package/package.json +4 -4
  5. package/src/RawEditor.tsx +49 -18
  6. package/src/VersionHistoryPanel.tsx +59 -17
  7. package/src/recorder/hooks/useMediaRecorder.ts +9 -1
  8. package/src/useMonacoLoader.ts +83 -0
  9. package/dist/DocumentSettingsDialog.d.ts +0 -26
  10. package/dist/DocumentSettingsDialog.d.ts.map +0 -1
  11. package/dist/DocumentSettingsDialog.js +0 -115
  12. package/dist/DocumentSettingsDialog.js.map +0 -1
  13. package/dist/DropZoneOverlay.d.ts +0 -24
  14. package/dist/DropZoneOverlay.d.ts.map +0 -1
  15. package/dist/DropZoneOverlay.js +0 -53
  16. package/dist/DropZoneOverlay.js.map +0 -1
  17. package/dist/EditorContext.d.ts +0 -391
  18. package/dist/EditorContext.d.ts.map +0 -1
  19. package/dist/EditorContext.js +0 -471
  20. package/dist/EditorContext.js.map +0 -1
  21. package/dist/EditorShell.d.ts +0 -328
  22. package/dist/EditorShell.d.ts.map +0 -1
  23. package/dist/EditorShell.js +0 -290
  24. package/dist/EditorShell.js.map +0 -1
  25. package/dist/EmojiPicker.d.ts +0 -50
  26. package/dist/EmojiPicker.d.ts.map +0 -1
  27. package/dist/EmojiPicker.js +0 -182
  28. package/dist/EmojiPicker.js.map +0 -1
  29. package/dist/ImageEditor.d.ts +0 -68
  30. package/dist/ImageEditor.d.ts.map +0 -1
  31. package/dist/ImageEditor.js +0 -166
  32. package/dist/ImageEditor.js.map +0 -1
  33. package/dist/ImageNodeView.d.ts +0 -27
  34. package/dist/ImageNodeView.d.ts.map +0 -1
  35. package/dist/ImageNodeView.js +0 -215
  36. package/dist/ImageNodeView.js.map +0 -1
  37. package/dist/ImageViewer.d.ts +0 -26
  38. package/dist/ImageViewer.d.ts.map +0 -1
  39. package/dist/ImageViewer.js +0 -119
  40. package/dist/ImageViewer.js.map +0 -1
  41. package/dist/InlineIcon.d.ts +0 -17
  42. package/dist/InlineIcon.d.ts.map +0 -1
  43. package/dist/InlineIcon.js +0 -72
  44. package/dist/InlineIcon.js.map +0 -1
  45. package/dist/InlinePreviewGutter.d.ts +0 -52
  46. package/dist/InlinePreviewGutter.d.ts.map +0 -1
  47. package/dist/InlinePreviewGutter.js +0 -397
  48. package/dist/InlinePreviewGutter.js.map +0 -1
  49. package/dist/LinkDialog.d.ts +0 -43
  50. package/dist/LinkDialog.d.ts.map +0 -1
  51. package/dist/LinkDialog.js +0 -102
  52. package/dist/LinkDialog.js.map +0 -1
  53. package/dist/MediaBin.d.ts +0 -29
  54. package/dist/MediaBin.d.ts.map +0 -1
  55. package/dist/MediaBin.js +0 -166
  56. package/dist/MediaBin.js.map +0 -1
  57. package/dist/MentionExtension.d.ts +0 -22
  58. package/dist/MentionExtension.d.ts.map +0 -1
  59. package/dist/MentionExtension.js +0 -245
  60. package/dist/MentionExtension.js.map +0 -1
  61. package/dist/OutlinePanel.d.ts +0 -17
  62. package/dist/OutlinePanel.d.ts.map +0 -1
  63. package/dist/OutlinePanel.js +0 -167
  64. package/dist/OutlinePanel.js.map +0 -1
  65. package/dist/PlainHtmlPreview.d.ts +0 -50
  66. package/dist/PlainHtmlPreview.d.ts.map +0 -1
  67. package/dist/PlainHtmlPreview.js +0 -155
  68. package/dist/PlainHtmlPreview.js.map +0 -1
  69. package/dist/PreviewControls.d.ts +0 -55
  70. package/dist/PreviewControls.d.ts.map +0 -1
  71. package/dist/PreviewControls.js +0 -277
  72. package/dist/PreviewControls.js.map +0 -1
  73. package/dist/PreviewPanel.d.ts +0 -29
  74. package/dist/PreviewPanel.d.ts.map +0 -1
  75. package/dist/PreviewPanel.js +0 -94
  76. package/dist/PreviewPanel.js.map +0 -1
  77. package/dist/RawEditor.d.ts +0 -32
  78. package/dist/RawEditor.d.ts.map +0 -1
  79. package/dist/RawEditor.js +0 -440
  80. package/dist/RawEditor.js.map +0 -1
  81. package/dist/RecorderEntry.d.ts +0 -24
  82. package/dist/RecorderEntry.d.ts.map +0 -1
  83. package/dist/RecorderEntry.js +0 -139
  84. package/dist/RecorderEntry.js.map +0 -1
  85. package/dist/StatusBar.d.ts +0 -15
  86. package/dist/StatusBar.d.ts.map +0 -1
  87. package/dist/StatusBar.js +0 -24
  88. package/dist/StatusBar.js.map +0 -1
  89. package/dist/TemplateAnnotation.d.ts +0 -20
  90. package/dist/TemplateAnnotation.d.ts.map +0 -1
  91. package/dist/TemplateAnnotation.js +0 -97
  92. package/dist/TemplateAnnotation.js.map +0 -1
  93. package/dist/TemplatePicker.d.ts +0 -53
  94. package/dist/TemplatePicker.d.ts.map +0 -1
  95. package/dist/TemplatePicker.js +0 -388
  96. package/dist/TemplatePicker.js.map +0 -1
  97. package/dist/ThemeCustomizerPanel.d.ts +0 -32
  98. package/dist/ThemeCustomizerPanel.d.ts.map +0 -1
  99. package/dist/ThemeCustomizerPanel.js +0 -256
  100. package/dist/ThemeCustomizerPanel.js.map +0 -1
  101. package/dist/ThemePicker.d.ts +0 -33
  102. package/dist/ThemePicker.d.ts.map +0 -1
  103. package/dist/ThemePicker.js +0 -148
  104. package/dist/ThemePicker.js.map +0 -1
  105. package/dist/Toolbar.d.ts +0 -36
  106. package/dist/Toolbar.d.ts.map +0 -1
  107. package/dist/Toolbar.js +0 -1001
  108. package/dist/Toolbar.js.map +0 -1
  109. package/dist/Tooltip.d.ts +0 -10
  110. package/dist/Tooltip.d.ts.map +0 -1
  111. package/dist/Tooltip.js +0 -104
  112. package/dist/Tooltip.js.map +0 -1
  113. package/dist/VersionHistoryPanel.d.ts +0 -14
  114. package/dist/VersionHistoryPanel.d.ts.map +0 -1
  115. package/dist/VersionHistoryPanel.js +0 -147
  116. package/dist/VersionHistoryPanel.js.map +0 -1
  117. package/dist/ViewMenuPanel.d.ts +0 -13
  118. package/dist/ViewMenuPanel.d.ts.map +0 -1
  119. package/dist/ViewMenuPanel.js +0 -58
  120. package/dist/ViewMenuPanel.js.map +0 -1
  121. package/dist/ViewSwitcher.d.ts +0 -14
  122. package/dist/ViewSwitcher.d.ts.map +0 -1
  123. package/dist/ViewSwitcher.js +0 -26
  124. package/dist/ViewSwitcher.js.map +0 -1
  125. package/dist/WysiwygEditor.d.ts +0 -39
  126. package/dist/WysiwygEditor.d.ts.map +0 -1
  127. package/dist/WysiwygEditor.js +0 -537
  128. package/dist/WysiwygEditor.js.map +0 -1
  129. package/dist/__tests__/detectMarkdown.test.d.ts +0 -2
  130. package/dist/__tests__/detectMarkdown.test.d.ts.map +0 -1
  131. package/dist/__tests__/detectMarkdown.test.js +0 -55
  132. package/dist/__tests__/detectMarkdown.test.js.map +0 -1
  133. package/dist/__tests__/documentSettingsDialog.test.d.ts +0 -2
  134. package/dist/__tests__/documentSettingsDialog.test.d.ts.map +0 -1
  135. package/dist/__tests__/documentSettingsDialog.test.js +0 -132
  136. package/dist/__tests__/documentSettingsDialog.test.js.map +0 -1
  137. package/dist/__tests__/emojiPicker.test.d.ts +0 -2
  138. package/dist/__tests__/emojiPicker.test.d.ts.map +0 -1
  139. package/dist/__tests__/emojiPicker.test.js +0 -111
  140. package/dist/__tests__/emojiPicker.test.js.map +0 -1
  141. package/dist/__tests__/fileKind.test.d.ts +0 -2
  142. package/dist/__tests__/fileKind.test.d.ts.map +0 -1
  143. package/dist/__tests__/fileKind.test.js +0 -94
  144. package/dist/__tests__/fileKind.test.js.map +0 -1
  145. package/dist/__tests__/imageEditAffordance.test.d.ts +0 -2
  146. package/dist/__tests__/imageEditAffordance.test.d.ts.map +0 -1
  147. package/dist/__tests__/imageEditAffordance.test.js +0 -188
  148. package/dist/__tests__/imageEditAffordance.test.js.map +0 -1
  149. package/dist/__tests__/imageEditorShell.test.d.ts +0 -2
  150. package/dist/__tests__/imageEditorShell.test.d.ts.map +0 -1
  151. package/dist/__tests__/imageEditorShell.test.js +0 -52
  152. package/dist/__tests__/imageEditorShell.test.js.map +0 -1
  153. package/dist/__tests__/imageEditorState.test.d.ts +0 -3
  154. package/dist/__tests__/imageEditorState.test.d.ts.map +0 -1
  155. package/dist/__tests__/imageEditorState.test.js +0 -148
  156. package/dist/__tests__/imageEditorState.test.js.map +0 -1
  157. package/dist/__tests__/inlinePreviewGutter.test.d.ts +0 -2
  158. package/dist/__tests__/inlinePreviewGutter.test.d.ts.map +0 -1
  159. package/dist/__tests__/inlinePreviewGutter.test.js +0 -51
  160. package/dist/__tests__/inlinePreviewGutter.test.js.map +0 -1
  161. package/dist/__tests__/inlinePreviewGutterAllBlocks.test.d.ts +0 -2
  162. package/dist/__tests__/inlinePreviewGutterAllBlocks.test.d.ts.map +0 -1
  163. package/dist/__tests__/inlinePreviewGutterAllBlocks.test.js +0 -63
  164. package/dist/__tests__/inlinePreviewGutterAllBlocks.test.js.map +0 -1
  165. package/dist/__tests__/jsonEditor.test.d.ts +0 -2
  166. package/dist/__tests__/jsonEditor.test.d.ts.map +0 -1
  167. package/dist/__tests__/jsonEditor.test.js +0 -134
  168. package/dist/__tests__/jsonEditor.test.js.map +0 -1
  169. package/dist/__tests__/layersPanel.test.d.ts +0 -2
  170. package/dist/__tests__/layersPanel.test.d.ts.map +0 -1
  171. package/dist/__tests__/layersPanel.test.js +0 -84
  172. package/dist/__tests__/layersPanel.test.js.map +0 -1
  173. package/dist/__tests__/linkDialogDocPicker.test.d.ts +0 -7
  174. package/dist/__tests__/linkDialogDocPicker.test.d.ts.map +0 -1
  175. package/dist/__tests__/linkDialogDocPicker.test.js +0 -75
  176. package/dist/__tests__/linkDialogDocPicker.test.js.map +0 -1
  177. package/dist/__tests__/mediaAttachmentFlow.test.d.ts +0 -2
  178. package/dist/__tests__/mediaAttachmentFlow.test.d.ts.map +0 -1
  179. package/dist/__tests__/mediaAttachmentFlow.test.js +0 -99
  180. package/dist/__tests__/mediaAttachmentFlow.test.js.map +0 -1
  181. package/dist/__tests__/outlinePanel.test.d.ts +0 -2
  182. package/dist/__tests__/outlinePanel.test.d.ts.map +0 -1
  183. package/dist/__tests__/outlinePanel.test.js +0 -68
  184. package/dist/__tests__/outlinePanel.test.js.map +0 -1
  185. package/dist/__tests__/plainHtmlPreview.test.d.ts +0 -2
  186. package/dist/__tests__/plainHtmlPreview.test.d.ts.map +0 -1
  187. package/dist/__tests__/plainHtmlPreview.test.js +0 -87
  188. package/dist/__tests__/plainHtmlPreview.test.js.map +0 -1
  189. package/dist/__tests__/propertiesPanel.test.d.ts +0 -2
  190. package/dist/__tests__/propertiesPanel.test.d.ts.map +0 -1
  191. package/dist/__tests__/propertiesPanel.test.js +0 -64
  192. package/dist/__tests__/propertiesPanel.test.js.map +0 -1
  193. package/dist/__tests__/recorderFormats.test.d.ts +0 -2
  194. package/dist/__tests__/recorderFormats.test.d.ts.map +0 -1
  195. package/dist/__tests__/recorderFormats.test.js +0 -121
  196. package/dist/__tests__/recorderFormats.test.js.map +0 -1
  197. package/dist/__tests__/recorderTimingJson.test.d.ts +0 -2
  198. package/dist/__tests__/recorderTimingJson.test.d.ts.map +0 -1
  199. package/dist/__tests__/recorderTimingJson.test.js +0 -37
  200. package/dist/__tests__/recorderTimingJson.test.js.map +0 -1
  201. package/dist/__tests__/templateAnnotationRoundTrip.test.d.ts +0 -2
  202. package/dist/__tests__/templateAnnotationRoundTrip.test.d.ts.map +0 -1
  203. package/dist/__tests__/templateAnnotationRoundTrip.test.js +0 -31
  204. package/dist/__tests__/templateAnnotationRoundTrip.test.js.map +0 -1
  205. package/dist/__tests__/tiptapBridge.test.d.ts +0 -2
  206. package/dist/__tests__/tiptapBridge.test.d.ts.map +0 -1
  207. package/dist/__tests__/tiptapBridge.test.js +0 -303
  208. package/dist/__tests__/tiptapBridge.test.js.map +0 -1
  209. package/dist/__tests__/tiptapImageRoundTrip.test.d.ts +0 -2
  210. package/dist/__tests__/tiptapImageRoundTrip.test.d.ts.map +0 -1
  211. package/dist/__tests__/tiptapImageRoundTrip.test.js +0 -68
  212. package/dist/__tests__/tiptapImageRoundTrip.test.js.map +0 -1
  213. package/dist/__tests__/useImageEditor.test.d.ts +0 -2
  214. package/dist/__tests__/useImageEditor.test.d.ts.map +0 -1
  215. package/dist/__tests__/useImageEditor.test.js +0 -131
  216. package/dist/__tests__/useImageEditor.test.js.map +0 -1
  217. package/dist/__tests__/useMediaRecorder.test.d.ts +0 -2
  218. package/dist/__tests__/useMediaRecorder.test.d.ts.map +0 -1
  219. package/dist/__tests__/useMediaRecorder.test.js +0 -153
  220. package/dist/__tests__/useMediaRecorder.test.js.map +0 -1
  221. package/dist/__tests__/versionHistory.test.d.ts +0 -2
  222. package/dist/__tests__/versionHistory.test.d.ts.map +0 -1
  223. package/dist/__tests__/versionHistory.test.js +0 -124
  224. package/dist/__tests__/versionHistory.test.js.map +0 -1
  225. package/dist/blockSlice.d.ts +0 -24
  226. package/dist/blockSlice.d.ts.map +0 -1
  227. package/dist/blockSlice.js +0 -63
  228. package/dist/blockSlice.js.map +0 -1
  229. package/dist/buildPreviewDoc.d.ts +0 -22
  230. package/dist/buildPreviewDoc.d.ts.map +0 -1
  231. package/dist/buildPreviewDoc.js +0 -262
  232. package/dist/buildPreviewDoc.js.map +0 -1
  233. package/dist/detectMarkdown.d.ts +0 -20
  234. package/dist/detectMarkdown.d.ts.map +0 -1
  235. package/dist/detectMarkdown.js +0 -61
  236. package/dist/detectMarkdown.js.map +0 -1
  237. package/dist/emojiData.d.ts +0 -81
  238. package/dist/emojiData.d.ts.map +0 -1
  239. package/dist/emojiData.js +0 -1283
  240. package/dist/emojiData.js.map +0 -1
  241. package/dist/fileKind.d.ts +0 -34
  242. package/dist/fileKind.d.ts.map +0 -1
  243. package/dist/fileKind.js +0 -144
  244. package/dist/fileKind.js.map +0 -1
  245. package/dist/hooks/useFileDrop.d.ts +0 -41
  246. package/dist/hooks/useFileDrop.d.ts.map +0 -1
  247. package/dist/hooks/useFileDrop.js +0 -205
  248. package/dist/hooks/useFileDrop.js.map +0 -1
  249. package/dist/imageEditor/CanvasSurface.d.ts +0 -31
  250. package/dist/imageEditor/CanvasSurface.d.ts.map +0 -1
  251. package/dist/imageEditor/CanvasSurface.js +0 -264
  252. package/dist/imageEditor/CanvasSurface.js.map +0 -1
  253. package/dist/imageEditor/ImageVersionHistoryDropdown.d.ts +0 -39
  254. package/dist/imageEditor/ImageVersionHistoryDropdown.d.ts.map +0 -1
  255. package/dist/imageEditor/ImageVersionHistoryDropdown.js +0 -283
  256. package/dist/imageEditor/ImageVersionHistoryDropdown.js.map +0 -1
  257. package/dist/imageEditor/LayersPanel.d.ts +0 -14
  258. package/dist/imageEditor/LayersPanel.d.ts.map +0 -1
  259. package/dist/imageEditor/LayersPanel.js +0 -43
  260. package/dist/imageEditor/LayersPanel.js.map +0 -1
  261. package/dist/imageEditor/PropertiesPanel.d.ts +0 -14
  262. package/dist/imageEditor/PropertiesPanel.d.ts.map +0 -1
  263. package/dist/imageEditor/PropertiesPanel.js +0 -97
  264. package/dist/imageEditor/PropertiesPanel.js.map +0 -1
  265. package/dist/imageEditor/Toolbar.d.ts +0 -30
  266. package/dist/imageEditor/Toolbar.d.ts.map +0 -1
  267. package/dist/imageEditor/Toolbar.js +0 -108
  268. package/dist/imageEditor/Toolbar.js.map +0 -1
  269. package/dist/imageEditor/icons.d.ts +0 -24
  270. package/dist/imageEditor/icons.d.ts.map +0 -1
  271. package/dist/imageEditor/icons.js +0 -45
  272. package/dist/imageEditor/icons.js.map +0 -1
  273. package/dist/imageEditor/layers/EditorImageLayer.d.ts +0 -16
  274. package/dist/imageEditor/layers/EditorImageLayer.d.ts.map +0 -1
  275. package/dist/imageEditor/layers/EditorImageLayer.js +0 -37
  276. package/dist/imageEditor/layers/EditorImageLayer.js.map +0 -1
  277. package/dist/imageEditor/layers/EditorShapeLayer.d.ts +0 -15
  278. package/dist/imageEditor/layers/EditorShapeLayer.d.ts.map +0 -1
  279. package/dist/imageEditor/layers/EditorShapeLayer.js +0 -20
  280. package/dist/imageEditor/layers/EditorShapeLayer.js.map +0 -1
  281. package/dist/imageEditor/layers/EditorTextLayer.d.ts +0 -18
  282. package/dist/imageEditor/layers/EditorTextLayer.d.ts.map +0 -1
  283. package/dist/imageEditor/layers/EditorTextLayer.js +0 -13
  284. package/dist/imageEditor/layers/EditorTextLayer.js.map +0 -1
  285. package/dist/imageEditor/layers/SelectionHandles.d.ts +0 -17
  286. package/dist/imageEditor/layers/SelectionHandles.d.ts.map +0 -1
  287. package/dist/imageEditor/layers/SelectionHandles.js +0 -19
  288. package/dist/imageEditor/layers/SelectionHandles.js.map +0 -1
  289. package/dist/imageEditor/state.d.ts +0 -76
  290. package/dist/imageEditor/state.d.ts.map +0 -1
  291. package/dist/imageEditor/state.js +0 -87
  292. package/dist/imageEditor/state.js.map +0 -1
  293. package/dist/imageEditor/useImageEditor.d.ts +0 -53
  294. package/dist/imageEditor/useImageEditor.d.ts.map +0 -1
  295. package/dist/imageEditor/useImageEditor.js +0 -244
  296. package/dist/imageEditor/useImageEditor.js.map +0 -1
  297. package/dist/imageEditor/useImageEditorTokens.d.ts +0 -16
  298. package/dist/imageEditor/useImageEditorTokens.d.ts.map +0 -1
  299. package/dist/imageEditor/useImageEditorTokens.js +0 -45
  300. package/dist/imageEditor/useImageEditorTokens.js.map +0 -1
  301. package/dist/index.d.ts.map +0 -1
  302. package/dist/jsonEditor/EmbeddedRichTextField.d.ts +0 -15
  303. package/dist/jsonEditor/EmbeddedRichTextField.d.ts.map +0 -1
  304. package/dist/jsonEditor/EmbeddedRichTextField.js +0 -74
  305. package/dist/jsonEditor/EmbeddedRichTextField.js.map +0 -1
  306. package/dist/jsonEditor/JsonEditor.d.ts +0 -36
  307. package/dist/jsonEditor/JsonEditor.d.ts.map +0 -1
  308. package/dist/jsonEditor/JsonEditor.js +0 -15
  309. package/dist/jsonEditor/JsonEditor.js.map +0 -1
  310. package/dist/jsonEditor/JsonEditorContext.d.ts +0 -28
  311. package/dist/jsonEditor/JsonEditorContext.d.ts.map +0 -1
  312. package/dist/jsonEditor/JsonEditorContext.js +0 -41
  313. package/dist/jsonEditor/JsonEditorContext.js.map +0 -1
  314. package/dist/jsonEditor/RenderNode.d.ts +0 -16
  315. package/dist/jsonEditor/RenderNode.d.ts.map +0 -1
  316. package/dist/jsonEditor/RenderNode.js +0 -32
  317. package/dist/jsonEditor/RenderNode.js.map +0 -1
  318. package/dist/jsonEditor/editors.d.ts +0 -36
  319. package/dist/jsonEditor/editors.d.ts.map +0 -1
  320. package/dist/jsonEditor/editors.js +0 -347
  321. package/dist/jsonEditor/editors.js.map +0 -1
  322. package/dist/jsonEditor/index.d.ts +0 -3
  323. package/dist/jsonEditor/index.d.ts.map +0 -1
  324. package/dist/jsonEditor/index.js +0 -2
  325. package/dist/jsonEditor/index.js.map +0 -1
  326. package/dist/jsonEditor/useJsonEditorTokens.d.ts +0 -13
  327. package/dist/jsonEditor/useJsonEditorTokens.d.ts.map +0 -1
  328. package/dist/jsonEditor/useJsonEditorTokens.js +0 -38
  329. package/dist/jsonEditor/useJsonEditorTokens.js.map +0 -1
  330. package/dist/mediaDragMime.d.ts +0 -17
  331. package/dist/mediaDragMime.d.ts.map +0 -1
  332. package/dist/mediaDragMime.js +0 -22
  333. package/dist/mediaDragMime.js.map +0 -1
  334. package/dist/recorder/RecorderButton.d.ts +0 -31
  335. package/dist/recorder/RecorderButton.d.ts.map +0 -1
  336. package/dist/recorder/RecorderButton.js +0 -24
  337. package/dist/recorder/RecorderButton.js.map +0 -1
  338. package/dist/recorder/RecorderModal.d.ts +0 -59
  339. package/dist/recorder/RecorderModal.d.ts.map +0 -1
  340. package/dist/recorder/RecorderModal.js +0 -333
  341. package/dist/recorder/RecorderModal.js.map +0 -1
  342. package/dist/recorder/RecorderPanel.d.ts +0 -25
  343. package/dist/recorder/RecorderPanel.d.ts.map +0 -1
  344. package/dist/recorder/RecorderPanel.js +0 -30
  345. package/dist/recorder/RecorderPanel.js.map +0 -1
  346. package/dist/recorder/formats.d.ts +0 -51
  347. package/dist/recorder/formats.d.ts.map +0 -1
  348. package/dist/recorder/formats.js +0 -144
  349. package/dist/recorder/formats.js.map +0 -1
  350. package/dist/recorder/hooks/useMediaRecorder.d.ts +0 -90
  351. package/dist/recorder/hooks/useMediaRecorder.d.ts.map +0 -1
  352. package/dist/recorder/hooks/useMediaRecorder.js +0 -277
  353. package/dist/recorder/hooks/useMediaRecorder.js.map +0 -1
  354. package/dist/recorder/hooks/useStreamPreview.d.ts +0 -22
  355. package/dist/recorder/hooks/useStreamPreview.d.ts.map +0 -1
  356. package/dist/recorder/hooks/useStreamPreview.js +0 -44
  357. package/dist/recorder/hooks/useStreamPreview.js.map +0 -1
  358. package/dist/recorder/sources/cameraStream.d.ts +0 -22
  359. package/dist/recorder/sources/cameraStream.d.ts.map +0 -1
  360. package/dist/recorder/sources/cameraStream.js +0 -24
  361. package/dist/recorder/sources/cameraStream.js.map +0 -1
  362. package/dist/recorder/sources/micStream.d.ts +0 -15
  363. package/dist/recorder/sources/micStream.d.ts.map +0 -1
  364. package/dist/recorder/sources/micStream.js +0 -24
  365. package/dist/recorder/sources/micStream.js.map +0 -1
  366. package/dist/recorder/sources/screenStream.d.ts +0 -53
  367. package/dist/recorder/sources/screenStream.d.ts.map +0 -1
  368. package/dist/recorder/sources/screenStream.js +0 -114
  369. package/dist/recorder/sources/screenStream.js.map +0 -1
  370. package/dist/recorder/timingJson.d.ts +0 -51
  371. package/dist/recorder/timingJson.d.ts.map +0 -1
  372. package/dist/recorder/timingJson.js +0 -42
  373. package/dist/recorder/timingJson.js.map +0 -1
  374. package/dist/tiptap/TiptapAudio.d.ts +0 -26
  375. package/dist/tiptap/TiptapAudio.d.ts.map +0 -1
  376. package/dist/tiptap/TiptapAudio.js +0 -58
  377. package/dist/tiptap/TiptapAudio.js.map +0 -1
  378. package/dist/tiptap/TiptapVideo.d.ts +0 -30
  379. package/dist/tiptap/TiptapVideo.d.ts.map +0 -1
  380. package/dist/tiptap/TiptapVideo.js +0 -66
  381. package/dist/tiptap/TiptapVideo.js.map +0 -1
  382. package/dist/tiptap/useResolvedMediaSrc.d.ts +0 -2
  383. package/dist/tiptap/useResolvedMediaSrc.d.ts.map +0 -1
  384. package/dist/tiptap/useResolvedMediaSrc.js +0 -42
  385. package/dist/tiptap/useResolvedMediaSrc.js.map +0 -1
  386. package/dist/tiptapBridge.d.ts +0 -24
  387. package/dist/tiptapBridge.d.ts.map +0 -1
  388. package/dist/tiptapBridge.js +0 -749
  389. package/dist/tiptapBridge.js.map +0 -1
  390. package/dist/useHeadingLayout.d.ts +0 -54
  391. package/dist/useHeadingLayout.d.ts.map +0 -1
  392. package/dist/useHeadingLayout.js +0 -260
  393. package/dist/useHeadingLayout.js.map +0 -1
  394. package/dist/utils/collectInlineFontAwesomeCss.d.ts +0 -21
  395. package/dist/utils/collectInlineFontAwesomeCss.d.ts.map +0 -1
  396. package/dist/utils/collectInlineFontAwesomeCss.js +0 -68
  397. package/dist/utils/collectInlineFontAwesomeCss.js.map +0 -1
  398. package/dist/utils/dropUtils.d.ts +0 -55
  399. package/dist/utils/dropUtils.d.ts.map +0 -1
  400. package/dist/utils/dropUtils.js +0 -110
  401. package/dist/utils/dropUtils.js.map +0 -1
  402. package/dist/utils/normalizeMalformedAssetUrl.d.ts +0 -15
  403. package/dist/utils/normalizeMalformedAssetUrl.d.ts.map +0 -1
  404. package/dist/utils/normalizeMalformedAssetUrl.js +0 -27
  405. package/dist/utils/normalizeMalformedAssetUrl.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"EditorTextLayer.js","sourceRoot":"","sources":["../../../src/imageEditor/layers/EditorTextLayer.tsx"],"names":[],"mappings":";AAgBA,MAAM,UAAU,eAAe,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAS;IAC/D,MAAM,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC;IACzB,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC,OAAO,CAAC;IACtC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,IAAI,GAAG,CAAC;IAC3C,MAAM,YAAY,GAAG,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;IACjD,MAAM,KAAK,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACvC,MAAM,UAAU,GACd,KAAK,CAAC,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;IAE1F,OAAO,CACL,eACE,CAAC,EAAE,CAAC,EACJ,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,QAAQ,EACrB,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,YAAY,EAC5C,QAAQ,EAAE,KAAK,CAAC,QAAQ,EACxB,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,QAAQ,EACxC,IAAI,EAAE,KAAK,CAAC,KAAK,EACjB,UAAU,EAAE,UAAU,YAErB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CACtB,gBAAe,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,YAChD,IAAI,IAAI,QAAQ,IADP,CAAC,CAEL,CACT,CAAC,GACG,CACR,CAAC;AACJ,CAAC"}
@@ -1,17 +0,0 @@
1
- /**
2
- * SelectionHandles
3
- *
4
- * Renders the dashed selection rectangle plus eight resize handles around
5
- * the currently-selected layer's bounding box. Pointer events on each
6
- * handle bubble back through `onHandlePointerDown` so the surrounding
7
- * `<CanvasSurface>` can run its drag loop with the right resize semantics.
8
- */
9
- import type { CanvasRect } from '../state.js';
10
- export type Handle = 'nw' | 'n' | 'ne' | 'e' | 'se' | 's' | 'sw' | 'w';
11
- interface Props {
12
- box: CanvasRect;
13
- onHandlePointerDown: (e: React.PointerEvent<SVGRectElement>, handle: Handle) => void;
14
- }
15
- export declare function SelectionHandles({ box, onHandlePointerDown }: Props): import("react/jsx-runtime").JSX.Element;
16
- export {};
17
- //# sourceMappingURL=SelectionHandles.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SelectionHandles.d.ts","sourceRoot":"","sources":["../../../src/imageEditor/layers/SelectionHandles.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAE9C,MAAM,MAAM,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,CAAC;AAIvE,UAAU,KAAK;IACb,GAAG,EAAE,UAAU,CAAC;IAChB,mBAAmB,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,YAAY,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;CACtF;AAED,wBAAgB,gBAAgB,CAAC,EAAE,GAAG,EAAE,mBAAmB,EAAE,EAAE,KAAK,2CAiEnE"}
@@ -1,19 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- const HANDLE_SIZE = 10; // canvas-pixel size of each square handle
3
- export function SelectionHandles({ box, onHandlePointerDown }) {
4
- const half = HANDLE_SIZE / 2;
5
- const cx = box.x + box.width / 2;
6
- const cy = box.y + box.height / 2;
7
- const handles = [
8
- { id: 'nw', x: box.x, y: box.y, cursor: 'nwse-resize' },
9
- { id: 'n', x: cx, y: box.y, cursor: 'ns-resize' },
10
- { id: 'ne', x: box.x + box.width, y: box.y, cursor: 'nesw-resize' },
11
- { id: 'e', x: box.x + box.width, y: cy, cursor: 'ew-resize' },
12
- { id: 'se', x: box.x + box.width, y: box.y + box.height, cursor: 'nwse-resize' },
13
- { id: 's', x: cx, y: box.y + box.height, cursor: 'ns-resize' },
14
- { id: 'sw', x: box.x, y: box.y + box.height, cursor: 'nesw-resize' },
15
- { id: 'w', x: box.x, y: cy, cursor: 'ew-resize' },
16
- ];
17
- return (_jsxs("g", { pointerEvents: "none", children: [_jsx("rect", { x: box.x, y: box.y, width: box.width, height: box.height, fill: "none", stroke: "#ffffff", strokeOpacity: 0.9, strokeWidth: 4, vectorEffect: "non-scaling-stroke" }), _jsx("rect", { x: box.x, y: box.y, width: box.width, height: box.height, fill: "none", stroke: "#39f", strokeWidth: 2, strokeDasharray: "6 4", vectorEffect: "non-scaling-stroke" }), handles.map((h) => (_jsx("rect", { x: h.x - half, y: h.y - half, width: HANDLE_SIZE, height: HANDLE_SIZE, fill: "#fff", stroke: "#39f", strokeWidth: 2, vectorEffect: "non-scaling-stroke", style: { cursor: h.cursor, pointerEvents: 'all' }, onPointerDown: (e) => onHandlePointerDown(e, h.id) }, h.id)))] }));
18
- }
19
- //# sourceMappingURL=SelectionHandles.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SelectionHandles.js","sourceRoot":"","sources":["../../../src/imageEditor/layers/SelectionHandles.tsx"],"names":[],"mappings":"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"}
@@ -1,76 +0,0 @@
1
- /**
2
- * Pure state + reducer for the `<ImageEditor>` component.
3
- *
4
- * Kept React-free so it's easy to unit-test in isolation. The actual
5
- * React hook that wires this to a {@link ContentContainer} (and the
6
- * version manager) lives in `useImageEditor.ts`.
7
- */
8
- import type { ImageEditDoc, ImageEditLayer } from '@bendyline/squisq/schemas';
9
- /**
10
- * Layer payload accepted by the `add-layer` action — the `id` field is
11
- * optional and will be assigned by the underlying `addLayer` helper if
12
- * the caller doesn't supply one.
13
- */
14
- export type ImageEditLayerInput = ImageEditLayer | (Omit<ImageEditLayer, 'id'> & {
15
- id?: string;
16
- });
17
- /** The currently active interaction tool. */
18
- export type ImageEditorTool = 'select' | 'text' | 'shape' | 'image' | 'crop';
19
- /** A pixel-space rectangle in canvas coordinates. */
20
- export interface CanvasRect {
21
- x: number;
22
- y: number;
23
- width: number;
24
- height: number;
25
- }
26
- export interface ImageEditorState {
27
- /** The persisted document. */
28
- doc: ImageEditDoc;
29
- /** Selected layer id, or `null` when nothing is selected. */
30
- selectedLayerId: string | null;
31
- /** Active tool. */
32
- tool: ImageEditorTool;
33
- /**
34
- * Dirty flag — true when the in-memory doc has unsaved changes
35
- * relative to the last `markClean()` call. The hook uses this to
36
- * debounce writes back to `state.json`.
37
- */
38
- dirty: boolean;
39
- }
40
- export type ImageEditorAction = {
41
- type: 'load';
42
- doc: ImageEditDoc;
43
- } | {
44
- type: 'mark-clean';
45
- } | {
46
- type: 'set-tool';
47
- tool: ImageEditorTool;
48
- } | {
49
- type: 'select';
50
- layerId: string | null;
51
- } | {
52
- type: 'set-canvas';
53
- canvas: ImageEditDoc['canvas'];
54
- } | {
55
- type: 'add-layer';
56
- layer: ImageEditLayerInput;
57
- select?: boolean;
58
- } | {
59
- type: 'remove-layer';
60
- layerId: string;
61
- } | {
62
- type: 'update-layer';
63
- layerId: string;
64
- patch: Partial<ImageEditLayer>;
65
- } | {
66
- type: 'reorder-layer';
67
- layerId: string;
68
- toIndex: number;
69
- } | {
70
- type: 'crop';
71
- rect: CanvasRect;
72
- };
73
- /** Build the initial state from a freshly-loaded doc. */
74
- export declare function initialImageEditorState(doc: ImageEditDoc): ImageEditorState;
75
- export declare function imageEditorReducer(state: ImageEditorState, action: ImageEditorAction): ImageEditorState;
76
- //# sourceMappingURL=state.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"state.d.ts","sourceRoot":"","sources":["../../src/imageEditor/state.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAU9E;;;;GAIG;AACH,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,GAAG;IAAE,EAAE,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAElG,6CAA6C;AAC7C,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAE7E,qDAAqD;AACrD,MAAM,WAAW,UAAU;IACzB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,gBAAgB;IAC/B,8BAA8B;IAC9B,GAAG,EAAE,YAAY,CAAC;IAClB,6DAA6D;IAC7D,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,mBAAmB;IACnB,IAAI,EAAE,eAAe,CAAC;IACtB;;;;OAIG;IACH,KAAK,EAAE,OAAO,CAAC;CAChB;AAED,MAAM,MAAM,iBAAiB,GACzB;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,YAAY,CAAA;CAAE,GACnC;IAAE,IAAI,EAAE,YAAY,CAAA;CAAE,GACtB;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,IAAI,EAAE,eAAe,CAAA;CAAE,GAC3C;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,GAC1C;IAAE,IAAI,EAAE,YAAY,CAAC;IAAC,MAAM,EAAE,YAAY,CAAC,QAAQ,CAAC,CAAA;CAAE,GACtD;IAAE,IAAI,EAAE,WAAW,CAAC;IAAC,KAAK,EAAE,mBAAmB,CAAC;IAAC,MAAM,CAAC,EAAE,OAAO,CAAA;CAAE,GACnE;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GACzC;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,OAAO,CAAC,cAAc,CAAC,CAAA;CAAE,GACzE;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GAC3D;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,UAAU,CAAA;CAAE,CAAC;AAEvC,yDAAyD;AACzD,wBAAgB,uBAAuB,CAAC,GAAG,EAAE,YAAY,GAAG,gBAAgB,CAO3E;AAED,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,gBAAgB,EACvB,MAAM,EAAE,iBAAiB,GACxB,gBAAgB,CA4ElB"}
@@ -1,87 +0,0 @@
1
- /**
2
- * Pure state + reducer for the `<ImageEditor>` component.
3
- *
4
- * Kept React-free so it's easy to unit-test in isolation. The actual
5
- * React hook that wires this to a {@link ContentContainer} (and the
6
- * version manager) lives in `useImageEditor.ts`.
7
- */
8
- import { addLayer, removeLayer, reorderLayer, setCanvas, updateLayer, touch, } from '@bendyline/squisq/imageEdit';
9
- /** Build the initial state from a freshly-loaded doc. */
10
- export function initialImageEditorState(doc) {
11
- return {
12
- doc,
13
- selectedLayerId: null,
14
- tool: 'select',
15
- dirty: false,
16
- };
17
- }
18
- export function imageEditorReducer(state, action) {
19
- switch (action.type) {
20
- case 'load':
21
- return { doc: action.doc, selectedLayerId: null, tool: 'select', dirty: false };
22
- case 'mark-clean':
23
- return state.dirty ? { ...state, dirty: false } : state;
24
- case 'set-tool':
25
- return state.tool === action.tool ? state : { ...state, tool: action.tool };
26
- case 'select':
27
- return state.selectedLayerId === action.layerId
28
- ? state
29
- : { ...state, selectedLayerId: action.layerId };
30
- case 'set-canvas': {
31
- const next = setCanvas(state.doc, action.canvas);
32
- return next === state.doc ? state : { ...state, doc: next, dirty: true };
33
- }
34
- case 'add-layer': {
35
- // `addLayer` from core assigns an id when missing; cast through
36
- // `ImageEditLayer` for the existing helper signature.
37
- const next = addLayer(state.doc, action.layer);
38
- // Pick up the assigned id (last layer)
39
- const newId = next.layers[next.layers.length - 1].id;
40
- return {
41
- ...state,
42
- doc: next,
43
- dirty: true,
44
- selectedLayerId: action.select === false ? state.selectedLayerId : newId,
45
- };
46
- }
47
- case 'remove-layer': {
48
- const next = removeLayer(state.doc, action.layerId);
49
- if (next === state.doc)
50
- return state;
51
- return {
52
- ...state,
53
- doc: next,
54
- dirty: true,
55
- selectedLayerId: state.selectedLayerId === action.layerId ? null : state.selectedLayerId,
56
- };
57
- }
58
- case 'update-layer': {
59
- const next = updateLayer(state.doc, action.layerId, action.patch);
60
- return next === state.doc ? state : { ...state, doc: next, dirty: true };
61
- }
62
- case 'reorder-layer': {
63
- const next = reorderLayer(state.doc, action.layerId, action.toIndex);
64
- return next === state.doc ? state : { ...state, doc: next, dirty: true };
65
- }
66
- case 'crop': {
67
- const { rect } = action;
68
- const newCanvas = {
69
- ...state.doc.canvas,
70
- width: Math.max(1, Math.round(rect.width)),
71
- height: Math.max(1, Math.round(rect.height)),
72
- };
73
- // Translate every layer by (-rect.x, -rect.y). Only handles numeric
74
- // positions; percentage strings are left alone (rare for image-edit
75
- // layers, which the editor produces with numeric coords).
76
- const translated = state.doc.layers.map((layer) => {
77
- const { position } = layer;
78
- const x = typeof position.x === 'number' ? position.x - rect.x : position.x;
79
- const y = typeof position.y === 'number' ? position.y - rect.y : position.y;
80
- return { ...layer, position: { ...position, x, y } };
81
- });
82
- const next = touch({ ...state.doc, canvas: newCanvas, layers: translated });
83
- return { ...state, doc: next, dirty: true };
84
- }
85
- }
86
- }
87
- //# sourceMappingURL=state.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"state.js","sourceRoot":"","sources":["../../src/imageEditor/state.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,EACL,QAAQ,EACR,WAAW,EACX,YAAY,EACZ,SAAS,EACT,WAAW,EACX,KAAK,GACN,MAAM,6BAA6B,CAAC;AA+CrC,yDAAyD;AACzD,MAAM,UAAU,uBAAuB,CAAC,GAAiB;IACvD,OAAO;QACL,GAAG;QACH,eAAe,EAAE,IAAI;QACrB,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE,KAAK;KACb,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAChC,KAAuB,EACvB,MAAyB;IAEzB,QAAQ,MAAM,CAAC,IAAI,EAAE,CAAC;QACpB,KAAK,MAAM;YACT,OAAO,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,eAAe,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;QAElF,KAAK,YAAY;YACf,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;QAE1D,KAAK,UAAU;YACb,OAAO,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;QAE9E,KAAK,QAAQ;YACX,OAAO,KAAK,CAAC,eAAe,KAAK,MAAM,CAAC,OAAO;gBAC7C,CAAC,CAAC,KAAK;gBACP,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,eAAe,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC;QAEpD,KAAK,YAAY,CAAC,CAAC,CAAC;YAClB,MAAM,IAAI,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YACjD,OAAO,IAAI,KAAK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAC3E,CAAC;QAED,KAAK,WAAW,CAAC,CAAC,CAAC;YACjB,gEAAgE;YAChE,sDAAsD;YACtD,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAuB,CAAC,CAAC;YACjE,uCAAuC;YACvC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAE,CAAC,EAAE,CAAC;YACtD,OAAO;gBACL,GAAG,KAAK;gBACR,GAAG,EAAE,IAAI;gBACT,KAAK,EAAE,IAAI;gBACX,eAAe,EAAE,MAAM,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK;aACzE,CAAC;QACJ,CAAC;QAED,KAAK,cAAc,CAAC,CAAC,CAAC;YACpB,MAAM,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;YACpD,IAAI,IAAI,KAAK,KAAK,CAAC,GAAG;gBAAE,OAAO,KAAK,CAAC;YACrC,OAAO;gBACL,GAAG,KAAK;gBACR,GAAG,EAAE,IAAI;gBACT,KAAK,EAAE,IAAI;gBACX,eAAe,EAAE,KAAK,CAAC,eAAe,KAAK,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,eAAe;aACzF,CAAC;QACJ,CAAC;QAED,KAAK,cAAc,CAAC,CAAC,CAAC;YACpB,MAAM,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;YAClE,OAAO,IAAI,KAAK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAC3E,CAAC;QAED,KAAK,eAAe,CAAC,CAAC,CAAC;YACrB,MAAM,IAAI,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;YACrE,OAAO,IAAI,KAAK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAC3E,CAAC;QAED,KAAK,MAAM,CAAC,CAAC,CAAC;YACZ,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,CAAC;YACxB,MAAM,SAAS,GAAG;gBAChB,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM;gBACnB,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC1C,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aAC7C,CAAC;YACF,oEAAoE;YACpE,oEAAoE;YACpE,0DAA0D;YAC1D,MAAM,UAAU,GAAqB,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;gBAClE,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;gBAC3B,MAAM,CAAC,GAAG,OAAO,QAAQ,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAC5E,MAAM,CAAC,GAAG,OAAO,QAAQ,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAC5E,OAAO,EAAE,GAAG,KAAK,EAAE,QAAQ,EAAE,EAAE,GAAG,QAAQ,EAAE,CAAC,EAAE,CAAC,EAAE,EAAoB,CAAC;YACzE,CAAC,CAAC,CAAC;YACH,MAAM,IAAI,GAAG,KAAK,CAAC,EAAE,GAAG,KAAK,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;YAC5E,OAAO,EAAE,GAAG,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAC9C,CAAC;IACH,CAAC;AACH,CAAC"}
@@ -1,53 +0,0 @@
1
- /**
2
- * React hook that bundles the image-editor reducer with sidecar
3
- * persistence, versioning, and an object-URL cache for asset bytes.
4
- *
5
- * Hosts pass an already-scoped {@link ContentContainer} (typically built
6
- * with `scopeContainer(parent, basename + '_files')`); the hook never
7
- * looks above that root.
8
- */
9
- import type { ContentContainer } from '@bendyline/squisq/storage';
10
- import { ImageEditVersionManager } from '@bendyline/squisq/imageEdit';
11
- import { type ImageEditorAction, type ImageEditorState } from './state.js';
12
- export interface UseImageEditorOptions {
13
- /** Sidecar container for the image being edited. */
14
- container: ContentContainer;
15
- /**
16
- * Initial source image URL — used to seed layer 0 when the sidecar has
17
- * no `state.json` yet. Bytes are fetched and copied into
18
- * `assets/source.<ext>` so the doc is portable.
19
- */
20
- initialSrc?: string;
21
- /** Override the state filename. Defaults to `state.json`. */
22
- stateFilename?: string;
23
- /** Enable version history. Default: `false`. */
24
- allowVersioning?: boolean;
25
- /** Auto-save idle delay (ms). `0` disables. Default: `5000`. */
26
- versioningAutoSaveIdleMs?: number;
27
- /** Debounced write delay for state.json (ms). Default: `500`. */
28
- persistDebounceMs?: number;
29
- }
30
- export interface UseImageEditorReturn {
31
- /** Current reducer state (or `null` while still loading the initial doc). */
32
- state: ImageEditorState | null;
33
- /** Dispatch a reducer action. No-op while loading. */
34
- dispatch: (action: ImageEditorAction) => void;
35
- /** Manually trigger a synchronous write of `state.json`. */
36
- flush: () => Promise<void>;
37
- /** Resolve an asset path inside the sidecar to a blob URL (cached). */
38
- resolveAssetUrl: (path: string) => Promise<string>;
39
- /**
40
- * Write a new asset (raster image) into `assets/` and return the
41
- * sidecar-relative path. The caller is then expected to push a layer
42
- * referencing that path.
43
- */
44
- uploadAsset: (file: Blob, suggestedName?: string) => Promise<string>;
45
- /** Versioning handle. `null` when `allowVersioning` is false or no container. */
46
- versioning: ImageEditVersionManager | null;
47
- /** True after the initial load completes (either an existing doc or seeded). */
48
- ready: boolean;
49
- /** Last load / persistence error, if any. */
50
- error: Error | null;
51
- }
52
- export declare function useImageEditor(options: UseImageEditorOptions): UseImageEditorReturn;
53
- //# sourceMappingURL=useImageEditor.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useImageEditor.d.ts","sourceRoot":"","sources":["../../src/imageEditor/useImageEditor.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAElE,OAAO,EAGL,uBAAuB,EAIxB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAGL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EACtB,MAAM,YAAY,CAAC;AAEpB,MAAM,WAAW,qBAAqB;IACpC,oDAAoD;IACpD,SAAS,EAAE,gBAAgB,CAAC;IAC5B;;;;OAIG;IACH,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,6DAA6D;IAC7D,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,gDAAgD;IAChD,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,gEAAgE;IAChE,wBAAwB,CAAC,EAAE,MAAM,CAAC;IAClC,iEAAiE;IACjE,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,oBAAoB;IACnC,6EAA6E;IAC7E,KAAK,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAC/B,sDAAsD;IACtD,QAAQ,EAAE,CAAC,MAAM,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC9C,4DAA4D;IAC5D,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,uEAAuE;IACvE,eAAe,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IACnD;;;;OAIG;IACH,WAAW,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,aAAa,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IACrE,iFAAiF;IACjF,UAAU,EAAE,uBAAuB,GAAG,IAAI,CAAC;IAC3C,gFAAgF;IAChF,KAAK,EAAE,OAAO,CAAC;IACf,6CAA6C;IAC7C,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;CACrB;AAED,wBAAgB,cAAc,CAAC,OAAO,EAAE,qBAAqB,GAAG,oBAAoB,CAyLnF"}
@@ -1,244 +0,0 @@
1
- /**
2
- * React hook that bundles the image-editor reducer with sidecar
3
- * persistence, versioning, and an object-URL cache for asset bytes.
4
- *
5
- * Hosts pass an already-scoped {@link ContentContainer} (typically built
6
- * with `scopeContainer(parent, basename + '_files')`); the hook never
7
- * looks above that root.
8
- */
9
- import { useCallback, useEffect, useMemo, useReducer, useRef, useState } from 'react';
10
- import { IMAGE_EDIT_ASSETS_PREFIX, IMAGE_EDIT_STATE_FILENAME, ImageEditVersionManager, createEmptyImageEditDoc, readImageEditDoc, writeImageEditDoc, } from '@bendyline/squisq/imageEdit';
11
- import { imageEditorReducer, initialImageEditorState, } from './state.js';
12
- export function useImageEditor(options) {
13
- const { container, initialSrc, stateFilename = IMAGE_EDIT_STATE_FILENAME, allowVersioning = false, versioningAutoSaveIdleMs = 5000, persistDebounceMs = 500, } = options;
14
- const [state, dispatch] = useReducer((s, a) => {
15
- if (s === null)
16
- return a.type === 'load' ? initialImageEditorState(a.doc) : null;
17
- return imageEditorReducer(s, a);
18
- }, null);
19
- const [ready, setReady] = useState(false);
20
- const [error, setError] = useState(null);
21
- // Set to true inside the initial-load effect when we just seeded the
22
- // sidecar (no prior `state.json`). The versioning effect below reads
23
- // this flag to write an "original" snapshot once the manager exists.
24
- const seededOnLoadRef = useRef(false);
25
- // ── Initial load (or seed from initialSrc) ────────────────────────────
26
- useEffect(() => {
27
- let cancelled = false;
28
- setReady(false);
29
- setError(null);
30
- (async () => {
31
- try {
32
- const existing = await readImageEditDoc(container, stateFilename);
33
- if (cancelled)
34
- return;
35
- if (existing) {
36
- dispatch({ type: 'load', doc: existing });
37
- setReady(true);
38
- return;
39
- }
40
- // No existing state — seed.
41
- const seeded = await seedFromSource(container, initialSrc);
42
- if (cancelled)
43
- return;
44
- await writeImageEditDoc(container, seeded, stateFilename);
45
- dispatch({ type: 'load', doc: seeded });
46
- setReady(true);
47
- // Capture an initial snapshot of the freshly-seeded state so the
48
- // version history always has an "original" entry the user can
49
- // revert to after their first edit.
50
- seededOnLoadRef.current = true;
51
- }
52
- catch (err) {
53
- if (cancelled)
54
- return;
55
- setError(err instanceof Error ? err : new Error(String(err)));
56
- setReady(true);
57
- }
58
- })();
59
- return () => {
60
- cancelled = true;
61
- };
62
- }, [container, stateFilename, initialSrc]);
63
- // ── Debounced persistence of state.json ────────────────────────────────
64
- const persistTimerRef = useRef(null);
65
- const docRef = useRef(null);
66
- docRef.current = state?.doc ?? null;
67
- useEffect(() => {
68
- if (!state?.dirty)
69
- return;
70
- if (persistTimerRef.current)
71
- clearTimeout(persistTimerRef.current);
72
- persistTimerRef.current = setTimeout(() => {
73
- const doc = docRef.current;
74
- if (!doc)
75
- return;
76
- writeImageEditDoc(container, doc, stateFilename)
77
- .then(() => dispatch({ type: 'mark-clean' }))
78
- .catch((err) => {
79
- console.warn('[squisq-editor] image-edit state persist failed:', err instanceof Error ? err.message : err);
80
- });
81
- }, persistDebounceMs);
82
- return () => {
83
- if (persistTimerRef.current)
84
- clearTimeout(persistTimerRef.current);
85
- };
86
- }, [state?.dirty, state?.doc, container, stateFilename, persistDebounceMs]);
87
- const flush = useCallback(async () => {
88
- const doc = docRef.current;
89
- if (!doc)
90
- return;
91
- if (persistTimerRef.current) {
92
- clearTimeout(persistTimerRef.current);
93
- persistTimerRef.current = null;
94
- }
95
- await writeImageEditDoc(container, doc, stateFilename);
96
- dispatch({ type: 'mark-clean' });
97
- }, [container, stateFilename]);
98
- // ── Versioning ─────────────────────────────────────────────────────────
99
- const versioning = useMemo(() => (allowVersioning ? new ImageEditVersionManager(container, { stateFilename }) : null), [allowVersioning, container, stateFilename]);
100
- // Drop the "original" snapshot once versioning is wired and we just
101
- // seeded a fresh sidecar. Guarded by `seededOnLoadRef` so we never
102
- // duplicate-snapshot on subsequent renders. Uses `force: true` so the
103
- // initial entry always lands even though no diff has occurred yet.
104
- useEffect(() => {
105
- if (!versioning)
106
- return;
107
- if (!ready)
108
- return;
109
- if (!seededOnLoadRef.current)
110
- return;
111
- seededOnLoadRef.current = false;
112
- versioning.saveVersion({ force: true }).catch((err) => {
113
- console.warn('[squisq-editor] image-edit initial snapshot failed:', err instanceof Error ? err.message : err);
114
- });
115
- }, [versioning, ready]);
116
- useEffect(() => {
117
- if (!versioning)
118
- return;
119
- if (versioningAutoSaveIdleMs <= 0)
120
- return;
121
- if (!state?.doc)
122
- return;
123
- const timer = setTimeout(() => {
124
- versioning.saveVersion({ doc: docRef.current ?? undefined }).catch((err) => {
125
- console.warn('[squisq-editor] image-edit auto-save version failed:', err instanceof Error ? err.message : err);
126
- });
127
- }, versioningAutoSaveIdleMs);
128
- return () => clearTimeout(timer);
129
- }, [versioning, versioningAutoSaveIdleMs, state?.doc]);
130
- // ── Asset URL cache ────────────────────────────────────────────────────
131
- const urlCacheRef = useRef(new Map());
132
- const resolveAssetUrl = useCallback(async (path) => {
133
- const cache = urlCacheRef.current;
134
- const cached = cache.get(path);
135
- if (cached)
136
- return cached;
137
- const data = await container.readFile(path);
138
- if (!data)
139
- throw new Error(`useImageEditor: missing asset "${path}"`);
140
- const list = await container.listFiles(path);
141
- const mime = list.find((e) => e.path === path)?.mimeType ?? 'application/octet-stream';
142
- const url = URL.createObjectURL(new Blob([data], { type: mime }));
143
- cache.set(path, url);
144
- return url;
145
- }, [container]);
146
- // Revoke all cached object URLs on unmount / container swap
147
- useEffect(() => {
148
- const cache = urlCacheRef.current;
149
- return () => {
150
- for (const url of cache.values())
151
- URL.revokeObjectURL(url);
152
- cache.clear();
153
- };
154
- }, [container]);
155
- const uploadAsset = useCallback(async (file, suggestedName) => {
156
- const ext = guessExtensionFromMime(file.type) ?? extensionFromName(suggestedName) ?? 'bin';
157
- const id = randomId();
158
- const path = `${IMAGE_EDIT_ASSETS_PREFIX}${id}.${ext}`;
159
- const buf = await file.arrayBuffer();
160
- await container.writeFile(path, buf, file.type || undefined);
161
- return path;
162
- }, [container]);
163
- return {
164
- state,
165
- dispatch,
166
- flush,
167
- resolveAssetUrl,
168
- uploadAsset,
169
- versioning,
170
- ready,
171
- error,
172
- };
173
- }
174
- // ============================================
175
- // Helpers
176
- // ============================================
177
- async function seedFromSource(container, initialSrc) {
178
- if (!initialSrc) {
179
- return createEmptyImageEditDoc(800, 600);
180
- }
181
- // Fetch the source bytes (works for blob:, data:, http(s):, and same-origin
182
- // relative URLs).
183
- const resp = await fetch(initialSrc);
184
- if (!resp.ok)
185
- throw new Error(`useImageEditor: failed to fetch initialSrc (${resp.status})`);
186
- const blob = await resp.blob();
187
- const ext = guessExtensionFromMime(blob.type) ?? 'png';
188
- const assetPath = `${IMAGE_EDIT_ASSETS_PREFIX}source.${ext}`;
189
- await container.writeFile(assetPath, await blob.arrayBuffer(), blob.type || undefined);
190
- // Probe natural dimensions by loading into an Image.
191
- const dims = await probeImageDimensions(initialSrc);
192
- const w = dims?.width ?? 800;
193
- const h = dims?.height ?? 600;
194
- const layer = {
195
- id: 'base',
196
- type: 'image',
197
- name: 'Background',
198
- position: { x: 0, y: 0, width: w, height: h },
199
- content: { src: assetPath, alt: '', fit: 'fill' },
200
- };
201
- return {
202
- version: 1,
203
- canvas: { width: w, height: h, background: 'transparent' },
204
- layers: [layer],
205
- meta: {
206
- sourcePath: assetPath,
207
- createdAt: new Date().toISOString(),
208
- updatedAt: new Date().toISOString(),
209
- },
210
- };
211
- }
212
- function probeImageDimensions(src) {
213
- return new Promise((resolve) => {
214
- const img = new Image();
215
- img.onload = () => resolve({ width: img.naturalWidth, height: img.naturalHeight });
216
- img.onerror = () => resolve(null);
217
- img.src = src;
218
- });
219
- }
220
- function guessExtensionFromMime(mime) {
221
- if (!mime)
222
- return null;
223
- if (mime.includes('png'))
224
- return 'png';
225
- if (mime.includes('jpeg') || mime.includes('jpg'))
226
- return 'jpg';
227
- if (mime.includes('webp'))
228
- return 'webp';
229
- if (mime.includes('gif'))
230
- return 'gif';
231
- if (mime.includes('svg'))
232
- return 'svg';
233
- return null;
234
- }
235
- function extensionFromName(name) {
236
- if (!name)
237
- return null;
238
- const dot = name.lastIndexOf('.');
239
- return dot >= 0 ? name.slice(dot + 1).toLowerCase() : null;
240
- }
241
- function randomId() {
242
- return Math.random().toString(36).slice(2, 10);
243
- }
244
- //# sourceMappingURL=useImageEditor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useImageEditor.js","sourceRoot":"","sources":["../../src/imageEditor/useImageEditor.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAGtF,OAAO,EACL,wBAAwB,EACxB,yBAAyB,EACzB,uBAAuB,EACvB,uBAAuB,EACvB,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACL,kBAAkB,EAClB,uBAAuB,GAGxB,MAAM,YAAY,CAAC;AA4CpB,MAAM,UAAU,cAAc,CAAC,OAA8B;IAC3D,MAAM,EACJ,SAAS,EACT,UAAU,EACV,aAAa,GAAG,yBAAyB,EACzC,eAAe,GAAG,KAAK,EACvB,wBAAwB,GAAG,IAAI,EAC/B,iBAAiB,GAAG,GAAG,GACxB,GAAG,OAAO,CAAC;IAEZ,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,UAAU,CAClC,CAAC,CAA0B,EAAE,CAAoB,EAA2B,EAAE;QAC5E,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACjF,OAAO,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAClC,CAAC,EACD,IAAI,CACL,CAAC;IACF,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC1C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IACvD,qEAAqE;IACrE,qEAAqE;IACrE,qEAAqE;IACrE,MAAM,eAAe,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEtC,yEAAyE;IACzE,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,GAAG,KAAK,CAAC;QACtB,QAAQ,CAAC,KAAK,CAAC,CAAC;QAChB,QAAQ,CAAC,IAAI,CAAC,CAAC;QAEf,CAAC,KAAK,IAAI,EAAE;YACV,IAAI,CAAC;gBACH,MAAM,QAAQ,GAAG,MAAM,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;gBAClE,IAAI,SAAS;oBAAE,OAAO;gBACtB,IAAI,QAAQ,EAAE,CAAC;oBACb,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;oBAC1C,QAAQ,CAAC,IAAI,CAAC,CAAC;oBACf,OAAO;gBACT,CAAC;gBACD,4BAA4B;gBAC5B,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;gBAC3D,IAAI,SAAS;oBAAE,OAAO;gBACtB,MAAM,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC;gBAC1D,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,CAAC;gBACxC,QAAQ,CAAC,IAAI,CAAC,CAAC;gBACf,iEAAiE;gBACjE,8DAA8D;gBAC9D,oCAAoC;gBACpC,eAAe,CAAC,OAAO,GAAG,IAAI,CAAC;YACjC,CAAC;YAAC,OAAO,GAAY,EAAE,CAAC;gBACtB,IAAI,SAAS;oBAAE,OAAO;gBACtB,QAAQ,CAAC,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBAC9D,QAAQ,CAAC,IAAI,CAAC,CAAC;YACjB,CAAC;QACH,CAAC,CAAC,EAAE,CAAC;QAEL,OAAO,GAAG,EAAE;YACV,SAAS,GAAG,IAAI,CAAC;QACnB,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,SAAS,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC,CAAC;IAE3C,0EAA0E;IAC1E,MAAM,eAAe,GAAG,MAAM,CAAuC,IAAI,CAAC,CAAC;IAC3E,MAAM,MAAM,GAAG,MAAM,CAAsB,IAAI,CAAC,CAAC;IACjD,MAAM,CAAC,OAAO,GAAG,KAAK,EAAE,GAAG,IAAI,IAAI,CAAC;IAEpC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,KAAK,EAAE,KAAK;YAAE,OAAO;QAC1B,IAAI,eAAe,CAAC,OAAO;YAAE,YAAY,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QACnE,eAAe,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;YACxC,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC;YAC3B,IAAI,CAAC,GAAG;gBAAE,OAAO;YACjB,iBAAiB,CAAC,SAAS,EAAE,GAAG,EAAE,aAAa,CAAC;iBAC7C,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;iBAC5C,KAAK,CAAC,CAAC,GAAY,EAAE,EAAE;gBACtB,OAAO,CAAC,IAAI,CACV,kDAAkD,EAClD,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CACzC,CAAC;YACJ,CAAC,CAAC,CAAC;QACP,CAAC,EAAE,iBAAiB,CAAC,CAAC;QACtB,OAAO,GAAG,EAAE;YACV,IAAI,eAAe,CAAC,OAAO;gBAAE,YAAY,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QACrE,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,aAAa,EAAE,iBAAiB,CAAC,CAAC,CAAC;IAE5E,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACnC,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC;QAC3B,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,IAAI,eAAe,CAAC,OAAO,EAAE,CAAC;YAC5B,YAAY,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;YACtC,eAAe,CAAC,OAAO,GAAG,IAAI,CAAC;QACjC,CAAC;QACD,MAAM,iBAAiB,CAAC,SAAS,EAAE,GAAG,EAAE,aAAa,CAAC,CAAC;QACvD,QAAQ,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;IACnC,CAAC,EAAE,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC,CAAC;IAE/B,0EAA0E;IAC1E,MAAM,UAAU,GAAG,OAAO,CACxB,GAAG,EAAE,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,uBAAuB,CAAC,SAAS,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAC1F,CAAC,eAAe,EAAE,SAAS,EAAE,aAAa,CAAC,CAC5C,CAAC;IAEF,oEAAoE;IACpE,mEAAmE;IACnE,sEAAsE;IACtE,mEAAmE;IACnE,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU;YAAE,OAAO;QACxB,IAAI,CAAC,KAAK;YAAE,OAAO;QACnB,IAAI,CAAC,eAAe,CAAC,OAAO;YAAE,OAAO;QACrC,eAAe,CAAC,OAAO,GAAG,KAAK,CAAC;QAChC,UAAU,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,GAAY,EAAE,EAAE;YAC7D,OAAO,CAAC,IAAI,CACV,qDAAqD,EACrD,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CACzC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC;IAExB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU;YAAE,OAAO;QACxB,IAAI,wBAAwB,IAAI,CAAC;YAAE,OAAO;QAC1C,IAAI,CAAC,KAAK,EAAE,GAAG;YAAE,OAAO;QACxB,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,UAAU,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,GAAY,EAAE,EAAE;gBAClF,OAAO,CAAC,IAAI,CACV,sDAAsD,EACtD,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CACzC,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,EAAE,wBAAwB,CAAC,CAAC;QAC7B,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC,EAAE,CAAC,UAAU,EAAE,wBAAwB,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IAEvD,0EAA0E;IAC1E,MAAM,WAAW,GAAG,MAAM,CAAsB,IAAI,GAAG,EAAE,CAAC,CAAC;IAE3D,MAAM,eAAe,GAAG,WAAW,CACjC,KAAK,EAAE,IAAY,EAAmB,EAAE;QACtC,MAAM,KAAK,GAAG,WAAW,CAAC,OAAO,CAAC;QAClC,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;QAC1B,MAAM,IAAI,GAAG,MAAM,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,IAAI;YAAE,MAAM,IAAI,KAAK,CAAC,kCAAkC,IAAI,GAAG,CAAC,CAAC;QACtE,MAAM,IAAI,GAAG,MAAM,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC7C,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,EAAE,QAAQ,IAAI,0BAA0B,CAAC;QACvF,MAAM,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAClE,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QACrB,OAAO,GAAG,CAAC;IACb,CAAC,EACD,CAAC,SAAS,CAAC,CACZ,CAAC;IAEF,4DAA4D;IAC5D,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,KAAK,GAAG,WAAW,CAAC,OAAO,CAAC;QAClC,OAAO,GAAG,EAAE;YACV,KAAK,MAAM,GAAG,IAAI,KAAK,CAAC,MAAM,EAAE;gBAAE,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;YAC3D,KAAK,CAAC,KAAK,EAAE,CAAC;QAChB,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,MAAM,WAAW,GAAG,WAAW,CAC7B,KAAK,EAAE,IAAU,EAAE,aAAsB,EAAmB,EAAE;QAC5D,MAAM,GAAG,GAAG,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,iBAAiB,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC;QAC3F,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC;QACtB,MAAM,IAAI,GAAG,GAAG,wBAAwB,GAAG,EAAE,IAAI,GAAG,EAAE,CAAC;QACvD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,SAAS,CAAC,SAAS,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,IAAI,SAAS,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC;IACd,CAAC,EACD,CAAC,SAAS,CAAC,CACZ,CAAC;IAEF,OAAO;QACL,KAAK;QACL,QAAQ;QACR,KAAK;QACL,eAAe;QACf,WAAW;QACX,UAAU;QACV,KAAK;QACL,KAAK;KACN,CAAC;AACJ,CAAC;AAED,+CAA+C;AAC/C,UAAU;AACV,+CAA+C;AAE/C,KAAK,UAAU,cAAc,CAC3B,SAA2B,EAC3B,UAA8B;IAE9B,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,OAAO,uBAAuB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAC3C,CAAC;IACD,4EAA4E;IAC5E,kBAAkB;IAClB,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,UAAU,CAAC,CAAC;IACrC,IAAI,CAAC,IAAI,CAAC,EAAE;QAAE,MAAM,IAAI,KAAK,CAAC,+CAA+C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IAC7F,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;IAC/B,MAAM,GAAG,GAAG,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC;IACvD,MAAM,SAAS,GAAG,GAAG,wBAAwB,UAAU,GAAG,EAAE,CAAC;IAC7D,MAAM,SAAS,CAAC,SAAS,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,IAAI,IAAI,SAAS,CAAC,CAAC;IAEvF,qDAAqD;IACrD,MAAM,IAAI,GAAG,MAAM,oBAAoB,CAAC,UAAU,CAAC,CAAC;IACpD,MAAM,CAAC,GAAG,IAAI,EAAE,KAAK,IAAI,GAAG,CAAC;IAC7B,MAAM,CAAC,GAAG,IAAI,EAAE,MAAM,IAAI,GAAG,CAAC;IAE9B,MAAM,KAAK,GAAmB;QAC5B,EAAE,EAAE,MAAM;QACV,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,YAAY;QAClB,QAAQ,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE;QAC7C,OAAO,EAAE,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE;KAClD,CAAC;IACF,OAAO;QACL,OAAO,EAAE,CAAC;QACV,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,UAAU,EAAE,aAAa,EAAE;QAC1D,MAAM,EAAE,CAAC,KAAK,CAAC;QACf,IAAI,EAAE;YACJ,UAAU,EAAE,SAAS;YACrB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC;KACF,CAAC;AACJ,CAAC;AAED,SAAS,oBAAoB,CAAC,GAAW;IACvC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;QACxB,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC;QACnF,GAAG,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAClC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,sBAAsB,CAAC,IAAwB;IACtD,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAC;IACvB,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IACvC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IAChE,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;QAAE,OAAO,MAAM,CAAC;IACzC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IACvC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IACvC,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAS,iBAAiB,CAAC,IAAwB;IACjD,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAC;IACvB,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAClC,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;AAC7D,CAAC;AAED,SAAS,QAAQ;IACf,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AACjD,CAAC"}
@@ -1,16 +0,0 @@
1
- /**
2
- * Derive `--squisq-image-editor-*` CSS custom properties from a Theme +
3
- * SurfaceScheme, mirroring `useJsonViewTokens` in squisq-react. Lets the
4
- * ImageEditor re-theme consistently with the rest of Squisq (light/dark
5
- * surface, theme palette, font family overrides).
6
- */
7
- import { type CSSProperties } from 'react';
8
- import { type SurfaceScheme, type Theme } from '@bendyline/squisq/schemas';
9
- export interface ImageEditorTokens {
10
- /** Inline style object to spread onto the root `.squisq-image-editor`. */
11
- style: CSSProperties;
12
- /** The effective theme (after surface application). */
13
- theme: Theme;
14
- }
15
- export declare function useImageEditorTokens(theme: Theme | undefined, surface: SurfaceScheme | 'auto' | undefined): ImageEditorTokens;
16
- //# sourceMappingURL=useImageEditorTokens.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useImageEditorTokens.d.ts","sourceRoot":"","sources":["../../src/imageEditor/useImageEditorTokens.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAW,KAAK,aAAa,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAGL,KAAK,aAAa,EAClB,KAAK,KAAK,EACX,MAAM,2BAA2B,CAAC;AAInC,MAAM,WAAW,iBAAiB;IAChC,0EAA0E;IAC1E,KAAK,EAAE,aAAa,CAAC;IACrB,uDAAuD;IACvD,KAAK,EAAE,KAAK,CAAC;CACd;AAED,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,KAAK,GAAG,SAAS,EACxB,OAAO,EAAE,aAAa,GAAG,MAAM,GAAG,SAAS,GAC1C,iBAAiB,CA0CnB"}
@@ -1,45 +0,0 @@
1
- /**
2
- * Derive `--squisq-image-editor-*` CSS custom properties from a Theme +
3
- * SurfaceScheme, mirroring `useJsonViewTokens` in squisq-react. Lets the
4
- * ImageEditor re-theme consistently with the rest of Squisq (light/dark
5
- * surface, theme palette, font family overrides).
6
- */
7
- import { useMemo } from 'react';
8
- import { applySurface, resolveFontFamily, } from '@bendyline/squisq/schemas';
9
- import { DEFAULT_THEME } from '@bendyline/squisq/doc';
10
- import { useAutoSurface } from '@bendyline/squisq-react';
11
- export function useImageEditorTokens(theme, surface) {
12
- const auto = useAutoSurface(surface === 'auto');
13
- const effectiveSurface = surface === 'auto' ? auto : (surface ?? undefined);
14
- return useMemo(() => {
15
- const baseTheme = theme ?? DEFAULT_THEME;
16
- const finalTheme = effectiveSurface ? applySurface(baseTheme, effectiveSurface) : baseTheme;
17
- const bg = finalTheme.colors.background;
18
- const text = finalTheme.colors.text;
19
- const muted = finalTheme.colors.textMuted;
20
- const accent = finalTheme.colors.primary;
21
- // Panel / control surfaces are derived by mixing toward the opposite
22
- // pole (text color), so the same recipe works for both light and dark
23
- // surfaces without conditional branches.
24
- const panelBg = `color-mix(in srgb, ${bg} 92%, ${text} 8%)`;
25
- const panelBorder = `color-mix(in srgb, ${bg} 80%, ${text} 20%)`;
26
- const controlBg = `color-mix(in srgb, ${bg} 86%, ${text} 14%)`;
27
- const controlBorder = `color-mix(in srgb, ${bg} 72%, ${text} 28%)`;
28
- const workspaceBg = `color-mix(in srgb, ${bg} 95%, ${text} 5%)`;
29
- const bodyFont = resolveFontFamily(finalTheme.typography.bodyFont, 'system-ui, -apple-system, sans-serif');
30
- const style = {
31
- ['--squisq-image-editor-bg']: bg,
32
- ['--squisq-image-editor-panel-bg']: panelBg,
33
- ['--squisq-image-editor-panel-border']: panelBorder,
34
- ['--squisq-image-editor-text']: text,
35
- ['--squisq-image-editor-text-muted']: muted,
36
- ['--squisq-image-editor-accent']: accent,
37
- ['--squisq-image-editor-control-bg']: controlBg,
38
- ['--squisq-image-editor-control-border']: controlBorder,
39
- ['--squisq-image-editor-workspace-bg']: workspaceBg,
40
- ['--squisq-image-editor-body-font']: bodyFont,
41
- };
42
- return { style, theme: finalTheme };
43
- }, [theme, effectiveSurface]);
44
- }
45
- //# sourceMappingURL=useImageEditorTokens.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useImageEditorTokens.js","sourceRoot":"","sources":["../../src/imageEditor/useImageEditorTokens.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,OAAO,EAAsB,MAAM,OAAO,CAAC;AACpD,OAAO,EACL,YAAY,EACZ,iBAAiB,GAGlB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AASzD,MAAM,UAAU,oBAAoB,CAClC,KAAwB,EACxB,OAA2C;IAE3C,MAAM,IAAI,GAAG,cAAc,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC;IAChD,MAAM,gBAAgB,GAAG,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,SAAS,CAAC,CAAC;IAE5E,OAAO,OAAO,CAAC,GAAG,EAAE;QAClB,MAAM,SAAS,GAAG,KAAK,IAAI,aAAa,CAAC;QACzC,MAAM,UAAU,GAAG,gBAAgB,CAAC,CAAC,CAAC,YAAY,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAE5F,MAAM,EAAE,GAAG,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC;QACxC,MAAM,IAAI,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC;QACpC,MAAM,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC;QAC1C,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC;QAEzC,qEAAqE;QACrE,sEAAsE;QACtE,yCAAyC;QACzC,MAAM,OAAO,GAAG,sBAAsB,EAAE,SAAS,IAAI,MAAM,CAAC;QAC5D,MAAM,WAAW,GAAG,sBAAsB,EAAE,SAAS,IAAI,OAAO,CAAC;QACjE,MAAM,SAAS,GAAG,sBAAsB,EAAE,SAAS,IAAI,OAAO,CAAC;QAC/D,MAAM,aAAa,GAAG,sBAAsB,EAAE,SAAS,IAAI,OAAO,CAAC;QACnE,MAAM,WAAW,GAAG,sBAAsB,EAAE,SAAS,IAAI,MAAM,CAAC;QAEhE,MAAM,QAAQ,GAAG,iBAAiB,CAChC,UAAU,CAAC,UAAU,CAAC,QAAQ,EAC9B,sCAAsC,CACvC,CAAC;QAEF,MAAM,KAAK,GAAkB;YAC3B,CAAC,0BAAoC,CAAC,EAAE,EAAE;YAC1C,CAAC,gCAA0C,CAAC,EAAE,OAAO;YACrD,CAAC,oCAA8C,CAAC,EAAE,WAAW;YAC7D,CAAC,4BAAsC,CAAC,EAAE,IAAI;YAC9C,CAAC,kCAA4C,CAAC,EAAE,KAAK;YACrD,CAAC,8BAAwC,CAAC,EAAE,MAAM;YAClD,CAAC,kCAA4C,CAAC,EAAE,SAAS;YACzD,CAAC,sCAAgD,CAAC,EAAE,aAAa;YACjE,CAAC,oCAA8C,CAAC,EAAE,WAAW;YAC7D,CAAC,iCAA2C,CAAC,EAAE,QAAQ;SACxD,CAAC;QAEF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;IACtC,CAAC,EAAE,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC,CAAC;AAChC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}