@bendyline/squisq-editor-react 1.5.0 → 1.5.2
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.
- package/dist/index.d.ts +1991 -90
- package/dist/index.js +17088 -82
- package/dist/index.js.map +1 -1
- package/package.json +4 -4
- package/dist/DocumentSettingsDialog.d.ts +0 -26
- package/dist/DocumentSettingsDialog.d.ts.map +0 -1
- package/dist/DocumentSettingsDialog.js +0 -115
- package/dist/DocumentSettingsDialog.js.map +0 -1
- package/dist/DropZoneOverlay.d.ts +0 -24
- package/dist/DropZoneOverlay.d.ts.map +0 -1
- package/dist/DropZoneOverlay.js +0 -53
- package/dist/DropZoneOverlay.js.map +0 -1
- package/dist/EditorContext.d.ts +0 -391
- package/dist/EditorContext.d.ts.map +0 -1
- package/dist/EditorContext.js +0 -471
- package/dist/EditorContext.js.map +0 -1
- package/dist/EditorShell.d.ts +0 -328
- package/dist/EditorShell.d.ts.map +0 -1
- package/dist/EditorShell.js +0 -290
- package/dist/EditorShell.js.map +0 -1
- package/dist/EmojiPicker.d.ts +0 -50
- package/dist/EmojiPicker.d.ts.map +0 -1
- package/dist/EmojiPicker.js +0 -182
- package/dist/EmojiPicker.js.map +0 -1
- package/dist/ImageEditor.d.ts +0 -68
- package/dist/ImageEditor.d.ts.map +0 -1
- package/dist/ImageEditor.js +0 -166
- package/dist/ImageEditor.js.map +0 -1
- package/dist/ImageNodeView.d.ts +0 -27
- package/dist/ImageNodeView.d.ts.map +0 -1
- package/dist/ImageNodeView.js +0 -215
- package/dist/ImageNodeView.js.map +0 -1
- package/dist/ImageViewer.d.ts +0 -26
- package/dist/ImageViewer.d.ts.map +0 -1
- package/dist/ImageViewer.js +0 -119
- package/dist/ImageViewer.js.map +0 -1
- package/dist/InlineIcon.d.ts +0 -17
- package/dist/InlineIcon.d.ts.map +0 -1
- package/dist/InlineIcon.js +0 -72
- package/dist/InlineIcon.js.map +0 -1
- package/dist/InlinePreviewGutter.d.ts +0 -52
- package/dist/InlinePreviewGutter.d.ts.map +0 -1
- package/dist/InlinePreviewGutter.js +0 -397
- package/dist/InlinePreviewGutter.js.map +0 -1
- package/dist/LinkDialog.d.ts +0 -43
- package/dist/LinkDialog.d.ts.map +0 -1
- package/dist/LinkDialog.js +0 -102
- package/dist/LinkDialog.js.map +0 -1
- package/dist/MediaBin.d.ts +0 -29
- package/dist/MediaBin.d.ts.map +0 -1
- package/dist/MediaBin.js +0 -166
- package/dist/MediaBin.js.map +0 -1
- package/dist/MentionExtension.d.ts +0 -22
- package/dist/MentionExtension.d.ts.map +0 -1
- package/dist/MentionExtension.js +0 -245
- package/dist/MentionExtension.js.map +0 -1
- package/dist/OutlinePanel.d.ts +0 -17
- package/dist/OutlinePanel.d.ts.map +0 -1
- package/dist/OutlinePanel.js +0 -167
- package/dist/OutlinePanel.js.map +0 -1
- package/dist/PlainHtmlPreview.d.ts +0 -50
- package/dist/PlainHtmlPreview.d.ts.map +0 -1
- package/dist/PlainHtmlPreview.js +0 -155
- package/dist/PlainHtmlPreview.js.map +0 -1
- package/dist/PreviewControls.d.ts +0 -55
- package/dist/PreviewControls.d.ts.map +0 -1
- package/dist/PreviewControls.js +0 -277
- package/dist/PreviewControls.js.map +0 -1
- package/dist/PreviewPanel.d.ts +0 -29
- package/dist/PreviewPanel.d.ts.map +0 -1
- package/dist/PreviewPanel.js +0 -94
- package/dist/PreviewPanel.js.map +0 -1
- package/dist/RawEditor.d.ts +0 -32
- package/dist/RawEditor.d.ts.map +0 -1
- package/dist/RawEditor.js +0 -440
- package/dist/RawEditor.js.map +0 -1
- package/dist/RecorderEntry.d.ts +0 -24
- package/dist/RecorderEntry.d.ts.map +0 -1
- package/dist/RecorderEntry.js +0 -139
- package/dist/RecorderEntry.js.map +0 -1
- package/dist/StatusBar.d.ts +0 -15
- package/dist/StatusBar.d.ts.map +0 -1
- package/dist/StatusBar.js +0 -24
- package/dist/StatusBar.js.map +0 -1
- package/dist/TemplateAnnotation.d.ts +0 -20
- package/dist/TemplateAnnotation.d.ts.map +0 -1
- package/dist/TemplateAnnotation.js +0 -97
- package/dist/TemplateAnnotation.js.map +0 -1
- package/dist/TemplatePicker.d.ts +0 -53
- package/dist/TemplatePicker.d.ts.map +0 -1
- package/dist/TemplatePicker.js +0 -388
- package/dist/TemplatePicker.js.map +0 -1
- package/dist/ThemeCustomizerPanel.d.ts +0 -32
- package/dist/ThemeCustomizerPanel.d.ts.map +0 -1
- package/dist/ThemeCustomizerPanel.js +0 -256
- package/dist/ThemeCustomizerPanel.js.map +0 -1
- package/dist/ThemePicker.d.ts +0 -33
- package/dist/ThemePicker.d.ts.map +0 -1
- package/dist/ThemePicker.js +0 -148
- package/dist/ThemePicker.js.map +0 -1
- package/dist/Toolbar.d.ts +0 -36
- package/dist/Toolbar.d.ts.map +0 -1
- package/dist/Toolbar.js +0 -1001
- package/dist/Toolbar.js.map +0 -1
- package/dist/Tooltip.d.ts +0 -10
- package/dist/Tooltip.d.ts.map +0 -1
- package/dist/Tooltip.js +0 -104
- package/dist/Tooltip.js.map +0 -1
- package/dist/VersionHistoryPanel.d.ts +0 -14
- package/dist/VersionHistoryPanel.d.ts.map +0 -1
- package/dist/VersionHistoryPanel.js +0 -147
- package/dist/VersionHistoryPanel.js.map +0 -1
- package/dist/ViewMenuPanel.d.ts +0 -13
- package/dist/ViewMenuPanel.d.ts.map +0 -1
- package/dist/ViewMenuPanel.js +0 -58
- package/dist/ViewMenuPanel.js.map +0 -1
- package/dist/ViewSwitcher.d.ts +0 -14
- package/dist/ViewSwitcher.d.ts.map +0 -1
- package/dist/ViewSwitcher.js +0 -26
- package/dist/ViewSwitcher.js.map +0 -1
- package/dist/WysiwygEditor.d.ts +0 -39
- package/dist/WysiwygEditor.d.ts.map +0 -1
- package/dist/WysiwygEditor.js +0 -537
- package/dist/WysiwygEditor.js.map +0 -1
- package/dist/__tests__/detectMarkdown.test.d.ts +0 -2
- package/dist/__tests__/detectMarkdown.test.d.ts.map +0 -1
- package/dist/__tests__/detectMarkdown.test.js +0 -55
- package/dist/__tests__/detectMarkdown.test.js.map +0 -1
- package/dist/__tests__/documentSettingsDialog.test.d.ts +0 -2
- package/dist/__tests__/documentSettingsDialog.test.d.ts.map +0 -1
- package/dist/__tests__/documentSettingsDialog.test.js +0 -132
- package/dist/__tests__/documentSettingsDialog.test.js.map +0 -1
- package/dist/__tests__/emojiPicker.test.d.ts +0 -2
- package/dist/__tests__/emojiPicker.test.d.ts.map +0 -1
- package/dist/__tests__/emojiPicker.test.js +0 -111
- package/dist/__tests__/emojiPicker.test.js.map +0 -1
- package/dist/__tests__/fileKind.test.d.ts +0 -2
- package/dist/__tests__/fileKind.test.d.ts.map +0 -1
- package/dist/__tests__/fileKind.test.js +0 -94
- package/dist/__tests__/fileKind.test.js.map +0 -1
- package/dist/__tests__/imageEditAffordance.test.d.ts +0 -2
- package/dist/__tests__/imageEditAffordance.test.d.ts.map +0 -1
- package/dist/__tests__/imageEditAffordance.test.js +0 -188
- package/dist/__tests__/imageEditAffordance.test.js.map +0 -1
- package/dist/__tests__/imageEditorShell.test.d.ts +0 -2
- package/dist/__tests__/imageEditorShell.test.d.ts.map +0 -1
- package/dist/__tests__/imageEditorShell.test.js +0 -52
- package/dist/__tests__/imageEditorShell.test.js.map +0 -1
- package/dist/__tests__/imageEditorState.test.d.ts +0 -3
- package/dist/__tests__/imageEditorState.test.d.ts.map +0 -1
- package/dist/__tests__/imageEditorState.test.js +0 -148
- package/dist/__tests__/imageEditorState.test.js.map +0 -1
- package/dist/__tests__/inlinePreviewGutter.test.d.ts +0 -2
- package/dist/__tests__/inlinePreviewGutter.test.d.ts.map +0 -1
- package/dist/__tests__/inlinePreviewGutter.test.js +0 -51
- package/dist/__tests__/inlinePreviewGutter.test.js.map +0 -1
- package/dist/__tests__/inlinePreviewGutterAllBlocks.test.d.ts +0 -2
- package/dist/__tests__/inlinePreviewGutterAllBlocks.test.d.ts.map +0 -1
- package/dist/__tests__/inlinePreviewGutterAllBlocks.test.js +0 -63
- package/dist/__tests__/inlinePreviewGutterAllBlocks.test.js.map +0 -1
- package/dist/__tests__/jsonEditor.test.d.ts +0 -2
- package/dist/__tests__/jsonEditor.test.d.ts.map +0 -1
- package/dist/__tests__/jsonEditor.test.js +0 -134
- package/dist/__tests__/jsonEditor.test.js.map +0 -1
- package/dist/__tests__/layersPanel.test.d.ts +0 -2
- package/dist/__tests__/layersPanel.test.d.ts.map +0 -1
- package/dist/__tests__/layersPanel.test.js +0 -84
- package/dist/__tests__/layersPanel.test.js.map +0 -1
- package/dist/__tests__/linkDialogDocPicker.test.d.ts +0 -7
- package/dist/__tests__/linkDialogDocPicker.test.d.ts.map +0 -1
- package/dist/__tests__/linkDialogDocPicker.test.js +0 -75
- package/dist/__tests__/linkDialogDocPicker.test.js.map +0 -1
- package/dist/__tests__/mediaAttachmentFlow.test.d.ts +0 -2
- package/dist/__tests__/mediaAttachmentFlow.test.d.ts.map +0 -1
- package/dist/__tests__/mediaAttachmentFlow.test.js +0 -99
- package/dist/__tests__/mediaAttachmentFlow.test.js.map +0 -1
- package/dist/__tests__/outlinePanel.test.d.ts +0 -2
- package/dist/__tests__/outlinePanel.test.d.ts.map +0 -1
- package/dist/__tests__/outlinePanel.test.js +0 -68
- package/dist/__tests__/outlinePanel.test.js.map +0 -1
- package/dist/__tests__/plainHtmlPreview.test.d.ts +0 -2
- package/dist/__tests__/plainHtmlPreview.test.d.ts.map +0 -1
- package/dist/__tests__/plainHtmlPreview.test.js +0 -87
- package/dist/__tests__/plainHtmlPreview.test.js.map +0 -1
- package/dist/__tests__/propertiesPanel.test.d.ts +0 -2
- package/dist/__tests__/propertiesPanel.test.d.ts.map +0 -1
- package/dist/__tests__/propertiesPanel.test.js +0 -64
- package/dist/__tests__/propertiesPanel.test.js.map +0 -1
- package/dist/__tests__/recorderFormats.test.d.ts +0 -2
- package/dist/__tests__/recorderFormats.test.d.ts.map +0 -1
- package/dist/__tests__/recorderFormats.test.js +0 -121
- package/dist/__tests__/recorderFormats.test.js.map +0 -1
- package/dist/__tests__/recorderTimingJson.test.d.ts +0 -2
- package/dist/__tests__/recorderTimingJson.test.d.ts.map +0 -1
- package/dist/__tests__/recorderTimingJson.test.js +0 -37
- package/dist/__tests__/recorderTimingJson.test.js.map +0 -1
- package/dist/__tests__/templateAnnotationRoundTrip.test.d.ts +0 -2
- package/dist/__tests__/templateAnnotationRoundTrip.test.d.ts.map +0 -1
- package/dist/__tests__/templateAnnotationRoundTrip.test.js +0 -31
- package/dist/__tests__/templateAnnotationRoundTrip.test.js.map +0 -1
- package/dist/__tests__/tiptapBridge.test.d.ts +0 -2
- package/dist/__tests__/tiptapBridge.test.d.ts.map +0 -1
- package/dist/__tests__/tiptapBridge.test.js +0 -303
- package/dist/__tests__/tiptapBridge.test.js.map +0 -1
- package/dist/__tests__/tiptapImageRoundTrip.test.d.ts +0 -2
- package/dist/__tests__/tiptapImageRoundTrip.test.d.ts.map +0 -1
- package/dist/__tests__/tiptapImageRoundTrip.test.js +0 -68
- package/dist/__tests__/tiptapImageRoundTrip.test.js.map +0 -1
- package/dist/__tests__/useImageEditor.test.d.ts +0 -2
- package/dist/__tests__/useImageEditor.test.d.ts.map +0 -1
- package/dist/__tests__/useImageEditor.test.js +0 -131
- package/dist/__tests__/useImageEditor.test.js.map +0 -1
- package/dist/__tests__/useMediaRecorder.test.d.ts +0 -2
- package/dist/__tests__/useMediaRecorder.test.d.ts.map +0 -1
- package/dist/__tests__/useMediaRecorder.test.js +0 -153
- package/dist/__tests__/useMediaRecorder.test.js.map +0 -1
- package/dist/__tests__/versionHistory.test.d.ts +0 -2
- package/dist/__tests__/versionHistory.test.d.ts.map +0 -1
- package/dist/__tests__/versionHistory.test.js +0 -124
- package/dist/__tests__/versionHistory.test.js.map +0 -1
- package/dist/blockSlice.d.ts +0 -24
- package/dist/blockSlice.d.ts.map +0 -1
- package/dist/blockSlice.js +0 -63
- package/dist/blockSlice.js.map +0 -1
- package/dist/buildPreviewDoc.d.ts +0 -22
- package/dist/buildPreviewDoc.d.ts.map +0 -1
- package/dist/buildPreviewDoc.js +0 -262
- package/dist/buildPreviewDoc.js.map +0 -1
- package/dist/detectMarkdown.d.ts +0 -20
- package/dist/detectMarkdown.d.ts.map +0 -1
- package/dist/detectMarkdown.js +0 -61
- package/dist/detectMarkdown.js.map +0 -1
- package/dist/emojiData.d.ts +0 -81
- package/dist/emojiData.d.ts.map +0 -1
- package/dist/emojiData.js +0 -1283
- package/dist/emojiData.js.map +0 -1
- package/dist/fileKind.d.ts +0 -34
- package/dist/fileKind.d.ts.map +0 -1
- package/dist/fileKind.js +0 -144
- package/dist/fileKind.js.map +0 -1
- package/dist/hooks/useFileDrop.d.ts +0 -41
- package/dist/hooks/useFileDrop.d.ts.map +0 -1
- package/dist/hooks/useFileDrop.js +0 -205
- package/dist/hooks/useFileDrop.js.map +0 -1
- package/dist/imageEditor/CanvasSurface.d.ts +0 -31
- package/dist/imageEditor/CanvasSurface.d.ts.map +0 -1
- package/dist/imageEditor/CanvasSurface.js +0 -264
- package/dist/imageEditor/CanvasSurface.js.map +0 -1
- package/dist/imageEditor/ImageVersionHistoryDropdown.d.ts +0 -39
- package/dist/imageEditor/ImageVersionHistoryDropdown.d.ts.map +0 -1
- package/dist/imageEditor/ImageVersionHistoryDropdown.js +0 -283
- package/dist/imageEditor/ImageVersionHistoryDropdown.js.map +0 -1
- package/dist/imageEditor/LayersPanel.d.ts +0 -14
- package/dist/imageEditor/LayersPanel.d.ts.map +0 -1
- package/dist/imageEditor/LayersPanel.js +0 -43
- package/dist/imageEditor/LayersPanel.js.map +0 -1
- package/dist/imageEditor/PropertiesPanel.d.ts +0 -14
- package/dist/imageEditor/PropertiesPanel.d.ts.map +0 -1
- package/dist/imageEditor/PropertiesPanel.js +0 -97
- package/dist/imageEditor/PropertiesPanel.js.map +0 -1
- package/dist/imageEditor/Toolbar.d.ts +0 -30
- package/dist/imageEditor/Toolbar.d.ts.map +0 -1
- package/dist/imageEditor/Toolbar.js +0 -108
- package/dist/imageEditor/Toolbar.js.map +0 -1
- package/dist/imageEditor/icons.d.ts +0 -24
- package/dist/imageEditor/icons.d.ts.map +0 -1
- package/dist/imageEditor/icons.js +0 -45
- package/dist/imageEditor/icons.js.map +0 -1
- package/dist/imageEditor/layers/EditorImageLayer.d.ts +0 -16
- package/dist/imageEditor/layers/EditorImageLayer.d.ts.map +0 -1
- package/dist/imageEditor/layers/EditorImageLayer.js +0 -37
- package/dist/imageEditor/layers/EditorImageLayer.js.map +0 -1
- package/dist/imageEditor/layers/EditorShapeLayer.d.ts +0 -15
- package/dist/imageEditor/layers/EditorShapeLayer.d.ts.map +0 -1
- package/dist/imageEditor/layers/EditorShapeLayer.js +0 -20
- package/dist/imageEditor/layers/EditorShapeLayer.js.map +0 -1
- package/dist/imageEditor/layers/EditorTextLayer.d.ts +0 -18
- package/dist/imageEditor/layers/EditorTextLayer.d.ts.map +0 -1
- package/dist/imageEditor/layers/EditorTextLayer.js +0 -13
- package/dist/imageEditor/layers/EditorTextLayer.js.map +0 -1
- package/dist/imageEditor/layers/SelectionHandles.d.ts +0 -17
- package/dist/imageEditor/layers/SelectionHandles.d.ts.map +0 -1
- package/dist/imageEditor/layers/SelectionHandles.js +0 -19
- package/dist/imageEditor/layers/SelectionHandles.js.map +0 -1
- package/dist/imageEditor/state.d.ts +0 -76
- package/dist/imageEditor/state.d.ts.map +0 -1
- package/dist/imageEditor/state.js +0 -87
- package/dist/imageEditor/state.js.map +0 -1
- package/dist/imageEditor/useImageEditor.d.ts +0 -53
- package/dist/imageEditor/useImageEditor.d.ts.map +0 -1
- package/dist/imageEditor/useImageEditor.js +0 -244
- package/dist/imageEditor/useImageEditor.js.map +0 -1
- package/dist/imageEditor/useImageEditorTokens.d.ts +0 -16
- package/dist/imageEditor/useImageEditorTokens.d.ts.map +0 -1
- package/dist/imageEditor/useImageEditorTokens.js +0 -45
- package/dist/imageEditor/useImageEditorTokens.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/jsonEditor/EmbeddedRichTextField.d.ts +0 -15
- package/dist/jsonEditor/EmbeddedRichTextField.d.ts.map +0 -1
- package/dist/jsonEditor/EmbeddedRichTextField.js +0 -74
- package/dist/jsonEditor/EmbeddedRichTextField.js.map +0 -1
- package/dist/jsonEditor/JsonEditor.d.ts +0 -36
- package/dist/jsonEditor/JsonEditor.d.ts.map +0 -1
- package/dist/jsonEditor/JsonEditor.js +0 -15
- package/dist/jsonEditor/JsonEditor.js.map +0 -1
- package/dist/jsonEditor/JsonEditorContext.d.ts +0 -28
- package/dist/jsonEditor/JsonEditorContext.d.ts.map +0 -1
- package/dist/jsonEditor/JsonEditorContext.js +0 -41
- package/dist/jsonEditor/JsonEditorContext.js.map +0 -1
- package/dist/jsonEditor/RenderNode.d.ts +0 -16
- package/dist/jsonEditor/RenderNode.d.ts.map +0 -1
- package/dist/jsonEditor/RenderNode.js +0 -32
- package/dist/jsonEditor/RenderNode.js.map +0 -1
- package/dist/jsonEditor/editors.d.ts +0 -36
- package/dist/jsonEditor/editors.d.ts.map +0 -1
- package/dist/jsonEditor/editors.js +0 -347
- package/dist/jsonEditor/editors.js.map +0 -1
- package/dist/jsonEditor/index.d.ts +0 -3
- package/dist/jsonEditor/index.d.ts.map +0 -1
- package/dist/jsonEditor/index.js +0 -2
- package/dist/jsonEditor/index.js.map +0 -1
- package/dist/jsonEditor/useJsonEditorTokens.d.ts +0 -13
- package/dist/jsonEditor/useJsonEditorTokens.d.ts.map +0 -1
- package/dist/jsonEditor/useJsonEditorTokens.js +0 -38
- package/dist/jsonEditor/useJsonEditorTokens.js.map +0 -1
- package/dist/mediaDragMime.d.ts +0 -17
- package/dist/mediaDragMime.d.ts.map +0 -1
- package/dist/mediaDragMime.js +0 -22
- package/dist/mediaDragMime.js.map +0 -1
- package/dist/recorder/RecorderButton.d.ts +0 -31
- package/dist/recorder/RecorderButton.d.ts.map +0 -1
- package/dist/recorder/RecorderButton.js +0 -24
- package/dist/recorder/RecorderButton.js.map +0 -1
- package/dist/recorder/RecorderModal.d.ts +0 -59
- package/dist/recorder/RecorderModal.d.ts.map +0 -1
- package/dist/recorder/RecorderModal.js +0 -333
- package/dist/recorder/RecorderModal.js.map +0 -1
- package/dist/recorder/RecorderPanel.d.ts +0 -25
- package/dist/recorder/RecorderPanel.d.ts.map +0 -1
- package/dist/recorder/RecorderPanel.js +0 -30
- package/dist/recorder/RecorderPanel.js.map +0 -1
- package/dist/recorder/formats.d.ts +0 -51
- package/dist/recorder/formats.d.ts.map +0 -1
- package/dist/recorder/formats.js +0 -144
- package/dist/recorder/formats.js.map +0 -1
- package/dist/recorder/hooks/useMediaRecorder.d.ts +0 -90
- package/dist/recorder/hooks/useMediaRecorder.d.ts.map +0 -1
- package/dist/recorder/hooks/useMediaRecorder.js +0 -277
- package/dist/recorder/hooks/useMediaRecorder.js.map +0 -1
- package/dist/recorder/hooks/useStreamPreview.d.ts +0 -22
- package/dist/recorder/hooks/useStreamPreview.d.ts.map +0 -1
- package/dist/recorder/hooks/useStreamPreview.js +0 -44
- package/dist/recorder/hooks/useStreamPreview.js.map +0 -1
- package/dist/recorder/sources/cameraStream.d.ts +0 -22
- package/dist/recorder/sources/cameraStream.d.ts.map +0 -1
- package/dist/recorder/sources/cameraStream.js +0 -24
- package/dist/recorder/sources/cameraStream.js.map +0 -1
- package/dist/recorder/sources/micStream.d.ts +0 -15
- package/dist/recorder/sources/micStream.d.ts.map +0 -1
- package/dist/recorder/sources/micStream.js +0 -24
- package/dist/recorder/sources/micStream.js.map +0 -1
- package/dist/recorder/sources/screenStream.d.ts +0 -53
- package/dist/recorder/sources/screenStream.d.ts.map +0 -1
- package/dist/recorder/sources/screenStream.js +0 -114
- package/dist/recorder/sources/screenStream.js.map +0 -1
- package/dist/recorder/timingJson.d.ts +0 -51
- package/dist/recorder/timingJson.d.ts.map +0 -1
- package/dist/recorder/timingJson.js +0 -42
- package/dist/recorder/timingJson.js.map +0 -1
- package/dist/tiptap/TiptapAudio.d.ts +0 -26
- package/dist/tiptap/TiptapAudio.d.ts.map +0 -1
- package/dist/tiptap/TiptapAudio.js +0 -58
- package/dist/tiptap/TiptapAudio.js.map +0 -1
- package/dist/tiptap/TiptapVideo.d.ts +0 -30
- package/dist/tiptap/TiptapVideo.d.ts.map +0 -1
- package/dist/tiptap/TiptapVideo.js +0 -66
- package/dist/tiptap/TiptapVideo.js.map +0 -1
- package/dist/tiptap/useResolvedMediaSrc.d.ts +0 -2
- package/dist/tiptap/useResolvedMediaSrc.d.ts.map +0 -1
- package/dist/tiptap/useResolvedMediaSrc.js +0 -42
- package/dist/tiptap/useResolvedMediaSrc.js.map +0 -1
- package/dist/tiptapBridge.d.ts +0 -24
- package/dist/tiptapBridge.d.ts.map +0 -1
- package/dist/tiptapBridge.js +0 -749
- package/dist/tiptapBridge.js.map +0 -1
- package/dist/useHeadingLayout.d.ts +0 -54
- package/dist/useHeadingLayout.d.ts.map +0 -1
- package/dist/useHeadingLayout.js +0 -260
- package/dist/useHeadingLayout.js.map +0 -1
- package/dist/utils/collectInlineFontAwesomeCss.d.ts +0 -21
- package/dist/utils/collectInlineFontAwesomeCss.d.ts.map +0 -1
- package/dist/utils/collectInlineFontAwesomeCss.js +0 -68
- package/dist/utils/collectInlineFontAwesomeCss.js.map +0 -1
- package/dist/utils/dropUtils.d.ts +0 -55
- package/dist/utils/dropUtils.d.ts.map +0 -1
- package/dist/utils/dropUtils.js +0 -110
- package/dist/utils/dropUtils.js.map +0 -1
- package/dist/utils/normalizeMalformedAssetUrl.d.ts +0 -15
- package/dist/utils/normalizeMalformedAssetUrl.d.ts.map +0 -1
- package/dist/utils/normalizeMalformedAssetUrl.js +0 -27
- 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":"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"}
|
|
@@ -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":"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"}
|
|
@@ -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"}
|
package/dist/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|