@witchcraft/editor 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/@types/@tiptap/core/index.d.ts +3 -0
- package/README.md +111 -0
- package/dist/module.d.mts +15 -0
- package/dist/module.json +9 -0
- package/dist/module.mjs +68 -0
- package/dist/runtime/assets/base.css +1 -0
- package/dist/runtime/assets/handle-arrow.svg +16 -0
- package/dist/runtime/assets/handle-border-circles-single.svg +44 -0
- package/dist/runtime/assets/handle-border-circles.svg +27 -0
- package/dist/runtime/assets/handle-temp.svg +1 -0
- package/dist/runtime/assets/utils.css +1 -0
- package/dist/runtime/components/CodeBlockThemePicker.d.vue.ts +12 -0
- package/dist/runtime/components/CodeBlockThemePicker.vue +123 -0
- package/dist/runtime/components/CodeBlockThemePicker.vue.d.ts +12 -0
- package/dist/runtime/components/Commands.d.vue.ts +10 -0
- package/dist/runtime/components/Commands.vue +60 -0
- package/dist/runtime/components/Commands.vue.d.ts +10 -0
- package/dist/runtime/components/Editor.d.vue.ts +40 -0
- package/dist/runtime/components/Editor.vue +208 -0
- package/dist/runtime/components/Editor.vue.d.ts +40 -0
- package/dist/runtime/components/EditorDemoApp.d.vue.ts +2 -0
- package/dist/runtime/components/EditorDemoApp.vue +104 -0
- package/dist/runtime/components/EditorDemoApp.vue.d.ts +2 -0
- package/dist/runtime/components/EditorDemoControls.d.vue.ts +12 -0
- package/dist/runtime/components/EditorDemoControls.vue +36 -0
- package/dist/runtime/components/EditorDemoControls.vue.d.ts +12 -0
- package/dist/runtime/components/TestWrapper.d.vue.ts +11 -0
- package/dist/runtime/components/TestWrapper.vue +63 -0
- package/dist/runtime/components/TestWrapper.vue.d.ts +11 -0
- package/dist/runtime/composables/useEditor.d.ts +9 -0
- package/dist/runtime/composables/useEditor.js +17 -0
- package/dist/runtime/composables/useWindowDebugging.d.ts +3 -0
- package/dist/runtime/composables/useWindowDebugging.js +16 -0
- package/dist/runtime/demo/App.d.vue.ts +2 -0
- package/dist/runtime/demo/App.vue +101 -0
- package/dist/runtime/demo/App.vue.d.ts +2 -0
- package/dist/runtime/demo/README.md +1 -0
- package/dist/runtime/demo/main.d.ts +1 -0
- package/dist/runtime/demo/main.js +4 -0
- package/dist/runtime/demo/tailwind.css +1 -0
- package/dist/runtime/env.d.ts +2 -0
- package/dist/runtime/injectionKeys.d.ts +6 -0
- package/dist/runtime/injectionKeys.js +3 -0
- package/dist/runtime/main.lib.d.ts +2 -0
- package/dist/runtime/main.lib.js +2 -0
- package/dist/runtime/pm/commands/backspace.d.ts +12 -0
- package/dist/runtime/pm/commands/backspace.js +26 -0
- package/dist/runtime/pm/commands/changeAttrs.d.ts +9 -0
- package/dist/runtime/pm/commands/changeAttrs.js +15 -0
- package/dist/runtime/pm/commands/deleteSelection.d.ts +9 -0
- package/dist/runtime/pm/commands/deleteSelection.js +8 -0
- package/dist/runtime/pm/commands/enter.d.ts +14 -0
- package/dist/runtime/pm/commands/enter.js +9 -0
- package/dist/runtime/pm/commands/insertBreak.d.ts +9 -0
- package/dist/runtime/pm/commands/insertBreak.js +22 -0
- package/dist/runtime/pm/features/Base/Base.d.ts +4 -0
- package/dist/runtime/pm/features/Base/Base.js +32 -0
- package/dist/runtime/pm/features/Base/commands/deleteNodes.d.ts +10 -0
- package/dist/runtime/pm/features/Base/commands/deleteNodes.js +29 -0
- package/dist/runtime/pm/features/Base/commands/setCursorVisible.d.ts +12 -0
- package/dist/runtime/pm/features/Base/commands/setCursorVisible.js +7 -0
- package/dist/runtime/pm/features/Base/plugins/debugSelectionPlugin.d.ts +9 -0
- package/dist/runtime/pm/features/Base/plugins/debugSelectionPlugin.js +48 -0
- package/dist/runtime/pm/features/Base/plugins/isCursorVisiblePlugin.d.ts +3 -0
- package/dist/runtime/pm/features/Base/plugins/isCursorVisiblePlugin.js +26 -0
- package/dist/runtime/pm/features/Base/plugins/isUsingTouchPlugin.d.ts +3 -0
- package/dist/runtime/pm/features/Base/plugins/isUsingTouchPlugin.js +38 -0
- package/dist/runtime/pm/features/Base/plugins/selectingIndicator.d.ts +5 -0
- package/dist/runtime/pm/features/Base/plugins/selectingIndicator.js +35 -0
- package/dist/runtime/pm/features/Base/plugins/unfocusedSelectionIndicatorPlugin.d.ts +33 -0
- package/dist/runtime/pm/features/Base/plugins/unfocusedSelectionIndicatorPlugin.js +66 -0
- package/dist/runtime/pm/features/Base/types.d.ts +3 -0
- package/dist/runtime/pm/features/Base/types.js +0 -0
- package/dist/runtime/pm/features/BaseShortcuts/BaseShortcuts.d.ts +3 -0
- package/dist/runtime/pm/features/BaseShortcuts/BaseShortcuts.js +34 -0
- package/dist/runtime/pm/features/Blockquote/Blockquote.d.ts +5 -0
- package/dist/runtime/pm/features/Blockquote/Blockquote.js +65 -0
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteEnter.d.ts +11 -0
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteEnter.js +31 -0
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteShiftEnter.d.ts +11 -0
- package/dist/runtime/pm/features/Blockquote/commands/blockquoteShiftEnter.js +12 -0
- package/dist/runtime/pm/features/Blocks/Blocks.d.ts +2 -0
- package/dist/runtime/pm/features/Blocks/Blocks.js +2 -0
- package/dist/runtime/pm/features/Blocks/Item.d.ts +11 -0
- package/dist/runtime/pm/features/Blocks/Item.js +157 -0
- package/dist/runtime/pm/features/Blocks/List.d.ts +4 -0
- package/dist/runtime/pm/features/Blocks/List.js +59 -0
- package/dist/runtime/pm/features/Blocks/commands/changeItemType.d.ts +20 -0
- package/dist/runtime/pm/features/Blocks/commands/changeItemType.js +40 -0
- package/dist/runtime/pm/features/Blocks/commands/changeTypeAttr.d.ts +14 -0
- package/dist/runtime/pm/features/Blocks/commands/changeTypeAttr.js +28 -0
- package/dist/runtime/pm/features/Blocks/commands/copyOrMoveItem.d.ts +23 -0
- package/dist/runtime/pm/features/Blocks/commands/copyOrMoveItem.js +124 -0
- package/dist/runtime/pm/features/Blocks/commands/deleteItem.d.ts +12 -0
- package/dist/runtime/pm/features/Blocks/commands/deleteItem.js +8 -0
- package/dist/runtime/pm/features/Blocks/commands/indentItem.d.ts +12 -0
- package/dist/runtime/pm/features/Blocks/commands/indentItem.js +58 -0
- package/dist/runtime/pm/features/Blocks/commands/itemMenuCommands.d.ts +18 -0
- package/dist/runtime/pm/features/Blocks/commands/itemMenuCommands.js +40 -0
- package/dist/runtime/pm/features/Blocks/commands/moveItem.d.ts +12 -0
- package/dist/runtime/pm/features/Blocks/commands/moveItem.js +80 -0
- package/dist/runtime/pm/features/Blocks/commands/setNode.d.ts +20 -0
- package/dist/runtime/pm/features/Blocks/commands/setNode.js +87 -0
- package/dist/runtime/pm/features/Blocks/commands/splitItem.d.ts +17 -0
- package/dist/runtime/pm/features/Blocks/commands/splitItem.js +87 -0
- package/dist/runtime/pm/features/Blocks/commands/unindentItem.d.ts +12 -0
- package/dist/runtime/pm/features/Blocks/commands/unindentItem.js +42 -0
- package/dist/runtime/pm/features/Blocks/components/DragTreeHandle.d.vue.ts +0 -0
- package/dist/runtime/pm/features/Blocks/components/DragTreeHandle.vue +122 -0
- package/dist/runtime/pm/features/Blocks/components/DragTreeHandle.vue.d.ts +0 -0
- package/dist/runtime/pm/features/Blocks/components/ItemMenu.d.vue.ts +6 -0
- package/dist/runtime/pm/features/Blocks/components/ItemMenu.vue +78 -0
- package/dist/runtime/pm/features/Blocks/components/ItemMenu.vue.d.ts +6 -0
- package/dist/runtime/pm/features/Blocks/components/ItemNodeView.d.vue.ts +92 -0
- package/dist/runtime/pm/features/Blocks/components/ItemNodeView.vue +350 -0
- package/dist/runtime/pm/features/Blocks/components/ItemNodeView.vue.d.ts +92 -0
- package/dist/runtime/pm/features/Blocks/components/defaultItemMenu.d.ts +5 -0
- package/dist/runtime/pm/features/Blocks/components/defaultItemMenu.js +42 -0
- package/dist/runtime/pm/features/Blocks/composables/useDragWithThreshold.d.ts +1 -0
- package/dist/runtime/pm/features/Blocks/composables/useDragWithThreshold.js +0 -0
- package/dist/runtime/pm/features/Blocks/composables/useHandleHeight.d.ts +5 -0
- package/dist/runtime/pm/features/Blocks/composables/useHandleHeight.js +22 -0
- package/dist/runtime/pm/features/Blocks/composables/useHasChildren.d.ts +5 -0
- package/dist/runtime/pm/features/Blocks/composables/useHasChildren.js +10 -0
- package/dist/runtime/pm/features/Blocks/composables/useNodeStates.d.ts +7 -0
- package/dist/runtime/pm/features/Blocks/composables/useNodeStates.js +20 -0
- package/dist/runtime/pm/features/Blocks/itemMenuMenuItems.d.ts +20 -0
- package/dist/runtime/pm/features/Blocks/itemMenuMenuItems.js +138 -0
- package/dist/runtime/pm/features/Blocks/plugins/ensureLastItemIsContentPlugin.d.ts +11 -0
- package/dist/runtime/pm/features/Blocks/plugins/ensureLastItemIsContentPlugin.js +36 -0
- package/dist/runtime/pm/features/Blocks/plugins/itemBlockIdPlugin.d.ts +8 -0
- package/dist/runtime/pm/features/Blocks/plugins/itemBlockIdPlugin.js +30 -0
- package/dist/runtime/pm/features/Blocks/plugins/itemHasSingularSelectionPlugin.d.ts +3 -0
- package/dist/runtime/pm/features/Blocks/plugins/itemHasSingularSelectionPlugin.js +30 -0
- package/dist/runtime/pm/features/Blocks/plugins/itemMenuPlugin.d.ts +4 -0
- package/dist/runtime/pm/features/Blocks/plugins/itemMenuPlugin.js +17 -0
- package/dist/runtime/pm/features/Blocks/states/stateful.d.ts +2 -0
- package/dist/runtime/pm/features/Blocks/states/stateful.js +37 -0
- package/dist/runtime/pm/features/Blocks/states/task/cancelled.svg +32 -0
- package/dist/runtime/pm/features/Blocks/states/task/checked.svg +27 -0
- package/dist/runtime/pm/features/Blocks/states/task/checked2.svg +24 -0
- package/dist/runtime/pm/features/Blocks/states/task/partial.svg +24 -0
- package/dist/runtime/pm/features/Blocks/states/task/partial2.svg +31 -0
- package/dist/runtime/pm/features/Blocks/states/task/unchecked.svg +20 -0
- package/dist/runtime/pm/features/Blocks/types.d.ts +43 -0
- package/dist/runtime/pm/features/Blocks/types.js +2 -0
- package/dist/runtime/pm/features/Blocks/utils/createItemMenuCommandExecuter.d.ts +3 -0
- package/dist/runtime/pm/features/Blocks/utils/createItemMenuCommandExecuter.js +24 -0
- package/dist/runtime/pm/features/Blocks/utils/fixBlockIds.d.ts +4 -0
- package/dist/runtime/pm/features/Blocks/utils/fixBlockIds.js +23 -0
- package/dist/runtime/pm/features/Blocks/utils/isValidId.d.ts +2 -0
- package/dist/runtime/pm/features/Blocks/utils/isValidId.js +7 -0
- package/dist/runtime/pm/features/CodeBlock/CodeBlock.d.ts +16 -0
- package/dist/runtime/pm/features/CodeBlock/CodeBlock.js +91 -0
- package/dist/runtime/pm/features/CodeBlock/build/generateHighlightJsInfo.d.ts +1 -0
- package/dist/runtime/pm/features/CodeBlock/build/generateHighlightJsInfo.js +63 -0
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockEnterOrSplit.d.ts +9 -0
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockEnterOrSplit.js +28 -0
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockIndent.d.ts +9 -0
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockIndent.js +39 -0
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockUnindent.d.ts +9 -0
- package/dist/runtime/pm/features/CodeBlock/commands/codeBlockUnindent.js +50 -0
- package/dist/runtime/pm/features/CodeBlock/commands/focusCodeBlockLanguage.d.ts +9 -0
- package/dist/runtime/pm/features/CodeBlock/commands/focusCodeBlockLanguage.js +27 -0
- package/dist/runtime/pm/features/CodeBlock/components/CodeBlockView.d.vue.ts +92 -0
- package/dist/runtime/pm/features/CodeBlock/components/CodeBlockView.vue +112 -0
- package/dist/runtime/pm/features/CodeBlock/components/CodeBlockView.vue.d.ts +92 -0
- package/dist/runtime/pm/features/CodeBlock/composables/useAsyncCodeBlockHighlighting.d.ts +28 -0
- package/dist/runtime/pm/features/CodeBlock/composables/useAsyncCodeBlockHighlighting.js +137 -0
- package/dist/runtime/pm/features/CodeBlock/composables/useHighlightJsTheme.d.ts +37 -0
- package/dist/runtime/pm/features/CodeBlock/composables/useHighlightJsTheme.js +101 -0
- package/dist/runtime/pm/features/CodeBlock/highlightJsInfo.d.ts +17 -0
- package/dist/runtime/pm/features/CodeBlock/highlightJsInfo.js +711 -0
- package/dist/runtime/pm/features/CodeBlock/types.d.ts +4 -0
- package/dist/runtime/pm/features/CodeBlock/types.js +2 -0
- package/dist/runtime/pm/features/Collaboration/Collaboration.d.ts +66 -0
- package/dist/runtime/pm/features/Collaboration/Collaboration.js +169 -0
- package/dist/runtime/pm/features/CommandsMenus/CommandBar.d.ts +19 -0
- package/dist/runtime/pm/features/CommandsMenus/CommandBar.js +97 -0
- package/dist/runtime/pm/features/CommandsMenus/commandBarMenuItems.d.ts +20 -0
- package/dist/runtime/pm/features/CommandsMenus/commandBarMenuItems.js +188 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBar.d.vue.ts +8 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBar.vue +58 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBar.vue.d.ts +8 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBarItem.d.vue.ts +12 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBarItem.vue +42 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandBarItem.vue.d.ts +12 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuGroup.d.vue.ts +10 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuGroup.vue +55 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuGroup.vue.d.ts +10 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuItem.d.vue.ts +11 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuItem.vue +58 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuItem.vue.d.ts +11 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuList.d.vue.ts +11 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuList.vue +54 -0
- package/dist/runtime/pm/features/CommandsMenus/components/CommandMenuList.vue.d.ts +11 -0
- package/dist/runtime/pm/features/CommandsMenus/components/TextIcon.d.vue.ts +5 -0
- package/dist/runtime/pm/features/CommandsMenus/components/TextIcon.vue +13 -0
- package/dist/runtime/pm/features/CommandsMenus/components/TextIcon.vue.d.ts +5 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/HighlightIcon.d.vue.ts +8 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/HighlightIcon.vue +45 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/HighlightIcon.vue.d.ts +8 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/SubscriptIcon.d.vue.ts +2 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/SubscriptIcon.vue +5 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/SubscriptIcon.vue.d.ts +2 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/SuperscriptIcon.d.vue.ts +2 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/SuperscriptIcon.vue +5 -0
- package/dist/runtime/pm/features/CommandsMenus/icons/SuperscriptIcon.vue.d.ts +2 -0
- package/dist/runtime/pm/features/CommandsMenus/types.d.ts +61 -0
- package/dist/runtime/pm/features/CommandsMenus/types.js +5 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/defaultCommandExecutor.d.ts +3 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/defaultCommandExecutor.js +11 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/findCommand.d.ts +10 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/findCommand.js +16 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/popupPositionModifier.d.ts +5 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/popupPositionModifier.js +9 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/popupVerticalPositioner.d.ts +5 -0
- package/dist/runtime/pm/features/CommandsMenus/utils/popupVerticalPositioner.js +11 -0
- package/dist/runtime/pm/features/Document/Document.d.ts +3 -0
- package/dist/runtime/pm/features/Document/Document.js +6 -0
- package/dist/runtime/pm/features/DocumentApi/DocumentApi.d.ts +85 -0
- package/dist/runtime/pm/features/DocumentApi/DocumentApi.js +161 -0
- package/dist/runtime/pm/features/DocumentApi/composables/useEditorContent.d.ts +13 -0
- package/dist/runtime/pm/features/DocumentApi/composables/useEditorContent.js +76 -0
- package/dist/runtime/pm/features/DocumentApi/composables/useTestDocumentApi.d.ts +23 -0
- package/dist/runtime/pm/features/DocumentApi/composables/useTestDocumentApi.js +70 -0
- package/dist/runtime/pm/features/DocumentApi/types.d.ts +133 -0
- package/dist/runtime/pm/features/DocumentApi/types.js +1 -0
- package/dist/runtime/pm/features/DocumentApi/utils/convertFullTransactionForPartialState.d.ts +3 -0
- package/dist/runtime/pm/features/DocumentApi/utils/convertFullTransactionForPartialState.js +37 -0
- package/dist/runtime/pm/features/DocumentApi/utils/convertTrForInstance.d.ts +4 -0
- package/dist/runtime/pm/features/DocumentApi/utils/convertTrForInstance.js +13 -0
- package/dist/runtime/pm/features/DocumentApi/utils/convertTransactionForFullState.d.ts +2 -0
- package/dist/runtime/pm/features/DocumentApi/utils/convertTransactionForFullState.js +22 -0
- package/dist/runtime/pm/features/DocumentApi/utils/copyMeta.d.ts +2 -0
- package/dist/runtime/pm/features/DocumentApi/utils/copyMeta.js +6 -0
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedJson.d.ts +1 -0
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedJson.js +14 -0
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedNodeFromDoc.d.ts +1 -0
- package/dist/runtime/pm/features/DocumentApi/utils/getEmbedNodeFromDoc.js +14 -0
- package/dist/runtime/pm/features/DocumentApi/utils/getStateEmbedRange.d.ts +9 -0
- package/dist/runtime/pm/features/DocumentApi/utils/getStateEmbedRange.js +19 -0
- package/dist/runtime/pm/features/DocumentApi/utils/isEmbedId.d.ts +2 -0
- package/dist/runtime/pm/features/DocumentApi/utils/isEmbedId.js +3 -0
- package/dist/runtime/pm/features/EmbeddedDocument/Embedded.d.ts +24 -0
- package/dist/runtime/pm/features/EmbeddedDocument/Embedded.js +73 -0
- package/dist/runtime/pm/features/EmbeddedDocument/EmbeddedDocument.d.ts +23 -0
- package/dist/runtime/pm/features/EmbeddedDocument/EmbeddedDocument.js +70 -0
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.d.vue.ts +14 -0
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.vue +171 -0
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.vue.d.ts +14 -0
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.d.vue.ts +92 -0
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.vue +172 -0
- package/dist/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.vue.d.ts +92 -0
- package/dist/runtime/pm/features/EmbeddedDocument/composables/useEmbeddedEditor.d.ts +31 -0
- package/dist/runtime/pm/features/EmbeddedDocument/composables/useEmbeddedEditor.js +199 -0
- package/dist/runtime/pm/features/EmbeddedDocument/types.d.ts +49 -0
- package/dist/runtime/pm/features/EmbeddedDocument/types.js +6 -0
- package/dist/runtime/pm/features/EmbeddedDocument/utils/isEmbeddedBlock.d.ts +9 -0
- package/dist/runtime/pm/features/EmbeddedDocument/utils/isEmbeddedBlock.js +3 -0
- package/dist/runtime/pm/features/EmbeddedDocument/utils/redirectFromEmbedded.d.ts +28 -0
- package/dist/runtime/pm/features/EmbeddedDocument/utils/redirectFromEmbedded.js +17 -0
- package/dist/runtime/pm/features/FileLoader/FileLoader.d.ts +16 -0
- package/dist/runtime/pm/features/FileLoader/FileLoader.js +99 -0
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/FileLoaderHandler.d.ts +28 -0
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/FileLoaderHandler.js +69 -0
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/TestFileLoaderHandler.d.ts +11 -0
- package/dist/runtime/pm/features/FileLoader/FileLoaderHandler/TestFileLoaderHandler.js +49 -0
- package/dist/runtime/pm/features/FileLoader/commands/insertFile.d.ts +17 -0
- package/dist/runtime/pm/features/FileLoader/commands/insertFile.js +39 -0
- package/dist/runtime/pm/features/FileLoader/components/FileLoaderNodeView.d.vue.ts +92 -0
- package/dist/runtime/pm/features/FileLoader/components/FileLoaderNodeView.vue +38 -0
- package/dist/runtime/pm/features/FileLoader/components/FileLoaderNodeView.vue.d.ts +92 -0
- package/dist/runtime/pm/features/FileLoader/plugins/fileLoaderPlugin.d.ts +5 -0
- package/dist/runtime/pm/features/FileLoader/plugins/fileLoaderPlugin.js +61 -0
- package/dist/runtime/pm/features/FileLoader/types.d.ts +73 -0
- package/dist/runtime/pm/features/FileLoader/types.js +0 -0
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNode.d.ts +4 -0
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNode.js +27 -0
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNodes.d.ts +9 -0
- package/dist/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNodes.js +22 -0
- package/dist/runtime/pm/features/FileLoader/utils/findLoadingNodePos.d.ts +2 -0
- package/dist/runtime/pm/features/FileLoader/utils/findLoadingNodePos.js +11 -0
- package/dist/runtime/pm/features/FileLoader/utils/optionsCheck.d.ts +3 -0
- package/dist/runtime/pm/features/FileLoader/utils/optionsCheck.js +8 -0
- package/dist/runtime/pm/features/FileLoader/utils/readAsDataUrl.d.ts +1 -0
- package/dist/runtime/pm/features/FileLoader/utils/readAsDataUrl.js +12 -0
- package/dist/runtime/pm/features/HardBreak/HardBreak.d.ts +5 -0
- package/dist/runtime/pm/features/HardBreak/HardBreak.js +14 -0
- package/dist/runtime/pm/features/Heading/Heading.d.ts +24 -0
- package/dist/runtime/pm/features/Heading/Heading.js +85 -0
- package/dist/runtime/pm/features/Heading/commands/changeLevelAttr.d.ts +16 -0
- package/dist/runtime/pm/features/Heading/commands/changeLevelAttr.js +33 -0
- package/dist/runtime/pm/features/Heading/types.d.ts +14 -0
- package/dist/runtime/pm/features/Heading/types.js +0 -0
- package/dist/runtime/pm/features/Highlight/Highlight.d.ts +72 -0
- package/dist/runtime/pm/features/Highlight/Highlight.js +163 -0
- package/dist/runtime/pm/features/Highlight/retyped/tiptapHighlight.d.ts +3 -0
- package/dist/runtime/pm/features/Highlight/retyped/tiptapHighlight.js +5 -0
- package/dist/runtime/pm/features/Highlight/types.d.ts +27 -0
- package/dist/runtime/pm/features/Highlight/types.js +2 -0
- package/dist/runtime/pm/features/History/History.d.ts +35 -0
- package/dist/runtime/pm/features/History/History.js +63 -0
- package/dist/runtime/pm/features/Iframe/Iframe.d.ts +21 -0
- package/dist/runtime/pm/features/Iframe/Iframe.js +127 -0
- package/dist/runtime/pm/features/Iframe/IframeParsers.d.ts +37 -0
- package/dist/runtime/pm/features/Iframe/IframeParsers.js +88 -0
- package/dist/runtime/pm/features/Iframe/components/IframeNodeView.d.vue.ts +92 -0
- package/dist/runtime/pm/features/Iframe/components/IframeNodeView.vue +82 -0
- package/dist/runtime/pm/features/Iframe/components/IframeNodeView.vue.d.ts +92 -0
- package/dist/runtime/pm/features/Iframe/types.d.ts +5 -0
- package/dist/runtime/pm/features/Iframe/types.js +0 -0
- package/dist/runtime/pm/features/Image/Image.d.ts +2 -0
- package/dist/runtime/pm/features/Image/Image.js +13 -0
- package/dist/runtime/pm/features/Link/Link.d.ts +38 -0
- package/dist/runtime/pm/features/Link/Link.js +241 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuExternalLink.d.vue.ts +28 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuExternalLink.vue +114 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuExternalLink.vue.d.ts +28 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuInternalLink.d.vue.ts +29 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuInternalLink.vue +107 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuInternalLink.vue.d.ts +29 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuLink.d.vue.ts +11 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuLink.vue +126 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuLink.vue.d.ts +11 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuLinkActions.d.vue.ts +18 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuLinkActions.vue +57 -0
- package/dist/runtime/pm/features/Link/components/BubbleMenuLinkActions.vue.d.ts +18 -0
- package/dist/runtime/pm/features/Link/types.d.ts +44 -0
- package/dist/runtime/pm/features/Link/types.js +3 -0
- package/dist/runtime/pm/features/Menus/Menus.d.ts +45 -0
- package/dist/runtime/pm/features/Menus/Menus.js +142 -0
- package/dist/runtime/pm/features/Menus/components/MarkMenuManager.d.vue.ts +6 -0
- package/dist/runtime/pm/features/Menus/components/MarkMenuManager.vue +166 -0
- package/dist/runtime/pm/features/Menus/components/MarkMenuManager.vue.d.ts +6 -0
- package/dist/runtime/pm/features/Menus/types.d.ts +51 -0
- package/dist/runtime/pm/features/Menus/types.js +3 -0
- package/dist/runtime/pm/features/Menus/utils/isMarkMenu.d.ts +2 -0
- package/dist/runtime/pm/features/Menus/utils/isMarkMenu.js +3 -0
- package/dist/runtime/pm/features/Tables/commands/tableEnter.d.ts +15 -0
- package/dist/runtime/pm/features/Tables/commands/tableEnter.js +19 -0
- package/dist/runtime/pm/features/Tables/index.d.ts +9 -0
- package/dist/runtime/pm/features/Tables/index.js +44 -0
- package/dist/runtime/pm/schema.d.ts +4 -0
- package/dist/runtime/pm/schema.js +80 -0
- package/dist/runtime/pm/testSchema.d.ts +5 -0
- package/dist/runtime/pm/testSchema.js +30 -0
- package/dist/runtime/pm/utils/createDropIndicator.d.ts +23 -0
- package/dist/runtime/pm/utils/createDropIndicator.js +32 -0
- package/dist/runtime/pm/utils/createStateOnlyPluginApply.d.ts +2 -0
- package/dist/runtime/pm/utils/createStateOnlyPluginApply.js +9 -0
- package/dist/runtime/pm/utils/createStateOnlyPluginObjApply.d.ts +2 -0
- package/dist/runtime/pm/utils/createStateOnlyPluginObjApply.js +14 -0
- package/dist/runtime/pm/utils/dropPointInfo.d.ts +56 -0
- package/dist/runtime/pm/utils/dropPointInfo.js +28 -0
- package/dist/runtime/pm/utils/findUpwards.d.ts +20 -0
- package/dist/runtime/pm/utils/findUpwards.js +18 -0
- package/dist/runtime/pm/utils/getChildChunks.d.ts +3 -0
- package/dist/runtime/pm/utils/getChildChunks.js +15 -0
- package/dist/runtime/pm/utils/getDiffReplacementRange.d.ts +20 -0
- package/dist/runtime/pm/utils/getDiffReplacementRange.js +9 -0
- package/dist/runtime/pm/utils/getElMaxVisualSize.d.ts +9 -0
- package/dist/runtime/pm/utils/getElMaxVisualSize.js +7 -0
- package/dist/runtime/pm/utils/getElPropertyAsInt.d.ts +1 -0
- package/dist/runtime/pm/utils/getElPropertyAsInt.js +8 -0
- package/dist/runtime/pm/utils/getGroupNodeNames.d.ts +2 -0
- package/dist/runtime/pm/utils/getGroupNodeNames.js +7 -0
- package/dist/runtime/pm/utils/getMarkPosition.d.ts +11 -0
- package/dist/runtime/pm/utils/getMarkPosition.js +34 -0
- package/dist/runtime/pm/utils/getMarksInSelection.d.ts +3 -0
- package/dist/runtime/pm/utils/getMarksInSelection.js +16 -0
- package/dist/runtime/pm/utils/getTypeByName.d.ts +2 -0
- package/dist/runtime/pm/utils/getTypeByName.js +5 -0
- package/dist/runtime/pm/utils/index.d.ts +15 -0
- package/dist/runtime/pm/utils/index.js +15 -0
- package/dist/runtime/pm/utils/internal/createNodeTypesList.d.ts +2 -0
- package/dist/runtime/pm/utils/internal/createNodeTypesList.js +17 -0
- package/dist/runtime/pm/utils/internal/debugMap.d.ts +7 -0
- package/dist/runtime/pm/utils/internal/debugMap.js +24 -0
- package/dist/runtime/pm/utils/internal/debugNode.d.ts +2 -0
- package/dist/runtime/pm/utils/internal/debugNode.js +18 -0
- package/dist/runtime/pm/utils/internal/debugSel.d.ts +5 -0
- package/dist/runtime/pm/utils/internal/debugSel.js +8 -0
- package/dist/runtime/pm/utils/internal/recurse.d.ts +2 -0
- package/dist/runtime/pm/utils/internal/recurse.js +39 -0
- package/dist/runtime/pm/utils/internal/stripBlockId.d.ts +2 -0
- package/dist/runtime/pm/utils/internal/stripBlockId.js +9 -0
- package/dist/runtime/pm/utils/mapSelection.d.ts +8 -0
- package/dist/runtime/pm/utils/mapSelection.js +12 -0
- package/dist/runtime/pm/utils/nodesBetween.d.ts +21 -0
- package/dist/runtime/pm/utils/nodesBetween.js +21 -0
- package/dist/runtime/pm/utils/pointToPmPoint.d.ts +2 -0
- package/dist/runtime/pm/utils/pointToPmPoint.js +3 -0
- package/dist/runtime/pm/utils/splitIntoChunks.d.ts +32 -0
- package/dist/runtime/pm/utils/splitIntoChunks.js +31 -0
- package/dist/runtime/testDocuments.d.ts +53 -0
- package/dist/runtime/testDocuments.js +122 -0
- package/dist/runtime/types/index.d.ts +53 -0
- package/dist/runtime/types/index.js +9 -0
- package/dist/types.d.mts +3 -0
- package/package.json +238 -0
- package/src/module.ts +101 -0
- package/src/runtime/assets/base.css +83 -0
- package/src/runtime/assets/handle-arrow.svg +16 -0
- package/src/runtime/assets/handle-border-circles-single.svg +44 -0
- package/src/runtime/assets/handle-border-circles.svg +27 -0
- package/src/runtime/assets/handle-temp.svg +1 -0
- package/src/runtime/assets/utils.css +9 -0
- package/src/runtime/components/CodeBlockThemePicker.vue +125 -0
- package/src/runtime/components/Commands.vue +67 -0
- package/src/runtime/components/Editor.vue +330 -0
- package/src/runtime/components/EditorDemoApp.vue +118 -0
- package/src/runtime/components/EditorDemoControls.vue +38 -0
- package/src/runtime/components/TestWrapper.vue +74 -0
- package/src/runtime/composables/useEditor.ts +29 -0
- package/src/runtime/composables/useWindowDebugging.ts +20 -0
- package/src/runtime/demo/App.vue +114 -0
- package/src/runtime/demo/README.md +1 -0
- package/src/runtime/demo/main.ts +8 -0
- package/src/runtime/demo/tailwind.css +4 -0
- package/src/runtime/env.d.ts +2 -0
- package/src/runtime/injectionKeys.ts +10 -0
- package/src/runtime/main.lib.ts +2 -0
- package/src/runtime/pm/commands/backspace.ts +44 -0
- package/src/runtime/pm/commands/changeAttrs.ts +37 -0
- package/src/runtime/pm/commands/deleteSelection.ts +22 -0
- package/src/runtime/pm/commands/enter.ts +27 -0
- package/src/runtime/pm/commands/insertBreak.ts +40 -0
- package/src/runtime/pm/features/Base/Base.ts +39 -0
- package/src/runtime/pm/features/Base/commands/deleteNodes.ts +54 -0
- package/src/runtime/pm/features/Base/commands/setCursorVisible.ts +24 -0
- package/src/runtime/pm/features/Base/plugins/debugSelectionPlugin.ts +57 -0
- package/src/runtime/pm/features/Base/plugins/isCursorVisiblePlugin.ts +28 -0
- package/src/runtime/pm/features/Base/plugins/isUsingTouchPlugin.ts +40 -0
- package/src/runtime/pm/features/Base/plugins/selectingIndicator.ts +38 -0
- package/src/runtime/pm/features/Base/plugins/unfocusedSelectionIndicatorPlugin.ts +107 -0
- package/src/runtime/pm/features/Base/types.ts +3 -0
- package/src/runtime/pm/features/BaseShortcuts/BaseShortcuts.ts +39 -0
- package/src/runtime/pm/features/Blockquote/Blockquote.ts +75 -0
- package/src/runtime/pm/features/Blockquote/commands/blockquoteEnter.ts +51 -0
- package/src/runtime/pm/features/Blockquote/commands/blockquoteShiftEnter.ts +26 -0
- package/src/runtime/pm/features/Blocks/Blocks.ts +3 -0
- package/src/runtime/pm/features/Blocks/Item.ts +176 -0
- package/src/runtime/pm/features/Blocks/List.ts +67 -0
- package/src/runtime/pm/features/Blocks/commands/changeItemType.ts +64 -0
- package/src/runtime/pm/features/Blocks/commands/changeTypeAttr.ts +47 -0
- package/src/runtime/pm/features/Blocks/commands/copyOrMoveItem.ts +179 -0
- package/src/runtime/pm/features/Blocks/commands/deleteItem.ts +24 -0
- package/src/runtime/pm/features/Blocks/commands/indentItem.ts +105 -0
- package/src/runtime/pm/features/Blocks/commands/itemMenuCommands.ts +62 -0
- package/src/runtime/pm/features/Blocks/commands/moveItem.ts +128 -0
- package/src/runtime/pm/features/Blocks/commands/setNode.ts +186 -0
- package/src/runtime/pm/features/Blocks/commands/splitItem.ts +116 -0
- package/src/runtime/pm/features/Blocks/commands/unindentItem.ts +82 -0
- package/src/runtime/pm/features/Blocks/components/DragTreeHandle.vue +142 -0
- package/src/runtime/pm/features/Blocks/components/ItemMenu.vue +88 -0
- package/src/runtime/pm/features/Blocks/components/ItemNodeView.vue +394 -0
- package/src/runtime/pm/features/Blocks/components/defaultItemMenu.ts +45 -0
- package/src/runtime/pm/features/Blocks/composables/useDragWithThreshold.ts +0 -0
- package/src/runtime/pm/features/Blocks/composables/useHandleHeight.ts +28 -0
- package/src/runtime/pm/features/Blocks/composables/useHasChildren.ts +14 -0
- package/src/runtime/pm/features/Blocks/composables/useNodeStates.ts +29 -0
- package/src/runtime/pm/features/Blocks/itemMenuMenuItems.ts +143 -0
- package/src/runtime/pm/features/Blocks/plugins/ensureLastItemIsContentPlugin.ts +52 -0
- package/src/runtime/pm/features/Blocks/plugins/itemBlockIdPlugin.ts +40 -0
- package/src/runtime/pm/features/Blocks/plugins/itemHasSingularSelectionPlugin.ts +32 -0
- package/src/runtime/pm/features/Blocks/plugins/itemMenuPlugin.ts +21 -0
- package/src/runtime/pm/features/Blocks/states/stateful.ts +41 -0
- package/src/runtime/pm/features/Blocks/states/task/cancelled.svg +32 -0
- package/src/runtime/pm/features/Blocks/states/task/checked.svg +27 -0
- package/src/runtime/pm/features/Blocks/states/task/checked2.svg +24 -0
- package/src/runtime/pm/features/Blocks/states/task/partial.svg +24 -0
- package/src/runtime/pm/features/Blocks/states/task/partial2.svg +31 -0
- package/src/runtime/pm/features/Blocks/states/task/unchecked.svg +20 -0
- package/src/runtime/pm/features/Blocks/types.ts +51 -0
- package/src/runtime/pm/features/Blocks/utils/createItemMenuCommandExecuter.ts +47 -0
- package/src/runtime/pm/features/Blocks/utils/fixBlockIds.ts +28 -0
- package/src/runtime/pm/features/Blocks/utils/isValidId.ts +8 -0
- package/src/runtime/pm/features/CodeBlock/CodeBlock.ts +104 -0
- package/src/runtime/pm/features/CodeBlock/build/generateHighlightJsInfo.js +63 -0
- package/src/runtime/pm/features/CodeBlock/commands/codeBlockEnterOrSplit.ts +55 -0
- package/src/runtime/pm/features/CodeBlock/commands/codeBlockIndent.ts +67 -0
- package/src/runtime/pm/features/CodeBlock/commands/codeBlockUnindent.ts +74 -0
- package/src/runtime/pm/features/CodeBlock/commands/focusCodeBlockLanguage.ts +44 -0
- package/src/runtime/pm/features/CodeBlock/components/CodeBlockView.vue +126 -0
- package/src/runtime/pm/features/CodeBlock/composables/useAsyncCodeBlockHighlighting.ts +185 -0
- package/src/runtime/pm/features/CodeBlock/composables/useHighlightJsTheme.ts +150 -0
- package/src/runtime/pm/features/CodeBlock/highlightJsInfo.ts +733 -0
- package/src/runtime/pm/features/CodeBlock/types.ts +7 -0
- package/src/runtime/pm/features/Collaboration/Collaboration.ts +295 -0
- package/src/runtime/pm/features/CommandsMenus/CommandBar.ts +130 -0
- package/src/runtime/pm/features/CommandsMenus/commandBarMenuItems.ts +209 -0
- package/src/runtime/pm/features/CommandsMenus/components/CommandBar.vue +63 -0
- package/src/runtime/pm/features/CommandsMenus/components/CommandBarItem.vue +48 -0
- package/src/runtime/pm/features/CommandsMenus/components/CommandMenuGroup.vue +59 -0
- package/src/runtime/pm/features/CommandsMenus/components/CommandMenuItem.vue +67 -0
- package/src/runtime/pm/features/CommandsMenus/components/CommandMenuList.vue +60 -0
- package/src/runtime/pm/features/CommandsMenus/components/TextIcon.vue +14 -0
- package/src/runtime/pm/features/CommandsMenus/icons/HighlightIcon.vue +51 -0
- package/src/runtime/pm/features/CommandsMenus/icons/SubscriptIcon.vue +5 -0
- package/src/runtime/pm/features/CommandsMenus/icons/SuperscriptIcon.vue +5 -0
- package/src/runtime/pm/features/CommandsMenus/types.ts +73 -0
- package/src/runtime/pm/features/CommandsMenus/utils/defaultCommandExecutor.ts +22 -0
- package/src/runtime/pm/features/CommandsMenus/utils/findCommand.ts +37 -0
- package/src/runtime/pm/features/CommandsMenus/utils/popupPositionModifier.ts +14 -0
- package/src/runtime/pm/features/CommandsMenus/utils/popupVerticalPositioner.ts +16 -0
- package/src/runtime/pm/features/Document/Document.ts +9 -0
- package/src/runtime/pm/features/DocumentApi/DocumentApi.ts +272 -0
- package/src/runtime/pm/features/DocumentApi/composables/useEditorContent.ts +105 -0
- package/src/runtime/pm/features/DocumentApi/composables/useTestDocumentApi.ts +95 -0
- package/src/runtime/pm/features/DocumentApi/types.ts +143 -0
- package/src/runtime/pm/features/DocumentApi/utils/convertFullTransactionForPartialState.ts +54 -0
- package/src/runtime/pm/features/DocumentApi/utils/convertTrForInstance.ts +24 -0
- package/src/runtime/pm/features/DocumentApi/utils/convertTransactionForFullState.ts +39 -0
- package/src/runtime/pm/features/DocumentApi/utils/copyMeta.ts +8 -0
- package/src/runtime/pm/features/DocumentApi/utils/getEmbedJson.ts +16 -0
- package/src/runtime/pm/features/DocumentApi/utils/getEmbedNodeFromDoc.ts +15 -0
- package/src/runtime/pm/features/DocumentApi/utils/getStateEmbedRange.ts +26 -0
- package/src/runtime/pm/features/DocumentApi/utils/isEmbedId.ts +5 -0
- package/src/runtime/pm/features/EmbeddedDocument/Embedded.ts +110 -0
- package/src/runtime/pm/features/EmbeddedDocument/EmbeddedDocument.ts +102 -0
- package/src/runtime/pm/features/EmbeddedDocument/components/EmbeddedDocumentPicker.vue +188 -0
- package/src/runtime/pm/features/EmbeddedDocument/components/EmbeddedNodeView.vue +187 -0
- package/src/runtime/pm/features/EmbeddedDocument/composables/useEmbeddedEditor.ts +302 -0
- package/src/runtime/pm/features/EmbeddedDocument/types.ts +61 -0
- package/src/runtime/pm/features/EmbeddedDocument/utils/isEmbeddedBlock.ts +12 -0
- package/src/runtime/pm/features/EmbeddedDocument/utils/redirectFromEmbedded.ts +48 -0
- package/src/runtime/pm/features/FileLoader/FileLoader.ts +120 -0
- package/src/runtime/pm/features/FileLoader/FileLoaderHandler/FileLoaderHandler.ts +100 -0
- package/src/runtime/pm/features/FileLoader/FileLoaderHandler/TestFileLoaderHandler.ts +61 -0
- package/src/runtime/pm/features/FileLoader/commands/insertFile.ts +87 -0
- package/src/runtime/pm/features/FileLoader/components/FileLoaderNodeView.vue +38 -0
- package/src/runtime/pm/features/FileLoader/plugins/fileLoaderPlugin.ts +70 -0
- package/src/runtime/pm/features/FileLoader/types.ts +91 -0
- package/src/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNode.ts +39 -0
- package/src/runtime/pm/features/FileLoader/utils/cleanupFileLoaderNodes.ts +42 -0
- package/src/runtime/pm/features/FileLoader/utils/findLoadingNodePos.ts +16 -0
- package/src/runtime/pm/features/FileLoader/utils/optionsCheck.ts +16 -0
- package/src/runtime/pm/features/FileLoader/utils/readAsDataUrl.ts +12 -0
- package/src/runtime/pm/features/HardBreak/HardBreak.ts +21 -0
- package/src/runtime/pm/features/Heading/Heading.ts +130 -0
- package/src/runtime/pm/features/Heading/commands/changeLevelAttr.ts +55 -0
- package/src/runtime/pm/features/Heading/types.ts +17 -0
- package/src/runtime/pm/features/Highlight/Highlight.ts +234 -0
- package/src/runtime/pm/features/Highlight/retyped/tiptapHighlight.d.ts +3 -0
- package/src/runtime/pm/features/Highlight/retyped/tiptapHighlight.js +5 -0
- package/src/runtime/pm/features/Highlight/types.ts +25 -0
- package/src/runtime/pm/features/History/History.ts +112 -0
- package/src/runtime/pm/features/Iframe/Iframe.ts +163 -0
- package/src/runtime/pm/features/Iframe/IframeParsers.ts +116 -0
- package/src/runtime/pm/features/Iframe/components/IframeNodeView.vue +83 -0
- package/src/runtime/pm/features/Iframe/types.ts +7 -0
- package/src/runtime/pm/features/Image/Image.ts +16 -0
- package/src/runtime/pm/features/Link/Link.ts +313 -0
- package/src/runtime/pm/features/Link/components/BubbleMenuExternalLink.vue +125 -0
- package/src/runtime/pm/features/Link/components/BubbleMenuInternalLink.vue +130 -0
- package/src/runtime/pm/features/Link/components/BubbleMenuLink.vue +149 -0
- package/src/runtime/pm/features/Link/components/BubbleMenuLinkActions.vue +65 -0
- package/src/runtime/pm/features/Link/types.ts +53 -0
- package/src/runtime/pm/features/Menus/Menus.ts +195 -0
- package/src/runtime/pm/features/Menus/components/MarkMenuManager.vue +203 -0
- package/src/runtime/pm/features/Menus/types.ts +64 -0
- package/src/runtime/pm/features/Menus/utils/isMarkMenu.ts +5 -0
- package/src/runtime/pm/features/Tables/commands/tableEnter.ts +40 -0
- package/src/runtime/pm/features/Tables/index.ts +60 -0
- package/src/runtime/pm/schema.ts +128 -0
- package/src/runtime/pm/testSchema.ts +34 -0
- package/src/runtime/pm/utils/createDropIndicator.ts +61 -0
- package/src/runtime/pm/utils/createStateOnlyPluginApply.ts +11 -0
- package/src/runtime/pm/utils/createStateOnlyPluginObjApply.ts +16 -0
- package/src/runtime/pm/utils/dropPointInfo.ts +85 -0
- package/src/runtime/pm/utils/findUpwards.ts +43 -0
- package/src/runtime/pm/utils/getChildChunks.ts +24 -0
- package/src/runtime/pm/utils/getDiffReplacementRange.ts +32 -0
- package/src/runtime/pm/utils/getElMaxVisualSize.ts +14 -0
- package/src/runtime/pm/utils/getElPropertyAsInt.ts +8 -0
- package/src/runtime/pm/utils/getGroupNodeNames.ts +9 -0
- package/src/runtime/pm/utils/getMarkPosition.ts +57 -0
- package/src/runtime/pm/utils/getMarksInSelection.ts +19 -0
- package/src/runtime/pm/utils/getTypeByName.ts +7 -0
- package/src/runtime/pm/utils/index.ts +17 -0
- package/src/runtime/pm/utils/internal/createNodeTypesList.ts +25 -0
- package/src/runtime/pm/utils/internal/debugMap.ts +36 -0
- package/src/runtime/pm/utils/internal/debugNode.ts +38 -0
- package/src/runtime/pm/utils/internal/debugSel.ts +10 -0
- package/src/runtime/pm/utils/internal/recurse.ts +44 -0
- package/src/runtime/pm/utils/internal/stripBlockId.ts +10 -0
- package/src/runtime/pm/utils/mapSelection.ts +21 -0
- package/src/runtime/pm/utils/nodesBetween.ts +47 -0
- package/src/runtime/pm/utils/pointToPmPoint.ts +5 -0
- package/src/runtime/pm/utils/splitIntoChunks.ts +68 -0
- package/src/runtime/testDocuments.ts +130 -0
- package/src/runtime/types/index.ts +56 -0
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div
|
|
3
|
+
:class="twMerge(`
|
|
4
|
+
flex
|
|
5
|
+
gap-2
|
|
6
|
+
flex-wrap
|
|
7
|
+
p-2
|
|
8
|
+
`)"
|
|
9
|
+
>
|
|
10
|
+
<div
|
|
11
|
+
:class="twMerge(`
|
|
12
|
+
pb-2
|
|
13
|
+
flex
|
|
14
|
+
flex-wrap
|
|
15
|
+
gap-2
|
|
16
|
+
`,
|
|
17
|
+
|
|
18
|
+
(command.buttons?.length ?? 0) >1 && `
|
|
19
|
+
border
|
|
20
|
+
border-neutral-500
|
|
21
|
+
rounded-sm
|
|
22
|
+
w-full
|
|
23
|
+
p-2
|
|
24
|
+
`
|
|
25
|
+
)"
|
|
26
|
+
v-for="command of commands"
|
|
27
|
+
:key="command.key"
|
|
28
|
+
>
|
|
29
|
+
<div v-if="(command?.buttons?.[0]?.length ?? 0) >= 1">
|
|
30
|
+
{{ command.key }}
|
|
31
|
+
</div>
|
|
32
|
+
<WButton
|
|
33
|
+
v-for="args in command.buttons"
|
|
34
|
+
:key="command.key as string + pretty(args)"
|
|
35
|
+
@pointerdown="handlePointerDown($event, command, args)"
|
|
36
|
+
>
|
|
37
|
+
{{ (command?.buttons?.[0]?.length ?? 0) >= 1 ? '': command.key }}
|
|
38
|
+
{{ args.map(_ => pretty(_ as any)).join(' ') }}
|
|
39
|
+
</WButton>
|
|
40
|
+
</div>
|
|
41
|
+
</div>
|
|
42
|
+
</template>
|
|
43
|
+
|
|
44
|
+
<script lang="ts" setup>
|
|
45
|
+
import { pretty } from "@alanscodelog/utils"
|
|
46
|
+
import type { Editor, SingleCommands } from "@tiptap/core"
|
|
47
|
+
import WButton from "@witchcraft/ui/components/LibButton"
|
|
48
|
+
import { twMerge } from "tailwind-merge"
|
|
49
|
+
|
|
50
|
+
const props = defineProps<{
|
|
51
|
+
editor: Editor
|
|
52
|
+
commands: { key: keyof SingleCommands, buttons?: any[][] }[]
|
|
53
|
+
}>()
|
|
54
|
+
|
|
55
|
+
function handlePointerDown(
|
|
56
|
+
$event: MouseEvent,
|
|
57
|
+
command: { key: keyof SingleCommands, buttons?: any[][] },
|
|
58
|
+
args: any[]
|
|
59
|
+
) {
|
|
60
|
+
$event.preventDefault()
|
|
61
|
+
$event.stopPropagation()
|
|
62
|
+
const commandFunc = (props.editor.chain().focus()[command.key] as any)(...args)
|
|
63
|
+
if (typeof commandFunc === "object") {
|
|
64
|
+
commandFunc.run()
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
</script>
|
|
@@ -0,0 +1,330 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div
|
|
3
|
+
:class="twMerge(`
|
|
4
|
+
editor-wrapper
|
|
5
|
+
[counter-reset:none]
|
|
6
|
+
flex-1
|
|
7
|
+
w-full
|
|
8
|
+
`,
|
|
9
|
+
isEmbedded && `p-1`,
|
|
10
|
+
isScrolling && `
|
|
11
|
+
relative
|
|
12
|
+
after:content-['']
|
|
13
|
+
after:absolute
|
|
14
|
+
after:inset-0
|
|
15
|
+
after:border-[length:var(--pmDragScrollMargin)]
|
|
16
|
+
after:border-transparent
|
|
17
|
+
after:pointer-events-none
|
|
18
|
+
`,
|
|
19
|
+
scrollIndicator.right && `after:border-r-accent-500/60`,
|
|
20
|
+
scrollIndicator.down && `after:border-b-accent-500/60`,
|
|
21
|
+
scrollIndicator.left && `after:border-l-accent-500/60`,
|
|
22
|
+
scrollIndicator.up && `after:border-t-accent-500/60`
|
|
23
|
+
)"
|
|
24
|
+
:data-code-blocks-theme-is-dark="codeBlocksThemeIsDark"
|
|
25
|
+
:style="`${cssVariablesString}`"
|
|
26
|
+
v-bind="$attrs"
|
|
27
|
+
>
|
|
28
|
+
<!-- The class `is-embedded-block` is not needed internally, but is added for consistency in case it might be useful. -->
|
|
29
|
+
<!-- @vue-expect-error -->
|
|
30
|
+
<editor-content
|
|
31
|
+
:editor="editor! as any"
|
|
32
|
+
spellcheck="false"
|
|
33
|
+
:class="twMerge(`
|
|
34
|
+
w-full flex-1
|
|
35
|
+
p-2
|
|
36
|
+
pl-6
|
|
37
|
+
[&>.ProseMirror]:outline-hidden
|
|
38
|
+
overflow-auto
|
|
39
|
+
`,
|
|
40
|
+
isEmbedded && `editor-is-embedded`,
|
|
41
|
+
isEmbeddedBlock && `editor-is-embedded-block`
|
|
42
|
+
)"
|
|
43
|
+
v-extract-root-el="(el:HTMLElement) => editorContainerEl = el"
|
|
44
|
+
/>
|
|
45
|
+
<MarkMenuManager
|
|
46
|
+
v-if="editor && !finalEditorOptions?.editable"
|
|
47
|
+
:editor="editor as any"
|
|
48
|
+
/>
|
|
49
|
+
<ItemMenu
|
|
50
|
+
v-if="editor"
|
|
51
|
+
:editor="editor as any"
|
|
52
|
+
/>
|
|
53
|
+
</div>
|
|
54
|
+
</template>
|
|
55
|
+
|
|
56
|
+
<script lang="ts" setup>
|
|
57
|
+
import { keys } from "@alanscodelog/utils"
|
|
58
|
+
import type { Content, EditorOptions } from "@tiptap/core"
|
|
59
|
+
import { EditorContent } from "@tiptap/vue-3"
|
|
60
|
+
import { useScrollNearContainerEdges } from "@witchcraft/ui/composables/useScrollNearContainerEdges"
|
|
61
|
+
import { vExtractRootEl } from "@witchcraft/ui/directives/vExtractRootEl"
|
|
62
|
+
import type { ScrollNearContainerEdgesOptions } from "@witchcraft/ui/types/index"
|
|
63
|
+
import { twMerge } from "@witchcraft/ui/utils/twMerge"
|
|
64
|
+
import { computed, type ComputedRef, inject, provide, ref, toRef, toRefs, watch } from "vue"
|
|
65
|
+
|
|
66
|
+
import handleCollapseIndicatorImage from "../assets/handle-arrow.svg"
|
|
67
|
+
import handleImage from "../assets/handle-border-circles-single.svg"
|
|
68
|
+
import { useEditor } from "../composables/useEditor.js"
|
|
69
|
+
import { useWindowDebugging } from "../composables/useWindowDebugging.js"
|
|
70
|
+
import { editorCssVariablesInjectionKey, editorScrollInjectionKey } from "../injectionKeys.js"
|
|
71
|
+
import ItemMenu from "../pm/features/Blocks/components/ItemMenu.vue"
|
|
72
|
+
import { statefulStates } from "../pm/features/Blocks/states/stateful.js"
|
|
73
|
+
import { statesInjectionKey } from "../pm/features/Blocks/types"
|
|
74
|
+
import { lowlightInstance } from "../pm/features/CodeBlock/CodeBlock.js"
|
|
75
|
+
import { useAsyncCodeBlockHighlighting } from "../pm/features/CodeBlock/composables/useAsyncCodeBlockHighlighting"
|
|
76
|
+
import { codeBlockThemeIsDarkInjectionKey } from "../pm/features/CodeBlock/types"
|
|
77
|
+
import { useEditorContent } from "../pm/features/DocumentApi/composables/useEditorContent"
|
|
78
|
+
import { documentApiInjectionKey, type DocumentApiInterface } from "../pm/features/DocumentApi/types.js"
|
|
79
|
+
import { embededEditorOptionsInjectionKey, isEmbeddedBlockInjectionKey, isEmbeddedInjectionKey, parentEditorIdInjectionKey } from "../pm/features/EmbeddedDocument/types"
|
|
80
|
+
import type { EditorLinkOptions } from "../pm/features/Link/types"
|
|
81
|
+
import MarkMenuManager from "../pm/features/Menus/components/MarkMenuManager.vue"
|
|
82
|
+
import { extensions } from "../pm/schema.js"
|
|
83
|
+
import { type CssVariables, type MenuRenderInfo, menusInjectionKey } from "../types/index.js"
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
const props = withDefaults(defineProps<
|
|
87
|
+
{
|
|
88
|
+
/** The content for the editor. It is better to use docId and the documentApi instead. */
|
|
89
|
+
content?: Content
|
|
90
|
+
docId?: string
|
|
91
|
+
/** The document api, required for the root editor if using nested embeds. This is provided as the documentApi using the documentApiInjectionKey. */
|
|
92
|
+
documentApi?: DocumentApiInterface
|
|
93
|
+
/** The link options, required for the root editor. Not required for embedded editors. */
|
|
94
|
+
linkOptions?: EditorLinkOptions
|
|
95
|
+
/** See my component library's (@witchcraft/ui) useScrollNearContainerEdges composable for more info. */
|
|
96
|
+
dragScrollOptions?: Pick<
|
|
97
|
+
ScrollNearContainerEdgesOptions,
|
|
98
|
+
"scrollMargin" | "outerScrollMargin" | "fastPixelMultiplier"
|
|
99
|
+
>
|
|
100
|
+
cssVariables?: Partial<CssVariables>
|
|
101
|
+
editorOptions?: Partial<EditorOptions>
|
|
102
|
+
codeBlocksThemeIsDark?: boolean
|
|
103
|
+
menus?: Record<string, MenuRenderInfo>
|
|
104
|
+
}>(), {
|
|
105
|
+
codeBlocksThemeIsDark: false,
|
|
106
|
+
content: undefined,
|
|
107
|
+
docId: undefined,
|
|
108
|
+
documentApi: undefined,
|
|
109
|
+
linkOptions: undefined,
|
|
110
|
+
cssVariables: () => ({ }),
|
|
111
|
+
editorOptions: () => ({
|
|
112
|
+
// todo user configurable
|
|
113
|
+
enablePasteRules: true,
|
|
114
|
+
enableInputRules: true
|
|
115
|
+
}),
|
|
116
|
+
dragScrollOptions: () => ({
|
|
117
|
+
scrollMargin: 15,
|
|
118
|
+
outerScrollMargin: 15,
|
|
119
|
+
fastPixelMultiplier: 8
|
|
120
|
+
}),
|
|
121
|
+
menus: () => ({})
|
|
122
|
+
})
|
|
123
|
+
const editorContainerEl = ref<HTMLElement | null>(null)
|
|
124
|
+
const scroll = useScrollNearContainerEdges({
|
|
125
|
+
containerEl: editorContainerEl,
|
|
126
|
+
...props.dragScrollOptions
|
|
127
|
+
})
|
|
128
|
+
const {
|
|
129
|
+
isScrolling,
|
|
130
|
+
scrollIndicator
|
|
131
|
+
} = scroll
|
|
132
|
+
provide(editorScrollInjectionKey, scroll)
|
|
133
|
+
|
|
134
|
+
const isEmbedded = inject(isEmbeddedInjectionKey, false)
|
|
135
|
+
const isEmbeddedBlock = inject(isEmbeddedBlockInjectionKey, ref(false))
|
|
136
|
+
const cssVariables = computed(() => (isEmbedded
|
|
137
|
+
? {}
|
|
138
|
+
: {
|
|
139
|
+
pmUnfocusedSelectionColor: "rgb(129,163,234)",
|
|
140
|
+
pmNodeTypeMargin: "var(--dragHandleMargin)",
|
|
141
|
+
pmCodeBlockBgColor: "",
|
|
142
|
+
pmMaxEmbedWidth: "800px",
|
|
143
|
+
pmDragScrollMargin: `${props.dragScrollOptions.scrollMargin}px`,
|
|
144
|
+
dragHandleSize: "9px",
|
|
145
|
+
dragHandleMargin: "5px",
|
|
146
|
+
dragHandleImage: `url("${handleImage}")`,
|
|
147
|
+
dragHandleCollapseIndicatorImage: `url("${handleCollapseIndicatorImage}")`,
|
|
148
|
+
...props.cssVariables
|
|
149
|
+
} satisfies CssVariables))
|
|
150
|
+
const cssVariablesString = computed(() => keys(cssVariables.value)
|
|
151
|
+
.map(key => `--${key}: ${cssVariables.value[key]};`).join(""))
|
|
152
|
+
|
|
153
|
+
// const linkOptions = toRef(props, "linkOptions")
|
|
154
|
+
const menus = toRef(props, "menus")
|
|
155
|
+
|
|
156
|
+
const alreadyProvidedDocumentApi = inject(documentApiInjectionKey, undefined)
|
|
157
|
+
if (!isEmbedded) {
|
|
158
|
+
const statefulStatesRef = ref(statefulStates)
|
|
159
|
+
const alreadyProvidedStatefulStates = inject(statesInjectionKey, undefined)
|
|
160
|
+
if (!alreadyProvidedStatefulStates) {
|
|
161
|
+
provide(statesInjectionKey, statefulStatesRef)
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
const codeBlockThemeIsDark = toRef(props, "codeBlocksThemeIsDark")
|
|
165
|
+
const alreadyProvidedCodeBlockThemeIsDark = inject(codeBlockThemeIsDarkInjectionKey, undefined)
|
|
166
|
+
if (!alreadyProvidedCodeBlockThemeIsDark) {
|
|
167
|
+
provide(codeBlockThemeIsDarkInjectionKey, codeBlockThemeIsDark)
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
const alreadyProvidedEditorCssVariables = inject(editorCssVariablesInjectionKey, undefined)
|
|
171
|
+
if (!alreadyProvidedEditorCssVariables) {
|
|
172
|
+
provide(editorCssVariablesInjectionKey, cssVariables as ComputedRef<CssVariables>)
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (props.documentApi && !alreadyProvidedDocumentApi) {
|
|
176
|
+
provide(documentApiInjectionKey, props.documentApi)
|
|
177
|
+
}
|
|
178
|
+
if (menus.value) {
|
|
179
|
+
provide(menusInjectionKey, menus)
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
const finalEditorOptions: Partial<EditorOptions> = {
|
|
184
|
+
enableInputRules: true,
|
|
185
|
+
enablePasteRules: true,
|
|
186
|
+
...props.editorOptions,
|
|
187
|
+
// force extensions to be their own instance per embedded editor
|
|
188
|
+
// see https://github.com/ueberdosis/tiptap/issues/4317
|
|
189
|
+
// and https://github.com/ueberdosis/tiptap/issues/2694
|
|
190
|
+
extensions: (props.editorOptions?.extensions ?? extensions) as any,
|
|
191
|
+
autofocus: isEmbedded ? false : (props.editorOptions?.autofocus ?? true),
|
|
192
|
+
injectCSS: false
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
provide(embededEditorOptionsInjectionKey, finalEditorOptions as any)
|
|
196
|
+
|
|
197
|
+
const emit = defineEmits<{
|
|
198
|
+
(e: "load"): void
|
|
199
|
+
(e: "unload"): void
|
|
200
|
+
}>()
|
|
201
|
+
|
|
202
|
+
const { editor, recreate } = useEditor(finalEditorOptions as any)
|
|
203
|
+
|
|
204
|
+
watch(editor, newVal => {
|
|
205
|
+
if (newVal) {
|
|
206
|
+
// we can't just use immediate: true because the editor is not yet mounted
|
|
207
|
+
if (props.linkOptions) {
|
|
208
|
+
editor.value!.commands.setLinkOpts(props.linkOptions)
|
|
209
|
+
}
|
|
210
|
+
emit("load")
|
|
211
|
+
}
|
|
212
|
+
})
|
|
213
|
+
useWindowDebugging(editor)
|
|
214
|
+
|
|
215
|
+
/* const { langsInfo } = */useAsyncCodeBlockHighlighting({
|
|
216
|
+
lowlightInstance,
|
|
217
|
+
editor
|
|
218
|
+
})
|
|
219
|
+
|
|
220
|
+
watch(() => props.editorOptions, newVal => {
|
|
221
|
+
if (newVal) {
|
|
222
|
+
editor.value?.setOptions(newVal as any)
|
|
223
|
+
}
|
|
224
|
+
}, { deep: true })
|
|
225
|
+
|
|
226
|
+
watch(() => props.linkOptions, newVal => {
|
|
227
|
+
if (!isEmbedded) {
|
|
228
|
+
if (newVal) {
|
|
229
|
+
editor.value?.commands.setLinkOpts(newVal)
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
}, { deep: true })
|
|
233
|
+
|
|
234
|
+
const {
|
|
235
|
+
content,
|
|
236
|
+
docId
|
|
237
|
+
} = toRefs(props)
|
|
238
|
+
|
|
239
|
+
useEditorContent(
|
|
240
|
+
editor,
|
|
241
|
+
content,
|
|
242
|
+
docId,
|
|
243
|
+
props.documentApi ?? alreadyProvidedDocumentApi,
|
|
244
|
+
recreate
|
|
245
|
+
)
|
|
246
|
+
|
|
247
|
+
provide(parentEditorIdInjectionKey, docId)
|
|
248
|
+
|
|
249
|
+
defineExpose({
|
|
250
|
+
editor
|
|
251
|
+
})
|
|
252
|
+
</script>
|
|
253
|
+
|
|
254
|
+
<style>
|
|
255
|
+
a {
|
|
256
|
+
text-decoration: underline !important;
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
.ProseMirror {
|
|
260
|
+
position: relative;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
.ProseMirror {
|
|
264
|
+
word-wrap: break-word;
|
|
265
|
+
white-space: pre-wrap;
|
|
266
|
+
white-space: break-spaces;
|
|
267
|
+
-webkit-font-variant-ligatures: none;
|
|
268
|
+
font-variant-ligatures: none;
|
|
269
|
+
font-feature-settings: "liga" 0; /* the above doesn't seem to work in Edge */
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
.ProseMirror [contenteditable="false"] {
|
|
273
|
+
white-space: normal;
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
.ProseMirror [contenteditable="false"] [contenteditable="true"] {
|
|
277
|
+
white-space: pre-wrap;
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
.ProseMirror pre {
|
|
281
|
+
white-space: pre-wrap;
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
img.ProseMirror-separator {
|
|
285
|
+
display: inline !important;
|
|
286
|
+
border: none !important;
|
|
287
|
+
margin: 0 !important;
|
|
288
|
+
width: 0 !important;
|
|
289
|
+
height: 0 !important;
|
|
290
|
+
}
|
|
291
|
+
|
|
292
|
+
@keyframes ProseMirror-cursor-blink {
|
|
293
|
+
to {
|
|
294
|
+
visibility: hidden;
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
.ProseMirror-gapcursor {
|
|
298
|
+
display: none;
|
|
299
|
+
pointer-events: none;
|
|
300
|
+
position:relative;
|
|
301
|
+
}
|
|
302
|
+
ul > .ProseMirror-gapcursor {
|
|
303
|
+
@apply pl-[calc(var(--dragHandleSize)+var(--dragHandleMargin)+var(--spacing-1))];
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
.ProseMirror-gapcursor:after {
|
|
307
|
+
content: "";
|
|
308
|
+
display: block;
|
|
309
|
+
position: absolute;
|
|
310
|
+
top: -2px;
|
|
311
|
+
width: 20px;
|
|
312
|
+
border-top: 1px solid black;
|
|
313
|
+
animation: ProseMirror-cursor-blink 1.1s steps(2, start) infinite;
|
|
314
|
+
}
|
|
315
|
+
.ProseMirror-focused .ProseMirror-gapcursor {
|
|
316
|
+
display: block;
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
.ProseMirror-hideselection *::selection {
|
|
320
|
+
background: transparent;
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
.ProseMirror-hideselection *::-moz-selection {
|
|
324
|
+
background: transparent;
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
.ProseMirror-hideselection * {
|
|
328
|
+
caret-color: transparent;
|
|
329
|
+
}
|
|
330
|
+
</style>
|
|
@@ -0,0 +1,118 @@
|
|
|
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 lang="ts">
|
|
41
|
+
// all imports must be explicit so this also works without nuxt
|
|
42
|
+
import type { EditorOptions } from "@tiptap/core"
|
|
43
|
+
import WRoot from "@witchcraft/ui/components/LibRoot"
|
|
44
|
+
import { reactive, ref, shallowRef } from "vue"
|
|
45
|
+
|
|
46
|
+
import Editor from "./Editor.vue"
|
|
47
|
+
import EditorDemoControls from "./EditorDemoControls.vue"
|
|
48
|
+
|
|
49
|
+
import { useHighlightJsTheme } from "../pm/features/CodeBlock/composables/useHighlightJsTheme.js"
|
|
50
|
+
import { defaultCommandBarMenuItems } from "../pm/features/CommandsMenus/commandBarMenuItems.js"
|
|
51
|
+
import CommandBar from "../pm/features/CommandsMenus/components/CommandBar.vue"
|
|
52
|
+
import { useTestDocumentApi } from "../pm/features/DocumentApi/composables/useTestDocumentApi.js"
|
|
53
|
+
import BubbleMenuLink from "../pm/features/Link/components/BubbleMenuLink.vue"
|
|
54
|
+
import type { EditorLinkOptions } from "../pm/features/Link/types.js"
|
|
55
|
+
import type { MenuRenderInfo } from "../pm/features/Menus/types"
|
|
56
|
+
import { testExtensions } from "../pm/testSchema.js"
|
|
57
|
+
import { testDocuments } from "../testDocuments.js"
|
|
58
|
+
|
|
59
|
+
const {
|
|
60
|
+
theme: codeBlocksTheme,
|
|
61
|
+
knownThemes: codeBlocksThemeList,
|
|
62
|
+
themeCss: codeBlocksThemeCss,
|
|
63
|
+
isDark: codeBlocksThemeIsDark,
|
|
64
|
+
backgroundColor: codeBlocksThemeBgColor
|
|
65
|
+
} = useHighlightJsTheme()
|
|
66
|
+
|
|
67
|
+
const editorOptions: Partial<EditorOptions> = {
|
|
68
|
+
extensions: testExtensions as any
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const linkOptions: EditorLinkOptions = {
|
|
72
|
+
openInternal: href => {
|
|
73
|
+
window.alert(`This would open an internal link to ${href}.`)
|
|
74
|
+
|
|
75
|
+
// eslint-disable-next-line no-console
|
|
76
|
+
console.log(`Would open internal link to ${href}.`)
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
const fakeSuggestions = reactive<string[]>(["some", "suggestions"])
|
|
80
|
+
|
|
81
|
+
const menus = shallowRef<Record<string, MenuRenderInfo>>({
|
|
82
|
+
linkMenu: {
|
|
83
|
+
component: BubbleMenuLink,
|
|
84
|
+
props: editor => ({
|
|
85
|
+
editor,
|
|
86
|
+
linkSuggestions: fakeSuggestions,
|
|
87
|
+
getInternalLinkHref(href: string) {
|
|
88
|
+
return `internal://${href.replace(/[^\w-]/g, "")}`
|
|
89
|
+
}
|
|
90
|
+
})
|
|
91
|
+
},
|
|
92
|
+
commandBar: {
|
|
93
|
+
component: CommandBar,
|
|
94
|
+
props: editor => ({
|
|
95
|
+
editor,
|
|
96
|
+
commands: defaultCommandBarMenuItems.commands
|
|
97
|
+
}),
|
|
98
|
+
popupOptions: {
|
|
99
|
+
pinToItemDistance: state => {
|
|
100
|
+
const { $from, $to } = state.selection
|
|
101
|
+
const fromNode = $from.node(-1)
|
|
102
|
+
const toNode = $to.node(-1)
|
|
103
|
+
// tables don't support selections outside of each cell, so no need to check we're in the same table or anything
|
|
104
|
+
if (fromNode.type !== toNode.type) {
|
|
105
|
+
return 0
|
|
106
|
+
}
|
|
107
|
+
return (fromNode.type.name.startsWith("table")) ? 120 : 0
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
})
|
|
112
|
+
|
|
113
|
+
const { documentApi } = useTestDocumentApi(
|
|
114
|
+
editorOptions as any,
|
|
115
|
+
testDocuments
|
|
116
|
+
)
|
|
117
|
+
const docId = ref("root")
|
|
118
|
+
</script>
|
|
@@ -0,0 +1,38 @@
|
|
|
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 lang="ts">
|
|
30
|
+
import WDarkModeSwitcher from "@witchcraft/ui/components/LibDarkModeSwitcher"
|
|
31
|
+
|
|
32
|
+
import CodeBlockThemePicker from "./CodeBlockThemePicker.vue"
|
|
33
|
+
|
|
34
|
+
defineProps<{
|
|
35
|
+
codeBlocksThemeList: string[]
|
|
36
|
+
}>()
|
|
37
|
+
const codeBlocksTheme = defineModel<string>("codeBlocksTheme", { required: true })
|
|
38
|
+
</script>
|
|
@@ -0,0 +1,74 @@
|
|
|
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 lang="ts">
|
|
18
|
+
import type { Editor as TipTapEditor, EditorOptions } from "@tiptap/core"
|
|
19
|
+
import WRoot from "@witchcraft/ui/components/LibRoot"
|
|
20
|
+
import { ref, watchEffect } from "vue"
|
|
21
|
+
|
|
22
|
+
import Editor from "./Editor.vue"
|
|
23
|
+
|
|
24
|
+
import { useTestDocumentApi } from "../pm/features/DocumentApi/composables/useTestDocumentApi.js"
|
|
25
|
+
import type { EditorLinkOptions } from "../pm/features/Link/types.js"
|
|
26
|
+
import { testExtensions } from "../pm/testSchema.js"
|
|
27
|
+
|
|
28
|
+
const props = defineProps<{
|
|
29
|
+
// helps ensure we don't have problems with tests when one fails (unmount is never called and the next test gets confused, things there's duplicate elements)
|
|
30
|
+
testId: string
|
|
31
|
+
documents: Record<string, { title: string, content: string }>
|
|
32
|
+
docId: string
|
|
33
|
+
loadDelay?: number
|
|
34
|
+
}>()
|
|
35
|
+
|
|
36
|
+
const editorOptions: Partial<EditorOptions> = {
|
|
37
|
+
extensions: testExtensions.map(ext => {
|
|
38
|
+
if (ext.name === "item") {
|
|
39
|
+
return ext.configure({
|
|
40
|
+
ensureLastItemIsParagraph: false
|
|
41
|
+
} as any)
|
|
42
|
+
}
|
|
43
|
+
return ext
|
|
44
|
+
}) as any,
|
|
45
|
+
enableCoreExtensions: {
|
|
46
|
+
keymap: false
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
const { documentApi } = useTestDocumentApi(
|
|
50
|
+
editorOptions as any,
|
|
51
|
+
props.documents,
|
|
52
|
+
{ loadDelay: props.loadDelay }
|
|
53
|
+
|
|
54
|
+
)
|
|
55
|
+
|
|
56
|
+
const linkOptions: EditorLinkOptions = {
|
|
57
|
+
openInternal: () => {
|
|
58
|
+
// eslint-disable-next-line no-console
|
|
59
|
+
console.log("openning internal")
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
const editor = ref<TipTapEditor | null>(null)
|
|
63
|
+
|
|
64
|
+
watchEffect(() => {
|
|
65
|
+
if (editor.value) {
|
|
66
|
+
// todo declare global
|
|
67
|
+
;(window as any)[`editor-${props.testId}`] = editor.value
|
|
68
|
+
}
|
|
69
|
+
})
|
|
70
|
+
</script>
|
|
71
|
+
|
|
72
|
+
<style>
|
|
73
|
+
@reference "../demo/tailwind.css"
|
|
74
|
+
</style>
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { EditorOptions } from "@tiptap/core"
|
|
2
|
+
import { Editor } from "@tiptap/core"
|
|
3
|
+
import { onBeforeUnmount, shallowRef } from "vue"
|
|
4
|
+
/**
|
|
5
|
+
* 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.
|
|
6
|
+
*/
|
|
7
|
+
export const useEditor = (options: Partial<EditorOptions> = {}) => {
|
|
8
|
+
const editor = shallowRef<Editor>()
|
|
9
|
+
function recreate(
|
|
10
|
+
modifyOptions?: (options: Partial<EditorOptions>) => Partial<EditorOptions>
|
|
11
|
+
): void {
|
|
12
|
+
options = modifyOptions?.(options) ?? options
|
|
13
|
+
editor.value?.destroy()
|
|
14
|
+
editor.value = new Editor(options)
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
// copied from tiptap
|
|
18
|
+
onBeforeUnmount(() => {
|
|
19
|
+
// Cloning root node (and its children) to avoid content being lost by destroy
|
|
20
|
+
const nodes = editor.value?.options.element
|
|
21
|
+
const newEl = nodes?.cloneNode(true) as HTMLElement
|
|
22
|
+
|
|
23
|
+
nodes?.parentNode?.replaceChild(newEl, nodes)
|
|
24
|
+
|
|
25
|
+
editor.value?.destroy()
|
|
26
|
+
})
|
|
27
|
+
|
|
28
|
+
return { editor, recreate }
|
|
29
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { Editor } from "@tiptap/core"
|
|
2
|
+
import type { ShallowRef } from "vue"
|
|
3
|
+
import { watch } from "vue"
|
|
4
|
+
|
|
5
|
+
import { debugNode } from "../pm/utils/internal/debugNode.js"
|
|
6
|
+
import { nodesBetween } from "../pm/utils/nodesBetween.js"
|
|
7
|
+
|
|
8
|
+
export const useWindowDebugging = (editor: ShallowRef<Editor | undefined>): void => {
|
|
9
|
+
watch(editor, () => {
|
|
10
|
+
if (!editor.value) return
|
|
11
|
+
if (typeof window === "undefined" || typeof process === "undefined") return
|
|
12
|
+
if (process.env.NODE_ENV === "development" && editor.value !== undefined) {
|
|
13
|
+
const w = window as any
|
|
14
|
+
w.editor = editor.value
|
|
15
|
+
w.tr = () => editor.value!.state.tr
|
|
16
|
+
w.debugNode = debugNode
|
|
17
|
+
w.nodesBetween = nodesBetween
|
|
18
|
+
}
|
|
19
|
+
})
|
|
20
|
+
}
|