@witchcraft/editor 0.0.3 → 0.0.5
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/module.d.cts +2 -0
- package/dist/module.d.mts +2 -15
- package/dist/module.json +1 -1
- package/dist/module.mjs +13 -72
- package/dist/types.d.mts +12 -2
- package/package.json +228 -237
- package/src/module.ts +1 -2
- package/src/runtime/assets/handle-border-circles.svg +0 -0
- package/src/runtime/components/Editor.vue +0 -0
- package/src/runtime/pm/features/Blocks/components/ItemNodeView.vue +1 -1
- package/src/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.vue +0 -2
- package/src/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.vue +1 -3
- package/src/runtime/pm/features/Iframe/components/IframeNodeView.vue +0 -3
- package/src/runtime/pm/features/Link/components/BubbleMenuExternalLink.vue +0 -1
- package/src/runtime/pm/features/Link/components/BubbleMenuInternalLink.vue +1 -4
- package/src/runtime/pm/features/Link/components/BubbleMenuLinkActions.vue +0 -3
- package/src/runtime/pm/features/Menus/components/MarkMenuManager.vue +0 -1
- package/src/runtime/pm/schema.ts +0 -0
- package/src/runtime/pm/utils/createDropIndicator.ts +9 -3
- package/src/runtime/pm/utils/getElPropertyAsInt.ts +3 -0
- package/src/runtime/pm/utils/internal/debugSel.ts +0 -0
- package/src/runtime/pm/utils/internal/recurse.ts +0 -0
- package/dist/runtime/assets/base.css +0 -1
- package/dist/runtime/assets/handle-arrow.svg +0 -16
- package/dist/runtime/assets/handle-border-circles-single.svg +0 -44
- package/dist/runtime/assets/handle-border-circles.svg +0 -27
- package/dist/runtime/assets/handle-temp.svg +0 -1
- package/dist/runtime/assets/utils.css +0 -1
- package/dist/runtime/components/CodeBlockThemePicker.d.vue.ts +0 -12
- package/dist/runtime/components/CodeBlockThemePicker.vue +0 -123
- package/dist/runtime/components/CodeBlockThemePicker.vue.d.ts +0 -12
- package/dist/runtime/components/Commands.d.vue.ts +0 -10
- package/dist/runtime/components/Commands.vue +0 -60
- package/dist/runtime/components/Commands.vue.d.ts +0 -10
- package/dist/runtime/components/Editor.d.vue.ts +0 -40
- package/dist/runtime/components/Editor.vue +0 -208
- package/dist/runtime/components/Editor.vue.d.ts +0 -40
- package/dist/runtime/components/EditorDemoApp.d.vue.ts +0 -2
- package/dist/runtime/components/EditorDemoApp.vue +0 -104
- package/dist/runtime/components/EditorDemoApp.vue.d.ts +0 -2
- package/dist/runtime/components/EditorDemoControls.d.vue.ts +0 -12
- package/dist/runtime/components/EditorDemoControls.vue +0 -36
- package/dist/runtime/components/EditorDemoControls.vue.d.ts +0 -12
- package/dist/runtime/components/TestWrapper.d.vue.ts +0 -11
- package/dist/runtime/components/TestWrapper.vue +0 -63
- package/dist/runtime/components/TestWrapper.vue.d.ts +0 -11
- package/dist/runtime/composables/useEditor.d.ts +0 -9
- package/dist/runtime/composables/useEditor.js +0 -21
- package/dist/runtime/composables/useWindowDebugging.d.ts +0 -3
- package/dist/runtime/composables/useWindowDebugging.js +0 -16
- package/dist/runtime/demo/App.d.vue.ts +0 -2
- package/dist/runtime/demo/App.vue +0 -101
- package/dist/runtime/demo/App.vue.d.ts +0 -2
- package/dist/runtime/demo/README.md +0 -1
- package/dist/runtime/demo/main.d.ts +0 -1
- package/dist/runtime/demo/main.js +0 -4
- package/dist/runtime/demo/tailwind.css +0 -1
- package/dist/runtime/env.d.ts +0 -2
- package/dist/runtime/injectionKeys.d.ts +0 -6
- package/dist/runtime/injectionKeys.js +0 -3
- package/dist/runtime/main.lib.d.ts +0 -2
- package/dist/runtime/main.lib.js +0 -2
- package/dist/runtime/pm/commands/backspace.d.ts +0 -12
- package/dist/runtime/pm/commands/backspace.js +0 -26
- package/dist/runtime/pm/commands/changeAttrs.d.ts +0 -9
- package/dist/runtime/pm/commands/changeAttrs.js +0 -15
- package/dist/runtime/pm/commands/deleteSelection.d.ts +0 -9
- package/dist/runtime/pm/commands/deleteSelection.js +0 -8
- package/dist/runtime/pm/commands/enter.d.ts +0 -14
- package/dist/runtime/pm/commands/enter.js +0 -9
- package/dist/runtime/pm/commands/insertBreak.d.ts +0 -9
- package/dist/runtime/pm/commands/insertBreak.js +0 -22
- package/dist/runtime/pm/features/Base/Base.d.ts +0 -4
- package/dist/runtime/pm/features/Base/Base.js +0 -32
- package/dist/runtime/pm/features/Base/commands/deleteNodes.d.ts +0 -10
- package/dist/runtime/pm/features/Base/commands/deleteNodes.js +0 -29
- package/dist/runtime/pm/features/Base/commands/setCursorVisible.d.ts +0 -12
- package/dist/runtime/pm/features/Base/commands/setCursorVisible.js +0 -7
- package/dist/runtime/pm/features/Base/plugins/debugSelectionPlugin.d.ts +0 -9
- package/dist/runtime/pm/features/Base/plugins/debugSelectionPlugin.js +0 -48
- package/dist/runtime/pm/features/Base/plugins/isCursorVisiblePlugin.d.ts +0 -3
- package/dist/runtime/pm/features/Base/plugins/isCursorVisiblePlugin.js +0 -26
- package/dist/runtime/pm/features/Base/plugins/isUsingTouchPlugin.d.ts +0 -3
- package/dist/runtime/pm/features/Base/plugins/isUsingTouchPlugin.js +0 -38
- package/dist/runtime/pm/features/Base/plugins/selectingIndicator.d.ts +0 -5
- package/dist/runtime/pm/features/Base/plugins/selectingIndicator.js +0 -35
- package/dist/runtime/pm/features/Base/plugins/unfocusedSelectionIndicatorPlugin.d.ts +0 -33
- package/dist/runtime/pm/features/Base/plugins/unfocusedSelectionIndicatorPlugin.js +0 -66
- package/dist/runtime/pm/features/Base/types.d.ts +0 -3
- package/dist/runtime/pm/features/Base/types.js +0 -0
- package/dist/runtime/pm/features/BaseShortcuts/BaseShortcuts.d.ts +0 -3
- package/dist/runtime/pm/features/BaseShortcuts/BaseShortcuts.js +0 -34
- package/dist/runtime/pm/features/Blockquote/Blockquote.d.ts +0 -5
- package/dist/runtime/pm/features/Blockquote/Blockquote.js +0 -65
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteEnter.d.ts +0 -11
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteEnter.js +0 -31
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteShiftEnter.d.ts +0 -11
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteShiftEnter.js +0 -12
- package/dist/runtime/pm/features/Blocks/Blocks.d.ts +0 -2
- package/dist/runtime/pm/features/Blocks/Blocks.js +0 -2
- package/dist/runtime/pm/features/Blocks/Item.d.ts +0 -11
- package/dist/runtime/pm/features/Blocks/Item.js +0 -157
- package/dist/runtime/pm/features/Blocks/List.d.ts +0 -4
- package/dist/runtime/pm/features/Blocks/List.js +0 -59
- package/dist/runtime/pm/features/Blocks/commands/changeItemType.d.ts +0 -20
- package/dist/runtime/pm/features/Blocks/commands/changeItemType.js +0 -40
- package/dist/runtime/pm/features/Blocks/commands/changeTypeAttr.d.ts +0 -14
- package/dist/runtime/pm/features/Blocks/commands/changeTypeAttr.js +0 -28
- package/dist/runtime/pm/features/Blocks/commands/copyOrMoveItem.d.ts +0 -23
- package/dist/runtime/pm/features/Blocks/commands/copyOrMoveItem.js +0 -124
- package/dist/runtime/pm/features/Blocks/commands/deleteItem.d.ts +0 -12
- package/dist/runtime/pm/features/Blocks/commands/deleteItem.js +0 -8
- package/dist/runtime/pm/features/Blocks/commands/indentItem.d.ts +0 -12
- package/dist/runtime/pm/features/Blocks/commands/indentItem.js +0 -58
- package/dist/runtime/pm/features/Blocks/commands/itemMenuCommands.d.ts +0 -18
- package/dist/runtime/pm/features/Blocks/commands/itemMenuCommands.js +0 -40
- package/dist/runtime/pm/features/Blocks/commands/moveItem.d.ts +0 -12
- package/dist/runtime/pm/features/Blocks/commands/moveItem.js +0 -80
- package/dist/runtime/pm/features/Blocks/commands/setNode.d.ts +0 -20
- package/dist/runtime/pm/features/Blocks/commands/setNode.js +0 -87
- package/dist/runtime/pm/features/Blocks/commands/splitItem.d.ts +0 -17
- package/dist/runtime/pm/features/Blocks/commands/splitItem.js +0 -87
- package/dist/runtime/pm/features/Blocks/commands/unindentItem.d.ts +0 -12
- package/dist/runtime/pm/features/Blocks/commands/unindentItem.js +0 -42
- package/dist/runtime/pm/features/Blocks/components/DragTreeHandle.d.vue.ts +0 -0
- package/dist/runtime/pm/features/Blocks/components/DragTreeHandle.vue +0 -122
- package/dist/runtime/pm/features/Blocks/components/DragTreeHandle.vue.d.ts +0 -0
- package/dist/runtime/pm/features/Blocks/components/ItemMenu.d.vue.ts +0 -6
- package/dist/runtime/pm/features/Blocks/components/ItemMenu.vue +0 -78
- package/dist/runtime/pm/features/Blocks/components/ItemMenu.vue.d.ts +0 -6
- package/dist/runtime/pm/features/Blocks/components/ItemNodeView.d.vue.ts +0 -92
- package/dist/runtime/pm/features/Blocks/components/ItemNodeView.vue +0 -350
- package/dist/runtime/pm/features/Blocks/components/ItemNodeView.vue.d.ts +0 -92
- package/dist/runtime/pm/features/Blocks/components/defaultItemMenu.d.ts +0 -5
- package/dist/runtime/pm/features/Blocks/components/defaultItemMenu.js +0 -42
- package/dist/runtime/pm/features/Blocks/composables/useDragWithThreshold.d.ts +0 -1
- package/dist/runtime/pm/features/Blocks/composables/useDragWithThreshold.js +0 -0
- package/dist/runtime/pm/features/Blocks/composables/useHandleHeight.d.ts +0 -5
- package/dist/runtime/pm/features/Blocks/composables/useHandleHeight.js +0 -22
- package/dist/runtime/pm/features/Blocks/composables/useHasChildren.d.ts +0 -5
- package/dist/runtime/pm/features/Blocks/composables/useHasChildren.js +0 -10
- package/dist/runtime/pm/features/Blocks/composables/useNodeStates.d.ts +0 -7
- package/dist/runtime/pm/features/Blocks/composables/useNodeStates.js +0 -20
- package/dist/runtime/pm/features/Blocks/itemMenuMenuItems.d.ts +0 -20
- package/dist/runtime/pm/features/Blocks/itemMenuMenuItems.js +0 -138
- package/dist/runtime/pm/features/Blocks/plugins/ensureLastItemIsContentPlugin.d.ts +0 -11
- package/dist/runtime/pm/features/Blocks/plugins/ensureLastItemIsContentPlugin.js +0 -36
- package/dist/runtime/pm/features/Blocks/plugins/itemBlockIdPlugin.d.ts +0 -8
- package/dist/runtime/pm/features/Blocks/plugins/itemBlockIdPlugin.js +0 -30
- package/dist/runtime/pm/features/Blocks/plugins/itemHasSingularSelectionPlugin.d.ts +0 -3
- package/dist/runtime/pm/features/Blocks/plugins/itemHasSingularSelectionPlugin.js +0 -30
- package/dist/runtime/pm/features/Blocks/plugins/itemMenuPlugin.d.ts +0 -4
- package/dist/runtime/pm/features/Blocks/plugins/itemMenuPlugin.js +0 -17
- package/dist/runtime/pm/features/Blocks/states/stateful.d.ts +0 -2
- package/dist/runtime/pm/features/Blocks/states/stateful.js +0 -37
- package/dist/runtime/pm/features/Blocks/states/task/cancelled.svg +0 -32
- package/dist/runtime/pm/features/Blocks/states/task/checked.svg +0 -27
- package/dist/runtime/pm/features/Blocks/states/task/checked2.svg +0 -24
- package/dist/runtime/pm/features/Blocks/states/task/partial.svg +0 -24
- package/dist/runtime/pm/features/Blocks/states/task/partial2.svg +0 -31
- package/dist/runtime/pm/features/Blocks/states/task/unchecked.svg +0 -20
- package/dist/runtime/pm/features/Blocks/types.d.ts +0 -43
- package/dist/runtime/pm/features/Blocks/types.js +0 -2
- package/dist/runtime/pm/features/Blocks/utils/createItemMenuCommandExecuter.d.ts +0 -3
- package/dist/runtime/pm/features/Blocks/utils/createItemMenuCommandExecuter.js +0 -24
- package/dist/runtime/pm/features/Blocks/utils/fixBlockIds.d.ts +0 -4
- package/dist/runtime/pm/features/Blocks/utils/fixBlockIds.js +0 -23
- package/dist/runtime/pm/features/Blocks/utils/isValidId.d.ts +0 -2
- package/dist/runtime/pm/features/Blocks/utils/isValidId.js +0 -7
- package/dist/runtime/pm/features/CodeBlock/CodeBlock.d.ts +0 -16
- package/dist/runtime/pm/features/CodeBlock/CodeBlock.js +0 -91
- package/dist/runtime/pm/features/CodeBlock/build/generateHighlightJsInfo.d.ts +0 -1
- package/dist/runtime/pm/features/CodeBlock/build/generateHighlightJsInfo.js +0 -63
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockEnterOrSplit.d.ts +0 -9
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockEnterOrSplit.js +0 -28
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockIndent.d.ts +0 -9
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockIndent.js +0 -39
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockUnindent.d.ts +0 -9
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockUnindent.js +0 -50
- package/dist/runtime/pm/features/CodeBlock/commands/focusCodeBlockLanguage.d.ts +0 -9
- package/dist/runtime/pm/features/CodeBlock/commands/focusCodeBlockLanguage.js +0 -27
- package/dist/runtime/pm/features/CodeBlock/components/CodeBlockView.d.vue.ts +0 -92
- package/dist/runtime/pm/features/CodeBlock/components/CodeBlockView.vue +0 -112
- package/dist/runtime/pm/features/CodeBlock/components/CodeBlockView.vue.d.ts +0 -92
- package/dist/runtime/pm/features/CodeBlock/composables/useAsyncCodeBlockHighlighting.d.ts +0 -28
- package/dist/runtime/pm/features/CodeBlock/composables/useAsyncCodeBlockHighlighting.js +0 -137
- package/dist/runtime/pm/features/CodeBlock/composables/useHighlightJsTheme.d.ts +0 -37
- package/dist/runtime/pm/features/CodeBlock/composables/useHighlightJsTheme.js +0 -101
- package/dist/runtime/pm/features/CodeBlock/highlightJsInfo.d.ts +0 -17
- package/dist/runtime/pm/features/CodeBlock/highlightJsInfo.js +0 -711
- package/dist/runtime/pm/features/CodeBlock/types.d.ts +0 -4
- package/dist/runtime/pm/features/CodeBlock/types.js +0 -2
- package/dist/runtime/pm/features/Collaboration/Collaboration.d.ts +0 -66
- package/dist/runtime/pm/features/Collaboration/Collaboration.js +0 -169
- package/dist/runtime/pm/features/CommandsMenus/CommandBar.d.ts +0 -19
- package/dist/runtime/pm/features/CommandsMenus/CommandBar.js +0 -97
- package/dist/runtime/pm/features/CommandsMenus/commandBarMenuItems.d.ts +0 -20
- package/dist/runtime/pm/features/CommandsMenus/commandBarMenuItems.js +0 -188
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBar.d.vue.ts +0 -8
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBar.vue +0 -58
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBar.vue.d.ts +0 -8
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBarItem.d.vue.ts +0 -12
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBarItem.vue +0 -42
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBarItem.vue.d.ts +0 -12
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuGroup.d.vue.ts +0 -10
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuGroup.vue +0 -55
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuGroup.vue.d.ts +0 -10
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuItem.d.vue.ts +0 -11
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuItem.vue +0 -58
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuItem.vue.d.ts +0 -11
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuList.d.vue.ts +0 -11
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuList.vue +0 -54
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuList.vue.d.ts +0 -11
- package/dist/runtime/pm/features/CommandsMenus/components/TextIcon.d.vue.ts +0 -5
- package/dist/runtime/pm/features/CommandsMenus/components/TextIcon.vue +0 -13
- package/dist/runtime/pm/features/CommandsMenus/components/TextIcon.vue.d.ts +0 -5
- package/dist/runtime/pm/features/CommandsMenus/icons/HighlightIcon.d.vue.ts +0 -8
- package/dist/runtime/pm/features/CommandsMenus/icons/HighlightIcon.vue +0 -45
- package/dist/runtime/pm/features/CommandsMenus/icons/HighlightIcon.vue.d.ts +0 -8
- package/dist/runtime/pm/features/CommandsMenus/icons/SubscriptIcon.d.vue.ts +0 -2
- package/dist/runtime/pm/features/CommandsMenus/icons/SubscriptIcon.vue +0 -5
- package/dist/runtime/pm/features/CommandsMenus/icons/SubscriptIcon.vue.d.ts +0 -2
- package/dist/runtime/pm/features/CommandsMenus/icons/SuperscriptIcon.d.vue.ts +0 -2
- package/dist/runtime/pm/features/CommandsMenus/icons/SuperscriptIcon.vue +0 -5
- package/dist/runtime/pm/features/CommandsMenus/icons/SuperscriptIcon.vue.d.ts +0 -2
- package/dist/runtime/pm/features/CommandsMenus/types.d.ts +0 -61
- package/dist/runtime/pm/features/CommandsMenus/types.js +0 -5
- package/dist/runtime/pm/features/CommandsMenus/utils/defaultCommandExecutor.d.ts +0 -3
- package/dist/runtime/pm/features/CommandsMenus/utils/defaultCommandExecutor.js +0 -11
- package/dist/runtime/pm/features/CommandsMenus/utils/findCommand.d.ts +0 -10
- package/dist/runtime/pm/features/CommandsMenus/utils/findCommand.js +0 -16
- package/dist/runtime/pm/features/CommandsMenus/utils/popupPositionModifier.d.ts +0 -5
- package/dist/runtime/pm/features/CommandsMenus/utils/popupPositionModifier.js +0 -9
- package/dist/runtime/pm/features/CommandsMenus/utils/popupVerticalPositioner.d.ts +0 -5
- package/dist/runtime/pm/features/CommandsMenus/utils/popupVerticalPositioner.js +0 -11
- package/dist/runtime/pm/features/Document/Document.d.ts +0 -3
- package/dist/runtime/pm/features/Document/Document.js +0 -6
- package/dist/runtime/pm/features/DocumentApi/DocumentApi.d.ts +0 -86
- package/dist/runtime/pm/features/DocumentApi/DocumentApi.js +0 -170
- package/dist/runtime/pm/features/DocumentApi/composables/useEditorContent.d.ts +0 -13
- package/dist/runtime/pm/features/DocumentApi/composables/useEditorContent.js +0 -76
- package/dist/runtime/pm/features/DocumentApi/composables/useTestDocumentApi.d.ts +0 -23
- package/dist/runtime/pm/features/DocumentApi/composables/useTestDocumentApi.js +0 -70
- package/dist/runtime/pm/features/DocumentApi/types.d.ts +0 -133
- package/dist/runtime/pm/features/DocumentApi/types.js +0 -1
- package/dist/runtime/pm/features/DocumentApi/utils/convertFullTransactionForPartialState.d.ts +0 -3
- package/dist/runtime/pm/features/DocumentApi/utils/convertFullTransactionForPartialState.js +0 -37
- package/dist/runtime/pm/features/DocumentApi/utils/convertTrForInstance.d.ts +0 -4
- package/dist/runtime/pm/features/DocumentApi/utils/convertTrForInstance.js +0 -13
- package/dist/runtime/pm/features/DocumentApi/utils/convertTransactionForFullState.d.ts +0 -2
- package/dist/runtime/pm/features/DocumentApi/utils/convertTransactionForFullState.js +0 -22
- package/dist/runtime/pm/features/DocumentApi/utils/copyMeta.d.ts +0 -2
- package/dist/runtime/pm/features/DocumentApi/utils/copyMeta.js +0 -6
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedJson.d.ts +0 -1
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedJson.js +0 -14
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedNodeFromDoc.d.ts +0 -1
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedNodeFromDoc.js +0 -14
- package/dist/runtime/pm/features/DocumentApi/utils/getStateEmbedRange.d.ts +0 -9
- package/dist/runtime/pm/features/DocumentApi/utils/getStateEmbedRange.js +0 -19
- package/dist/runtime/pm/features/DocumentApi/utils/isEmbedId.d.ts +0 -2
- package/dist/runtime/pm/features/DocumentApi/utils/isEmbedId.js +0 -3
- package/dist/runtime/pm/features/EmbeddedDocument/Embedded.d.ts +0 -24
- package/dist/runtime/pm/features/EmbeddedDocument/Embedded.js +0 -73
- package/dist/runtime/pm/features/EmbeddedDocument/EmbeddedDocument.d.ts +0 -23
- package/dist/runtime/pm/features/EmbeddedDocument/EmbeddedDocument.js +0 -70
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.d.vue.ts +0 -14
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.vue +0 -171
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.vue.d.ts +0 -14
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.d.vue.ts +0 -92
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.vue +0 -172
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.vue.d.ts +0 -92
- package/dist/runtime/pm/features/EmbeddedDocument/composables/useEmbeddedEditor.d.ts +0 -31
- package/dist/runtime/pm/features/EmbeddedDocument/composables/useEmbeddedEditor.js +0 -199
- package/dist/runtime/pm/features/EmbeddedDocument/types.d.ts +0 -49
- package/dist/runtime/pm/features/EmbeddedDocument/types.js +0 -6
- package/dist/runtime/pm/features/EmbeddedDocument/utils/isEmbeddedBlock.d.ts +0 -9
- package/dist/runtime/pm/features/EmbeddedDocument/utils/isEmbeddedBlock.js +0 -3
- package/dist/runtime/pm/features/EmbeddedDocument/utils/redirectFromEmbedded.d.ts +0 -28
- package/dist/runtime/pm/features/EmbeddedDocument/utils/redirectFromEmbedded.js +0 -17
- package/dist/runtime/pm/features/FileLoader/FileLoader.d.ts +0 -16
- package/dist/runtime/pm/features/FileLoader/FileLoader.js +0 -99
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/FileLoaderHandler.d.ts +0 -28
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/FileLoaderHandler.js +0 -69
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/TestFileLoaderHandler.d.ts +0 -11
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/TestFileLoaderHandler.js +0 -49
- package/dist/runtime/pm/features/FileLoader/commands/insertFile.d.ts +0 -17
- package/dist/runtime/pm/features/FileLoader/commands/insertFile.js +0 -39
- package/dist/runtime/pm/features/FileLoader/components/FileLoaderNodeView.d.vue.ts +0 -92
- package/dist/runtime/pm/features/FileLoader/components/FileLoaderNodeView.vue +0 -38
- package/dist/runtime/pm/features/FileLoader/components/FileLoaderNodeView.vue.d.ts +0 -92
- package/dist/runtime/pm/features/FileLoader/plugins/fileLoaderPlugin.d.ts +0 -5
- package/dist/runtime/pm/features/FileLoader/plugins/fileLoaderPlugin.js +0 -61
- package/dist/runtime/pm/features/FileLoader/types.d.ts +0 -73
- package/dist/runtime/pm/features/FileLoader/types.js +0 -0
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNode.d.ts +0 -4
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNode.js +0 -27
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNodes.d.ts +0 -9
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNodes.js +0 -22
- package/dist/runtime/pm/features/FileLoader/utils/findLoadingNodePos.d.ts +0 -2
- package/dist/runtime/pm/features/FileLoader/utils/findLoadingNodePos.js +0 -11
- package/dist/runtime/pm/features/FileLoader/utils/optionsCheck.d.ts +0 -3
- package/dist/runtime/pm/features/FileLoader/utils/optionsCheck.js +0 -8
- package/dist/runtime/pm/features/FileLoader/utils/readAsDataUrl.d.ts +0 -1
- package/dist/runtime/pm/features/FileLoader/utils/readAsDataUrl.js +0 -12
- package/dist/runtime/pm/features/HardBreak/HardBreak.d.ts +0 -5
- package/dist/runtime/pm/features/HardBreak/HardBreak.js +0 -14
- package/dist/runtime/pm/features/Heading/Heading.d.ts +0 -24
- package/dist/runtime/pm/features/Heading/Heading.js +0 -85
- package/dist/runtime/pm/features/Heading/commands/changeLevelAttr.d.ts +0 -16
- package/dist/runtime/pm/features/Heading/commands/changeLevelAttr.js +0 -33
- package/dist/runtime/pm/features/Heading/types.d.ts +0 -14
- package/dist/runtime/pm/features/Heading/types.js +0 -0
- package/dist/runtime/pm/features/Highlight/Highlight.d.ts +0 -72
- package/dist/runtime/pm/features/Highlight/Highlight.js +0 -163
- package/dist/runtime/pm/features/Highlight/retyped/tiptapHighlight.d.ts +0 -3
- package/dist/runtime/pm/features/Highlight/retyped/tiptapHighlight.js +0 -5
- package/dist/runtime/pm/features/Highlight/types.d.ts +0 -27
- package/dist/runtime/pm/features/Highlight/types.js +0 -2
- package/dist/runtime/pm/features/History/History.d.ts +0 -35
- package/dist/runtime/pm/features/History/History.js +0 -63
- package/dist/runtime/pm/features/Iframe/Iframe.d.ts +0 -21
- package/dist/runtime/pm/features/Iframe/Iframe.js +0 -127
- package/dist/runtime/pm/features/Iframe/IframeParsers.d.ts +0 -37
- package/dist/runtime/pm/features/Iframe/IframeParsers.js +0 -88
- package/dist/runtime/pm/features/Iframe/components/IframeNodeView.d.vue.ts +0 -92
- package/dist/runtime/pm/features/Iframe/components/IframeNodeView.vue +0 -82
- package/dist/runtime/pm/features/Iframe/components/IframeNodeView.vue.d.ts +0 -92
- package/dist/runtime/pm/features/Iframe/types.d.ts +0 -5
- package/dist/runtime/pm/features/Iframe/types.js +0 -0
- package/dist/runtime/pm/features/Image/Image.d.ts +0 -2
- package/dist/runtime/pm/features/Image/Image.js +0 -13
- package/dist/runtime/pm/features/Link/Link.d.ts +0 -38
- package/dist/runtime/pm/features/Link/Link.js +0 -241
- package/dist/runtime/pm/features/Link/components/BubbleMenuExternalLink.d.vue.ts +0 -28
- package/dist/runtime/pm/features/Link/components/BubbleMenuExternalLink.vue +0 -114
- package/dist/runtime/pm/features/Link/components/BubbleMenuExternalLink.vue.d.ts +0 -28
- package/dist/runtime/pm/features/Link/components/BubbleMenuInternalLink.d.vue.ts +0 -29
- package/dist/runtime/pm/features/Link/components/BubbleMenuInternalLink.vue +0 -107
- package/dist/runtime/pm/features/Link/components/BubbleMenuInternalLink.vue.d.ts +0 -29
- package/dist/runtime/pm/features/Link/components/BubbleMenuLink.d.vue.ts +0 -11
- package/dist/runtime/pm/features/Link/components/BubbleMenuLink.vue +0 -126
- package/dist/runtime/pm/features/Link/components/BubbleMenuLink.vue.d.ts +0 -11
- package/dist/runtime/pm/features/Link/components/BubbleMenuLinkActions.d.vue.ts +0 -18
- package/dist/runtime/pm/features/Link/components/BubbleMenuLinkActions.vue +0 -57
- package/dist/runtime/pm/features/Link/components/BubbleMenuLinkActions.vue.d.ts +0 -18
- package/dist/runtime/pm/features/Link/types.d.ts +0 -44
- package/dist/runtime/pm/features/Link/types.js +0 -3
- package/dist/runtime/pm/features/Menus/Menus.d.ts +0 -45
- package/dist/runtime/pm/features/Menus/Menus.js +0 -142
- package/dist/runtime/pm/features/Menus/components/MarkMenuManager.d.vue.ts +0 -6
- package/dist/runtime/pm/features/Menus/components/MarkMenuManager.vue +0 -166
- package/dist/runtime/pm/features/Menus/components/MarkMenuManager.vue.d.ts +0 -6
- package/dist/runtime/pm/features/Menus/types.d.ts +0 -51
- package/dist/runtime/pm/features/Menus/types.js +0 -3
- package/dist/runtime/pm/features/Menus/utils/isMarkMenu.d.ts +0 -2
- package/dist/runtime/pm/features/Menus/utils/isMarkMenu.js +0 -3
- package/dist/runtime/pm/features/Tables/commands/tableEnter.d.ts +0 -15
- package/dist/runtime/pm/features/Tables/commands/tableEnter.js +0 -19
- package/dist/runtime/pm/features/Tables/index.d.ts +0 -9
- package/dist/runtime/pm/features/Tables/index.js +0 -44
- package/dist/runtime/pm/schema.d.ts +0 -4
- package/dist/runtime/pm/schema.js +0 -80
- package/dist/runtime/pm/testSchema.d.ts +0 -5
- package/dist/runtime/pm/testSchema.js +0 -30
- package/dist/runtime/pm/utils/createDropIndicator.d.ts +0 -23
- package/dist/runtime/pm/utils/createDropIndicator.js +0 -32
- package/dist/runtime/pm/utils/createStateOnlyPluginApply.d.ts +0 -2
- package/dist/runtime/pm/utils/createStateOnlyPluginApply.js +0 -9
- package/dist/runtime/pm/utils/createStateOnlyPluginObjApply.d.ts +0 -2
- package/dist/runtime/pm/utils/createStateOnlyPluginObjApply.js +0 -14
- package/dist/runtime/pm/utils/dropPointInfo.d.ts +0 -56
- package/dist/runtime/pm/utils/dropPointInfo.js +0 -28
- package/dist/runtime/pm/utils/findUpwards.d.ts +0 -20
- package/dist/runtime/pm/utils/findUpwards.js +0 -18
- package/dist/runtime/pm/utils/getChildChunks.d.ts +0 -3
- package/dist/runtime/pm/utils/getChildChunks.js +0 -15
- package/dist/runtime/pm/utils/getDiffReplacementRange.d.ts +0 -20
- package/dist/runtime/pm/utils/getDiffReplacementRange.js +0 -9
- package/dist/runtime/pm/utils/getElMaxVisualSize.d.ts +0 -9
- package/dist/runtime/pm/utils/getElMaxVisualSize.js +0 -7
- package/dist/runtime/pm/utils/getElPropertyAsInt.d.ts +0 -1
- package/dist/runtime/pm/utils/getElPropertyAsInt.js +0 -8
- package/dist/runtime/pm/utils/getGroupNodeNames.d.ts +0 -2
- package/dist/runtime/pm/utils/getGroupNodeNames.js +0 -7
- package/dist/runtime/pm/utils/getMarkPosition.d.ts +0 -11
- package/dist/runtime/pm/utils/getMarkPosition.js +0 -34
- package/dist/runtime/pm/utils/getMarksInSelection.d.ts +0 -3
- package/dist/runtime/pm/utils/getMarksInSelection.js +0 -16
- package/dist/runtime/pm/utils/getTypeByName.d.ts +0 -2
- package/dist/runtime/pm/utils/getTypeByName.js +0 -5
- package/dist/runtime/pm/utils/index.d.ts +0 -15
- package/dist/runtime/pm/utils/index.js +0 -15
- package/dist/runtime/pm/utils/internal/createNodeTypesList.d.ts +0 -2
- package/dist/runtime/pm/utils/internal/createNodeTypesList.js +0 -17
- package/dist/runtime/pm/utils/internal/debugMap.d.ts +0 -7
- package/dist/runtime/pm/utils/internal/debugMap.js +0 -24
- package/dist/runtime/pm/utils/internal/debugNode.d.ts +0 -2
- package/dist/runtime/pm/utils/internal/debugNode.js +0 -18
- package/dist/runtime/pm/utils/internal/debugSel.d.ts +0 -5
- package/dist/runtime/pm/utils/internal/debugSel.js +0 -8
- package/dist/runtime/pm/utils/internal/recurse.d.ts +0 -2
- package/dist/runtime/pm/utils/internal/recurse.js +0 -39
- package/dist/runtime/pm/utils/internal/stripBlockId.d.ts +0 -2
- package/dist/runtime/pm/utils/internal/stripBlockId.js +0 -9
- package/dist/runtime/pm/utils/mapSelection.d.ts +0 -8
- package/dist/runtime/pm/utils/mapSelection.js +0 -12
- package/dist/runtime/pm/utils/nodesBetween.d.ts +0 -21
- package/dist/runtime/pm/utils/nodesBetween.js +0 -21
- package/dist/runtime/pm/utils/pointToPmPoint.d.ts +0 -2
- package/dist/runtime/pm/utils/pointToPmPoint.js +0 -3
- package/dist/runtime/pm/utils/splitIntoChunks.d.ts +0 -32
- package/dist/runtime/pm/utils/splitIntoChunks.js +0 -31
- package/dist/runtime/testDocuments.d.ts +0 -53
- package/dist/runtime/testDocuments.js +0 -122
- package/dist/runtime/types/index.d.ts +0 -53
- package/dist/runtime/types/index.js +0 -9
|
@@ -1,208 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div
|
|
3
|
-
:class="twMerge(
|
|
4
|
-
`
|
|
5
|
-
editor-wrapper
|
|
6
|
-
[counter-reset:none]
|
|
7
|
-
flex-1
|
|
8
|
-
w-full
|
|
9
|
-
`,
|
|
10
|
-
isEmbedded && `p-1`,
|
|
11
|
-
isScrolling && `
|
|
12
|
-
relative
|
|
13
|
-
after:content-['']
|
|
14
|
-
after:absolute
|
|
15
|
-
after:inset-0
|
|
16
|
-
after:border-[length:var(--pmDragScrollMargin)]
|
|
17
|
-
after:border-transparent
|
|
18
|
-
after:pointer-events-none
|
|
19
|
-
`,
|
|
20
|
-
scrollIndicator.right && `after:border-r-accent-500/60`,
|
|
21
|
-
scrollIndicator.down && `after:border-b-accent-500/60`,
|
|
22
|
-
scrollIndicator.left && `after:border-l-accent-500/60`,
|
|
23
|
-
scrollIndicator.up && `after:border-t-accent-500/60`
|
|
24
|
-
)"
|
|
25
|
-
:data-code-blocks-theme-is-dark="codeBlocksThemeIsDark"
|
|
26
|
-
:style="`${cssVariablesString}`"
|
|
27
|
-
v-bind="$attrs"
|
|
28
|
-
>
|
|
29
|
-
<!-- The class `is-embedded-block` is not needed internally, but is added for consistency in case it might be useful. -->
|
|
30
|
-
<!-- @vue-expect-error -->
|
|
31
|
-
<editor-content
|
|
32
|
-
:editor="editor"
|
|
33
|
-
spellcheck="false"
|
|
34
|
-
:class="twMerge(
|
|
35
|
-
`
|
|
36
|
-
w-full flex-1
|
|
37
|
-
p-2
|
|
38
|
-
pl-6
|
|
39
|
-
[&>.ProseMirror]:outline-hidden
|
|
40
|
-
overflow-auto
|
|
41
|
-
`,
|
|
42
|
-
isEmbedded && `editor-is-embedded`,
|
|
43
|
-
isEmbeddedBlock && `editor-is-embedded-block`
|
|
44
|
-
)"
|
|
45
|
-
v-extract-root-el="(el) => editorContainerEl = el"
|
|
46
|
-
/>
|
|
47
|
-
<MarkMenuManager
|
|
48
|
-
v-if="editor && !finalEditorOptions?.editable"
|
|
49
|
-
:editor="editor"
|
|
50
|
-
/>
|
|
51
|
-
<ItemMenu
|
|
52
|
-
v-if="editor"
|
|
53
|
-
:editor="editor"
|
|
54
|
-
/>
|
|
55
|
-
</div>
|
|
56
|
-
</template>
|
|
57
|
-
|
|
58
|
-
<script setup>
|
|
59
|
-
import { keys } from "@alanscodelog/utils";
|
|
60
|
-
import { EditorContent } from "@tiptap/vue-3";
|
|
61
|
-
import { useScrollNearContainerEdges } from "@witchcraft/ui/composables/useScrollNearContainerEdges";
|
|
62
|
-
import { vExtractRootEl } from "@witchcraft/ui/directives/vExtractRootEl";
|
|
63
|
-
import { twMerge } from "@witchcraft/ui/utils/twMerge";
|
|
64
|
-
import { computed, inject, provide, ref, toRef, toRefs, watch } from "vue";
|
|
65
|
-
import handleCollapseIndicatorImage from "../assets/handle-arrow.svg";
|
|
66
|
-
import handleImage from "../assets/handle-border-circles-single.svg";
|
|
67
|
-
import { useEditor } from "../composables/useEditor.js";
|
|
68
|
-
import { useWindowDebugging } from "../composables/useWindowDebugging.js";
|
|
69
|
-
import { editorCssVariablesInjectionKey, editorScrollInjectionKey } from "../injectionKeys.js";
|
|
70
|
-
import ItemMenu from "../pm/features/Blocks/components/ItemMenu.vue";
|
|
71
|
-
import { statefulStates } from "../pm/features/Blocks/states/stateful.js";
|
|
72
|
-
import { statesInjectionKey } from "../pm/features/Blocks/types";
|
|
73
|
-
import { lowlightInstance } from "../pm/features/CodeBlock/CodeBlock.js";
|
|
74
|
-
import { useAsyncCodeBlockHighlighting } from "../pm/features/CodeBlock/composables/useAsyncCodeBlockHighlighting";
|
|
75
|
-
import { codeBlockThemeIsDarkInjectionKey } from "../pm/features/CodeBlock/types";
|
|
76
|
-
import { useEditorContent } from "../pm/features/DocumentApi/composables/useEditorContent";
|
|
77
|
-
import { documentApiInjectionKey } from "../pm/features/DocumentApi/types.js";
|
|
78
|
-
import { embededEditorOptionsInjectionKey, isEmbeddedBlockInjectionKey, isEmbeddedInjectionKey, parentEditorIdInjectionKey } from "../pm/features/EmbeddedDocument/types";
|
|
79
|
-
import MarkMenuManager from "../pm/features/Menus/components/MarkMenuManager.vue";
|
|
80
|
-
import { extensions } from "../pm/schema.js";
|
|
81
|
-
import { menusInjectionKey } from "../types/index.js";
|
|
82
|
-
const props = defineProps({
|
|
83
|
-
content: { type: null, required: false, default: void 0 },
|
|
84
|
-
docId: { type: String, required: false, default: void 0 },
|
|
85
|
-
documentApi: { type: null, required: false, default: void 0 },
|
|
86
|
-
linkOptions: { type: Object, required: false, default: void 0 },
|
|
87
|
-
dragScrollOptions: { type: Object, required: false, default: () => ({
|
|
88
|
-
scrollMargin: 15,
|
|
89
|
-
outerScrollMargin: 15,
|
|
90
|
-
fastPixelMultiplier: 8
|
|
91
|
-
}) },
|
|
92
|
-
cssVariables: { type: Object, required: false, default: () => ({}) },
|
|
93
|
-
editorOptions: { type: Object, required: false, default: () => ({
|
|
94
|
-
// todo user configurable
|
|
95
|
-
enablePasteRules: true,
|
|
96
|
-
enableInputRules: true
|
|
97
|
-
}) },
|
|
98
|
-
codeBlocksThemeIsDark: { type: Boolean, required: false, default: false },
|
|
99
|
-
menus: { type: Object, required: false, default: () => ({}) }
|
|
100
|
-
});
|
|
101
|
-
const editorContainerEl = ref(null);
|
|
102
|
-
const scroll = useScrollNearContainerEdges({
|
|
103
|
-
containerEl: editorContainerEl,
|
|
104
|
-
...props.dragScrollOptions
|
|
105
|
-
});
|
|
106
|
-
const {
|
|
107
|
-
isScrolling,
|
|
108
|
-
scrollIndicator
|
|
109
|
-
} = scroll;
|
|
110
|
-
provide(editorScrollInjectionKey, scroll);
|
|
111
|
-
const isEmbedded = inject(isEmbeddedInjectionKey, false);
|
|
112
|
-
const isEmbeddedBlock = inject(isEmbeddedBlockInjectionKey, ref(false));
|
|
113
|
-
const cssVariables = computed(() => isEmbedded ? {} : {
|
|
114
|
-
pmUnfocusedSelectionColor: "rgb(129,163,234)",
|
|
115
|
-
pmNodeTypeMargin: "var(--dragHandleMargin)",
|
|
116
|
-
pmCodeBlockBgColor: "",
|
|
117
|
-
pmMaxEmbedWidth: "800px",
|
|
118
|
-
pmDragScrollMargin: `${props.dragScrollOptions.scrollMargin}px`,
|
|
119
|
-
dragHandleSize: "9px",
|
|
120
|
-
dragHandleMargin: "5px",
|
|
121
|
-
dragHandleImage: `url("${handleImage}")`,
|
|
122
|
-
dragHandleCollapseIndicatorImage: `url("${handleCollapseIndicatorImage}")`,
|
|
123
|
-
...props.cssVariables
|
|
124
|
-
});
|
|
125
|
-
const cssVariablesString = computed(() => keys(cssVariables.value).map((key) => `--${key}: ${cssVariables.value[key]};`).join(""));
|
|
126
|
-
const menus = toRef(props, "menus");
|
|
127
|
-
const alreadyProvidedDocumentApi = inject(documentApiInjectionKey, void 0);
|
|
128
|
-
if (!isEmbedded) {
|
|
129
|
-
const statefulStatesRef = ref(statefulStates);
|
|
130
|
-
const alreadyProvidedStatefulStates = inject(statesInjectionKey, void 0);
|
|
131
|
-
if (!alreadyProvidedStatefulStates) {
|
|
132
|
-
provide(statesInjectionKey, statefulStatesRef);
|
|
133
|
-
}
|
|
134
|
-
const codeBlockThemeIsDark = toRef(props, "codeBlocksThemeIsDark");
|
|
135
|
-
const alreadyProvidedCodeBlockThemeIsDark = inject(codeBlockThemeIsDarkInjectionKey, void 0);
|
|
136
|
-
if (!alreadyProvidedCodeBlockThemeIsDark) {
|
|
137
|
-
provide(codeBlockThemeIsDarkInjectionKey, codeBlockThemeIsDark);
|
|
138
|
-
}
|
|
139
|
-
const alreadyProvidedEditorCssVariables = inject(editorCssVariablesInjectionKey, void 0);
|
|
140
|
-
if (!alreadyProvidedEditorCssVariables) {
|
|
141
|
-
provide(editorCssVariablesInjectionKey, cssVariables);
|
|
142
|
-
}
|
|
143
|
-
if (props.documentApi && !alreadyProvidedDocumentApi) {
|
|
144
|
-
provide(documentApiInjectionKey, props.documentApi);
|
|
145
|
-
}
|
|
146
|
-
if (menus.value) {
|
|
147
|
-
provide(menusInjectionKey, menus);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
const finalEditorOptions = {
|
|
151
|
-
enableInputRules: true,
|
|
152
|
-
enablePasteRules: true,
|
|
153
|
-
...props.editorOptions,
|
|
154
|
-
// force extensions to be their own instance per embedded editor
|
|
155
|
-
// see https://github.com/ueberdosis/tiptap/issues/4317
|
|
156
|
-
// and https://github.com/ueberdosis/tiptap/issues/2694
|
|
157
|
-
extensions: props.editorOptions?.extensions ?? extensions,
|
|
158
|
-
autofocus: isEmbedded ? false : props.editorOptions?.autofocus ?? true,
|
|
159
|
-
injectCSS: false
|
|
160
|
-
};
|
|
161
|
-
provide(embededEditorOptionsInjectionKey, finalEditorOptions);
|
|
162
|
-
const emit = defineEmits(["load", "unload"]);
|
|
163
|
-
const { editor, recreate } = useEditor(finalEditorOptions);
|
|
164
|
-
watch(editor, (newVal) => {
|
|
165
|
-
if (newVal) {
|
|
166
|
-
if (props.linkOptions) {
|
|
167
|
-
editor.value.commands.setLinkOpts(props.linkOptions);
|
|
168
|
-
}
|
|
169
|
-
emit("load");
|
|
170
|
-
}
|
|
171
|
-
});
|
|
172
|
-
useWindowDebugging(editor);
|
|
173
|
-
useAsyncCodeBlockHighlighting({
|
|
174
|
-
lowlightInstance,
|
|
175
|
-
editor
|
|
176
|
-
});
|
|
177
|
-
watch(() => props.editorOptions, (newVal) => {
|
|
178
|
-
if (newVal) {
|
|
179
|
-
editor.value?.setOptions(newVal);
|
|
180
|
-
}
|
|
181
|
-
}, { deep: true });
|
|
182
|
-
watch(() => props.linkOptions, (newVal) => {
|
|
183
|
-
if (!isEmbedded) {
|
|
184
|
-
if (newVal) {
|
|
185
|
-
editor.value?.commands.setLinkOpts(newVal);
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
}, { deep: true });
|
|
189
|
-
const {
|
|
190
|
-
content,
|
|
191
|
-
docId
|
|
192
|
-
} = toRefs(props);
|
|
193
|
-
useEditorContent(
|
|
194
|
-
editor,
|
|
195
|
-
content,
|
|
196
|
-
docId,
|
|
197
|
-
props.documentApi ?? alreadyProvidedDocumentApi,
|
|
198
|
-
recreate
|
|
199
|
-
);
|
|
200
|
-
provide(parentEditorIdInjectionKey, docId);
|
|
201
|
-
defineExpose({
|
|
202
|
-
editor
|
|
203
|
-
});
|
|
204
|
-
</script>
|
|
205
|
-
|
|
206
|
-
<style>
|
|
207
|
-
a{text-decoration:underline!important}.ProseMirror{position:relative;word-wrap:break-word;font-feature-settings:"liga" 0;font-variant-ligatures:none;white-space:pre-wrap;white-space:break-spaces}.ProseMirror [contenteditable=false]{white-space:normal}.ProseMirror [contenteditable=false] [contenteditable=true]{white-space:pre-wrap}.ProseMirror pre{white-space:pre-wrap}img.ProseMirror-separator{border:none!important;display:inline!important;height:0!important;margin:0!important;width:0!important}@keyframes ProseMirror-cursor-blink{to{visibility:hidden}}.ProseMirror-gapcursor{display:none;pointer-events:none;position:relative}ul>.ProseMirror-gapcursor{@apply pl-[calc(var(--dragHandleSize)+var(--dragHandleMargin)+var(--spacing-1))]}.ProseMirror-gapcursor:after{animation:ProseMirror-cursor-blink 1.1s steps(2,start) infinite;border-top:1px solid #000;content:"";display:block;position:absolute;top:-2px;width:20px}.ProseMirror-focused .ProseMirror-gapcursor{display:block}.ProseMirror-hideselection ::selection{background:transparent}.ProseMirror-hideselection ::-moz-selection{background:transparent}.ProseMirror-hideselection *{caret-color:transparent}
|
|
208
|
-
</style>
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import type { Content, EditorOptions } from "@tiptap/core";
|
|
2
|
-
import type { ScrollNearContainerEdgesOptions } from "@witchcraft/ui/types/index";
|
|
3
|
-
import { type DocumentApiInterface } from "../pm/features/DocumentApi/types.js.js";
|
|
4
|
-
import type { EditorLinkOptions } from "../pm/features/Link/types.js";
|
|
5
|
-
import { type CssVariables, type MenuRenderInfo } from "../types/index.js.js";
|
|
6
|
-
type __VLS_Props = {
|
|
7
|
-
/** The content for the editor. It is better to use docId and the documentApi instead. */
|
|
8
|
-
content?: Content;
|
|
9
|
-
docId?: string;
|
|
10
|
-
/** The document api, required for the root editor if using nested embeds. This is provided as the documentApi using the documentApiInjectionKey. */
|
|
11
|
-
documentApi?: DocumentApiInterface;
|
|
12
|
-
/** The link options, required for the root editor. Not required for embedded editors. */
|
|
13
|
-
linkOptions?: EditorLinkOptions;
|
|
14
|
-
/** See my component library's (@witchcraft/ui) useScrollNearContainerEdges composable for more info. */
|
|
15
|
-
dragScrollOptions?: Pick<ScrollNearContainerEdgesOptions, "scrollMargin" | "outerScrollMargin" | "fastPixelMultiplier">;
|
|
16
|
-
cssVariables?: Partial<CssVariables>;
|
|
17
|
-
editorOptions?: Partial<EditorOptions>;
|
|
18
|
-
codeBlocksThemeIsDark?: boolean;
|
|
19
|
-
menus?: Record<string, MenuRenderInfo>;
|
|
20
|
-
};
|
|
21
|
-
declare const _default: import("vue").DefineComponent<__VLS_Props, {
|
|
22
|
-
editor: import("vue").ShallowRef<import("@tiptap/vue-3").Editor | undefined, import("@tiptap/vue-3").Editor | undefined>;
|
|
23
|
-
}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
|
|
24
|
-
load: () => any;
|
|
25
|
-
unload: () => any;
|
|
26
|
-
}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
|
|
27
|
-
onLoad?: (() => any) | undefined;
|
|
28
|
-
onUnload?: (() => any) | undefined;
|
|
29
|
-
}>, {
|
|
30
|
-
menus: Record<string, MenuRenderInfo>;
|
|
31
|
-
content: Content;
|
|
32
|
-
docId: string;
|
|
33
|
-
documentApi: DocumentApiInterface;
|
|
34
|
-
linkOptions: EditorLinkOptions;
|
|
35
|
-
dragScrollOptions: Pick<ScrollNearContainerEdgesOptions, "scrollMargin" | "outerScrollMargin" | "fastPixelMultiplier">;
|
|
36
|
-
cssVariables: Partial<CssVariables>;
|
|
37
|
-
editorOptions: Partial<EditorOptions>;
|
|
38
|
-
codeBlocksThemeIsDark: boolean;
|
|
39
|
-
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
40
|
-
export default _default;
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
2
|
-
export default _default;
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<WRoot class="items-center py-10 gap-2 h-dvh">
|
|
3
|
-
<component :is="'style'">
|
|
4
|
-
<!-- use unhead in a real app -->
|
|
5
|
-
{{ codeBlocksThemeCss.join("\n") }}
|
|
6
|
-
</component>
|
|
7
|
-
<div class="text-xl font-bold">
|
|
8
|
-
<a href="https://github.com/witchcraftjs/editor">@witchcraft/editor</a>
|
|
9
|
-
</div>
|
|
10
|
-
<EditorDemoControls
|
|
11
|
-
:code-blocks-theme-list="codeBlocksThemeList"
|
|
12
|
-
v-model:code-blocks-theme="codeBlocksTheme"
|
|
13
|
-
/>
|
|
14
|
-
<Editor
|
|
15
|
-
class="
|
|
16
|
-
max-w-[700px]
|
|
17
|
-
flex-1
|
|
18
|
-
flex
|
|
19
|
-
border
|
|
20
|
-
border-neutral-300
|
|
21
|
-
dark:border-neutral-700
|
|
22
|
-
rounded-sm
|
|
23
|
-
min-h-0
|
|
24
|
-
"
|
|
25
|
-
v-bind="{
|
|
26
|
-
codeBlocksThemeIsDark,
|
|
27
|
-
cssVariables: {
|
|
28
|
-
pmCodeBlockBgColor: codeBlocksThemeBgColor
|
|
29
|
-
},
|
|
30
|
-
docId,
|
|
31
|
-
documentApi,
|
|
32
|
-
linkOptions,
|
|
33
|
-
editorOptions,
|
|
34
|
-
menus
|
|
35
|
-
}"
|
|
36
|
-
/>
|
|
37
|
-
</WRoot>
|
|
38
|
-
</template>
|
|
39
|
-
|
|
40
|
-
<script setup>
|
|
41
|
-
import WRoot from "@witchcraft/ui/components/LibRoot";
|
|
42
|
-
import { reactive, ref, shallowRef } from "vue";
|
|
43
|
-
import Editor from "./Editor.vue";
|
|
44
|
-
import EditorDemoControls from "./EditorDemoControls.vue";
|
|
45
|
-
import { useHighlightJsTheme } from "../pm/features/CodeBlock/composables/useHighlightJsTheme.js";
|
|
46
|
-
import { defaultCommandBarMenuItems } from "../pm/features/CommandsMenus/commandBarMenuItems.js";
|
|
47
|
-
import CommandBar from "../pm/features/CommandsMenus/components/CommandBar.vue";
|
|
48
|
-
import { useTestDocumentApi } from "../pm/features/DocumentApi/composables/useTestDocumentApi.js";
|
|
49
|
-
import BubbleMenuLink from "../pm/features/Link/components/BubbleMenuLink.vue";
|
|
50
|
-
import { testExtensions } from "../pm/testSchema.js";
|
|
51
|
-
import { testDocuments } from "../testDocuments.js";
|
|
52
|
-
const {
|
|
53
|
-
theme: codeBlocksTheme,
|
|
54
|
-
knownThemes: codeBlocksThemeList,
|
|
55
|
-
themeCss: codeBlocksThemeCss,
|
|
56
|
-
isDark: codeBlocksThemeIsDark,
|
|
57
|
-
backgroundColor: codeBlocksThemeBgColor
|
|
58
|
-
} = useHighlightJsTheme();
|
|
59
|
-
const editorOptions = {
|
|
60
|
-
extensions: testExtensions
|
|
61
|
-
};
|
|
62
|
-
const linkOptions = {
|
|
63
|
-
openInternal: (href) => {
|
|
64
|
-
window.alert(`This would open an internal link to ${href}.`);
|
|
65
|
-
console.log(`Would open internal link to ${href}.`);
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
const fakeSuggestions = reactive(["some", "suggestions"]);
|
|
69
|
-
const menus = shallowRef({
|
|
70
|
-
linkMenu: {
|
|
71
|
-
component: BubbleMenuLink,
|
|
72
|
-
props: (editor) => ({
|
|
73
|
-
editor,
|
|
74
|
-
linkSuggestions: fakeSuggestions,
|
|
75
|
-
getInternalLinkHref(href) {
|
|
76
|
-
return `internal://${href.replace(/[^\w-]/g, "")}`;
|
|
77
|
-
}
|
|
78
|
-
})
|
|
79
|
-
},
|
|
80
|
-
commandBar: {
|
|
81
|
-
component: CommandBar,
|
|
82
|
-
props: (editor) => ({
|
|
83
|
-
editor,
|
|
84
|
-
commands: defaultCommandBarMenuItems.commands
|
|
85
|
-
}),
|
|
86
|
-
popupOptions: {
|
|
87
|
-
pinToItemDistance: (state) => {
|
|
88
|
-
const { $from, $to } = state.selection;
|
|
89
|
-
const fromNode = $from.node(-1);
|
|
90
|
-
const toNode = $to.node(-1);
|
|
91
|
-
if (fromNode.type !== toNode.type) {
|
|
92
|
-
return 0;
|
|
93
|
-
}
|
|
94
|
-
return fromNode.type.name.startsWith("table") ? 120 : 0;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
const { documentApi } = useTestDocumentApi(
|
|
100
|
-
editorOptions,
|
|
101
|
-
testDocuments
|
|
102
|
-
);
|
|
103
|
-
const docId = ref("root");
|
|
104
|
-
</script>
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
2
|
-
export default _default;
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
type __VLS_Props = {
|
|
2
|
-
codeBlocksThemeList: string[];
|
|
3
|
-
};
|
|
4
|
-
type __VLS_PublicProps = __VLS_Props & {
|
|
5
|
-
"codeBlocksTheme": string;
|
|
6
|
-
};
|
|
7
|
-
declare const _default: import("vue").DefineComponent<__VLS_PublicProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
8
|
-
"update:codeBlocksTheme": (value: string) => any;
|
|
9
|
-
}, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
|
|
10
|
-
"onUpdate:codeBlocksTheme"?: ((value: string) => any) | undefined;
|
|
11
|
-
}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
12
|
-
export default _default;
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div
|
|
3
|
-
class="
|
|
4
|
-
w-full
|
|
5
|
-
flex
|
|
6
|
-
items-stretch
|
|
7
|
-
justify-center
|
|
8
|
-
gap-2
|
|
9
|
-
[&>*]:rounded-sm
|
|
10
|
-
[&>*]:p-2
|
|
11
|
-
[&>*]:border
|
|
12
|
-
[&>*]:border-neutral-300
|
|
13
|
-
[&>*]:dark:border-neutral-700
|
|
14
|
-
"
|
|
15
|
-
>
|
|
16
|
-
<div class="flex items-center gap-2">
|
|
17
|
-
<span>
|
|
18
|
-
Global Theme:
|
|
19
|
-
</span>
|
|
20
|
-
<WDarkModeSwitcher/>
|
|
21
|
-
</div>
|
|
22
|
-
<CodeBlockThemePicker
|
|
23
|
-
:code-blocks-theme-list="codeBlocksThemeList"
|
|
24
|
-
v-model:code-blocks-theme="codeBlocksTheme"
|
|
25
|
-
/>
|
|
26
|
-
</div>
|
|
27
|
-
</template>
|
|
28
|
-
|
|
29
|
-
<script setup>
|
|
30
|
-
import WDarkModeSwitcher from "@witchcraft/ui/components/LibDarkModeSwitcher";
|
|
31
|
-
import CodeBlockThemePicker from "./CodeBlockThemePicker.vue";
|
|
32
|
-
defineProps({
|
|
33
|
-
codeBlocksThemeList: { type: Array, required: true }
|
|
34
|
-
});
|
|
35
|
-
const codeBlocksTheme = defineModel("codeBlocksTheme", { type: String, ...{ required: true } });
|
|
36
|
-
</script>
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
type __VLS_Props = {
|
|
2
|
-
codeBlocksThemeList: string[];
|
|
3
|
-
};
|
|
4
|
-
type __VLS_PublicProps = __VLS_Props & {
|
|
5
|
-
"codeBlocksTheme": string;
|
|
6
|
-
};
|
|
7
|
-
declare const _default: import("vue").DefineComponent<__VLS_PublicProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
8
|
-
"update:codeBlocksTheme": (value: string) => any;
|
|
9
|
-
}, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
|
|
10
|
-
"onUpdate:codeBlocksTheme"?: ((value: string) => any) | undefined;
|
|
11
|
-
}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
12
|
-
export default _default;
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
type __VLS_Props = {
|
|
2
|
-
testId: string;
|
|
3
|
-
documents: Record<string, {
|
|
4
|
-
title: string;
|
|
5
|
-
content: string;
|
|
6
|
-
}>;
|
|
7
|
-
docId: string;
|
|
8
|
-
loadDelay?: number;
|
|
9
|
-
};
|
|
10
|
-
declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
11
|
-
export default _default;
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<WRoot :test-wrapper-mode="true">
|
|
3
|
-
<Editor
|
|
4
|
-
:data-testid="`test-editor-${testId}`"
|
|
5
|
-
ref="editor"
|
|
6
|
-
v-bind="{
|
|
7
|
-
docId,
|
|
8
|
-
documentApi,
|
|
9
|
-
linkOptions,
|
|
10
|
-
editorOptions
|
|
11
|
-
}"
|
|
12
|
-
/>
|
|
13
|
-
<div class="py-[50px]"/>
|
|
14
|
-
</WRoot>
|
|
15
|
-
</template>
|
|
16
|
-
|
|
17
|
-
<script setup>
|
|
18
|
-
import WRoot from "@witchcraft/ui/components/LibRoot";
|
|
19
|
-
import { ref, watchEffect } from "vue";
|
|
20
|
-
import Editor from "./Editor.vue";
|
|
21
|
-
import { useTestDocumentApi } from "../pm/features/DocumentApi/composables/useTestDocumentApi.js";
|
|
22
|
-
import { testExtensions } from "../pm/testSchema.js";
|
|
23
|
-
const props = defineProps({
|
|
24
|
-
testId: { type: String, required: true },
|
|
25
|
-
documents: { type: Object, required: true },
|
|
26
|
-
docId: { type: String, required: true },
|
|
27
|
-
loadDelay: { type: Number, required: false }
|
|
28
|
-
});
|
|
29
|
-
const editorOptions = {
|
|
30
|
-
extensions: testExtensions.map((ext) => {
|
|
31
|
-
if (ext.name === "item") {
|
|
32
|
-
return ext.configure({
|
|
33
|
-
ensureLastItemIsParagraph: false
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
return ext;
|
|
37
|
-
}),
|
|
38
|
-
enableCoreExtensions: {
|
|
39
|
-
keymap: false
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
const { documentApi } = useTestDocumentApi(
|
|
43
|
-
editorOptions,
|
|
44
|
-
props.documents,
|
|
45
|
-
{ loadDelay: props.loadDelay }
|
|
46
|
-
);
|
|
47
|
-
const linkOptions = {
|
|
48
|
-
openInternal: () => {
|
|
49
|
-
console.log("openning internal");
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
const editor = ref(null);
|
|
53
|
-
watchEffect(() => {
|
|
54
|
-
if (editor.value) {
|
|
55
|
-
;
|
|
56
|
-
window[`editor-${props.testId}`] = editor.value;
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
</script>
|
|
60
|
-
|
|
61
|
-
<style>
|
|
62
|
-
@reference "../demo/tailwind.css"
|
|
63
|
-
</style>
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
type __VLS_Props = {
|
|
2
|
-
testId: string;
|
|
3
|
-
documents: Record<string, {
|
|
4
|
-
title: string;
|
|
5
|
-
content: string;
|
|
6
|
-
}>;
|
|
7
|
-
docId: string;
|
|
8
|
-
loadDelay?: number;
|
|
9
|
-
};
|
|
10
|
-
declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
11
|
-
export default _default;
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { EditorOptions } from "@tiptap/core";
|
|
2
|
-
import { Editor } from "@tiptap/vue-3";
|
|
3
|
-
/**
|
|
4
|
-
* Unline tiptap's useEditor, this does not auto-mount the editor. Instead the returned `recreate` function must be called manually. This was built with the use of {@link useContentEditor} in mind.
|
|
5
|
-
*/
|
|
6
|
-
export declare const useEditor: (options?: Partial<EditorOptions>) => {
|
|
7
|
-
editor: import("@vue/reactivity").ShallowRef<Editor | undefined, Editor | undefined>;
|
|
8
|
-
recreate: (modifyOptions?: (options: Partial<EditorOptions>) => Partial<EditorOptions>) => void;
|
|
9
|
-
};
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Editor } from "@tiptap/vue-3";
|
|
2
|
-
import { onBeforeUnmount, shallowRef } from "vue";
|
|
3
|
-
export const useEditor = (options = {}) => {
|
|
4
|
-
const editor = shallowRef();
|
|
5
|
-
function recreate(modifyOptions) {
|
|
6
|
-
options = modifyOptions?.(options) ?? options;
|
|
7
|
-
editor.value?.destroy();
|
|
8
|
-
editor.value = new Editor(options);
|
|
9
|
-
}
|
|
10
|
-
onBeforeUnmount(() => {
|
|
11
|
-
const nodes = editor.value?.options.element;
|
|
12
|
-
if (nodes && !(nodes instanceof HTMLElement)) {
|
|
13
|
-
console.warn(`Expected editor element to be an HTMLElement, got ${nodes.constructor.name}: ${nodes}`);
|
|
14
|
-
return;
|
|
15
|
-
}
|
|
16
|
-
const newEl = nodes?.cloneNode(true);
|
|
17
|
-
nodes?.parentNode?.replaceChild(newEl, nodes);
|
|
18
|
-
editor.value?.destroy();
|
|
19
|
-
});
|
|
20
|
-
return { editor, recreate };
|
|
21
|
-
};
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { watch } from "vue";
|
|
2
|
-
import { debugNode } from "../pm/utils/internal/debugNode.js";
|
|
3
|
-
import { nodesBetween } from "../pm/utils/nodesBetween.js";
|
|
4
|
-
export const useWindowDebugging = (editor) => {
|
|
5
|
-
watch(editor, () => {
|
|
6
|
-
if (!editor.value) return;
|
|
7
|
-
if (typeof window === "undefined" || typeof process === "undefined") return;
|
|
8
|
-
if (import.meta.dev && editor.value !== void 0) {
|
|
9
|
-
const w = window;
|
|
10
|
-
w.editor = editor.value;
|
|
11
|
-
w.tr = () => editor.value.state.tr;
|
|
12
|
-
w.debugNode = debugNode;
|
|
13
|
-
w.nodesBetween = nodesBetween;
|
|
14
|
-
}
|
|
15
|
-
});
|
|
16
|
-
};
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
2
|
-
export default _default;
|
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<WRoot class="items-center py-4">
|
|
3
|
-
<!-- @vue-expect-error use unhead in a real app -->
|
|
4
|
-
<style>
|
|
5
|
-
{{ codeBlocksThemeCss.join("\n") }}
|
|
6
|
-
</style>
|
|
7
|
-
<DemoControls
|
|
8
|
-
:code-blocks-theme-list="codeBlocksThemeList"
|
|
9
|
-
v-model:code-blocks-theme="codeBlocksTheme"
|
|
10
|
-
@blur="blur"
|
|
11
|
-
/>
|
|
12
|
-
<Editor
|
|
13
|
-
class="max-w-[700px] flex-1 max-h-[700px] flex"
|
|
14
|
-
v-bind="{
|
|
15
|
-
codeBlocksThemeIsDark,
|
|
16
|
-
cssVariables: {
|
|
17
|
-
pmCodeBlockBgColor: codeBlocksThemeBgColor
|
|
18
|
-
},
|
|
19
|
-
docId,
|
|
20
|
-
documentApi,
|
|
21
|
-
linkOptions,
|
|
22
|
-
editorOptions,
|
|
23
|
-
menus
|
|
24
|
-
}"
|
|
25
|
-
/>
|
|
26
|
-
<div class="py-[50px]"/>
|
|
27
|
-
</WRoot>
|
|
28
|
-
</template>
|
|
29
|
-
|
|
30
|
-
<script setup>
|
|
31
|
-
import WRoot from "@witchcraft/ui/components/LibRoot";
|
|
32
|
-
import { nextTick, reactive, ref, shallowRef } from "vue";
|
|
33
|
-
import Editor from "../components/Editor.vue";
|
|
34
|
-
import DemoControls from "../components/EditorDemoControls.vue";
|
|
35
|
-
import { useHighlightJsTheme } from "../pm/features/CodeBlock/composables/useHighlightJsTheme.js";
|
|
36
|
-
import { defaultCommandBarMenuItems } from "../pm/features/CommandsMenus/commandBarMenuItems";
|
|
37
|
-
import CommandBar from "../pm/features/CommandsMenus/components/CommandBar.vue";
|
|
38
|
-
import { useTestDocumentApi } from "../pm/features/DocumentApi/composables/useTestDocumentApi.js";
|
|
39
|
-
import BubbleMenuLink from "../pm/features/Link/components/BubbleMenuLink.vue";
|
|
40
|
-
import { testExtensions } from "../pm/testSchema.js";
|
|
41
|
-
import { testDocuments } from "../testDocuments";
|
|
42
|
-
const {
|
|
43
|
-
theme: codeBlocksTheme,
|
|
44
|
-
knownThemes: codeBlocksThemeList,
|
|
45
|
-
themeCss: codeBlocksThemeCss,
|
|
46
|
-
isDark: codeBlocksThemeIsDark,
|
|
47
|
-
backgroundColor: codeBlocksThemeBgColor
|
|
48
|
-
} = useHighlightJsTheme();
|
|
49
|
-
function blur() {
|
|
50
|
-
const was = codeBlocksTheme.value;
|
|
51
|
-
codeBlocksTheme.value = "";
|
|
52
|
-
nextTick(() => {
|
|
53
|
-
codeBlocksTheme.value = was;
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
const editorOptions = {
|
|
57
|
-
extensions: testExtensions
|
|
58
|
-
};
|
|
59
|
-
const linkOptions = {
|
|
60
|
-
openInternal: (href) => {
|
|
61
|
-
window.alert(`This would open an internal link to ${href}.`);
|
|
62
|
-
console.log(`Would open internal link to ${href}.`);
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
const fakeSuggestions = reactive(["some", "suggestions"]);
|
|
66
|
-
const menus = shallowRef({
|
|
67
|
-
linkMenu: {
|
|
68
|
-
component: BubbleMenuLink,
|
|
69
|
-
props: (editor) => ({
|
|
70
|
-
editor,
|
|
71
|
-
linkSuggestions: fakeSuggestions,
|
|
72
|
-
getInternalLinkHref(href) {
|
|
73
|
-
return `internal://${href.replace(/[^\w-]/g, "")}`;
|
|
74
|
-
}
|
|
75
|
-
})
|
|
76
|
-
},
|
|
77
|
-
commandBar: {
|
|
78
|
-
component: CommandBar,
|
|
79
|
-
props: (editor) => ({
|
|
80
|
-
editor,
|
|
81
|
-
commands: defaultCommandBarMenuItems.commands
|
|
82
|
-
}),
|
|
83
|
-
popupOptions: {
|
|
84
|
-
pinToItemDistance: (state) => {
|
|
85
|
-
const { $from, $to } = state.selection;
|
|
86
|
-
const fromNode = $from.node(-1);
|
|
87
|
-
const toNode = $to.node(-1);
|
|
88
|
-
if (fromNode.type !== toNode.type) {
|
|
89
|
-
return 0;
|
|
90
|
-
}
|
|
91
|
-
return fromNode.type.name.startsWith("table") ? 120 : 0;
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
const { documentApi } = useTestDocumentApi(
|
|
97
|
-
editorOptions,
|
|
98
|
-
testDocuments
|
|
99
|
-
);
|
|
100
|
-
const docId = ref("root");
|
|
101
|
-
</script>
|