@quadrats/react 0.6.7 → 0.7.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/_internal/index.cjs.js +42 -44
- package/_internal/renderer/composeRenderElementsBase.js +10 -10
- package/_internal/renderer/composeRenderLeafsBase.js +8 -8
- package/_internal/renderer/createRenderElementBase.js +6 -6
- package/_internal/renderer/createRenderElementsBase.js +8 -8
- package/_internal/renderer/createRenderMarkBase.js +10 -10
- package/blockquote/constants.js +5 -5
- package/blockquote/createReactBlockquote.d.ts +1 -1
- package/blockquote/createReactBlockquote.js +58 -58
- package/blockquote/defaultRenderBlockquoteElement.d.ts +2 -2
- package/blockquote/index.cjs.js +64 -71
- package/blockquote/jsx-serializer/createJsxSerializeBlockquote.d.ts +2 -2
- package/blockquote/jsx-serializer/createJsxSerializeBlockquote.js +3 -3
- package/blockquote/jsx-serializer/index.cjs.js +3 -5
- package/blockquote/jsx-serializer/typings.d.ts +1 -1
- package/blockquote/toolbar/BlockquoteToolbarIcon.d.ts +2 -2
- package/blockquote/toolbar/BlockquoteToolbarIcon.js +4 -4
- package/blockquote/toolbar/index.cjs.js +10 -16
- package/blockquote/toolbar/useBlockquoteTool.js +6 -6
- package/blockquote/typings.d.ts +1 -1
- package/bold/constants.js +5 -5
- package/bold/createReactBold.d.ts +1 -1
- package/bold/createReactBold.js +3 -3
- package/bold/defaultRenderBold.d.ts +2 -2
- package/bold/defaultRenderBold.js +1 -1
- package/bold/index.cjs.js +9 -15
- package/bold/jsx-serializer/createJsxSerializeBold.js +3 -3
- package/bold/jsx-serializer/index.cjs.js +3 -5
- package/components/Icon/index.d.ts +1 -1
- package/components/Icon/index.js +15 -15
- package/components/Portal/index.d.ts +1 -0
- package/components/Portal/index.js +3 -3
- package/components/Progress/index.js +10 -10
- package/components/Tooltip/calculatePosition.js +66 -66
- package/components/Tooltip/index.d.ts +2 -2
- package/components/Tooltip/index.js +109 -109
- package/components/Tooltip/typings.d.ts +4 -4
- package/components/index.cjs.js +203 -211
- package/configs/ConfigsProvider.d.ts +2 -2
- package/configs/ConfigsProvider.js +7 -7
- package/configs/index.cjs.js +38 -44
- package/configs/locale.js +3 -3
- package/configs/theme.js +28 -28
- package/core/components/DefaultElement.d.ts +2 -2
- package/core/components/DefaultLeaf.d.ts +2 -2
- package/core/components/Editable.d.ts +3 -3
- package/core/components/Editable.js +41 -42
- package/core/components/Quadrats.d.ts +3 -3
- package/core/components/Quadrats.js +7 -7
- package/core/composeHandlers.js +30 -30
- package/core/composeRenderElements.d.ts +1 -1
- package/core/composeRenderElements.js +5 -5
- package/core/composeRenderLeafs.js +5 -5
- package/core/createReactEditor.js +2 -2
- package/core/createRenderElement.d.ts +1 -1
- package/core/createRenderElement.js +2 -2
- package/core/createRenderElements.d.ts +1 -1
- package/core/createRenderElements.js +2 -2
- package/core/createRenderMark.js +2 -2
- package/core/index.d.ts +6 -4
- package/core/index.js +11 -0
- package/core/typings/descendant.d.ts +1 -1
- package/core/typings/handler.d.ts +7 -7
- package/core/typings/renderer.d.ts +5 -5
- package/core/typings/with.d.ts +2 -2
- package/divider/createReactDivider.d.ts +1 -1
- package/divider/createReactDivider.js +4 -4
- package/divider/defaultRenderDividerElement.d.ts +2 -2
- package/divider/defaultRenderDividerElement.js +2 -2
- package/divider/index.cjs.js +6 -12
- package/divider/jsx-serializer/createJsxSerializeDivider.d.ts +2 -2
- package/divider/jsx-serializer/createJsxSerializeDivider.js +3 -3
- package/divider/jsx-serializer/defaultRenderDividerElement.d.ts +2 -2
- package/divider/jsx-serializer/index.cjs.js +4 -10
- package/divider/jsx-serializer/typings.d.ts +1 -1
- package/divider/toolbar/DividerToolbarIcon.d.ts +2 -2
- package/divider/toolbar/DividerToolbarIcon.js +4 -4
- package/divider/toolbar/index.cjs.js +9 -15
- package/divider/toolbar/useDividerTool.js +5 -5
- package/divider/typings.d.ts +1 -1
- package/embed/components/VideoIframe.d.ts +2 -2
- package/embed/components/VideoIframe.js +8 -8
- package/embed/createReactEmbed.d.ts +1 -1
- package/embed/createReactEmbed.js +7 -7
- package/embed/createRenderEmbedElementBase.js +9 -9
- package/embed/hooks/useVideoIframeSize.js +19 -19
- package/embed/index.cjs.js +43 -49
- package/embed/jsx-serializer/createJsxSerializeEmbed.d.ts +1 -1
- package/embed/jsx-serializer/createJsxSerializeEmbed.js +6 -6
- package/embed/jsx-serializer/facebook/index.cjs.js +2 -4
- package/embed/jsx-serializer/index.cjs.js +6 -8
- package/embed/jsx-serializer/instagram/index.cjs.js +2 -4
- package/embed/jsx-serializer/twitter/index.cjs.js +2 -4
- package/embed/jsx-serializer/vimeo/index.cjs.js +2 -4
- package/embed/jsx-serializer/youtube/index.cjs.js +2 -4
- package/embed/renderers/facebook/components/Facebook.d.ts +2 -2
- package/embed/renderers/facebook/components/Facebook.js +11 -11
- package/embed/renderers/facebook/defaultRenderFacebookEmbedElement.d.ts +2 -2
- package/embed/renderers/facebook/index.cjs.js +12 -18
- package/embed/renderers/instagram/components/Instagram.d.ts +2 -2
- package/embed/renderers/instagram/components/Instagram.js +18 -18
- package/embed/renderers/instagram/defaultRenderInstagramEmbedElement.d.ts +2 -2
- package/embed/renderers/instagram/hooks/useLoadInstagramEmbedApi.js +22 -22
- package/embed/renderers/instagram/index.cjs.js +41 -47
- package/embed/renderers/podcast-apple/components/PodcastApple.d.ts +2 -2
- package/embed/renderers/podcast-apple/components/PodcastApple.js +6 -6
- package/embed/renderers/podcast-apple/defaultRenderPodcastAppleEmbedElement.d.ts +2 -2
- package/embed/renderers/podcast-apple/index.cjs.js +7 -13
- package/embed/renderers/spotify/components/Spotify.d.ts +2 -2
- package/embed/renderers/spotify/components/Spotify.js +10 -10
- package/embed/renderers/spotify/defaultRenderSpotifyEmbedElement.d.ts +2 -2
- package/embed/renderers/spotify/index.cjs.js +11 -17
- package/embed/renderers/twitter/components/Twitter.d.ts +2 -2
- package/embed/renderers/twitter/components/Twitter.js +5 -5
- package/embed/renderers/twitter/defaultRenderTwitterEmbedElement.d.ts +2 -2
- package/embed/renderers/twitter/hooks/useLoadTwitterEmbedApi.js +28 -28
- package/embed/renderers/twitter/index.cjs.js +34 -40
- package/embed/renderers/vimeo/defaultRenderVimeoEmbedElement.d.ts +2 -2
- package/embed/renderers/vimeo/index.cjs.js +1 -7
- package/embed/renderers/youtube/defaultRenderYoutubeEmbedElement.d.ts +2 -2
- package/embed/renderers/youtube/index.cjs.js +1 -7
- package/embed/toolbar/EmbedToolbarIcon.d.ts +2 -2
- package/embed/toolbar/EmbedToolbarIcon.js +4 -4
- package/embed/toolbar/index.cjs.js +16 -22
- package/embed/toolbar/useEmbedTool.js +12 -12
- package/embed/typings.d.ts +1 -1
- package/file-uploader/components/FileUploader.d.ts +2 -2
- package/file-uploader/components/FileUploader.js +7 -7
- package/file-uploader/createReactFileUploader.js +7 -7
- package/file-uploader/hooks/useFileUploader.js +7 -7
- package/file-uploader/index.cjs.js +22 -28
- package/file-uploader/toolbar/FileUploaderToolbarIcon.d.ts +2 -2
- package/file-uploader/toolbar/FileUploaderToolbarIcon.js +4 -4
- package/file-uploader/toolbar/index.cjs.js +9 -15
- package/file-uploader/toolbar/useFileUploaderTool.js +5 -5
- package/file-uploader/typings.d.ts +3 -3
- package/footnote/createReactFootnote.d.ts +1 -1
- package/footnote/createReactFootnote.js +6 -6
- package/footnote/defaultRenderFootnoteElement.d.ts +2 -2
- package/footnote/defaultRenderFootnoteElement.js +9 -9
- package/footnote/index.cjs.js +51 -57
- package/footnote/jsx-serializer/createJsxSerializeFootnote.d.ts +2 -2
- package/footnote/jsx-serializer/createJsxSerializeFootnote.js +4 -4
- package/footnote/jsx-serializer/defaultRenderFootnoteElement.d.ts +2 -2
- package/footnote/jsx-serializer/defaultRenderFootnoteElement.js +5 -5
- package/footnote/jsx-serializer/index.cjs.js +9 -15
- package/footnote/jsx-serializer/typings.d.ts +1 -1
- package/footnote/toolbar/FootnoteToolbarIcon.d.ts +2 -2
- package/footnote/toolbar/FootnoteToolbarIcon.js +4 -4
- package/footnote/toolbar/index.cjs.js +17 -23
- package/footnote/toolbar/useFootnoteTool.d.ts +1 -1
- package/footnote/toolbar/useFootnoteTool.js +13 -13
- package/footnote/typings.d.ts +1 -1
- package/footnote/useFootnotes.js +15 -15
- package/footnote/useFootnotesFromNodes.js +21 -21
- package/heading/constants.js +8 -8
- package/heading/createReactHeading.d.ts +1 -1
- package/heading/createReactHeading.js +37 -37
- package/heading/defaultRenderHeadingElement.d.ts +2 -2
- package/heading/defaultRenderHeadingElement.js +14 -14
- package/heading/index.cjs.js +59 -66
- package/heading/jsx-serializer/createJsxSerializeHeading.d.ts +2 -2
- package/heading/jsx-serializer/createJsxSerializeHeading.js +3 -3
- package/heading/jsx-serializer/index.cjs.js +3 -5
- package/heading/jsx-serializer/typings.d.ts +1 -1
- package/heading/toolbar/HeadingToolbarIcon.d.ts +2 -2
- package/heading/toolbar/HeadingToolbarIcon.js +4 -4
- package/heading/toolbar/index.cjs.js +10 -16
- package/heading/toolbar/useToggleHeadingTool.js +6 -6
- package/heading/typings.d.ts +1 -1
- package/highlight/constants.js +5 -5
- package/highlight/createReactHighlight.d.ts +1 -1
- package/highlight/createReactHighlight.js +3 -3
- package/highlight/defaultRenderHighlight.d.ts +2 -2
- package/highlight/defaultRenderHighlight.js +1 -1
- package/highlight/index.cjs.js +9 -15
- package/highlight/jsx-serializer/createJsxSerializeHighlight.d.ts +1 -1
- package/highlight/jsx-serializer/createJsxSerializeHighlight.js +4 -4
- package/highlight/jsx-serializer/index.cjs.js +4 -6
- package/image/components/Image.d.ts +2 -2
- package/image/components/Image.js +11 -11
- package/image/components/ImageCaption.d.ts +2 -2
- package/image/components/ImageCaption.js +13 -13
- package/image/components/ImageFigure.d.ts +2 -2
- package/image/components/ImageFigure.js +8 -8
- package/image/createReactImage.d.ts +1 -1
- package/image/createReactImage.js +94 -94
- package/image/defaultRenderImageElements.js +4 -4
- package/image/hooks/useImageResizer.js +89 -89
- package/image/image.css +1 -1
- package/image/index.cjs.js +219 -227
- package/image/jsx-serializer/createJsxSerializeImage.d.ts +2 -3
- package/image/jsx-serializer/createJsxSerializeImage.js +34 -34
- package/image/jsx-serializer/defaultRenderImageElements.js +4 -4
- package/image/jsx-serializer/index.cjs.js +38 -44
- package/image/jsx-serializer/typings.d.ts +1 -1
- package/image/typings.d.ts +3 -3
- package/index.cjs.js +103 -109
- package/index.js +3 -2
- package/input-block/components/InputBlock.d.ts +2 -2
- package/input-block/components/InputBlock.js +19 -19
- package/input-block/createReactInputBlock.d.ts +1 -1
- package/input-block/createReactInputBlock.js +10 -10
- package/input-block/hooks/useInputBlock.js +43 -43
- package/input-block/index.cjs.js +73 -79
- package/input-block/typings.d.ts +2 -2
- package/italic/constants.js +5 -5
- package/italic/createReactItalic.d.ts +1 -1
- package/italic/createReactItalic.js +3 -3
- package/italic/defaultRenderItalic.d.ts +2 -2
- package/italic/defaultRenderItalic.js +1 -1
- package/italic/index.cjs.js +9 -15
- package/italic/jsx-serializer/createJsxSerializeItalic.js +3 -3
- package/italic/jsx-serializer/index.cjs.js +3 -5
- package/jsx-serializer/createJsxSerializeElement.d.ts +1 -1
- package/jsx-serializer/createJsxSerializeElement.js +2 -2
- package/jsx-serializer/createJsxSerializeElements.d.ts +1 -1
- package/jsx-serializer/createJsxSerializeElements.js +2 -2
- package/jsx-serializer/createJsxSerializeMark.js +2 -2
- package/jsx-serializer/createJsxSerializer.js +42 -42
- package/jsx-serializer/index.cjs.js +48 -54
- package/jsx-serializer/typings.d.ts +5 -5
- package/line-break/commonBreak.js +26 -26
- package/line-break/createOnKeyDownBreak.js +41 -41
- package/line-break/createReactLineBreak.d.ts +1 -1
- package/line-break/createReactLineBreak.js +6 -6
- package/line-break/defaultRenderLineBreakElement.d.ts +2 -2
- package/line-break/index.cjs.js +75 -82
- package/line-break/jsx-serializer/createJsxSerializeLineBreak.d.ts +2 -2
- package/line-break/jsx-serializer/createJsxSerializeLineBreak.js +4 -4
- package/line-break/jsx-serializer/defaultRenderLineBreakElement.d.ts +2 -2
- package/line-break/jsx-serializer/defaultRenderLineBreakElement.js +1 -1
- package/line-break/jsx-serializer/index.cjs.js +6 -12
- package/line-break/jsx-serializer/typings.d.ts +1 -1
- package/line-break/renderLineBreakElementWithSymbol.d.ts +2 -2
- package/line-break/typings.d.ts +1 -1
- package/link/createReactLink.js +22 -22
- package/link/defaultRenderLinkElement.d.ts +2 -2
- package/link/defaultRenderLinkElement.js +7 -7
- package/link/index.cjs.js +29 -35
- package/link/jsx-serializer/createJsxSerializeLink.d.ts +2 -2
- package/link/jsx-serializer/createJsxSerializeLink.js +3 -3
- package/link/jsx-serializer/defaultRenderLinkElement.d.ts +2 -2
- package/link/jsx-serializer/index.cjs.js +4 -10
- package/link/jsx-serializer/typings.d.ts +1 -1
- package/link/toolbar/LinkToolbarIcon.d.ts +2 -2
- package/link/toolbar/LinkToolbarIcon.js +4 -4
- package/link/toolbar/UnlinkToolbarIcon.d.ts +2 -2
- package/link/toolbar/UnlinkToolbarIcon.js +4 -4
- package/link/toolbar/index.cjs.js +27 -33
- package/link/toolbar/useLinkTool.d.ts +1 -1
- package/link/toolbar/useLinkTool.js +14 -14
- package/link/toolbar/useUnlinkTool.js +5 -5
- package/link/typings.d.ts +1 -1
- package/list/createReactList.d.ts +1 -1
- package/list/createReactList.js +18 -18
- package/list/defaultRenderListElements.js +4 -4
- package/list/index.cjs.js +22 -28
- package/list/jsx-serializer/createJsxSerializeList.d.ts +2 -2
- package/list/jsx-serializer/createJsxSerializeList.js +8 -8
- package/list/jsx-serializer/index.cjs.js +8 -10
- package/list/jsx-serializer/typings.d.ts +1 -1
- package/list/toolbar/ListToolbarIcon.d.ts +2 -2
- package/list/toolbar/ListToolbarIcon.js +4 -4
- package/list/toolbar/index.cjs.js +10 -16
- package/list/toolbar/useListTool.js +6 -6
- package/list/typings.d.ts +2 -2
- package/package.json +10 -10
- package/paragraph/createRenderParagraphElement.d.ts +2 -2
- package/paragraph/createRenderParagraphElement.js +3 -3
- package/paragraph/defaultRenderParagraphElement.d.ts +2 -2
- package/paragraph/index.cjs.js +5 -11
- package/paragraph/jsx-serializer/createJsxSerializeParagraph.d.ts +2 -2
- package/paragraph/jsx-serializer/createJsxSerializeParagraph.js +3 -3
- package/paragraph/jsx-serializer/index.cjs.js +3 -5
- package/paragraph/jsx-serializer/typings.d.ts +1 -1
- package/paragraph/renderParagraphElementWithSymbol.d.ts +2 -2
- package/read-more/components/ReadMore.d.ts +2 -2
- package/read-more/components/ReadMore.js +6 -6
- package/read-more/createReactReadMore.d.ts +1 -1
- package/read-more/createReactReadMore.js +4 -4
- package/read-more/defaultRenderReadMoreElement.d.ts +2 -2
- package/read-more/index.cjs.js +11 -17
- package/read-more/jsx-serializer/createJsxSerializeReadMore.d.ts +2 -2
- package/read-more/jsx-serializer/createJsxSerializeReadMore.js +3 -3
- package/read-more/jsx-serializer/index.cjs.js +3 -5
- package/read-more/jsx-serializer/typings.d.ts +1 -1
- package/read-more/toolbar/ReadMoreToolbarIcon.d.ts +2 -2
- package/read-more/toolbar/ReadMoreToolbarIcon.js +4 -4
- package/read-more/toolbar/index.cjs.js +9 -15
- package/read-more/toolbar/useReadMoreTool.js +5 -5
- package/read-more/typings.d.ts +1 -1
- package/strikethrough/constants.js +5 -5
- package/strikethrough/createReactStrikethrough.d.ts +1 -1
- package/strikethrough/createReactStrikethrough.js +3 -3
- package/strikethrough/defaultRenderStrikethrough.d.ts +2 -2
- package/strikethrough/defaultRenderStrikethrough.js +1 -1
- package/strikethrough/index.cjs.js +9 -15
- package/strikethrough/jsx-serializer/createJsxSerializeStrikethrough.js +3 -3
- package/strikethrough/jsx-serializer/index.cjs.js +3 -5
- package/toggle-mark/createReactToggleMarkCreator.d.ts +2 -2
- package/toggle-mark/createReactToggleMarkCreator.js +14 -14
- package/toggle-mark/index.cjs.js +14 -20
- package/toggle-mark/jsx-serializer/createJsxSerializeToggleMarkCreator.d.ts +3 -3
- package/toggle-mark/jsx-serializer/createJsxSerializeToggleMarkCreator.js +2 -2
- package/toggle-mark/jsx-serializer/index.cjs.js +2 -4
- package/toggle-mark/jsx-serializer/typings.d.ts +1 -1
- package/toggle-mark/toolbar/ToggleMarkToolbarIcon.d.ts +2 -2
- package/toggle-mark/toolbar/ToggleMarkToolbarIcon.js +4 -4
- package/toggle-mark/toolbar/index.cjs.js +10 -16
- package/toggle-mark/toolbar/useToggleMarkTool.js +6 -6
- package/toggle-mark/typings.d.ts +2 -2
- package/toolbar/components/Toolbar.d.ts +1 -1
- package/toolbar/components/Toolbar.js +102 -102
- package/toolbar/components/ToolbarIcon.d.ts +2 -2
- package/toolbar/components/ToolbarIcon.js +6 -6
- package/toolbar/components/ToolbarInput.d.ts +2 -2
- package/toolbar/components/ToolbarInput.js +23 -23
- package/toolbar/constants.d.ts +2 -2
- package/toolbar/constants.js +3 -3
- package/toolbar/hooks/useStartToolInput.js +2 -2
- package/toolbar/index.cjs.js +137 -144
- package/toolbar/toolbar.css +1 -1
- package/toolbar/typings.d.ts +1 -1
- package/underline/constants.js +5 -5
- package/underline/createReactUnderline.d.ts +1 -1
- package/underline/createReactUnderline.js +3 -3
- package/underline/defaultRenderUnderline.d.ts +2 -2
- package/underline/defaultRenderUnderline.js +1 -1
- package/underline/index.cjs.js +9 -15
- package/underline/jsx-serializer/createJsxSerializeUnderline.js +3 -3
- package/underline/jsx-serializer/index.cjs.js +3 -5
- package/utils/composeRefs.js +29 -29
- package/utils/index.cjs.js +29 -31
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import { RenderLeafProps } from '../typings/renderer';
|
|
3
|
-
declare const DefaultLeaf: ({ attributes, children }: RenderLeafProps) => JSX.Element;
|
|
3
|
+
declare const DefaultLeaf: ({ attributes, children }: RenderLeafProps) => React.JSX.Element;
|
|
4
4
|
export default DefaultLeaf;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import { EditableProps as SlateEditableProps } from 'slate-react/dist/components/editable';
|
|
3
3
|
import { RenderElementProps, RenderLeafProps } from '../typings/renderer';
|
|
4
|
-
export
|
|
4
|
+
export type EditableProps = Omit<SlateEditableProps, 'renderLeaf' | 'renderElement'> & {
|
|
5
5
|
renderLeaf?: (props: RenderLeafProps) => JSX.Element;
|
|
6
6
|
renderElement?: (props: RenderElementProps) => JSX.Element;
|
|
7
7
|
};
|
|
8
|
-
declare function Editable(props: EditableProps): JSX.Element;
|
|
8
|
+
declare function Editable(props: EditableProps): React.JSX.Element;
|
|
9
9
|
export default Editable;
|
|
@@ -5,49 +5,48 @@ import clsx from 'clsx';
|
|
|
5
5
|
import { isAncestorEmpty, Editor } from '@quadrats/core';
|
|
6
6
|
import { useLocale, useTheme } from '@quadrats/react/configs';
|
|
7
7
|
import DefaultLeaf from './DefaultLeaf.js';
|
|
8
|
+
import { PLACEHOLDER_KEY } from '../index.js';
|
|
8
9
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
const locale =
|
|
12
|
-
const {
|
|
13
|
-
const
|
|
14
|
-
const
|
|
15
|
-
const
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
}, [renderLeafProp, placeholder, placeholderShowable]);
|
|
50
|
-
return (React.createElement(Editable$1, Object.assign({}, slateEditableProps, { className: clsx('qdr-editable', themeProps.className, className), decorate: decorate, onCompositionStart: onCompositionStart, onCompositionEnd: onCompositionEnd, renderLeaf: renderLeaf, style: Object.assign(Object.assign({}, themeProps.style), style) })));
|
|
10
|
+
function Editable(props) {
|
|
11
|
+
const locale = useLocale();
|
|
12
|
+
const { className, decorate: decorateProp, onCompositionEnd: onCompositionEndProp, onCompositionStart: onCompositionStartProp, placeholder = locale.editor.placeholder, renderLeaf: renderLeafProp, style } = props, slateEditableProps = __rest(props, ["className", "decorate", "onCompositionEnd", "onCompositionStart", "placeholder", "renderLeaf", "style"]);
|
|
13
|
+
const { props: themeProps } = useTheme();
|
|
14
|
+
const editor = useSlate();
|
|
15
|
+
const isEditorEmpty = isAncestorEmpty(editor);
|
|
16
|
+
const [placeholderShowable, setPlaceholderShowable] = useState(isEditorEmpty);
|
|
17
|
+
const decorate = useCallback((entry) => {
|
|
18
|
+
const result = decorateProp ? decorateProp(entry) : [];
|
|
19
|
+
const [node] = entry;
|
|
20
|
+
if (isEditorEmpty && Editor.isEditor(node)) {
|
|
21
|
+
const start = Editor.start(node, []);
|
|
22
|
+
result.push({
|
|
23
|
+
[PLACEHOLDER_KEY]: true,
|
|
24
|
+
anchor: start,
|
|
25
|
+
focus: start,
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
return result;
|
|
29
|
+
}, [decorateProp, isEditorEmpty]);
|
|
30
|
+
const onCompositionEnd = useCallback((event) => {
|
|
31
|
+
onCompositionEndProp === null || onCompositionEndProp === void 0 ? void 0 : onCompositionEndProp(event);
|
|
32
|
+
setPlaceholderShowable(true);
|
|
33
|
+
}, [onCompositionEndProp]);
|
|
34
|
+
const onCompositionStart = useCallback((event) => {
|
|
35
|
+
onCompositionStartProp === null || onCompositionStartProp === void 0 ? void 0 : onCompositionStartProp(event);
|
|
36
|
+
if (isEditorEmpty) {
|
|
37
|
+
setPlaceholderShowable(false);
|
|
38
|
+
}
|
|
39
|
+
}, [onCompositionStartProp, isEditorEmpty]);
|
|
40
|
+
const renderLeaf = useCallback((props) => {
|
|
41
|
+
const children = renderLeafProp ? renderLeafProp(props) : React.createElement(DefaultLeaf, Object.assign({}, props));
|
|
42
|
+
if (placeholderShowable && props.leaf[PLACEHOLDER_KEY]) {
|
|
43
|
+
return (React.createElement(React.Fragment, null,
|
|
44
|
+
React.createElement("span", { className: "qdr-editable__placeholder", contentEditable: false }, placeholder),
|
|
45
|
+
children));
|
|
46
|
+
}
|
|
47
|
+
return children;
|
|
48
|
+
}, [renderLeafProp, placeholder, placeholderShowable]);
|
|
49
|
+
return (React.createElement(Editable$1, Object.assign({}, slateEditableProps, { className: clsx('qdr-editable', themeProps.className, className), decorate: decorate, onCompositionStart: onCompositionStart, onCompositionEnd: onCompositionEnd, renderLeaf: renderLeaf, style: Object.assign(Object.assign({}, themeProps.style), style) })));
|
|
51
50
|
}
|
|
52
51
|
|
|
53
52
|
export { Editable as default };
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import { Slate } from 'slate-react';
|
|
3
3
|
import { ConfigsProviderProps } from '@quadrats/react/configs';
|
|
4
4
|
import { Descendant } from '..';
|
|
5
|
-
export
|
|
5
|
+
export type QuadratsProps = Pick<Parameters<typeof Slate>[0], 'children' | 'editor'> & Omit<ConfigsProviderProps, 'children'> & {
|
|
6
6
|
onChange: (value: Descendant[]) => void;
|
|
7
7
|
value: Descendant[];
|
|
8
8
|
};
|
|
9
9
|
/**
|
|
10
10
|
* Provide configs of quadrats and control the value.
|
|
11
11
|
*/
|
|
12
|
-
declare function Quadrats(props: QuadratsProps): JSX.Element;
|
|
12
|
+
declare function Quadrats(props: QuadratsProps): React.JSX.Element;
|
|
13
13
|
export default Quadrats;
|
|
@@ -2,13 +2,13 @@ import React from 'react';
|
|
|
2
2
|
import { Slate } from 'slate-react';
|
|
3
3
|
import { ConfigsProvider } from '@quadrats/react/configs';
|
|
4
4
|
|
|
5
|
-
/**
|
|
6
|
-
* Provide configs of quadrats and control the value.
|
|
7
|
-
*/
|
|
8
|
-
function Quadrats(props) {
|
|
9
|
-
const { children, editor, locale, onChange, theme, value, } = props;
|
|
10
|
-
return (React.createElement(ConfigsProvider, { theme: theme, locale: locale },
|
|
11
|
-
React.createElement(Slate, { editor: editor, onChange: onChange, value: value }, children)));
|
|
5
|
+
/**
|
|
6
|
+
* Provide configs of quadrats and control the value.
|
|
7
|
+
*/
|
|
8
|
+
function Quadrats(props) {
|
|
9
|
+
const { children, editor, locale, onChange, theme, value, } = props;
|
|
10
|
+
return (React.createElement(ConfigsProvider, { theme: theme, locale: locale },
|
|
11
|
+
React.createElement(Slate, { editor: editor, onChange: onChange, value: value }, children)));
|
|
12
12
|
}
|
|
13
13
|
|
|
14
14
|
export { Quadrats as default };
|
package/core/composeHandlers.js
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
function createEventHandler(editor, handlers) {
|
|
2
|
-
const [handler, ...restHandlers] = handlers;
|
|
3
|
-
return event => handler(event, editor, () => {
|
|
4
|
-
const next = restHandlers.length > 0 ? createEventHandler(editor, restHandlers) : () => { };
|
|
5
|
-
next(event);
|
|
6
|
-
});
|
|
7
|
-
}
|
|
8
|
-
/**
|
|
9
|
-
* To compose sequential `event handlers` to single for each event types.
|
|
10
|
-
*/
|
|
11
|
-
function composeHandlers(handlersList) {
|
|
12
|
-
const handlersListRecord = handlersList.reduce((acc, handlers) => {
|
|
13
|
-
Object.entries(handlers).forEach(([key, value]) => {
|
|
14
|
-
const name = key;
|
|
15
|
-
const handler = value;
|
|
16
|
-
const origin = acc[name];
|
|
17
|
-
if (origin) {
|
|
18
|
-
origin.push(handler);
|
|
19
|
-
}
|
|
20
|
-
else {
|
|
21
|
-
acc[name] = [handler];
|
|
22
|
-
}
|
|
23
|
-
});
|
|
24
|
-
return acc;
|
|
25
|
-
}, {});
|
|
26
|
-
const handlersEntries = Object.entries(handlersListRecord);
|
|
27
|
-
return editor => handlersEntries.reduce((acc, [name, handlers]) => {
|
|
28
|
-
acc[name] = createEventHandler(editor, handlers);
|
|
29
|
-
return acc;
|
|
30
|
-
}, {});
|
|
1
|
+
function createEventHandler(editor, handlers) {
|
|
2
|
+
const [handler, ...restHandlers] = handlers;
|
|
3
|
+
return event => handler(event, editor, () => {
|
|
4
|
+
const next = restHandlers.length > 0 ? createEventHandler(editor, restHandlers) : () => { };
|
|
5
|
+
next(event);
|
|
6
|
+
});
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* To compose sequential `event handlers` to single for each event types.
|
|
10
|
+
*/
|
|
11
|
+
function composeHandlers(handlersList) {
|
|
12
|
+
const handlersListRecord = handlersList.reduce((acc, handlers) => {
|
|
13
|
+
Object.entries(handlers).forEach(([key, value]) => {
|
|
14
|
+
const name = key;
|
|
15
|
+
const handler = value;
|
|
16
|
+
const origin = acc[name];
|
|
17
|
+
if (origin) {
|
|
18
|
+
origin.push(handler);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
acc[name] = [handler];
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
return acc;
|
|
25
|
+
}, {});
|
|
26
|
+
const handlersEntries = Object.entries(handlersListRecord);
|
|
27
|
+
return editor => handlersEntries.reduce((acc, [name, handlers]) => {
|
|
28
|
+
acc[name] = createEventHandler(editor, handlers);
|
|
29
|
+
return acc;
|
|
30
|
+
}, {});
|
|
31
31
|
}
|
|
32
32
|
|
|
33
33
|
export { composeHandlers };
|
|
@@ -3,4 +3,4 @@ import { RenderElementProps } from './typings/renderer';
|
|
|
3
3
|
/**
|
|
4
4
|
* To compose sequential `renderElement`s to single.
|
|
5
5
|
*/
|
|
6
|
-
export declare function composeRenderElements(renderElements: ((props: RenderElementProps) => JSX.Element | null | undefined)[]): (props: RenderElementProps
|
|
6
|
+
export declare function composeRenderElements(renderElements: ((props: RenderElementProps) => JSX.Element | null | undefined)[]): (props: RenderElementProps) => JSX.Element;
|
|
@@ -2,11 +2,11 @@ import React from 'react';
|
|
|
2
2
|
import { composeRenderElementsBase } from '@quadrats/react/_internal';
|
|
3
3
|
import DefaultElement from './components/DefaultElement.js';
|
|
4
4
|
|
|
5
|
-
/**
|
|
6
|
-
* To compose sequential `renderElement`s to single.
|
|
7
|
-
*/
|
|
8
|
-
function composeRenderElements(renderElements) {
|
|
9
|
-
return composeRenderElementsBase(props => React.createElement(DefaultElement, Object.assign({}, props)), renderElements);
|
|
5
|
+
/**
|
|
6
|
+
* To compose sequential `renderElement`s to single.
|
|
7
|
+
*/
|
|
8
|
+
function composeRenderElements(renderElements) {
|
|
9
|
+
return composeRenderElementsBase(props => React.createElement(DefaultElement, Object.assign({}, props)), renderElements);
|
|
10
10
|
}
|
|
11
11
|
|
|
12
12
|
export { composeRenderElements };
|
|
@@ -2,11 +2,11 @@ import React from 'react';
|
|
|
2
2
|
import { composeRenderLeafsBase } from '@quadrats/react/_internal';
|
|
3
3
|
import DefaultLeaf from './components/DefaultLeaf.js';
|
|
4
4
|
|
|
5
|
-
/**
|
|
6
|
-
* To compose sequential `renderLeaf`s or `renderMark`s to single.
|
|
7
|
-
*/
|
|
8
|
-
function composeRenderLeafs(renderLeafs) {
|
|
9
|
-
return composeRenderLeafsBase(props => React.createElement(DefaultLeaf, Object.assign({}, props)), renderLeafs);
|
|
5
|
+
/**
|
|
6
|
+
* To compose sequential `renderLeaf`s or `renderMark`s to single.
|
|
7
|
+
*/
|
|
8
|
+
function composeRenderLeafs(renderLeafs) {
|
|
9
|
+
return composeRenderLeafsBase(props => React.createElement(DefaultLeaf, Object.assign({}, props)), renderLeafs);
|
|
10
10
|
}
|
|
11
11
|
|
|
12
12
|
export { composeRenderLeafs };
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { withReact } from 'slate-react';
|
|
2
2
|
import { createEditor } from '@quadrats/core';
|
|
3
3
|
|
|
4
|
-
function createReactEditor() {
|
|
5
|
-
return withReact(createEditor());
|
|
4
|
+
function createReactEditor() {
|
|
5
|
+
return withReact(createEditor());
|
|
6
6
|
}
|
|
7
7
|
|
|
8
8
|
export { createReactEditor };
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import { CreateRenderElementOptions, RenderElementProps } from './typings/renderer';
|
|
3
|
-
export declare function createRenderElement<P extends RenderElementProps>(options: CreateRenderElementOptions<P>): (props: RenderElementProps
|
|
3
|
+
export declare function createRenderElement<P extends RenderElementProps>(options: CreateRenderElementOptions<P>): (props: RenderElementProps) => JSX.Element | null | undefined;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { createRenderElementBase } from '@quadrats/react/_internal';
|
|
2
2
|
|
|
3
|
-
function createRenderElement(options) {
|
|
4
|
-
return createRenderElementBase(options);
|
|
3
|
+
function createRenderElement(options) {
|
|
4
|
+
return createRenderElementBase(options);
|
|
5
5
|
}
|
|
6
6
|
|
|
7
7
|
export { createRenderElement };
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import { CreateRenderElementOptions, RenderElementProps } from './typings/renderer';
|
|
3
|
-
export declare function createRenderElements<P extends RenderElementProps>(options: CreateRenderElementOptions<P>[]): (props: RenderElementProps
|
|
3
|
+
export declare function createRenderElements<P extends RenderElementProps>(options: CreateRenderElementOptions<P>[]): (props: RenderElementProps) => JSX.Element | null | undefined;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { createRenderElementsBase } from '@quadrats/react/_internal';
|
|
2
2
|
|
|
3
|
-
function createRenderElements(options) {
|
|
4
|
-
return createRenderElementsBase(options);
|
|
3
|
+
function createRenderElements(options) {
|
|
4
|
+
return createRenderElementsBase(options);
|
|
5
5
|
}
|
|
6
6
|
|
|
7
7
|
export { createRenderElements };
|
package/core/createRenderMark.js
CHANGED
package/core/index.d.ts
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { QuadratsEditor, QuadratsElement, QuadratsText } from '@quadrats/core';
|
|
2
2
|
import { ReactEditor } from 'slate-react';
|
|
3
3
|
export { useSlateStatic, useFocused, useReadOnly, useSelected, useSlate as useQuadrats, ReactEditor, } from 'slate-react';
|
|
4
|
-
export { Editor } from '@quadrats/core';
|
|
5
4
|
export * from './typings/handler';
|
|
6
5
|
export * from './typings/renderer';
|
|
7
6
|
export * from './typings/with';
|
|
8
7
|
export * from './typings/descendant';
|
|
8
|
+
export { Editor } from '@quadrats/core';
|
|
9
9
|
export { default as Editable, EditableProps } from './components/Editable';
|
|
10
10
|
export { default as DefaultElement } from './components/DefaultElement';
|
|
11
11
|
export { default as DefaultLeaf } from './components/DefaultLeaf';
|
|
@@ -17,12 +17,14 @@ export { createReactEditor } from './createReactEditor';
|
|
|
17
17
|
export { createRenderElement } from './createRenderElement';
|
|
18
18
|
export { createRenderElements } from './createRenderElements';
|
|
19
19
|
export { createRenderMark } from './createRenderMark';
|
|
20
|
-
export
|
|
21
|
-
|
|
20
|
+
export type QuadratsReactEditor = QuadratsEditor & ReactEditor;
|
|
21
|
+
export declare const PLACEHOLDER_KEY = "__quadrats-placeholder__";
|
|
22
22
|
declare module '@quadrats/core' {
|
|
23
23
|
interface CustomTypes {
|
|
24
24
|
Editor: QuadratsReactEditor;
|
|
25
25
|
Element: QuadratsElement;
|
|
26
|
-
Text: QuadratsText
|
|
26
|
+
Text: QuadratsText & {
|
|
27
|
+
[PLACEHOLDER_KEY]?: boolean;
|
|
28
|
+
};
|
|
27
29
|
}
|
|
28
30
|
}
|
package/core/index.js
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { ReactEditor, useFocused, useSlate as useQuadrats, useReadOnly, useSelected, useSlateStatic } from 'slate-react';
|
|
2
|
+
export { Editor } from '@quadrats/core';
|
|
3
|
+
import 'tslib';
|
|
4
|
+
import 'react';
|
|
5
|
+
import 'clsx';
|
|
6
|
+
import '@quadrats/react/configs';
|
|
7
|
+
import '@quadrats/react/_internal';
|
|
8
|
+
|
|
9
|
+
const PLACEHOLDER_KEY = '__quadrats-placeholder__';
|
|
10
|
+
|
|
11
|
+
export { PLACEHOLDER_KEY };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { QuadratsElement, QuadratsText } from '@quadrats/core';
|
|
2
|
-
export
|
|
2
|
+
export type Descendant = QuadratsElement | QuadratsText;
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { Editor } from '
|
|
1
|
+
import { Editor } from 'slate';
|
|
2
2
|
import { DOMAttributes, EventHandler } from 'react';
|
|
3
|
-
export
|
|
3
|
+
export type EventHandlerName = {
|
|
4
4
|
[K in keyof Required<DOMAttributes<HTMLElement>>]: NonNullable<DOMAttributes<HTMLElement>[K]> extends EventHandler<any> ? K : never;
|
|
5
5
|
}[keyof DOMAttributes<HTMLElement>];
|
|
6
|
-
export
|
|
7
|
-
export
|
|
8
|
-
export
|
|
9
|
-
export
|
|
10
|
-
export
|
|
6
|
+
export type EventHandlers = Pick<DOMAttributes<HTMLElement>, EventHandlerName>;
|
|
7
|
+
export type GetEventHandlerByName<H extends EventHandlerName> = NonNullable<EventHandlers[H]>;
|
|
8
|
+
export type GetEventByName<H extends EventHandlerName> = GetEventHandlerByName<H> extends (event: infer E) => void ? E : never;
|
|
9
|
+
export type Handler<H extends EventHandlerName> = (event: GetEventByName<H>, editor: Editor, next: VoidFunction) => void;
|
|
10
|
+
export type Handlers = {
|
|
11
11
|
[H in EventHandlerName]?: Handler<H>;
|
|
12
12
|
};
|
|
13
13
|
export interface WithCreateHandlers<P extends any[] = []> {
|
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
import { RenderElementProps as SlateReactRenderElementProps, RenderLeafProps as SlateRenderLeafProps } from 'slate-react';
|
|
3
3
|
import { QuadratsElement } from '@quadrats/core';
|
|
4
4
|
import { CreateRenderElementOptionsBase, CreateRenderMarkOptionsBase, RenderElementPropsBase, RenderLeafPropsBase, RenderMarkPropsBase } from '@quadrats/react/_internal';
|
|
5
|
-
export
|
|
6
|
-
export
|
|
7
|
-
export
|
|
8
|
-
export
|
|
9
|
-
export
|
|
5
|
+
export type RenderLeafProps = RenderLeafPropsBase & Pick<SlateRenderLeafProps, 'attributes'>;
|
|
6
|
+
export type RenderMarkProps<M> = RenderMarkPropsBase<M>;
|
|
7
|
+
export type RenderElementProps<E extends QuadratsElement = QuadratsElement> = RenderElementPropsBase<E> & Pick<SlateReactRenderElementProps, 'attributes'>;
|
|
8
|
+
export type CreateRenderMarkOptions<M> = CreateRenderMarkOptionsBase<M, RenderMarkProps<M>>;
|
|
9
|
+
export type CreateRenderElementOptions<P extends RenderElementProps<QuadratsElement>> = CreateRenderElementOptionsBase<P>;
|
|
10
10
|
export interface WithCreateRenderLeaf<P extends any[] = []> {
|
|
11
11
|
createRenderLeaf: (...params: P) => (props: RenderLeafProps) => JSX.Element;
|
|
12
12
|
}
|
package/core/typings/with.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Editor } from 'slate';
|
|
2
2
|
export interface ReactWithable<R = undefined> {
|
|
3
|
-
with: <T extends
|
|
3
|
+
with: <T extends Editor>(editor: T) => R extends undefined ? T : T & R;
|
|
4
4
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { CreateDividerOptions } from '@quadrats/common/divider';
|
|
2
2
|
import { ReactDivider } from './typings';
|
|
3
|
-
export
|
|
3
|
+
export type CreateReactDividerOptions = CreateDividerOptions;
|
|
4
4
|
export declare function createReactDivider(options?: CreateReactDividerOptions): ReactDivider;
|
|
@@ -2,10 +2,10 @@ import { createDivider } from '@quadrats/common/divider';
|
|
|
2
2
|
import { createRenderElement } from '@quadrats/react';
|
|
3
3
|
import { defaultRenderDividerElement } from './defaultRenderDividerElement.js';
|
|
4
4
|
|
|
5
|
-
function createReactDivider(options = {}) {
|
|
6
|
-
const core = createDivider(options);
|
|
7
|
-
const { type } = core;
|
|
8
|
-
return Object.assign(Object.assign({}, core), { createRenderElement: ({ render = defaultRenderDividerElement } = {}) => createRenderElement({ type, render }) });
|
|
5
|
+
function createReactDivider(options = {}) {
|
|
6
|
+
const core = createDivider(options);
|
|
7
|
+
const { type } = core;
|
|
8
|
+
return Object.assign(Object.assign({}, core), { createRenderElement: ({ render = defaultRenderDividerElement } = {}) => createRenderElement({ type, render }) });
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
export { createReactDivider };
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import { RenderDividerElementProps } from './typings';
|
|
3
|
-
export declare const defaultRenderDividerElement: ({ attributes, children }: RenderDividerElementProps) => JSX.Element;
|
|
3
|
+
export declare const defaultRenderDividerElement: ({ attributes, children }: RenderDividerElementProps) => React.JSX.Element;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
|
|
3
|
-
const defaultRenderDividerElement = ({ attributes, children }) => (React.createElement("div", Object.assign({}, attributes, { className: "qdr-divider", contentEditable: false }),
|
|
4
|
-
React.createElement("hr", null),
|
|
3
|
+
const defaultRenderDividerElement = ({ attributes, children }) => (React.createElement("div", Object.assign({}, attributes, { className: "qdr-divider", contentEditable: false }),
|
|
4
|
+
React.createElement("hr", null),
|
|
5
5
|
children));
|
|
6
6
|
|
|
7
7
|
export { defaultRenderDividerElement };
|
package/divider/index.cjs.js
CHANGED
|
@@ -1,23 +1,17 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
3
|
var React = require('react');
|
|
6
4
|
var divider = require('@quadrats/common/divider');
|
|
7
5
|
var react = require('@quadrats/react');
|
|
8
6
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
12
|
-
|
|
13
|
-
const defaultRenderDividerElement = ({ attributes, children }) => (React__default.createElement("div", Object.assign({}, attributes, { className: "qdr-divider", contentEditable: false }),
|
|
14
|
-
React__default.createElement("hr", null),
|
|
7
|
+
const defaultRenderDividerElement = ({ attributes, children }) => (React.createElement("div", Object.assign({}, attributes, { className: "qdr-divider", contentEditable: false }),
|
|
8
|
+
React.createElement("hr", null),
|
|
15
9
|
children));
|
|
16
10
|
|
|
17
|
-
function createReactDivider(options = {}) {
|
|
18
|
-
const core = divider.createDivider(options);
|
|
19
|
-
const { type } = core;
|
|
20
|
-
return Object.assign(Object.assign({}, core), { createRenderElement: ({ render = defaultRenderDividerElement } = {}) => react.createRenderElement({ type, render }) });
|
|
11
|
+
function createReactDivider(options = {}) {
|
|
12
|
+
const core = divider.createDivider(options);
|
|
13
|
+
const { type } = core;
|
|
14
|
+
return Object.assign(Object.assign({}, core), { createRenderElement: ({ render = defaultRenderDividerElement } = {}) => react.createRenderElement({ type, render }) });
|
|
21
15
|
}
|
|
22
16
|
|
|
23
17
|
exports.createReactDivider = createReactDivider;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import { CreateJsxSerializeElementOptions } from '@quadrats/react/jsx-serializer';
|
|
3
3
|
import { JsxSerializeDividerProps } from './typings';
|
|
4
|
-
export
|
|
5
|
-
export declare function createJsxSerializeDivider(options?: CreateJsxSerializeDividerOptions): (props: import("@quadrats/react/jsx-serializer").JsxSerializeElementProps
|
|
4
|
+
export type CreateJsxSerializeDividerOptions = Partial<CreateJsxSerializeElementOptions<JsxSerializeDividerProps>>;
|
|
5
|
+
export declare function createJsxSerializeDivider(options?: CreateJsxSerializeDividerOptions): (props: import("@quadrats/react/jsx-serializer").JsxSerializeElementProps) => JSX.Element | null | undefined;
|
|
@@ -2,9 +2,9 @@ import { DIVIDER_TYPE } from '@quadrats/common/divider';
|
|
|
2
2
|
import { createJsxSerializeElement } from '@quadrats/react/jsx-serializer';
|
|
3
3
|
import { defaultRenderDividerElement } from './defaultRenderDividerElement.js';
|
|
4
4
|
|
|
5
|
-
function createJsxSerializeDivider(options = {}) {
|
|
6
|
-
const { type = DIVIDER_TYPE, render = defaultRenderDividerElement } = options;
|
|
7
|
-
return createJsxSerializeElement({ type, render });
|
|
5
|
+
function createJsxSerializeDivider(options = {}) {
|
|
6
|
+
const { type = DIVIDER_TYPE, render = defaultRenderDividerElement } = options;
|
|
7
|
+
return createJsxSerializeElement({ type, render });
|
|
8
8
|
}
|
|
9
9
|
|
|
10
10
|
export { createJsxSerializeDivider };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
export declare const defaultRenderDividerElement: () => JSX.Element;
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare const defaultRenderDividerElement: () => React.JSX.Element;
|
|
@@ -1,20 +1,14 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
3
|
var React = require('react');
|
|
6
4
|
var divider = require('@quadrats/common/divider');
|
|
7
5
|
var jsxSerializer = require('@quadrats/react/jsx-serializer');
|
|
8
6
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
12
|
-
|
|
13
|
-
const defaultRenderDividerElement = () => React__default.createElement("hr", null);
|
|
7
|
+
const defaultRenderDividerElement = () => React.createElement("hr", null);
|
|
14
8
|
|
|
15
|
-
function createJsxSerializeDivider(options = {}) {
|
|
16
|
-
const { type = divider.DIVIDER_TYPE, render = defaultRenderDividerElement } = options;
|
|
17
|
-
return jsxSerializer.createJsxSerializeElement({ type, render });
|
|
9
|
+
function createJsxSerializeDivider(options = {}) {
|
|
10
|
+
const { type = divider.DIVIDER_TYPE, render = defaultRenderDividerElement } = options;
|
|
11
|
+
return jsxSerializer.createJsxSerializeElement({ type, render });
|
|
18
12
|
}
|
|
19
13
|
|
|
20
14
|
exports.createJsxSerializeDivider = createJsxSerializeDivider;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { DividerElement } from '@quadrats/common/divider';
|
|
2
2
|
import { JsxSerializeElementProps } from '@quadrats/react/jsx-serializer';
|
|
3
|
-
export
|
|
3
|
+
export type JsxSerializeDividerProps = JsxSerializeElementProps<DividerElement>;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import { ToolbarIconProps } from '@quadrats/react/toolbar';
|
|
3
3
|
import { ReactDivider } from '@quadrats/react/divider';
|
|
4
4
|
export interface DividerToolbarIconProps extends Omit<ToolbarIconProps, 'active' | 'onClick'> {
|
|
5
5
|
controller: ReactDivider;
|
|
6
6
|
}
|
|
7
|
-
declare function DividerToolbarIcon(props: DividerToolbarIconProps): JSX.Element;
|
|
7
|
+
declare function DividerToolbarIcon(props: DividerToolbarIconProps): React.JSX.Element;
|
|
8
8
|
export default DividerToolbarIcon;
|
|
@@ -3,10 +3,10 @@ import React from 'react';
|
|
|
3
3
|
import { ToolbarIcon } from '@quadrats/react/toolbar';
|
|
4
4
|
import { useDividerTool } from './useDividerTool.js';
|
|
5
5
|
|
|
6
|
-
function DividerToolbarIcon(props) {
|
|
7
|
-
const { controller } = props, rest = __rest(props, ["controller"]);
|
|
8
|
-
const { onClick } = useDividerTool(controller);
|
|
9
|
-
return React.createElement(ToolbarIcon, Object.assign({}, rest, { onClick: onClick }));
|
|
6
|
+
function DividerToolbarIcon(props) {
|
|
7
|
+
const { controller } = props, rest = __rest(props, ["controller"]);
|
|
8
|
+
const { onClick } = useDividerTool(controller);
|
|
9
|
+
return React.createElement(ToolbarIcon, Object.assign({}, rest, { onClick: onClick }));
|
|
10
10
|
}
|
|
11
11
|
|
|
12
12
|
export { DividerToolbarIcon as default };
|