@canonical/react-ds-app-launchpad 0.9.0-experimental.9 → 0.9.0
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/esm/ui/DiffChangeMarker/DiffChangeMarker.js +47 -0
- package/dist/esm/ui/DiffChangeMarker/DiffChangeMarker.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.js +8 -0
- package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/index.js +4 -0
- package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/index.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/styles.css +21 -0
- package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/types.js +2 -0
- package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/types.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.js +11 -0
- package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/index.js +4 -0
- package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/index.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/styles.css +29 -0
- package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/types.js +2 -0
- package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/types.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/common/index.js +3 -0
- package/dist/esm/ui/DiffChangeMarker/common/index.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/icons.js +5 -0
- package/dist/esm/ui/DiffChangeMarker/icons.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/index.js +4 -0
- package/dist/esm/ui/DiffChangeMarker/index.js.map +1 -0
- package/dist/esm/ui/DiffChangeMarker/styles.css +30 -0
- package/dist/esm/ui/DiffChangeMarker/types.js +2 -0
- package/dist/esm/ui/DiffChangeMarker/types.js.map +1 -0
- package/dist/esm/ui/EditableBlock/EditableBlock.js +5 -3
- package/dist/esm/ui/EditableBlock/EditableBlock.js.map +1 -1
- package/dist/esm/ui/EditableBlock/styles.css +0 -3
- package/dist/esm/ui/FileTree/Provider.js +3 -3
- package/dist/esm/ui/FileTree/Provider.js.map +1 -1
- package/dist/esm/ui/FileTree/common/Node/Provider.js +3 -1
- package/dist/esm/ui/FileTree/common/Node/Provider.js.map +1 -1
- package/dist/esm/ui/FileTree/common/Node/styles.css +12 -16
- package/dist/esm/ui/FileTree/common/SearchBox/SearchBox.js +1 -1
- package/dist/esm/ui/FileTree/common/SearchBox/SearchBox.js.map +1 -1
- package/dist/esm/ui/FileTree/common/SearchBox/styles.css +11 -11
- package/dist/esm/ui/FileTree/styles.css +16 -4
- package/dist/esm/ui/GitDiffViewer/Provider.js +7 -11
- package/dist/esm/ui/GitDiffViewer/Provider.js.map +1 -1
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.js +38 -83
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.js.map +1 -1
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/HighlighTheme.css +170 -171
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.js +38 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.js.map +1 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.js +4 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.js.map +1 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/styles.css +15 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.js +3 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.js.map +1 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.js +11 -8
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.js.map +1 -1
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/styles.css +16 -9
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.js +3 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.js.map +1 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/constants.js +2 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/constants.js.map +1 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/index.js +1 -0
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/index.js.map +1 -1
- package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/styles.css +4 -16
- package/dist/esm/ui/GitDiffViewer/common/FileHeader/FileHeader.js +3 -2
- package/dist/esm/ui/GitDiffViewer/common/FileHeader/FileHeader.js.map +1 -1
- package/dist/esm/ui/GitDiffViewer/common/FileHeader/styles.css +6 -25
- package/dist/esm/ui/GitDiffViewer/index.js.map +1 -1
- package/dist/esm/ui/GitDiffViewer/styles.css +3 -15
- package/dist/esm/ui/GitDiffViewer/utils/highlightDiffHunkLines.js +52 -0
- package/dist/esm/ui/GitDiffViewer/utils/highlightDiffHunkLines.js.map +1 -0
- package/dist/esm/ui/GitDiffViewer/utils/index.js +1 -0
- package/dist/esm/ui/GitDiffViewer/utils/index.js.map +1 -1
- package/dist/esm/ui/GitDiffViewer/utils/parseGitDiff.js +27 -4
- package/dist/esm/ui/GitDiffViewer/utils/parseGitDiff.js.map +1 -1
- package/dist/esm/ui/MarkdownEditor/MarkdownEditor.js +75 -0
- package/dist/esm/ui/MarkdownEditor/MarkdownEditor.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/Toolbar.js +52 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/Toolbar.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/Button.js +19 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/Button.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/index.js +4 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/styles.css +17 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/types.js +2 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/types.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/Group.js +13 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/Group.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/index.js +4 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/styles.css +7 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/types.js +2 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/types.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.js +13 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/index.js +4 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/styles.css +7 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/types.js +2 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/types.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/index.js +4 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/index.js +9 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/styles.css +16 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/types.js +2 -0
- package/dist/esm/ui/MarkdownEditor/common/Toolbar/types.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.js +34 -0
- package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/index.js +4 -0
- package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/styles.css +42 -0
- package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/types.js +2 -0
- package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/types.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/icons.js +10 -0
- package/dist/esm/ui/MarkdownEditor/common/icons.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/common/index.js +4 -0
- package/dist/esm/ui/MarkdownEditor/common/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/hooks/index.js +2 -0
- package/dist/esm/ui/MarkdownEditor/hooks/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/hooks/useEditor.js +274 -0
- package/dist/esm/ui/MarkdownEditor/hooks/useEditor.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/index.js +4 -0
- package/dist/esm/ui/MarkdownEditor/index.js.map +1 -0
- package/dist/esm/ui/MarkdownEditor/styles.css +83 -0
- package/dist/esm/ui/MarkdownEditor/types.js +2 -0
- package/dist/esm/ui/MarkdownEditor/types.js.map +1 -0
- package/dist/esm/ui/RelativeTime/utils/formatHumanTime.js +1 -1
- package/dist/esm/ui/RelativeTime/utils/formatHumanTime.js.map +1 -1
- package/dist/esm/ui/RelativeTime/utils/getOptimalUpdateInterval.js +1 -1
- package/dist/esm/ui/RelativeTime/utils/getOptimalUpdateInterval.js.map +1 -1
- package/dist/esm/ui/index.js +2 -0
- package/dist/esm/ui/index.js.map +1 -1
- package/dist/types/ui/DiffChangeMarker/DiffChangeMarker.d.ts +11 -0
- package/dist/types/ui/DiffChangeMarker/DiffChangeMarker.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.d.ts +6 -0
- package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/index.d.ts +3 -0
- package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/index.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/types.d.ts +10 -0
- package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/types.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.d.ts +6 -0
- package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/index.d.ts +3 -0
- package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/index.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/types.d.ts +9 -0
- package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/types.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/common/index.d.ts +3 -0
- package/dist/types/ui/DiffChangeMarker/common/index.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/icons.d.ts +4 -0
- package/dist/types/ui/DiffChangeMarker/icons.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/index.d.ts +3 -0
- package/dist/types/ui/DiffChangeMarker/index.d.ts.map +1 -0
- package/dist/types/ui/DiffChangeMarker/types.d.ts +18 -0
- package/dist/types/ui/DiffChangeMarker/types.d.ts.map +1 -0
- package/dist/types/ui/EditableBlock/EditableBlock.d.ts +1 -1
- package/dist/types/ui/EditableBlock/EditableBlock.d.ts.map +1 -1
- package/dist/types/ui/EditableBlock/types.d.ts +2 -0
- package/dist/types/ui/EditableBlock/types.d.ts.map +1 -1
- package/dist/types/ui/FileTree/Provider.d.ts +1 -1
- package/dist/types/ui/FileTree/Provider.d.ts.map +1 -1
- package/dist/types/ui/FileTree/common/File/File.d.ts.map +1 -1
- package/dist/types/ui/FileTree/common/Folder/Folder.d.ts.map +1 -1
- package/dist/types/ui/FileTree/common/IndentationBlock/IndentationBlock.d.ts.map +1 -1
- package/dist/types/ui/FileTree/common/Node/Provider.d.ts.map +1 -1
- package/dist/types/ui/FileTree/common/SearchBox/SearchBox.d.ts +1 -1
- package/dist/types/ui/FileTree/common/SearchBox/SearchBox.d.ts.map +1 -1
- package/dist/types/ui/FileTree/common/SearchBox/types.d.ts +0 -2
- package/dist/types/ui/FileTree/common/SearchBox/types.d.ts.map +1 -1
- package/dist/types/ui/FileTree/common/TreeView/TreeView.d.ts.map +1 -1
- package/dist/types/ui/FileTree/types.d.ts +5 -1
- package/dist/types/ui/FileTree/types.d.ts.map +1 -1
- package/dist/types/ui/FileTree/utils/hashNodeName.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/Provider.d.ts +1 -1
- package/dist/types/ui/GitDiffViewer/Provider.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.d.ts +3 -12
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.d.ts +10 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.d.ts.map +1 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.d.ts +3 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.d.ts.map +1 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.d.ts +21 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.d.ts.map +1 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.d.ts +1 -1
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/types.d.ts +20 -6
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/types.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.d.ts +2 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.d.ts.map +1 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/constants.d.ts +2 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/constants.d.ts.map +1 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/index.d.ts +1 -0
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/index.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/types.d.ts +19 -3
- package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/types.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/common/FileHeader/FileHeader.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/index.d.ts +6 -2
- package/dist/types/ui/GitDiffViewer/index.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/types.d.ts +9 -11
- package/dist/types/ui/GitDiffViewer/types.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/utils/highlightDiffHunkLines.d.ts +4 -0
- package/dist/types/ui/GitDiffViewer/utils/highlightDiffHunkLines.d.ts.map +1 -0
- package/dist/types/ui/GitDiffViewer/utils/index.d.ts +1 -0
- package/dist/types/ui/GitDiffViewer/utils/index.d.ts.map +1 -1
- package/dist/types/ui/GitDiffViewer/utils/parseGitDiff.d.ts.map +1 -1
- package/dist/types/ui/MarkdownEditor/MarkdownEditor.d.ts +10 -0
- package/dist/types/ui/MarkdownEditor/MarkdownEditor.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/Toolbar.d.ts +8 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/Toolbar.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/Button.d.ts +9 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/Button.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/index.d.ts +3 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/types.d.ts +14 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/types.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/Group.d.ts +9 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/Group.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/index.d.ts +3 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/types.d.ts +14 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/types.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.d.ts +9 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/index.d.ts +3 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/types.d.ts +10 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/types.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/index.d.ts +4 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/common/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/index.d.ts +4 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/types.d.ts +20 -0
- package/dist/types/ui/MarkdownEditor/common/Toolbar/types.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.d.ts +9 -0
- package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/index.d.ts +3 -0
- package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/types.d.ts +14 -0
- package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/types.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/icons.d.ts +9 -0
- package/dist/types/ui/MarkdownEditor/common/icons.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/common/index.d.ts +4 -0
- package/dist/types/ui/MarkdownEditor/common/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/hooks/index.d.ts +2 -0
- package/dist/types/ui/MarkdownEditor/hooks/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/hooks/useEditor.d.ts +40 -0
- package/dist/types/ui/MarkdownEditor/hooks/useEditor.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/index.d.ts +3 -0
- package/dist/types/ui/MarkdownEditor/index.d.ts.map +1 -0
- package/dist/types/ui/MarkdownEditor/types.d.ts +47 -0
- package/dist/types/ui/MarkdownEditor/types.d.ts.map +1 -0
- package/dist/types/ui/RelativeTime/RelativeTime.d.ts.map +1 -1
- package/dist/types/ui/RelativeTime/utils/formatHumanTime.d.ts.map +1 -1
- package/dist/types/ui/RelativeTime/utils/getOptimalUpdateInterval.d.ts.map +1 -1
- package/dist/types/ui/index.d.ts +2 -0
- package/dist/types/ui/index.d.ts.map +1 -1
- package/package.json +27 -25
- package/dist/esm/ui/EditableBlock/EditableBlock.test.js +0 -57
- package/dist/esm/ui/EditableBlock/EditableBlock.test.js.map +0 -1
- package/dist/types/ui/EditableBlock/EditableBlock.test.d.ts +0 -2
- package/dist/types/ui/EditableBlock/EditableBlock.test.d.ts.map +0 -1
@@ -0,0 +1,19 @@
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
2
|
+
import { useId } from "react";
|
3
|
+
import { Tooltip } from "react-tooltip";
|
4
|
+
import "./styles.css";
|
5
|
+
const componentCssClassName = "ds toolbar-button";
|
6
|
+
/**
|
7
|
+
* An accessible button with tooltip support designed for use in toolbars.
|
8
|
+
*/
|
9
|
+
const ToolbarButton = ({ children, className, style, label, shortcut, ...buttonProps }) => {
|
10
|
+
const id = useId();
|
11
|
+
const tooltipMessage = shortcut ? `${label} (${shortcut})` : label;
|
12
|
+
const tooltipId = `${id}-tooltip`;
|
13
|
+
return (_jsxs(_Fragment, { children: [_jsx("button", { id: id, style: style, className: [componentCssClassName, className].filter(Boolean).join(" "), "aria-label": label, type: "button", "data-tooltip-id": tooltipId, "data-tooltip-content": tooltipMessage, "data-tooltip-place": "bottom", ...buttonProps, children: children }), _jsx(Tooltip, { id: tooltipId, style: {
|
14
|
+
padding: "5px 10px",
|
15
|
+
fontSize: "0.75em",
|
16
|
+
} })] }));
|
17
|
+
};
|
18
|
+
export default ToolbarButton;
|
19
|
+
//# sourceMappingURL=Button.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Button/Button.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,cAAc,CAAC;AAGtB,MAAM,qBAAqB,GAAG,mBAAmB,CAAC;AAElD;;GAEG;AACH,MAAM,aAAa,GAAG,CAAC,EACrB,QAAQ,EACR,SAAS,EACT,KAAK,EACL,KAAK,EACL,QAAQ,EACR,GAAG,WAAW,EACK,EAAsB,EAAE;IAC3C,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IAEnB,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,KAAK,QAAQ,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC;IACnE,MAAM,SAAS,GAAG,GAAG,EAAE,UAAU,CAAC;IAElC,OAAO,CACL,8BACE,iBACE,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,gBAC3D,KAAK,EACjB,IAAI,EAAC,QAAQ,qBACI,SAAS,0BACJ,cAAc,wBACjB,QAAQ,KACvB,WAAW,YAEd,QAAQ,GACF,EACT,KAAC,OAAO,IACN,EAAE,EAAE,SAAS,EACb,KAAK,EAAE;oBACL,OAAO,EAAE,UAAU;oBACnB,QAAQ,EAAE,QAAQ;iBACnB,GACD,IACD,CACJ,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,aAAa,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Button/index.ts"],"names":[],"mappings":"AAAA,kDAAkD;AAClD,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,aAAa,CAAC;AACvD,cAAc,YAAY,CAAC"}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
/* @canonical/generator-ds 0.9.0-experimental.4 */
|
2
|
+
|
3
|
+
.ds.toolbar-button {
|
4
|
+
height: var(--markdown-editor-toolbar-button-size);
|
5
|
+
width: var(--markdown-editor-toolbar-button-size);
|
6
|
+
border: none;
|
7
|
+
background: none;
|
8
|
+
cursor: pointer;
|
9
|
+
display: inline-flex;
|
10
|
+
align-items: center;
|
11
|
+
justify-content: center;
|
12
|
+
|
13
|
+
&:hover,
|
14
|
+
&:focus {
|
15
|
+
background-color: var(--markdown-editor-toolbar-hover-background-color);
|
16
|
+
}
|
17
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Button/types.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
2
|
+
import "./styles.css";
|
3
|
+
const componentCssClassName = "ds toolbar-group";
|
4
|
+
/**
|
5
|
+
* A container for grouping related controls within a toolbar.
|
6
|
+
*/
|
7
|
+
const ToolbarGroup = ({ id, children, className, style, label, }) => {
|
8
|
+
return (_jsx("div", { id: id, style: style, className: [componentCssClassName, className].filter(Boolean).join(" "), "aria-label": label,
|
9
|
+
// biome-ignore lint/a11y/useSemanticElements: This element is a group of controls
|
10
|
+
role: "group", children: children }));
|
11
|
+
};
|
12
|
+
export default ToolbarGroup;
|
13
|
+
//# sourceMappingURL=Group.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Group.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Group/Group.tsx"],"names":[],"mappings":";AAGA,OAAO,cAAc,CAAC;AAEtB,MAAM,qBAAqB,GAAG,kBAAkB,CAAC;AAEjD;;GAEG;AACH,MAAM,YAAY,GAAG,CAAC,EACpB,EAAE,EACF,QAAQ,EACR,SAAS,EACT,KAAK,EACL,KAAK,GACa,EAAsB,EAAE;IAC1C,OAAO,CACL,cACE,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,gBAC3D,KAAK;QACjB,kFAAkF;QAClF,IAAI,EAAC,OAAO,YAEX,QAAQ,GACL,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,YAAY,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Group/index.ts"],"names":[],"mappings":"AAAA,kDAAkD;AAClD,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,YAAY,CAAC;AACrD,cAAc,YAAY,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Group/types.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
2
|
+
import "./styles.css";
|
3
|
+
const componentCssClassName = "ds toolbar-separator";
|
4
|
+
/**
|
5
|
+
* A visual separator between groups of controls in a toolbar.
|
6
|
+
*/
|
7
|
+
const ToolbarSeparator = ({ id, className, style, }) => {
|
8
|
+
return (
|
9
|
+
// biome-ignore lint/a11y/useFocusableInteractive: This element is not interactive
|
10
|
+
_jsx("div", { id: id, style: style, className: [componentCssClassName, className].filter(Boolean).join(" "), role: "separator", "aria-orientation": "horizontal" }));
|
11
|
+
};
|
12
|
+
export default ToolbarSeparator;
|
13
|
+
//# sourceMappingURL=Separator.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Separator.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.tsx"],"names":[],"mappings":";AAEA,OAAO,cAAc,CAAC;AAGtB,MAAM,qBAAqB,GAAG,sBAAsB,CAAC;AAErD;;GAEG;AACH,MAAM,gBAAgB,GAAG,CAAC,EACxB,EAAE,EACF,SAAS,EACT,KAAK,GACiB,EAAsB,EAAE;IAC9C,OAAO;IACL,kFAAkF;IAClF,cACE,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EACvE,IAAI,EAAC,WAAW,sBACC,YAAY,GAC7B,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Separator/index.ts"],"names":[],"mappings":"AAAA,kDAAkD;AAClD,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC7D,cAAc,YAAY,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/Separator/types.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../src/ui/MarkdownEditor/common/Toolbar/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC"}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
/* @canonical/generator-ds 0.9.0-experimental.4 */
|
2
|
+
import Toolbar from "./Toolbar.js";
|
3
|
+
import { ToolbarButton, ToolbarGroup, ToolbarSeparator, } from "./common/index.js";
|
4
|
+
Toolbar.Group = ToolbarGroup;
|
5
|
+
Toolbar.Button = ToolbarButton;
|
6
|
+
Toolbar.Separator = ToolbarSeparator;
|
7
|
+
export * from "./types.js";
|
8
|
+
export { Toolbar };
|
9
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/ui/MarkdownEditor/common/Toolbar/index.ts"],"names":[],"mappings":"AAAA,kDAAkD;AAClD,OAAO,OAAO,MAAM,cAAc,CAAC;AACnC,OAAO,EACL,aAAa,EACb,YAAY,EACZ,gBAAgB,GACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,CAAC,KAAK,GAAG,YAAY,CAAC;AAC7B,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC;AAC/B,OAAO,CAAC,SAAS,GAAG,gBAAgB,CAAC;AAErC,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,OAAO,EAAE,CAAC"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
/* @canonical/generator-ds 0.9.0-experimental.4 */
|
2
|
+
|
3
|
+
.ds.toolbar {
|
4
|
+
display: none;
|
5
|
+
|
6
|
+
gap: var(--markdown-editor-toolbar-buttons-gap);
|
7
|
+
padding: var(--markdown-editor-toolbar-vert-padding)
|
8
|
+
var(--markdown-editor-toolbar-horizontal-padding);
|
9
|
+
}
|
10
|
+
|
11
|
+
@container (min-width: 410px) {
|
12
|
+
.ds.toolbar {
|
13
|
+
display: flex;
|
14
|
+
flex-wrap: wrap;
|
15
|
+
}
|
16
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../src/ui/MarkdownEditor/common/Toolbar/types.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
2
|
+
import { useId, useRef } from "react";
|
3
|
+
import "./styles.css";
|
4
|
+
const componentCssClassName = "ds view-mode-tabs";
|
5
|
+
const selectedTabCssClassName = "selected";
|
6
|
+
const tabs = ["write", "preview"];
|
7
|
+
/**
|
8
|
+
* A toggle interface for switching between write and preview modes.
|
9
|
+
*/
|
10
|
+
const ViewModeTabs = ({ className, style, editMode, onEditModeChange, ariaLabelMessage = "View Mode Tabs", }) => {
|
11
|
+
const id = useId();
|
12
|
+
const tabRefs = useRef([]);
|
13
|
+
const handleKeyDown = (event) => {
|
14
|
+
if (event.key === "Enter" || event.key === " ") {
|
15
|
+
onEditModeChange(event.currentTarget.dataset.tab, "keydown");
|
16
|
+
}
|
17
|
+
if (event.key === "ArrowLeft" || event.key === "ArrowRight") {
|
18
|
+
const currentIndex = tabs.indexOf(editMode);
|
19
|
+
const nextIndex = currentIndex === 0 ? 1 : 0;
|
20
|
+
onEditModeChange(tabs[nextIndex], "keydown");
|
21
|
+
tabRefs.current[nextIndex]?.focus();
|
22
|
+
event.preventDefault();
|
23
|
+
}
|
24
|
+
};
|
25
|
+
return (_jsx("div", { id: id, style: style, className: [componentCssClassName, className].filter(Boolean).join(" "), role: "tablist", "aria-label": ariaLabelMessage, children: tabs.map((tab, index) => (_jsx("button", { type: "button", role: "tab", className: ["tab", editMode === tab && selectedTabCssClassName]
|
26
|
+
.filter(Boolean)
|
27
|
+
.join(" "), "aria-selected": editMode === tab, onClick: () => onEditModeChange(tab, "click"), onKeyDown: handleKeyDown, tabIndex: editMode === tab ? 0 : -1, "data-tab": tab, ref: (el) => {
|
28
|
+
if (el) {
|
29
|
+
tabRefs.current[index] = el;
|
30
|
+
}
|
31
|
+
}, children: tab.charAt(0).toUpperCase() + tab.slice(1) }, `tab-${id}-${tab}`))) }));
|
32
|
+
};
|
33
|
+
export default ViewModeTabs;
|
34
|
+
//# sourceMappingURL=ViewModeTabs.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ViewModeTabs.js","sourceRoot":"","sources":["../../../../../../src/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAEtC,OAAO,cAAc,CAAC;AAGtB,MAAM,qBAAqB,GAAG,mBAAmB,CAAC;AAClD,MAAM,uBAAuB,GAAG,UAAU,CAAC;AAC3C,MAAM,IAAI,GAAe,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;AAE9C;;GAEG;AACH,MAAM,YAAY,GAAG,CAAC,EACpB,SAAS,EACT,KAAK,EACL,QAAQ,EACR,gBAAgB,EAChB,gBAAgB,GAAG,gBAAgB,GACjB,EAAsB,EAAE;IAC1C,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IACnB,MAAM,OAAO,GAAG,MAAM,CAAsB,EAAE,CAAC,CAAC;IAEhD,MAAM,aAAa,GAAG,CAAC,KAA6C,EAAE,EAAE;QACtE,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;YAC/C,gBAAgB,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,GAAe,EAAE,SAAS,CAAC,CAAC;QAC3E,CAAC;QACD,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,IAAI,KAAK,CAAC,GAAG,KAAK,YAAY,EAAE,CAAC;YAC5D,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAC5C,MAAM,SAAS,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE7C,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,SAAS,CAAC,CAAC;YAC7C,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,CAAC;YACpC,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CACL,cACE,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EACvE,IAAI,EAAC,SAAS,gBACF,gBAAgB,YAE3B,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,CACxB,iBAEE,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,KAAK,EACV,SAAS,EAAE,CAAC,KAAK,EAAE,QAAQ,KAAK,GAAG,IAAI,uBAAuB,CAAC;iBAC5D,MAAM,CAAC,OAAO,CAAC;iBACf,IAAI,CAAC,GAAG,CAAC,mBACG,QAAQ,KAAK,GAAG,EAC/B,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,EAAE,OAAO,CAAC,EAC7C,SAAS,EAAE,aAAa,EACxB,QAAQ,EAAE,QAAQ,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cACzB,GAAG,EACb,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE;gBACV,IAAI,EAAE,EAAE,CAAC;oBACP,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;gBAC9B,CAAC;YACH,CAAC,YAEA,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,IAjBtC,OAAO,EAAE,IAAI,GAAG,EAAE,CAkBhB,CACV,CAAC,GACE,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,YAAY,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/ui/MarkdownEditor/common/ViewModeTabs/index.ts"],"names":[],"mappings":"AAAA,kDAAkD;AAClD,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC5D,cAAc,YAAY,CAAC"}
|
@@ -0,0 +1,42 @@
|
|
1
|
+
/* @canonical/generator-ds 0.9.0-experimental.4 */
|
2
|
+
|
3
|
+
.ds.view-mode-tabs {
|
4
|
+
display: flex;
|
5
|
+
|
6
|
+
& > .tab {
|
7
|
+
padding: var(--markdown-editor-tabs-vert-padding)
|
8
|
+
var(--markdown-editor-tabs-horizontal-padding);
|
9
|
+
border: 1px solid var(--markdown-editor-tabs-inactive-border-color);
|
10
|
+
border-width: 1px 1px 0 1px;
|
11
|
+
color: var(--markdown-editor-tabs-inactive-color);
|
12
|
+
background-color: var(--markdown-editor-tabs-inactive-background-color);
|
13
|
+
cursor: pointer;
|
14
|
+
|
15
|
+
&:hover,
|
16
|
+
&:focus {
|
17
|
+
color: var(--markdown-editor-tabs-hover-color);
|
18
|
+
background-color: var(--markdown-editor-tabs-hover-background-color);
|
19
|
+
}
|
20
|
+
&:focus {
|
21
|
+
outline-offset: -6px;
|
22
|
+
}
|
23
|
+
|
24
|
+
&.selected {
|
25
|
+
color: var(--markdown-editor-editor-color);
|
26
|
+
border-color: var(--markdown-editor-editor-border-color);
|
27
|
+
background-color: var(--markdown-editor-editor-background-color);
|
28
|
+
position: relative;
|
29
|
+
|
30
|
+
/* hide the top border of the tab panel for the selected tab */
|
31
|
+
&::after {
|
32
|
+
content: "";
|
33
|
+
position: absolute;
|
34
|
+
bottom: -1px;
|
35
|
+
left: 0;
|
36
|
+
right: 0;
|
37
|
+
height: 1px;
|
38
|
+
background-color: var(--markdown-editor-editor-background-color);
|
39
|
+
}
|
40
|
+
}
|
41
|
+
}
|
42
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../src/ui/MarkdownEditor/common/ViewModeTabs/types.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1,10 @@
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
2
|
+
export const ToolbarTitle = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", fill: "none", viewBox: "0 0 16 17", width: "16", height: "17", children: [_jsx("title", { children: "title" }), _jsx("path", { fill: "currentColor", d: "M3.299 14V3h1.939v4.3h5.524V3h1.94v11h-1.94V8.96H5.238V14h-1.94Z" })] }));
|
3
|
+
export const ToolbarBold = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", fill: "none", viewBox: "0 0 16 17", width: "16", height: "17", children: [_jsx("title", { children: "bold" }), _jsx("path", { fill: "currentColor", d: "M6.982 14.5c-.34 0-.708-.011-1.104-.034a21.394 21.394 0 0 1-1.17-.102 9.836 9.836 0 0 1-1.087-.187V2.822c.317-.079.662-.141 1.035-.186A19.847 19.847 0 0 1 6.88 2.5c.928 0 1.76.096 2.495.289.735.192 1.324.52 1.765.984.441.464.662 1.098.662 1.901 0 .554-.141 1.035-.424 1.443-.272.407-.657.724-1.155.95.713.226 1.25.572 1.613 1.036.362.463.543 1.075.543 1.833 0 1.176-.447 2.065-1.34 2.664-.895.6-2.247.9-4.057.9Zm.101-1.562a7.75 7.75 0 0 0 1.68-.17c.51-.112.912-.316 1.206-.61.305-.294.458-.707.458-1.24 0-.735-.255-1.238-.764-1.51s-1.216-.407-2.121-.407H5.47v3.836c.192.022.43.045.713.068.283.022.583.034.9.034ZM5.471 7.49h1.782c.555 0 1.03-.05 1.426-.153.396-.101.701-.277.916-.526.215-.26.323-.61.323-1.052 0-.623-.255-1.058-.764-1.307-.498-.26-1.188-.39-2.07-.39-.317 0-.617.005-.9.016-.272.012-.51.034-.713.068V7.49Z" })] }));
|
4
|
+
export const ToolbarItalic = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", fill: "none", viewBox: "0 0 16 17", width: "16", height: "17", children: [_jsx("title", { children: "italic" }), _jsx("path", { fill: "currentColor", d: "m5.912 13 2.173-9H6.65l.162-1.5h4.838L11.49 4H10.04l-2.173 9H9.35l-.161 1.5H4.35l.161-1.5h1.401Z" })] }));
|
5
|
+
export const ToolbarQuote = (_jsxs("svg", { viewBox: "0 0 16 17", width: "16", height: "17", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [_jsx("title", { children: "quote" }), _jsx("path", { d: "M3.5 2.5H2V14.5H3.5V2.5Z", fill: "black" }), _jsx("path", { d: "M10 3.5H5V5H10V3.5Z", fill: "black" }), _jsx("path", { d: "M14 8H5V9.5H14V8Z", fill: "black" }), _jsx("path", { d: "M5 12.5H12V14H5V12.5Z", fill: "black" })] }));
|
6
|
+
export const ToolbarCode = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 16 17", width: "16", height: "17", fill: "none", children: [_jsx("title", { children: "code" }), _jsx("path", { fill: "currentColor", d: "m.99 8.5 4.773 4.773 1.06-1.06L3.111 8.5l3.712-3.712-1.06-1.061L.99 8.5ZM15.01 8.5l-4.772 4.773-1.061-1.06L12.889 8.5 9.177 4.788l1.06-1.061L15.012 8.5Z" })] }));
|
7
|
+
export const ToolbarLink = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 16 17", width: "16", height: "17", fill: "none", children: [_jsx("title", { children: "link" }), _jsx("path", { fill: "currentColor", d: "M8.781 5.272c.976.683 1.5 1.77 1.508 2.876l-.065.105c-.317.457-.88.637-1.308.4a.831.831 0 0 1-.162-.118A2.036 2.036 0 0 0 5.177 6.88l-.09.121-2.255 3.22a2.036 2.036 0 0 0 3.243 2.455l.092-.12.114-.163c.392.326.849.565 1.34.7l-.225.322A3.536 3.536 0 1 1 1.604 9.36L3.857 6.14a3.536 3.536 0 0 1 4.924-.868Zm4.747-3.042a3.536 3.536 0 0 1 .868 4.924l-2.253 3.218A3.536 3.536 0 0 1 5.71 8.365l.065-.105c.317-.458.88-.637 1.308-.4a.87.87 0 0 1 .162.117 2.036 2.036 0 0 0 3.577 1.656l.091-.12 2.254-3.219a2.036 2.036 0 0 0-3.243-2.457l-.092.122-.114.162a3.582 3.582 0 0 0-1.34-.7l.225-.323a3.536 3.536 0 0 1 4.925-.868Z" })] }));
|
8
|
+
export const ToolbarUnorderedList = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 16 17", width: "16", height: "17", fill: "none", children: [_jsx("title", { children: "unordered list" }), _jsx("path", { fill: "currentColor", d: "M3.5 12.5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-1A.5.5 0 0 1 2 14v-1a.5.5 0 0 1 .5-.5h1Zm9.5.25v1.5H6v-1.5h7ZM3.5 7.5A.5.5 0 0 1 4 8v1a.5.5 0 0 1-.5.5h-1A.5.5 0 0 1 2 9V8a.5.5 0 0 1 .5-.5h1Zm8.5.25v1.5H6v-1.5h6ZM3.5 2.5A.5.5 0 0 1 4 3v1a.5.5 0 0 1-.5.5h-1A.5.5 0 0 1 2 4V3a.5.5 0 0 1 .5-.5h1Zm10.5.25v1.5H6v-1.5h8Z" })] }));
|
9
|
+
export const ToolbarOrderedList = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 16 17", width: "16", height: "17", fill: "none", children: [_jsx("title", { children: "ordered list" }), _jsx("path", { fill: "currentColor", d: "M3.04 4.44v4.81h1.49V2.5H3.49a4.606 4.606 0 0 1-1.07.83c-.42.247-.827.45-1.22.61l.45 1.15c.16-.053.32-.113.48-.18.16-.067.317-.14.47-.22.16-.08.307-.163.44-.25ZM13.8 14v-1.5h-7V14h7ZM12.8 9.25v-1.5h-6v1.5h6ZM14.8 4.5V3h-8v1.5h8Z" })] }));
|
10
|
+
//# sourceMappingURL=icons.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"icons.js","sourceRoot":"","sources":["../../../../../src/ui/MarkdownEditor/common/icons.tsx"],"names":[],"mappings":";AAAA,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,eACE,KAAK,EAAC,4BAA4B,EAClC,IAAI,EAAC,MAAM,EACX,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,aAEX,oCAAoB,EACpB,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,kEAAkE,GACpE,IACE,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,eACE,KAAK,EAAC,4BAA4B,EAClC,IAAI,EAAC,MAAM,EACX,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,aAEX,mCAAmB,EACnB,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,szBAAszB,GACxzB,IACE,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAC3B,eACE,KAAK,EAAC,4BAA4B,EAClC,IAAI,EAAC,MAAM,EACX,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,aAEX,qCAAqB,EACrB,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,kGAAkG,GACpG,IACE,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,eACE,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,4BAA4B,aAElC,oCAAoB,EACpB,eAAM,CAAC,EAAC,0BAA0B,EAAC,IAAI,EAAC,OAAO,GAAG,EAClD,eAAM,CAAC,EAAC,qBAAqB,EAAC,IAAI,EAAC,OAAO,GAAG,EAC7C,eAAM,CAAC,EAAC,mBAAmB,EAAC,IAAI,EAAC,OAAO,GAAG,EAC3C,eAAM,CAAC,EAAC,uBAAuB,EAAC,IAAI,EAAC,OAAO,GAAG,IAC3C,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,eACE,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,IAAI,EAAC,MAAM,aAEX,mCAAmB,EACnB,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,0JAA0J,GAC5J,IACE,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,eACE,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,IAAI,EAAC,MAAM,aAEX,mCAAmB,EACnB,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,smBAAsmB,GACxmB,IACE,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAClC,eACE,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,IAAI,EAAC,MAAM,aAEX,6CAA6B,EAC7B,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,yTAAyT,GAC3T,IACE,CACP,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,eACE,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,IAAI,EAAC,MAAM,aAEX,2CAA2B,EAC3B,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,sOAAsO,GACxO,IACE,CACP,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/ui/MarkdownEditor/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AAExC,OAAO,KAAK,KAAK,MAAM,YAAY,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/ui/MarkdownEditor/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,gBAAgB,CAAC"}
|
@@ -0,0 +1,274 @@
|
|
1
|
+
import { useCallback, useEffect } from "react";
|
2
|
+
const useEditor = (textareaRef) => {
|
3
|
+
const wrapText = useCallback((character) => {
|
4
|
+
const textarea = textareaRef.current;
|
5
|
+
if (!textarea)
|
6
|
+
return;
|
7
|
+
const { selectionStart, selectionEnd } = textarea;
|
8
|
+
const isSelected = selectionStart !== selectionEnd;
|
9
|
+
textarea.focus();
|
10
|
+
if (isSelected) {
|
11
|
+
const selectedText = textarea.value.slice(selectionStart, selectionEnd);
|
12
|
+
const wrappedText = character + selectedText + character;
|
13
|
+
document.execCommand("insertText", false, wrappedText);
|
14
|
+
// Adjust selection to exclude the wrapping characters
|
15
|
+
const newStart = selectionStart + character.length;
|
16
|
+
const newEnd = selectionEnd + character.length;
|
17
|
+
textarea.setSelectionRange(newStart, newEnd);
|
18
|
+
}
|
19
|
+
else {
|
20
|
+
const insertText = character + character;
|
21
|
+
document.execCommand("insertText", false, insertText);
|
22
|
+
// Move cursor between the characters
|
23
|
+
textarea.setSelectionRange(selectionStart + character.length, selectionStart + character.length);
|
24
|
+
}
|
25
|
+
}, [textareaRef]);
|
26
|
+
const prefixLines = useCallback((prefix) => {
|
27
|
+
const textarea = textareaRef.current;
|
28
|
+
if (!textarea)
|
29
|
+
return;
|
30
|
+
const { selectionStart, selectionEnd } = textarea;
|
31
|
+
const isSelected = selectionStart !== selectionEnd;
|
32
|
+
const text = textarea.value;
|
33
|
+
const lines = text.split("\n");
|
34
|
+
const lineStartIndex = text.substring(0, selectionStart).split("\n").length - 1;
|
35
|
+
const lineEndIndex = text.substring(0, selectionEnd).split("\n").length;
|
36
|
+
// Extract selected lines and apply prefix
|
37
|
+
const selectedLines = lines.slice(lineStartIndex, lineEndIndex);
|
38
|
+
const wrappedLines = selectedLines.map((line, index) => {
|
39
|
+
const prefixString = typeof prefix === "function" ? prefix(index) : prefix;
|
40
|
+
return `${prefixString}${line}`;
|
41
|
+
});
|
42
|
+
// Calculate start and end positions of the selected lines
|
43
|
+
let startPos = 0;
|
44
|
+
for (let i = 0; i < lineStartIndex; i++) {
|
45
|
+
startPos += lines[i].length + 1; // +1 for newline
|
46
|
+
}
|
47
|
+
let endPos = startPos;
|
48
|
+
for (let i = lineStartIndex; i < lineEndIndex; i++) {
|
49
|
+
endPos += lines[i].length + 1;
|
50
|
+
}
|
51
|
+
endPos -= 1;
|
52
|
+
textarea.focus();
|
53
|
+
textarea.setSelectionRange(startPos, endPos);
|
54
|
+
document.execCommand("insertText", false, wrappedLines.join("\n"));
|
55
|
+
if (isSelected) {
|
56
|
+
const newEnd = startPos + wrappedLines.join("\n").length;
|
57
|
+
textarea.setSelectionRange(startPos, newEnd);
|
58
|
+
}
|
59
|
+
}, [textareaRef]);
|
60
|
+
const handleItalic = useCallback(() => wrapText("*"), [wrapText]);
|
61
|
+
const handleBold = useCallback(() => wrapText("**"), [wrapText]);
|
62
|
+
const handleTitle = useCallback(() => prefixLines("### "), [prefixLines]);
|
63
|
+
const handleQuote = useCallback(() => prefixLines("> "), [prefixLines]);
|
64
|
+
const handleCode = useCallback(() => wrapText("`"), [wrapText]);
|
65
|
+
const handleUList = useCallback(() => prefixLines("- "), [prefixLines]);
|
66
|
+
const handleOList = useCallback(() => prefixLines((index) => `${index + 1}. `), [prefixLines]);
|
67
|
+
const handleLink = useCallback(() => {
|
68
|
+
const textarea = textareaRef.current;
|
69
|
+
if (!textarea)
|
70
|
+
return;
|
71
|
+
const { selectionStart, selectionEnd } = textarea;
|
72
|
+
const isSelected = selectionStart !== selectionEnd;
|
73
|
+
textarea.focus();
|
74
|
+
const linkPlaceholder = "url";
|
75
|
+
const placeholderLength = linkPlaceholder.length;
|
76
|
+
if (isSelected) {
|
77
|
+
const selectedText = textarea.value.slice(selectionStart, selectionEnd);
|
78
|
+
const newText = `[${selectedText}](${linkPlaceholder})`;
|
79
|
+
document.execCommand("insertText", false, newText);
|
80
|
+
// Adjust selection to the URL part
|
81
|
+
const newStart = selectionEnd + placeholderLength;
|
82
|
+
const newEnd = newStart + placeholderLength;
|
83
|
+
textarea.setSelectionRange(newStart, newEnd);
|
84
|
+
}
|
85
|
+
else {
|
86
|
+
const insertText = "[](url)";
|
87
|
+
const originalStart = selectionStart;
|
88
|
+
document.execCommand("insertText", false, insertText);
|
89
|
+
// Position cursor between the square brackets
|
90
|
+
textarea.setSelectionRange(originalStart + 1, originalStart + 1);
|
91
|
+
}
|
92
|
+
}, [textareaRef]);
|
93
|
+
const formatShortcut = (key, { isShift = false, isCtrl = false }) => {
|
94
|
+
const isMac = navigator.platform.toUpperCase().indexOf("MAC") >= 0;
|
95
|
+
const ctrlKey = isMac ? "⌘" : "^";
|
96
|
+
const shiftKey = "⇧";
|
97
|
+
return [isCtrl && ctrlKey, isShift && shiftKey, key.toUpperCase()]
|
98
|
+
.filter(Boolean)
|
99
|
+
.join(" ");
|
100
|
+
};
|
101
|
+
// To be called when a user types Enter in the textarea
|
102
|
+
// Will insert the appropriate Markdown syntax for the next line
|
103
|
+
// In case of lists, code block.
|
104
|
+
const handleMarkdownSyntaxAutoComplete = useCallback((event) => {
|
105
|
+
const textarea = textareaRef.current;
|
106
|
+
if (!textarea)
|
107
|
+
return false;
|
108
|
+
if (event.key !== "Enter")
|
109
|
+
return false;
|
110
|
+
const { selectionStart, selectionEnd } = textarea;
|
111
|
+
const hasSelection = selectionStart !== selectionEnd;
|
112
|
+
if (hasSelection)
|
113
|
+
return false;
|
114
|
+
const textBeforeCursor = textarea.value.substring(0, selectionStart);
|
115
|
+
const linesBeforeCursor = textBeforeCursor.split("\n");
|
116
|
+
const currentLine = linesBeforeCursor[linesBeforeCursor.length - 1];
|
117
|
+
// list autocompletion
|
118
|
+
const listRegex = /^(\s*)([-*]|\d+\.)\s/; // matches "- ", "* ", "1. "
|
119
|
+
const listMatch = currentLine.match(listRegex);
|
120
|
+
if (listMatch) {
|
121
|
+
const leadingWhitespace = listMatch[1];
|
122
|
+
const marker = listMatch[2];
|
123
|
+
const restOfLine = currentLine.substring(listMatch[0].length).trim();
|
124
|
+
// If the line is empty, exit list
|
125
|
+
// and replace current line with empty line
|
126
|
+
if (restOfLine.length === 0 || restOfLine === "[ ]") {
|
127
|
+
const lineStart = selectionStart - currentLine.length;
|
128
|
+
textarea.selectionStart = lineStart;
|
129
|
+
textarea.selectionEnd = selectionStart;
|
130
|
+
document.execCommand("insertText", false, "\n");
|
131
|
+
return true;
|
132
|
+
}
|
133
|
+
// Determine next marker based on type
|
134
|
+
const isCheckbox = /^\[([ xX])\]/.test(restOfLine);
|
135
|
+
const isOrdered = /\d/.test(marker);
|
136
|
+
let nextMarker;
|
137
|
+
if (isCheckbox) {
|
138
|
+
nextMarker = `${leadingWhitespace}- [ ]`;
|
139
|
+
}
|
140
|
+
else {
|
141
|
+
nextMarker = isOrdered
|
142
|
+
? `${Number.parseInt(marker) + 1}.`
|
143
|
+
: `${marker}`;
|
144
|
+
}
|
145
|
+
const nextLine = `\n${leadingWhitespace}${nextMarker} `;
|
146
|
+
document.execCommand("insertText", false, nextLine);
|
147
|
+
return true;
|
148
|
+
}
|
149
|
+
// code block autocompletion
|
150
|
+
const codeBlockRegex = /^(\s*)```/;
|
151
|
+
const codeBlockMatch = currentLine.match(codeBlockRegex);
|
152
|
+
if (codeBlockMatch) {
|
153
|
+
const occurrences = (textBeforeCursor.match(/```/g) || []).length;
|
154
|
+
if (occurrences % 2 === 1) {
|
155
|
+
const newText = `${textBeforeCursor}\n\n\`\`\`${textarea.value.substring(selectionStart)}`;
|
156
|
+
textarea.value = newText;
|
157
|
+
textarea.selectionStart = selectionStart + 1;
|
158
|
+
textarea.selectionEnd = selectionStart + 1;
|
159
|
+
return true;
|
160
|
+
}
|
161
|
+
}
|
162
|
+
return false;
|
163
|
+
}, [textareaRef]);
|
164
|
+
const handleShortcuts = useCallback((event) => {
|
165
|
+
const textarea = textareaRef.current;
|
166
|
+
if (!textarea)
|
167
|
+
return;
|
168
|
+
const isMac = navigator.platform.toUpperCase().indexOf("MAC") >= 0;
|
169
|
+
const isCtrl = isMac ? event.metaKey : event.ctrlKey;
|
170
|
+
const isShift = event.shiftKey;
|
171
|
+
let shortcutHandled = false;
|
172
|
+
// Ctrl + b
|
173
|
+
if (isCtrl && event.key === "b") {
|
174
|
+
handleBold();
|
175
|
+
shortcutHandled = true;
|
176
|
+
}
|
177
|
+
// Ctrl + i
|
178
|
+
if (isCtrl && event.key === "i") {
|
179
|
+
handleItalic();
|
180
|
+
shortcutHandled = true;
|
181
|
+
}
|
182
|
+
// Ctrl + k
|
183
|
+
if (isCtrl && event.key === "k") {
|
184
|
+
handleLink();
|
185
|
+
shortcutHandled = true;
|
186
|
+
}
|
187
|
+
// Ctrl + .
|
188
|
+
if (isCtrl && event.key === ".") {
|
189
|
+
handleQuote();
|
190
|
+
shortcutHandled = true;
|
191
|
+
}
|
192
|
+
// Ctrl + e
|
193
|
+
if (isCtrl && event.key === "e") {
|
194
|
+
handleCode();
|
195
|
+
shortcutHandled = true;
|
196
|
+
}
|
197
|
+
// Ctrl + Shift + 7
|
198
|
+
if (isCtrl && isShift && event.key === "7") {
|
199
|
+
handleOList();
|
200
|
+
shortcutHandled = true;
|
201
|
+
}
|
202
|
+
// Ctrl + Shift + 8
|
203
|
+
if (isCtrl && isShift && event.key === "8") {
|
204
|
+
handleUList();
|
205
|
+
shortcutHandled = true;
|
206
|
+
}
|
207
|
+
if (!shortcutHandled) {
|
208
|
+
shortcutHandled = handleMarkdownSyntaxAutoComplete(event);
|
209
|
+
}
|
210
|
+
if (shortcutHandled) {
|
211
|
+
event.preventDefault();
|
212
|
+
}
|
213
|
+
}, [
|
214
|
+
textareaRef,
|
215
|
+
handleBold,
|
216
|
+
handleItalic,
|
217
|
+
handleLink,
|
218
|
+
handleQuote,
|
219
|
+
handleCode,
|
220
|
+
handleOList,
|
221
|
+
handleUList,
|
222
|
+
handleMarkdownSyntaxAutoComplete,
|
223
|
+
]);
|
224
|
+
useEffect(() => {
|
225
|
+
if (!textareaRef.current)
|
226
|
+
return;
|
227
|
+
textareaRef.current.addEventListener("keydown", handleShortcuts);
|
228
|
+
return () => {
|
229
|
+
if (!textareaRef.current)
|
230
|
+
return;
|
231
|
+
textareaRef.current.removeEventListener("keydown", handleShortcuts);
|
232
|
+
};
|
233
|
+
}, [textareaRef, handleShortcuts]);
|
234
|
+
if (typeof window === "undefined")
|
235
|
+
return {};
|
236
|
+
return {
|
237
|
+
toolbar: {
|
238
|
+
italic: {
|
239
|
+
shortcut: formatShortcut("i", { isCtrl: true }),
|
240
|
+
handler: handleItalic,
|
241
|
+
},
|
242
|
+
bold: {
|
243
|
+
shortcut: formatShortcut("b", { isCtrl: true }),
|
244
|
+
handler: handleBold,
|
245
|
+
},
|
246
|
+
title: {
|
247
|
+
shortcut: undefined,
|
248
|
+
handler: handleTitle,
|
249
|
+
},
|
250
|
+
quote: {
|
251
|
+
shortcut: formatShortcut(".", { isCtrl: true }),
|
252
|
+
handler: handleQuote,
|
253
|
+
},
|
254
|
+
code: {
|
255
|
+
shortcut: formatShortcut("e", { isCtrl: true }),
|
256
|
+
handler: handleCode,
|
257
|
+
},
|
258
|
+
uList: {
|
259
|
+
shortcut: formatShortcut("8", { isCtrl: true, isShift: true }),
|
260
|
+
handler: handleUList,
|
261
|
+
},
|
262
|
+
oList: {
|
263
|
+
shortcut: formatShortcut("7", { isCtrl: true, isShift: true }),
|
264
|
+
handler: handleOList,
|
265
|
+
},
|
266
|
+
link: {
|
267
|
+
shortcut: formatShortcut("k", { isCtrl: true }),
|
268
|
+
handler: handleLink,
|
269
|
+
},
|
270
|
+
},
|
271
|
+
};
|
272
|
+
};
|
273
|
+
export default useEditor;
|
274
|
+
//# sourceMappingURL=useEditor.js.map
|