@ruya.sa/richtext-slate 3.71.3
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/LICENSE.md +22 -0
- package/README.md +26 -0
- package/dist/cell/rscEntry.d.ts +11 -0
- package/dist/cell/rscEntry.d.ts.map +1 -0
- package/dist/cell/rscEntry.js +54 -0
- package/dist/cell/rscEntry.js.map +1 -0
- package/dist/data/defaultValue.d.ts +6 -0
- package/dist/data/defaultValue.d.ts.map +1 -0
- package/dist/data/defaultValue.js +11 -0
- package/dist/data/defaultValue.js.map +1 -0
- package/dist/data/populate.d.ts +21 -0
- package/dist/data/populate.d.ts.map +1 -0
- package/dist/data/populate.js +24 -0
- package/dist/data/populate.js.map +1 -0
- package/dist/data/recurseNestedFields.d.ts +16 -0
- package/dist/data/recurseNestedFields.d.ts.map +1 -0
- package/dist/data/recurseNestedFields.js +187 -0
- package/dist/data/recurseNestedFields.js.map +1 -0
- package/dist/data/richTextRelationshipPromise.d.ts +19 -0
- package/dist/data/richTextRelationshipPromise.d.ts.map +1 -0
- package/dist/data/richTextRelationshipPromise.js +110 -0
- package/dist/data/richTextRelationshipPromise.js.map +1 -0
- package/dist/data/validation.d.ts +4 -0
- package/dist/data/validation.d.ts.map +1 -0
- package/dist/data/validation.js +14 -0
- package/dist/data/validation.js.map +1 -0
- package/dist/exports/client/index.d.ts +51 -0
- package/dist/exports/client/index.d.ts.map +1 -0
- package/dist/exports/client/index.js +53 -0
- package/dist/exports/client/index.js.map +1 -0
- package/dist/exports/server/rsc.d.ts +3 -0
- package/dist/exports/server/rsc.d.ts.map +1 -0
- package/dist/exports/server/rsc.js +4 -0
- package/dist/exports/server/rsc.js.map +1 -0
- package/dist/field/RichText.d.ts +16 -0
- package/dist/field/RichText.d.ts.map +1 -0
- package/dist/field/RichText.js +434 -0
- package/dist/field/RichText.js.map +1 -0
- package/dist/field/buttons.scss +17 -0
- package/dist/field/createFeatureMap.d.ts +4 -0
- package/dist/field/createFeatureMap.d.ts.map +1 -0
- package/dist/field/createFeatureMap.js +50 -0
- package/dist/field/createFeatureMap.js.map +1 -0
- package/dist/field/elements/Button.d.ts +6 -0
- package/dist/field/elements/Button.d.ts.map +1 -0
- package/dist/field/elements/Button.js +50 -0
- package/dist/field/elements/Button.js.map +1 -0
- package/dist/field/elements/EnabledRelationshipsCondition.d.ts +3 -0
- package/dist/field/elements/EnabledRelationshipsCondition.d.ts.map +1 -0
- package/dist/field/elements/EnabledRelationshipsCondition.js +34 -0
- package/dist/field/elements/EnabledRelationshipsCondition.js.map +1 -0
- package/dist/field/elements/ListButton.d.ts +6 -0
- package/dist/field/elements/ListButton.d.ts.map +1 -0
- package/dist/field/elements/ListButton.js +30 -0
- package/dist/field/elements/ListButton.js.map +1 -0
- package/dist/field/elements/areAllChildrenElements.d.ts +3 -0
- package/dist/field/elements/areAllChildrenElements.d.ts.map +1 -0
- package/dist/field/elements/areAllChildrenElements.js +6 -0
- package/dist/field/elements/areAllChildrenElements.js.map +1 -0
- package/dist/field/elements/blockquote/Button.d.ts +4 -0
- package/dist/field/elements/blockquote/Button.d.ts.map +1 -0
- package/dist/field/elements/blockquote/Button.js +11 -0
- package/dist/field/elements/blockquote/Button.js.map +1 -0
- package/dist/field/elements/blockquote/Element.d.ts +3 -0
- package/dist/field/elements/blockquote/Element.d.ts.map +1 -0
- package/dist/field/elements/blockquote/Element.js +15 -0
- package/dist/field/elements/blockquote/Element.js.map +1 -0
- package/dist/field/elements/blockquote/index.d.ts +3 -0
- package/dist/field/elements/blockquote/index.d.ts.map +1 -0
- package/dist/field/elements/blockquote/index.js +13 -0
- package/dist/field/elements/blockquote/index.js.map +1 -0
- package/dist/field/elements/blockquote/index.scss +11 -0
- package/dist/field/elements/getCommonBlock.d.ts +4 -0
- package/dist/field/elements/getCommonBlock.d.ts.map +1 -0
- package/dist/field/elements/getCommonBlock.js +20 -0
- package/dist/field/elements/getCommonBlock.js.map +1 -0
- package/dist/field/elements/h1/Button.d.ts +4 -0
- package/dist/field/elements/h1/Button.d.ts.map +1 -0
- package/dist/field/elements/h1/Button.js +11 -0
- package/dist/field/elements/h1/Button.js.map +1 -0
- package/dist/field/elements/h1/Heading1.d.ts +2 -0
- package/dist/field/elements/h1/Heading1.d.ts.map +1 -0
- package/dist/field/elements/h1/Heading1.js +13 -0
- package/dist/field/elements/h1/Heading1.js.map +1 -0
- package/dist/field/elements/h1/index.d.ts +3 -0
- package/dist/field/elements/h1/index.d.ts.map +1 -0
- package/dist/field/elements/h1/index.js +13 -0
- package/dist/field/elements/h1/index.js.map +1 -0
- package/dist/field/elements/h2/Button.d.ts +4 -0
- package/dist/field/elements/h2/Button.d.ts.map +1 -0
- package/dist/field/elements/h2/Button.js +11 -0
- package/dist/field/elements/h2/Button.js.map +1 -0
- package/dist/field/elements/h2/Heading2.d.ts +2 -0
- package/dist/field/elements/h2/Heading2.d.ts.map +1 -0
- package/dist/field/elements/h2/Heading2.js +13 -0
- package/dist/field/elements/h2/Heading2.js.map +1 -0
- package/dist/field/elements/h2/index.d.ts +3 -0
- package/dist/field/elements/h2/index.d.ts.map +1 -0
- package/dist/field/elements/h2/index.js +13 -0
- package/dist/field/elements/h2/index.js.map +1 -0
- package/dist/field/elements/h3/Button.d.ts +4 -0
- package/dist/field/elements/h3/Button.d.ts.map +1 -0
- package/dist/field/elements/h3/Button.js +11 -0
- package/dist/field/elements/h3/Button.js.map +1 -0
- package/dist/field/elements/h3/Heading3.d.ts +2 -0
- package/dist/field/elements/h3/Heading3.d.ts.map +1 -0
- package/dist/field/elements/h3/Heading3.js +13 -0
- package/dist/field/elements/h3/Heading3.js.map +1 -0
- package/dist/field/elements/h3/index.d.ts +3 -0
- package/dist/field/elements/h3/index.d.ts.map +1 -0
- package/dist/field/elements/h3/index.js +13 -0
- package/dist/field/elements/h3/index.js.map +1 -0
- package/dist/field/elements/h4/Button.d.ts +4 -0
- package/dist/field/elements/h4/Button.d.ts.map +1 -0
- package/dist/field/elements/h4/Button.js +11 -0
- package/dist/field/elements/h4/Button.js.map +1 -0
- package/dist/field/elements/h4/Heading4.d.ts +2 -0
- package/dist/field/elements/h4/Heading4.d.ts.map +1 -0
- package/dist/field/elements/h4/Heading4.js +13 -0
- package/dist/field/elements/h4/Heading4.js.map +1 -0
- package/dist/field/elements/h4/index.d.ts +3 -0
- package/dist/field/elements/h4/index.d.ts.map +1 -0
- package/dist/field/elements/h4/index.js +13 -0
- package/dist/field/elements/h4/index.js.map +1 -0
- package/dist/field/elements/h5/Button.d.ts +4 -0
- package/dist/field/elements/h5/Button.d.ts.map +1 -0
- package/dist/field/elements/h5/Button.js +11 -0
- package/dist/field/elements/h5/Button.js.map +1 -0
- package/dist/field/elements/h5/Heading5.d.ts +2 -0
- package/dist/field/elements/h5/Heading5.d.ts.map +1 -0
- package/dist/field/elements/h5/Heading5.js +13 -0
- package/dist/field/elements/h5/Heading5.js.map +1 -0
- package/dist/field/elements/h5/index.d.ts +3 -0
- package/dist/field/elements/h5/index.d.ts.map +1 -0
- package/dist/field/elements/h5/index.js +13 -0
- package/dist/field/elements/h5/index.js.map +1 -0
- package/dist/field/elements/h6/Button.d.ts +4 -0
- package/dist/field/elements/h6/Button.d.ts.map +1 -0
- package/dist/field/elements/h6/Button.js +11 -0
- package/dist/field/elements/h6/Button.js.map +1 -0
- package/dist/field/elements/h6/Heading6.d.ts +2 -0
- package/dist/field/elements/h6/Heading6.d.ts.map +1 -0
- package/dist/field/elements/h6/Heading6.js +13 -0
- package/dist/field/elements/h6/Heading6.js.map +1 -0
- package/dist/field/elements/h6/index.d.ts +3 -0
- package/dist/field/elements/h6/index.d.ts.map +1 -0
- package/dist/field/elements/h6/index.js +13 -0
- package/dist/field/elements/h6/index.js.map +1 -0
- package/dist/field/elements/indent/Button.d.ts +3 -0
- package/dist/field/elements/indent/Button.d.ts.map +1 -0
- package/dist/field/elements/indent/Button.js +184 -0
- package/dist/field/elements/indent/Button.js.map +1 -0
- package/dist/field/elements/indent/Element.d.ts +3 -0
- package/dist/field/elements/indent/Element.d.ts.map +1 -0
- package/dist/field/elements/indent/Element.js +16 -0
- package/dist/field/elements/indent/Element.js.map +1 -0
- package/dist/field/elements/indent/index.d.ts +3 -0
- package/dist/field/elements/indent/index.d.ts.map +1 -0
- package/dist/field/elements/indent/index.js +8 -0
- package/dist/field/elements/indent/index.js.map +1 -0
- package/dist/field/elements/indent/shared.d.ts +2 -0
- package/dist/field/elements/indent/shared.d.ts.map +1 -0
- package/dist/field/elements/indent/shared.js +3 -0
- package/dist/field/elements/indent/shared.js.map +1 -0
- package/dist/field/elements/index.d.ts +3 -0
- package/dist/field/elements/index.d.ts.map +1 -0
- package/dist/field/elements/index.js +34 -0
- package/dist/field/elements/index.js.map +1 -0
- package/dist/field/elements/injectVoid.d.ts +4 -0
- package/dist/field/elements/injectVoid.d.ts.map +1 -0
- package/dist/field/elements/injectVoid.js +36 -0
- package/dist/field/elements/injectVoid.js.map +1 -0
- package/dist/field/elements/isActive.d.ts +3 -0
- package/dist/field/elements/isActive.d.ts.map +1 -0
- package/dist/field/elements/isActive.js +13 -0
- package/dist/field/elements/isActive.js.map +1 -0
- package/dist/field/elements/isBlockElement.d.ts +9 -0
- package/dist/field/elements/isBlockElement.d.ts.map +1 -0
- package/dist/field/elements/isBlockElement.js +23 -0
- package/dist/field/elements/isBlockElement.js.map +1 -0
- package/dist/field/elements/isLastSelectedElementEmpty.d.ts +3 -0
- package/dist/field/elements/isLastSelectedElementEmpty.d.ts.map +1 -0
- package/dist/field/elements/isLastSelectedElementEmpty.js +15 -0
- package/dist/field/elements/isLastSelectedElementEmpty.js.map +1 -0
- package/dist/field/elements/isListActive.d.ts +3 -0
- package/dist/field/elements/isListActive.d.ts.map +1 -0
- package/dist/field/elements/isListActive.js +21 -0
- package/dist/field/elements/isListActive.js.map +1 -0
- package/dist/field/elements/isWithinListItem.d.ts +3 -0
- package/dist/field/elements/isWithinListItem.d.ts.map +1 -0
- package/dist/field/elements/isWithinListItem.js +15 -0
- package/dist/field/elements/isWithinListItem.js.map +1 -0
- package/dist/field/elements/li/ListItem.d.ts +3 -0
- package/dist/field/elements/li/ListItem.d.ts.map +1 -0
- package/dist/field/elements/li/ListItem.js +20 -0
- package/dist/field/elements/li/ListItem.js.map +1 -0
- package/dist/field/elements/li/index.d.ts +3 -0
- package/dist/field/elements/li/index.d.ts.map +1 -0
- package/dist/field/elements/li/index.js +6 -0
- package/dist/field/elements/li/index.js.map +1 -0
- package/dist/field/elements/link/Button/index.d.ts +5 -0
- package/dist/field/elements/link/Button/index.d.ts.map +1 -0
- package/dist/field/elements/link/Button/index.js +127 -0
- package/dist/field/elements/link/Button/index.js.map +1 -0
- package/dist/field/elements/link/Element/index.d.ts +3 -0
- package/dist/field/elements/link/Element/index.d.ts.map +1 -0
- package/dist/field/elements/link/Element/index.js +218 -0
- package/dist/field/elements/link/Element/index.js.map +1 -0
- package/dist/field/elements/link/Element/index.scss +90 -0
- package/dist/field/elements/link/LinkDrawer/baseFields.d.ts +3 -0
- package/dist/field/elements/link/LinkDrawer/baseFields.d.ts.map +1 -0
- package/dist/field/elements/link/LinkDrawer/baseFields.js +70 -0
- package/dist/field/elements/link/LinkDrawer/baseFields.js.map +1 -0
- package/dist/field/elements/link/LinkDrawer/index.d.ts +5 -0
- package/dist/field/elements/link/LinkDrawer/index.d.ts.map +1 -0
- package/dist/field/elements/link/LinkDrawer/index.js +89 -0
- package/dist/field/elements/link/LinkDrawer/index.js.map +1 -0
- package/dist/field/elements/link/LinkDrawer/index.scss +52 -0
- package/dist/field/elements/link/LinkDrawer/types.d.ts +10 -0
- package/dist/field/elements/link/LinkDrawer/types.d.ts.map +1 -0
- package/dist/field/elements/link/LinkDrawer/types.js +3 -0
- package/dist/field/elements/link/LinkDrawer/types.js.map +1 -0
- package/dist/field/elements/link/WithLinks.d.ts +3 -0
- package/dist/field/elements/link/WithLinks.d.ts.map +1 -0
- package/dist/field/elements/link/WithLinks.js +19 -0
- package/dist/field/elements/link/WithLinks.js.map +1 -0
- package/dist/field/elements/link/index.d.ts +3 -0
- package/dist/field/elements/link/index.d.ts.map +1 -0
- package/dist/field/elements/link/index.js +10 -0
- package/dist/field/elements/link/index.js.map +1 -0
- package/dist/field/elements/link/shared.d.ts +3 -0
- package/dist/field/elements/link/shared.d.ts.map +1 -0
- package/dist/field/elements/link/shared.js +4 -0
- package/dist/field/elements/link/shared.js.map +1 -0
- package/dist/field/elements/link/types.d.ts +9 -0
- package/dist/field/elements/link/types.d.ts.map +1 -0
- package/dist/field/elements/link/types.js +3 -0
- package/dist/field/elements/link/types.js.map +1 -0
- package/dist/field/elements/link/utilities.d.ts +12 -0
- package/dist/field/elements/link/utilities.d.ts.map +1 -0
- package/dist/field/elements/link/utilities.js +72 -0
- package/dist/field/elements/link/utilities.js.map +1 -0
- package/dist/field/elements/listTypes.d.ts +2 -0
- package/dist/field/elements/listTypes.d.ts.map +1 -0
- package/dist/field/elements/listTypes.js +6 -0
- package/dist/field/elements/listTypes.js.map +1 -0
- package/dist/field/elements/ol/Button.d.ts +4 -0
- package/dist/field/elements/ol/Button.d.ts.map +1 -0
- package/dist/field/elements/ol/Button.js +11 -0
- package/dist/field/elements/ol/Button.js.map +1 -0
- package/dist/field/elements/ol/OrderedList.d.ts +4 -0
- package/dist/field/elements/ol/OrderedList.d.ts.map +1 -0
- package/dist/field/elements/ol/OrderedList.js +15 -0
- package/dist/field/elements/ol/OrderedList.js.map +1 -0
- package/dist/field/elements/ol/index.d.ts +3 -0
- package/dist/field/elements/ol/index.d.ts.map +1 -0
- package/dist/field/elements/ol/index.js +13 -0
- package/dist/field/elements/ol/index.js.map +1 -0
- package/dist/field/elements/ol/index.scss +9 -0
- package/dist/field/elements/relationship/Button/index.d.ts +9 -0
- package/dist/field/elements/relationship/Button/index.d.ts.map +1 -0
- package/dist/field/elements/relationship/Button/index.js +76 -0
- package/dist/field/elements/relationship/Button/index.js.map +1 -0
- package/dist/field/elements/relationship/Button/index.scss +9 -0
- package/dist/field/elements/relationship/Element/index.d.ts +4 -0
- package/dist/field/elements/relationship/Element/index.d.ts.map +1 -0
- package/dist/field/elements/relationship/Element/index.js +192 -0
- package/dist/field/elements/relationship/Element/index.js.map +1 -0
- package/dist/field/elements/relationship/Element/index.scss +95 -0
- package/dist/field/elements/relationship/index.d.ts +3 -0
- package/dist/field/elements/relationship/index.d.ts.map +1 -0
- package/dist/field/elements/relationship/index.js +11 -0
- package/dist/field/elements/relationship/index.js.map +1 -0
- package/dist/field/elements/relationship/plugin.d.ts +3 -0
- package/dist/field/elements/relationship/plugin.d.ts.map +1 -0
- package/dist/field/elements/relationship/plugin.js +14 -0
- package/dist/field/elements/relationship/plugin.js.map +1 -0
- package/dist/field/elements/relationship/shared.d.ts +2 -0
- package/dist/field/elements/relationship/shared.d.ts.map +1 -0
- package/dist/field/elements/relationship/shared.js +3 -0
- package/dist/field/elements/relationship/shared.js.map +1 -0
- package/dist/field/elements/relationship/types.d.ts +8 -0
- package/dist/field/elements/relationship/types.d.ts.map +1 -0
- package/dist/field/elements/relationship/types.js +3 -0
- package/dist/field/elements/relationship/types.js.map +1 -0
- package/dist/field/elements/textAlign/Button.d.ts +2 -0
- package/dist/field/elements/textAlign/Button.d.ts.map +1 -0
- package/dist/field/elements/textAlign/Button.js +28 -0
- package/dist/field/elements/textAlign/Button.js.map +1 -0
- package/dist/field/elements/textAlign/index.d.ts +3 -0
- package/dist/field/elements/textAlign/index.d.ts.map +1 -0
- package/dist/field/elements/textAlign/index.js +7 -0
- package/dist/field/elements/textAlign/index.js.map +1 -0
- package/dist/field/elements/toggle.d.ts +3 -0
- package/dist/field/elements/toggle.d.ts.map +1 -0
- package/dist/field/elements/toggle.js +32 -0
- package/dist/field/elements/toggle.js.map +1 -0
- package/dist/field/elements/toggleList.d.ts +3 -0
- package/dist/field/elements/toggleList.d.ts.map +1 -0
- package/dist/field/elements/toggleList.js +82 -0
- package/dist/field/elements/toggleList.js.map +1 -0
- package/dist/field/elements/types.d.ts +12 -0
- package/dist/field/elements/types.d.ts.map +1 -0
- package/dist/field/elements/types.js +3 -0
- package/dist/field/elements/types.js.map +1 -0
- package/dist/field/elements/ul/Button.d.ts +4 -0
- package/dist/field/elements/ul/Button.d.ts.map +1 -0
- package/dist/field/elements/ul/Button.js +11 -0
- package/dist/field/elements/ul/Button.js.map +1 -0
- package/dist/field/elements/ul/UnorderedList.d.ts +4 -0
- package/dist/field/elements/ul/UnorderedList.d.ts.map +1 -0
- package/dist/field/elements/ul/UnorderedList.js +15 -0
- package/dist/field/elements/ul/UnorderedList.js.map +1 -0
- package/dist/field/elements/ul/index.d.ts +3 -0
- package/dist/field/elements/ul/index.d.ts.map +1 -0
- package/dist/field/elements/ul/index.js +13 -0
- package/dist/field/elements/ul/index.js.map +1 -0
- package/dist/field/elements/ul/index.scss +9 -0
- package/dist/field/elements/unwrapList.d.ts +4 -0
- package/dist/field/elements/unwrapList.d.ts.map +1 -0
- package/dist/field/elements/unwrapList.js +34 -0
- package/dist/field/elements/unwrapList.js.map +1 -0
- package/dist/field/elements/upload/Button/index.d.ts +9 -0
- package/dist/field/elements/upload/Button/index.d.ts.map +1 -0
- package/dist/field/elements/upload/Button/index.js +76 -0
- package/dist/field/elements/upload/Button/index.js.map +1 -0
- package/dist/field/elements/upload/Button/index.scss +9 -0
- package/dist/field/elements/upload/Element/UploadDrawer/index.d.ts +12 -0
- package/dist/field/elements/upload/Element/UploadDrawer/index.d.ts.map +1 -0
- package/dist/field/elements/upload/Element/UploadDrawer/index.js +127 -0
- package/dist/field/elements/upload/Element/UploadDrawer/index.js.map +1 -0
- package/dist/field/elements/upload/Element/index.d.ts +4 -0
- package/dist/field/elements/upload/Element/index.d.ts.map +1 -0
- package/dist/field/elements/upload/Element/index.js +230 -0
- package/dist/field/elements/upload/Element/index.js.map +1 -0
- package/dist/field/elements/upload/Element/index.scss +149 -0
- package/dist/field/elements/upload/index.d.ts +3 -0
- package/dist/field/elements/upload/index.d.ts.map +1 -0
- package/dist/field/elements/upload/index.js +11 -0
- package/dist/field/elements/upload/index.js.map +1 -0
- package/dist/field/elements/upload/plugin.d.ts +3 -0
- package/dist/field/elements/upload/plugin.d.ts.map +1 -0
- package/dist/field/elements/upload/plugin.js +14 -0
- package/dist/field/elements/upload/plugin.js.map +1 -0
- package/dist/field/elements/upload/shared.d.ts +3 -0
- package/dist/field/elements/upload/shared.d.ts.map +1 -0
- package/dist/field/elements/upload/shared.js +4 -0
- package/dist/field/elements/upload/shared.js.map +1 -0
- package/dist/field/elements/upload/types.d.ts +9 -0
- package/dist/field/elements/upload/types.d.ts.map +1 -0
- package/dist/field/elements/upload/types.js +3 -0
- package/dist/field/elements/upload/types.js.map +1 -0
- package/dist/field/hotkeys.d.ts +7 -0
- package/dist/field/hotkeys.d.ts.map +1 -0
- package/dist/field/hotkeys.js +8 -0
- package/dist/field/hotkeys.js.map +1 -0
- package/dist/field/icons/AlignCenter/index.d.ts +3 -0
- package/dist/field/icons/AlignCenter/index.d.ts.map +1 -0
- package/dist/field/icons/AlignCenter/index.js +13 -0
- package/dist/field/icons/AlignCenter/index.js.map +1 -0
- package/dist/field/icons/AlignLeft/index.d.ts +3 -0
- package/dist/field/icons/AlignLeft/index.d.ts.map +1 -0
- package/dist/field/icons/AlignLeft/index.js +13 -0
- package/dist/field/icons/AlignLeft/index.js.map +1 -0
- package/dist/field/icons/AlignRight/index.d.ts +3 -0
- package/dist/field/icons/AlignRight/index.d.ts.map +1 -0
- package/dist/field/icons/AlignRight/index.js +13 -0
- package/dist/field/icons/AlignRight/index.js.map +1 -0
- package/dist/field/icons/Blockquote/index.d.ts +3 -0
- package/dist/field/icons/Blockquote/index.d.ts.map +1 -0
- package/dist/field/icons/Blockquote/index.js +22 -0
- package/dist/field/icons/Blockquote/index.js.map +1 -0
- package/dist/field/icons/Bold/index.d.ts +3 -0
- package/dist/field/icons/Bold/index.d.ts.map +1 -0
- package/dist/field/icons/Bold/index.js +22 -0
- package/dist/field/icons/Bold/index.js.map +1 -0
- package/dist/field/icons/Code/index.d.ts +3 -0
- package/dist/field/icons/Code/index.d.ts.map +1 -0
- package/dist/field/icons/Code/index.js +16 -0
- package/dist/field/icons/Code/index.js.map +1 -0
- package/dist/field/icons/IndentLeft/index.d.ts +4 -0
- package/dist/field/icons/IndentLeft/index.d.ts.map +1 -0
- package/dist/field/icons/IndentLeft/index.js +37 -0
- package/dist/field/icons/IndentLeft/index.js.map +1 -0
- package/dist/field/icons/IndentLeft/index.scss +18 -0
- package/dist/field/icons/IndentRight/index.d.ts +4 -0
- package/dist/field/icons/IndentRight/index.d.ts.map +1 -0
- package/dist/field/icons/IndentRight/index.js +37 -0
- package/dist/field/icons/IndentRight/index.js.map +1 -0
- package/dist/field/icons/IndentRight/index.scss +18 -0
- package/dist/field/icons/Italic/index.d.ts +3 -0
- package/dist/field/icons/Italic/index.d.ts.map +1 -0
- package/dist/field/icons/Italic/index.js +22 -0
- package/dist/field/icons/Italic/index.js.map +1 -0
- package/dist/field/icons/Link/index.d.ts +4 -0
- package/dist/field/icons/Link/index.d.ts.map +1 -0
- package/dist/field/icons/Link/index.js +23 -0
- package/dist/field/icons/Link/index.js.map +1 -0
- package/dist/field/icons/Link/index.scss +13 -0
- package/dist/field/icons/OrderedList/index.d.ts +3 -0
- package/dist/field/icons/OrderedList/index.d.ts.map +1 -0
- package/dist/field/icons/OrderedList/index.js +22 -0
- package/dist/field/icons/OrderedList/index.js.map +1 -0
- package/dist/field/icons/Relationship/index.d.ts +4 -0
- package/dist/field/icons/Relationship/index.d.ts.map +1 -0
- package/dist/field/icons/Relationship/index.js +30 -0
- package/dist/field/icons/Relationship/index.js.map +1 -0
- package/dist/field/icons/Relationship/index.scss +14 -0
- package/dist/field/icons/Strikethrough/index.d.ts +3 -0
- package/dist/field/icons/Strikethrough/index.d.ts.map +1 -0
- package/dist/field/icons/Strikethrough/index.js +22 -0
- package/dist/field/icons/Strikethrough/index.js.map +1 -0
- package/dist/field/icons/Underline/index.d.ts +3 -0
- package/dist/field/icons/Underline/index.d.ts.map +1 -0
- package/dist/field/icons/Underline/index.js +22 -0
- package/dist/field/icons/Underline/index.js.map +1 -0
- package/dist/field/icons/UnorderedList/index.d.ts +3 -0
- package/dist/field/icons/UnorderedList/index.d.ts.map +1 -0
- package/dist/field/icons/UnorderedList/index.js +22 -0
- package/dist/field/icons/UnorderedList/index.js.map +1 -0
- package/dist/field/icons/Upload/index.d.ts +4 -0
- package/dist/field/icons/Upload/index.d.ts.map +1 -0
- package/dist/field/icons/Upload/index.js +22 -0
- package/dist/field/icons/Upload/index.js.map +1 -0
- package/dist/field/icons/Upload/index.scss +13 -0
- package/dist/field/icons/headings/H1/index.d.ts +3 -0
- package/dist/field/icons/headings/H1/index.d.ts.map +1 -0
- package/dist/field/icons/headings/H1/index.js +22 -0
- package/dist/field/icons/headings/H1/index.js.map +1 -0
- package/dist/field/icons/headings/H2/index.d.ts +3 -0
- package/dist/field/icons/headings/H2/index.d.ts.map +1 -0
- package/dist/field/icons/headings/H2/index.js +22 -0
- package/dist/field/icons/headings/H2/index.js.map +1 -0
- package/dist/field/icons/headings/H3/index.d.ts +3 -0
- package/dist/field/icons/headings/H3/index.d.ts.map +1 -0
- package/dist/field/icons/headings/H3/index.js +22 -0
- package/dist/field/icons/headings/H3/index.js.map +1 -0
- package/dist/field/icons/headings/H4/index.d.ts +3 -0
- package/dist/field/icons/headings/H4/index.d.ts.map +1 -0
- package/dist/field/icons/headings/H4/index.js +22 -0
- package/dist/field/icons/headings/H4/index.js.map +1 -0
- package/dist/field/icons/headings/H5/index.d.ts +3 -0
- package/dist/field/icons/headings/H5/index.d.ts.map +1 -0
- package/dist/field/icons/headings/H5/index.js +22 -0
- package/dist/field/icons/headings/H5/index.js.map +1 -0
- package/dist/field/icons/headings/H6/index.d.ts +3 -0
- package/dist/field/icons/headings/H6/index.d.ts.map +1 -0
- package/dist/field/icons/headings/H6/index.js +22 -0
- package/dist/field/icons/headings/H6/index.js.map +1 -0
- package/dist/field/index.d.ts +4 -0
- package/dist/field/index.d.ts.map +1 -0
- package/dist/field/index.js +63 -0
- package/dist/field/index.js.map +1 -0
- package/dist/field/index.scss +215 -0
- package/dist/field/leaves/Button.d.ts +6 -0
- package/dist/field/leaves/Button.d.ts.map +1 -0
- package/dist/field/leaves/Button.js +25 -0
- package/dist/field/leaves/Button.js.map +1 -0
- package/dist/field/leaves/bold/Bold/index.d.ts +2 -0
- package/dist/field/leaves/bold/Bold/index.d.ts.map +1 -0
- package/dist/field/leaves/bold/Bold/index.js +13 -0
- package/dist/field/leaves/bold/Bold/index.js.map +1 -0
- package/dist/field/leaves/bold/LeafButton.d.ts +2 -0
- package/dist/field/leaves/bold/LeafButton.d.ts.map +1 -0
- package/dist/field/leaves/bold/LeafButton.js +11 -0
- package/dist/field/leaves/bold/LeafButton.js.map +1 -0
- package/dist/field/leaves/bold/index.d.ts +3 -0
- package/dist/field/leaves/bold/index.d.ts.map +1 -0
- package/dist/field/leaves/bold/index.js +7 -0
- package/dist/field/leaves/bold/index.js.map +1 -0
- package/dist/field/leaves/code/Code/index.d.ts +2 -0
- package/dist/field/leaves/code/Code/index.d.ts.map +1 -0
- package/dist/field/leaves/code/Code/index.js +13 -0
- package/dist/field/leaves/code/Code/index.js.map +1 -0
- package/dist/field/leaves/code/LeafButton.d.ts +2 -0
- package/dist/field/leaves/code/LeafButton.d.ts.map +1 -0
- package/dist/field/leaves/code/LeafButton.js +11 -0
- package/dist/field/leaves/code/LeafButton.js.map +1 -0
- package/dist/field/leaves/code/index.d.ts +3 -0
- package/dist/field/leaves/code/index.d.ts.map +1 -0
- package/dist/field/leaves/code/index.js +7 -0
- package/dist/field/leaves/code/index.js.map +1 -0
- package/dist/field/leaves/index.d.ts +3 -0
- package/dist/field/leaves/index.d.ts.map +1 -0
- package/dist/field/leaves/index.js +14 -0
- package/dist/field/leaves/index.js.map +1 -0
- package/dist/field/leaves/isActive.d.ts +2 -0
- package/dist/field/leaves/isActive.d.ts.map +1 -0
- package/dist/field/leaves/isActive.js +7 -0
- package/dist/field/leaves/isActive.js.map +1 -0
- package/dist/field/leaves/italic/Italic/index.d.ts +2 -0
- package/dist/field/leaves/italic/Italic/index.d.ts.map +1 -0
- package/dist/field/leaves/italic/Italic/index.js +13 -0
- package/dist/field/leaves/italic/Italic/index.js.map +1 -0
- package/dist/field/leaves/italic/LeafButton.d.ts +2 -0
- package/dist/field/leaves/italic/LeafButton.d.ts.map +1 -0
- package/dist/field/leaves/italic/LeafButton.js +11 -0
- package/dist/field/leaves/italic/LeafButton.js.map +1 -0
- package/dist/field/leaves/italic/index.d.ts +3 -0
- package/dist/field/leaves/italic/index.d.ts.map +1 -0
- package/dist/field/leaves/italic/index.js +7 -0
- package/dist/field/leaves/italic/index.js.map +1 -0
- package/dist/field/leaves/strikethrough/LeafButton.d.ts +2 -0
- package/dist/field/leaves/strikethrough/LeafButton.d.ts.map +1 -0
- package/dist/field/leaves/strikethrough/LeafButton.js +11 -0
- package/dist/field/leaves/strikethrough/LeafButton.js.map +1 -0
- package/dist/field/leaves/strikethrough/Strikethrough/index.d.ts +2 -0
- package/dist/field/leaves/strikethrough/Strikethrough/index.d.ts.map +1 -0
- package/dist/field/leaves/strikethrough/Strikethrough/index.js +13 -0
- package/dist/field/leaves/strikethrough/Strikethrough/index.js.map +1 -0
- package/dist/field/leaves/strikethrough/index.d.ts +3 -0
- package/dist/field/leaves/strikethrough/index.d.ts.map +1 -0
- package/dist/field/leaves/strikethrough/index.js +7 -0
- package/dist/field/leaves/strikethrough/index.js.map +1 -0
- package/dist/field/leaves/toggle.d.ts +2 -0
- package/dist/field/leaves/toggle.d.ts.map +1 -0
- package/dist/field/leaves/toggle.js +12 -0
- package/dist/field/leaves/toggle.js.map +1 -0
- package/dist/field/leaves/underline/LeafButton.d.ts +2 -0
- package/dist/field/leaves/underline/LeafButton.d.ts.map +1 -0
- package/dist/field/leaves/underline/LeafButton.js +11 -0
- package/dist/field/leaves/underline/LeafButton.js.map +1 -0
- package/dist/field/leaves/underline/Underline/index.d.ts +2 -0
- package/dist/field/leaves/underline/Underline/index.d.ts.map +1 -0
- package/dist/field/leaves/underline/Underline/index.js +13 -0
- package/dist/field/leaves/underline/Underline/index.js.map +1 -0
- package/dist/field/leaves/underline/index.d.ts +3 -0
- package/dist/field/leaves/underline/index.d.ts.map +1 -0
- package/dist/field/leaves/underline/index.js +7 -0
- package/dist/field/leaves/underline/index.js.map +1 -0
- package/dist/field/mergeCustomFunctions.d.ts +3 -0
- package/dist/field/mergeCustomFunctions.d.ts.map +1 -0
- package/dist/field/mergeCustomFunctions.js +25 -0
- package/dist/field/mergeCustomFunctions.js.map +1 -0
- package/dist/field/plugins/withEnterBreakOut.d.ts +2 -0
- package/dist/field/plugins/withEnterBreakOut.d.ts.map +1 -0
- package/dist/field/plugins/withEnterBreakOut.js +16 -0
- package/dist/field/plugins/withEnterBreakOut.js.map +1 -0
- package/dist/field/plugins/withHTML.d.ts +2 -0
- package/dist/field/plugins/withHTML.d.ts.map +1 -0
- package/dist/field/plugins/withHTML.js +122 -0
- package/dist/field/plugins/withHTML.js.map +1 -0
- package/dist/field/providers/ElementButtonProvider.d.ts +14 -0
- package/dist/field/providers/ElementButtonProvider.d.ts.map +1 -0
- package/dist/field/providers/ElementButtonProvider.js +23 -0
- package/dist/field/providers/ElementButtonProvider.js.map +1 -0
- package/dist/field/providers/ElementProvider.d.ts +18 -0
- package/dist/field/providers/ElementProvider.d.ts.map +1 -0
- package/dist/field/providers/ElementProvider.js +27 -0
- package/dist/field/providers/ElementProvider.js.map +1 -0
- package/dist/field/providers/LeafButtonProvider.d.ts +13 -0
- package/dist/field/providers/LeafButtonProvider.d.ts.map +1 -0
- package/dist/field/providers/LeafButtonProvider.js +23 -0
- package/dist/field/providers/LeafButtonProvider.js.map +1 -0
- package/dist/field/providers/LeafProvider.d.ts +17 -0
- package/dist/field/providers/LeafProvider.d.ts.map +1 -0
- package/dist/field/providers/LeafProvider.js +28 -0
- package/dist/field/providers/LeafProvider.js.map +1 -0
- package/dist/field/rscEntry.d.ts +10 -0
- package/dist/field/rscEntry.d.ts.map +1 -0
- package/dist/field/rscEntry.js +129 -0
- package/dist/field/rscEntry.js.map +1 -0
- package/dist/field/types.d.ts +24 -0
- package/dist/field/types.d.ts.map +1 -0
- package/dist/field/types.js +3 -0
- package/dist/field/types.js.map +1 -0
- package/dist/generateSchemaMap.d.ts +4 -0
- package/dist/generateSchemaMap.d.ts.map +1 -0
- package/dist/generateSchemaMap.js +68 -0
- package/dist/generateSchemaMap.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +162 -0
- package/dist/index.js.map +1 -0
- package/dist/types.d.ts +88 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +7 -0
- package/dist/types.js.map +1 -0
- package/dist/utilities/SlatePropsProvider.d.ts +11 -0
- package/dist/utilities/SlatePropsProvider.d.ts.map +1 -0
- package/dist/utilities/SlatePropsProvider.js +21 -0
- package/dist/utilities/SlatePropsProvider.js.map +1 -0
- package/dist/utilities/useSlatePlugin.d.ts +5 -0
- package/dist/utilities/useSlatePlugin.d.ts.map +1 -0
- package/dist/utilities/useSlatePlugin.js +8 -0
- package/dist/utilities/useSlatePlugin.js.map +1 -0
- package/package.json +85 -0
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useListDrawer, useTranslation } from '@ruya.sa/ui';
|
|
4
|
+
import React, { Fragment, useCallback } from 'react';
|
|
5
|
+
import { ReactEditor, useSlate } from 'slate-react';
|
|
6
|
+
import { UploadIcon } from '../../../icons/Upload/index.js';
|
|
7
|
+
import { ElementButton } from '../../Button.js';
|
|
8
|
+
import { EnabledRelationshipsCondition } from '../../EnabledRelationshipsCondition.js';
|
|
9
|
+
import { injectVoidElement } from '../../injectVoid.js';
|
|
10
|
+
import './index.scss';
|
|
11
|
+
const baseClass = 'upload-rich-text-button';
|
|
12
|
+
const insertUpload = (editor, { relationTo, value })=>{
|
|
13
|
+
const text = {
|
|
14
|
+
text: ' '
|
|
15
|
+
};
|
|
16
|
+
const upload = {
|
|
17
|
+
type: 'upload',
|
|
18
|
+
children: [
|
|
19
|
+
text
|
|
20
|
+
],
|
|
21
|
+
relationTo,
|
|
22
|
+
value
|
|
23
|
+
};
|
|
24
|
+
injectVoidElement(editor, upload);
|
|
25
|
+
ReactEditor.focus(editor);
|
|
26
|
+
};
|
|
27
|
+
const UploadButton = ({ enabledCollectionSlugs })=>{
|
|
28
|
+
const { t } = useTranslation();
|
|
29
|
+
const editor = useSlate();
|
|
30
|
+
const [ListDrawer, ListDrawerToggler, { closeDrawer }] = useListDrawer({
|
|
31
|
+
collectionSlugs: enabledCollectionSlugs,
|
|
32
|
+
uploads: true
|
|
33
|
+
});
|
|
34
|
+
const onSelect = useCallback(({ collectionSlug, doc })=>{
|
|
35
|
+
insertUpload(editor, {
|
|
36
|
+
relationTo: collectionSlug,
|
|
37
|
+
value: {
|
|
38
|
+
id: doc.id
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
closeDrawer();
|
|
42
|
+
}, [
|
|
43
|
+
editor,
|
|
44
|
+
closeDrawer
|
|
45
|
+
]);
|
|
46
|
+
return /*#__PURE__*/ _jsxs(Fragment, {
|
|
47
|
+
children: [
|
|
48
|
+
/*#__PURE__*/ _jsx(ListDrawerToggler, {
|
|
49
|
+
children: /*#__PURE__*/ _jsx(ElementButton, {
|
|
50
|
+
className: baseClass,
|
|
51
|
+
el: "div",
|
|
52
|
+
format: "upload",
|
|
53
|
+
onClick: ()=>{
|
|
54
|
+
// do nothing
|
|
55
|
+
},
|
|
56
|
+
tooltip: t('fields:addUpload'),
|
|
57
|
+
children: /*#__PURE__*/ _jsx(UploadIcon, {})
|
|
58
|
+
})
|
|
59
|
+
}),
|
|
60
|
+
/*#__PURE__*/ _jsx(ListDrawer, {
|
|
61
|
+
onSelect: onSelect
|
|
62
|
+
})
|
|
63
|
+
]
|
|
64
|
+
});
|
|
65
|
+
};
|
|
66
|
+
export const UploadElementButton = (props)=>{
|
|
67
|
+
return /*#__PURE__*/ _jsx(EnabledRelationshipsCondition, {
|
|
68
|
+
...props,
|
|
69
|
+
uploads: true,
|
|
70
|
+
children: /*#__PURE__*/ _jsx(UploadButton, {
|
|
71
|
+
...props
|
|
72
|
+
})
|
|
73
|
+
});
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/field/elements/upload/Button/index.tsx"],"sourcesContent":["'use client'\n\nimport type { ListDrawerProps } from '@ruya.sa/ui'\n\nimport { useListDrawer, useTranslation } from '@ruya.sa/ui'\nimport React, { Fragment, useCallback } from 'react'\nimport { ReactEditor, useSlate } from 'slate-react'\n\nimport { UploadIcon } from '../../../icons/Upload/index.js'\nimport { ElementButton } from '../../Button.js'\nimport { EnabledRelationshipsCondition } from '../../EnabledRelationshipsCondition.js'\nimport { injectVoidElement } from '../../injectVoid.js'\nimport './index.scss'\n\nconst baseClass = 'upload-rich-text-button'\n\nconst insertUpload = (editor, { relationTo, value }) => {\n const text = { text: ' ' }\n\n const upload = {\n type: 'upload',\n children: [text],\n relationTo,\n value,\n }\n\n injectVoidElement(editor, upload)\n\n ReactEditor.focus(editor)\n}\n\ntype ButtonProps = {\n enabledCollectionSlugs: string[]\n path: string\n}\n\nconst UploadButton: React.FC<ButtonProps> = ({ enabledCollectionSlugs }) => {\n const { t } = useTranslation()\n const editor = useSlate()\n\n const [ListDrawer, ListDrawerToggler, { closeDrawer }] = useListDrawer({\n collectionSlugs: enabledCollectionSlugs,\n uploads: true,\n })\n\n const onSelect = useCallback<NonNullable<ListDrawerProps['onSelect']>>(\n ({ collectionSlug, doc }) => {\n insertUpload(editor, {\n relationTo: collectionSlug,\n value: {\n id: doc.id,\n },\n })\n closeDrawer()\n },\n [editor, closeDrawer],\n )\n\n return (\n <Fragment>\n <ListDrawerToggler>\n <ElementButton\n className={baseClass}\n el=\"div\"\n format=\"upload\"\n onClick={() => {\n // do nothing\n }}\n tooltip={t('fields:addUpload')}\n >\n <UploadIcon />\n </ElementButton>\n </ListDrawerToggler>\n <ListDrawer onSelect={onSelect} />\n </Fragment>\n )\n}\n\nexport const UploadElementButton = (props: ButtonProps): React.ReactNode => {\n return (\n <EnabledRelationshipsCondition {...props} uploads>\n <UploadButton {...props} />\n </EnabledRelationshipsCondition>\n )\n}\n"],"names":["useListDrawer","useTranslation","React","Fragment","useCallback","ReactEditor","useSlate","UploadIcon","ElementButton","EnabledRelationshipsCondition","injectVoidElement","baseClass","insertUpload","editor","relationTo","value","text","upload","type","children","focus","UploadButton","enabledCollectionSlugs","t","ListDrawer","ListDrawerToggler","closeDrawer","collectionSlugs","uploads","onSelect","collectionSlug","doc","id","className","el","format","onClick","tooltip","UploadElementButton","props"],"mappings":"AAAA;;AAIA,SAASA,aAAa,EAAEC,cAAc,QAAQ,cAAa;AAC3D,OAAOC,SAASC,QAAQ,EAAEC,WAAW,QAAQ,QAAO;AACpD,SAASC,WAAW,EAAEC,QAAQ,QAAQ,cAAa;AAEnD,SAASC,UAAU,QAAQ,iCAAgC;AAC3D,SAASC,aAAa,QAAQ,kBAAiB;AAC/C,SAASC,6BAA6B,QAAQ,yCAAwC;AACtF,SAASC,iBAAiB,QAAQ,sBAAqB;AACvD,OAAO,eAAc;AAErB,MAAMC,YAAY;AAElB,MAAMC,eAAe,CAACC,QAAQ,EAAEC,UAAU,EAAEC,KAAK,EAAE;IACjD,MAAMC,OAAO;QAAEA,MAAM;IAAI;IAEzB,MAAMC,SAAS;QACbC,MAAM;QACNC,UAAU;YAACH;SAAK;QAChBF;QACAC;IACF;IAEAL,kBAAkBG,QAAQI;IAE1BZ,YAAYe,KAAK,CAACP;AACpB;AAOA,MAAMQ,eAAsC,CAAC,EAAEC,sBAAsB,EAAE;IACrE,MAAM,EAAEC,CAAC,EAAE,GAAGtB;IACd,MAAMY,SAASP;IAEf,MAAM,CAACkB,YAAYC,mBAAmB,EAAEC,WAAW,EAAE,CAAC,GAAG1B,cAAc;QACrE2B,iBAAiBL;QACjBM,SAAS;IACX;IAEA,MAAMC,WAAWzB,YACf,CAAC,EAAE0B,cAAc,EAAEC,GAAG,EAAE;QACtBnB,aAAaC,QAAQ;YACnBC,YAAYgB;YACZf,OAAO;gBACLiB,IAAID,IAAIC,EAAE;YACZ;QACF;QACAN;IACF,GACA;QAACb;QAAQa;KAAY;IAGvB,qBACE,MAACvB;;0BACC,KAACsB;0BACC,cAAA,KAACjB;oBACCyB,WAAWtB;oBACXuB,IAAG;oBACHC,QAAO;oBACPC,SAAS;oBACP,aAAa;oBACf;oBACAC,SAASd,EAAE;8BAEX,cAAA,KAAChB;;;0BAGL,KAACiB;gBAAWK,UAAUA;;;;AAG5B;AAEA,OAAO,MAAMS,sBAAsB,CAACC;IAClC,qBACE,KAAC9B;QAA+B,GAAG8B,KAAK;QAAEX,OAAO;kBAC/C,cAAA,KAACP;YAAc,GAAGkB,KAAK;;;AAG7B,EAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { ClientCollectionConfig } from '@ruya.sa/payload';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import type { LoadedSlateFieldProps } from '../../../../types.js';
|
|
4
|
+
import type { UploadElementType } from '../../types.js';
|
|
5
|
+
export declare const UploadDrawer: React.FC<{
|
|
6
|
+
readonly drawerSlug: string;
|
|
7
|
+
readonly element: UploadElementType;
|
|
8
|
+
readonly fieldProps: LoadedSlateFieldProps;
|
|
9
|
+
readonly relatedCollection: ClientCollectionConfig;
|
|
10
|
+
readonly schemaPath: string;
|
|
11
|
+
}>;
|
|
12
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/field/elements/upload/Element/UploadDrawer/index.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAA;AAiB9D,OAAO,KAA2C,MAAM,OAAO,CAAA;AAI/D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAA;AACjE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAIvD,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC;IAClC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAA;IAC3B,QAAQ,CAAC,OAAO,EAAE,iBAAiB,CAAA;IACnC,QAAQ,CAAC,UAAU,EAAE,qBAAqB,CAAA;IAC1C,QAAQ,CAAC,iBAAiB,EAAE,sBAAsB,CAAA;IAClD,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAA;CAC5B,CA+HA,CAAA"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { getTranslation } from '@ruya.sa/translations';
|
|
4
|
+
import { Drawer, EditDepthProvider, Form, FormSubmit, RenderFields, useConfig, useDocumentInfo, useLocale, useModal, useServerFunctions, useTranslation } from '@ruya.sa/ui';
|
|
5
|
+
import { deepCopyObject } from '@ruya.sa/payload/shared';
|
|
6
|
+
import React, { useCallback, useEffect, useState } from 'react';
|
|
7
|
+
import { Transforms } from 'slate';
|
|
8
|
+
import { ReactEditor, useSlateStatic } from 'slate-react';
|
|
9
|
+
import { uploadFieldsSchemaPath } from '../../shared.js';
|
|
10
|
+
export const UploadDrawer = (props)=>{
|
|
11
|
+
const editor = useSlateStatic();
|
|
12
|
+
const { drawerSlug, element, fieldProps, relatedCollection, schemaPath } = props;
|
|
13
|
+
const { i18n, t } = useTranslation();
|
|
14
|
+
const { code: locale } = useLocale();
|
|
15
|
+
const { closeModal } = useModal();
|
|
16
|
+
const { id, collectionSlug, getDocPreferences, globalSlug } = useDocumentInfo();
|
|
17
|
+
const { getFormState } = useServerFunctions();
|
|
18
|
+
const [initialState, setInitialState] = useState({});
|
|
19
|
+
const { componentMap } = fieldProps;
|
|
20
|
+
const relatedFieldSchemaPath = `${uploadFieldsSchemaPath}.${relatedCollection.slug}`;
|
|
21
|
+
const fields = componentMap[relatedFieldSchemaPath];
|
|
22
|
+
const { config } = useConfig();
|
|
23
|
+
const handleUpdateEditData = useCallback((_, data)=>{
|
|
24
|
+
const newNode = {
|
|
25
|
+
fields: data
|
|
26
|
+
};
|
|
27
|
+
const elementPath = ReactEditor.findPath(editor, element);
|
|
28
|
+
Transforms.setNodes(editor, newNode, {
|
|
29
|
+
at: elementPath
|
|
30
|
+
});
|
|
31
|
+
closeModal(drawerSlug);
|
|
32
|
+
}, [
|
|
33
|
+
closeModal,
|
|
34
|
+
editor,
|
|
35
|
+
element,
|
|
36
|
+
drawerSlug
|
|
37
|
+
]);
|
|
38
|
+
useEffect(()=>{
|
|
39
|
+
const data = deepCopyObject(element?.fields || {});
|
|
40
|
+
const awaitInitialState = async ()=>{
|
|
41
|
+
const { state } = await getFormState({
|
|
42
|
+
id,
|
|
43
|
+
collectionSlug,
|
|
44
|
+
data,
|
|
45
|
+
docPermissions: {
|
|
46
|
+
fields: true
|
|
47
|
+
},
|
|
48
|
+
docPreferences: await getDocPreferences(),
|
|
49
|
+
globalSlug,
|
|
50
|
+
operation: 'update',
|
|
51
|
+
renderAllFields: true,
|
|
52
|
+
schemaPath: `${schemaPath}.${uploadFieldsSchemaPath}.${relatedCollection.slug}`
|
|
53
|
+
});
|
|
54
|
+
setInitialState(state);
|
|
55
|
+
};
|
|
56
|
+
void awaitInitialState();
|
|
57
|
+
}, [
|
|
58
|
+
config,
|
|
59
|
+
element?.fields,
|
|
60
|
+
locale,
|
|
61
|
+
t,
|
|
62
|
+
collectionSlug,
|
|
63
|
+
id,
|
|
64
|
+
schemaPath,
|
|
65
|
+
relatedCollection.slug,
|
|
66
|
+
getFormState,
|
|
67
|
+
globalSlug,
|
|
68
|
+
getDocPreferences
|
|
69
|
+
]);
|
|
70
|
+
const onChange = useCallback(async ({ formState: prevFormState })=>{
|
|
71
|
+
const { state } = await getFormState({
|
|
72
|
+
id,
|
|
73
|
+
collectionSlug,
|
|
74
|
+
docPermissions: {
|
|
75
|
+
fields: true
|
|
76
|
+
},
|
|
77
|
+
docPreferences: await getDocPreferences(),
|
|
78
|
+
formState: prevFormState,
|
|
79
|
+
globalSlug,
|
|
80
|
+
operation: 'update',
|
|
81
|
+
schemaPath: `${schemaPath}.${uploadFieldsSchemaPath}.${relatedCollection.slug}`
|
|
82
|
+
});
|
|
83
|
+
return state;
|
|
84
|
+
}, [
|
|
85
|
+
getFormState,
|
|
86
|
+
id,
|
|
87
|
+
collectionSlug,
|
|
88
|
+
getDocPreferences,
|
|
89
|
+
globalSlug,
|
|
90
|
+
schemaPath,
|
|
91
|
+
relatedCollection.slug
|
|
92
|
+
]);
|
|
93
|
+
return /*#__PURE__*/ _jsx(EditDepthProvider, {
|
|
94
|
+
children: /*#__PURE__*/ _jsx(Drawer, {
|
|
95
|
+
slug: drawerSlug,
|
|
96
|
+
title: t('general:editLabel', {
|
|
97
|
+
label: getTranslation(relatedCollection.labels.singular, i18n)
|
|
98
|
+
}),
|
|
99
|
+
children: /*#__PURE__*/ _jsxs(Form, {
|
|
100
|
+
beforeSubmit: [
|
|
101
|
+
onChange
|
|
102
|
+
],
|
|
103
|
+
disableValidationOnSubmit: true,
|
|
104
|
+
initialState: initialState,
|
|
105
|
+
onChange: [
|
|
106
|
+
onChange
|
|
107
|
+
],
|
|
108
|
+
onSubmit: handleUpdateEditData,
|
|
109
|
+
children: [
|
|
110
|
+
/*#__PURE__*/ _jsx(RenderFields, {
|
|
111
|
+
fields: Array.isArray(fields) ? fields : [],
|
|
112
|
+
parentIndexPath: "",
|
|
113
|
+
parentPath: "",
|
|
114
|
+
parentSchemaPath: "",
|
|
115
|
+
permissions: true,
|
|
116
|
+
readOnly: false
|
|
117
|
+
}),
|
|
118
|
+
/*#__PURE__*/ _jsx(FormSubmit, {
|
|
119
|
+
children: t('fields:saveChanges')
|
|
120
|
+
})
|
|
121
|
+
]
|
|
122
|
+
})
|
|
123
|
+
})
|
|
124
|
+
});
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../../src/field/elements/upload/Element/UploadDrawer/index.tsx"],"sourcesContent":["'use client'\n\nimport type { FormProps } from '@ruya.sa/ui'\nimport type { ClientCollectionConfig } from '@ruya.sa/payload'\n\nimport { getTranslation } from '@ruya.sa/translations'\nimport {\n Drawer,\n EditDepthProvider,\n Form,\n FormSubmit,\n RenderFields,\n useConfig,\n useDocumentInfo,\n useLocale,\n useModal,\n useServerFunctions,\n useTranslation,\n} from '@ruya.sa/ui'\nimport { deepCopyObject } from '@ruya.sa/payload/shared'\nimport React, { useCallback, useEffect, useState } from 'react'\nimport { Transforms } from 'slate'\nimport { ReactEditor, useSlateStatic } from 'slate-react'\n\nimport type { LoadedSlateFieldProps } from '../../../../types.js'\nimport type { UploadElementType } from '../../types.js'\n\nimport { uploadFieldsSchemaPath } from '../../shared.js'\n\nexport const UploadDrawer: React.FC<{\n readonly drawerSlug: string\n readonly element: UploadElementType\n readonly fieldProps: LoadedSlateFieldProps\n readonly relatedCollection: ClientCollectionConfig\n readonly schemaPath: string\n}> = (props) => {\n const editor = useSlateStatic()\n\n const { drawerSlug, element, fieldProps, relatedCollection, schemaPath } = props\n\n const { i18n, t } = useTranslation()\n const { code: locale } = useLocale()\n const { closeModal } = useModal()\n const { id, collectionSlug, getDocPreferences, globalSlug } = useDocumentInfo()\n\n const { getFormState } = useServerFunctions()\n\n const [initialState, setInitialState] = useState({})\n const { componentMap } = fieldProps\n\n const relatedFieldSchemaPath = `${uploadFieldsSchemaPath}.${relatedCollection.slug}`\n const fields = componentMap[relatedFieldSchemaPath]\n\n const { config } = useConfig()\n\n const handleUpdateEditData = useCallback(\n (_, data) => {\n const newNode = {\n fields: data,\n }\n\n const elementPath = ReactEditor.findPath(editor, element)\n\n Transforms.setNodes(editor, newNode, { at: elementPath })\n closeModal(drawerSlug)\n },\n [closeModal, editor, element, drawerSlug],\n )\n\n useEffect(() => {\n const data = deepCopyObject(element?.fields || {})\n\n const awaitInitialState = async () => {\n const { state } = await getFormState({\n id,\n collectionSlug,\n data,\n docPermissions: {\n fields: true,\n },\n docPreferences: await getDocPreferences(),\n globalSlug,\n operation: 'update',\n renderAllFields: true,\n schemaPath: `${schemaPath}.${uploadFieldsSchemaPath}.${relatedCollection.slug}`,\n })\n\n setInitialState(state)\n }\n\n void awaitInitialState()\n }, [\n config,\n element?.fields,\n locale,\n t,\n collectionSlug,\n id,\n schemaPath,\n relatedCollection.slug,\n getFormState,\n globalSlug,\n getDocPreferences,\n ])\n\n const onChange: FormProps['onChange'][0] = useCallback(\n async ({ formState: prevFormState }) => {\n const { state } = await getFormState({\n id,\n collectionSlug,\n docPermissions: {\n fields: true,\n },\n docPreferences: await getDocPreferences(),\n formState: prevFormState,\n globalSlug,\n operation: 'update',\n schemaPath: `${schemaPath}.${uploadFieldsSchemaPath}.${relatedCollection.slug}`,\n })\n\n return state\n },\n\n [\n getFormState,\n id,\n collectionSlug,\n getDocPreferences,\n globalSlug,\n schemaPath,\n relatedCollection.slug,\n ],\n )\n\n return (\n <EditDepthProvider>\n <Drawer\n slug={drawerSlug}\n title={t('general:editLabel', {\n label: getTranslation(relatedCollection.labels.singular, i18n),\n })}\n >\n <Form\n beforeSubmit={[onChange]}\n disableValidationOnSubmit\n initialState={initialState}\n onChange={[onChange]}\n onSubmit={handleUpdateEditData}\n >\n <RenderFields\n fields={Array.isArray(fields) ? fields : []}\n parentIndexPath=\"\"\n parentPath=\"\"\n parentSchemaPath=\"\"\n permissions={true}\n readOnly={false}\n />\n <FormSubmit>{t('fields:saveChanges')}</FormSubmit>\n </Form>\n </Drawer>\n </EditDepthProvider>\n )\n}\n"],"names":["getTranslation","Drawer","EditDepthProvider","Form","FormSubmit","RenderFields","useConfig","useDocumentInfo","useLocale","useModal","useServerFunctions","useTranslation","deepCopyObject","React","useCallback","useEffect","useState","Transforms","ReactEditor","useSlateStatic","uploadFieldsSchemaPath","UploadDrawer","props","editor","drawerSlug","element","fieldProps","relatedCollection","schemaPath","i18n","t","code","locale","closeModal","id","collectionSlug","getDocPreferences","globalSlug","getFormState","initialState","setInitialState","componentMap","relatedFieldSchemaPath","slug","fields","config","handleUpdateEditData","_","data","newNode","elementPath","findPath","setNodes","at","awaitInitialState","state","docPermissions","docPreferences","operation","renderAllFields","onChange","formState","prevFormState","title","label","labels","singular","beforeSubmit","disableValidationOnSubmit","onSubmit","Array","isArray","parentIndexPath","parentPath","parentSchemaPath","permissions","readOnly"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/field/elements/upload/Element/index.tsx"],"names":[],"mappings":"AAkBA,OAAO,KAA4C,MAAM,OAAO,CAAA;AAShE,OAAO,cAAc,CAAA;AAuMrB,eAAO,MAAM,aAAa,UAAW,GAAG,KAAG,KAAK,CAAC,SAMhD,CAAA"}
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { getTranslation } from '@ruya.sa/translations';
|
|
4
|
+
import { Button, DrawerToggler, File, useConfig, useDocumentDrawer, useDrawerSlug, useListDrawer, usePayloadAPI, useTranslation } from '@ruya.sa/ui';
|
|
5
|
+
import { formatAdminURL } from '@ruya.sa/payload/shared';
|
|
6
|
+
import React, { useCallback, useReducer, useState } from 'react';
|
|
7
|
+
import { Transforms } from 'slate';
|
|
8
|
+
import { ReactEditor, useFocused, useSelected, useSlateStatic } from 'slate-react';
|
|
9
|
+
import { useElement } from '../../../providers/ElementProvider.js';
|
|
10
|
+
import { EnabledRelationshipsCondition } from '../../EnabledRelationshipsCondition.js';
|
|
11
|
+
import { uploadFieldsSchemaPath, uploadName } from '../shared.js';
|
|
12
|
+
import './index.scss';
|
|
13
|
+
import { UploadDrawer } from './UploadDrawer/index.js';
|
|
14
|
+
const baseClass = 'rich-text-upload';
|
|
15
|
+
const initialParams = {
|
|
16
|
+
depth: 0
|
|
17
|
+
};
|
|
18
|
+
const UploadElementComponent = ({ enabledCollectionSlugs })=>{
|
|
19
|
+
const { attributes, children, element: { relationTo, value }, element, fieldProps, schemaPath } = useElement();
|
|
20
|
+
const { config: { routes: { api }, serverURL }, getEntityConfig } = useConfig();
|
|
21
|
+
const { i18n, t } = useTranslation();
|
|
22
|
+
const [cacheBust, dispatchCacheBust] = useReducer((state)=>state + 1, 0);
|
|
23
|
+
const [relatedCollection, setRelatedCollection] = useState(()=>getEntityConfig({
|
|
24
|
+
collectionSlug: relationTo
|
|
25
|
+
}));
|
|
26
|
+
const drawerSlug = useDrawerSlug('upload-drawer');
|
|
27
|
+
const [ListDrawer, ListDrawerToggler, { closeDrawer: closeListDrawer }] = useListDrawer({
|
|
28
|
+
collectionSlugs: enabledCollectionSlugs,
|
|
29
|
+
selectedCollection: relatedCollection.slug
|
|
30
|
+
});
|
|
31
|
+
const [DocumentDrawer, DocumentDrawerToggler, { closeDrawer }] = useDocumentDrawer({
|
|
32
|
+
id: value?.id,
|
|
33
|
+
collectionSlug: relatedCollection.slug
|
|
34
|
+
});
|
|
35
|
+
const editor = useSlateStatic();
|
|
36
|
+
const selected = useSelected();
|
|
37
|
+
const focused = useFocused();
|
|
38
|
+
// Get the referenced document
|
|
39
|
+
const [{ data }, { setParams }] = usePayloadAPI(formatAdminURL({
|
|
40
|
+
apiRoute: api,
|
|
41
|
+
path: `/${relatedCollection.slug}/${value?.id}`,
|
|
42
|
+
serverURL
|
|
43
|
+
}), {
|
|
44
|
+
initialParams
|
|
45
|
+
});
|
|
46
|
+
const thumbnailSRC = data?.thumbnailURL || data?.url;
|
|
47
|
+
const removeUpload = useCallback(()=>{
|
|
48
|
+
const elementPath = ReactEditor.findPath(editor, element);
|
|
49
|
+
Transforms.removeNodes(editor, {
|
|
50
|
+
at: elementPath
|
|
51
|
+
});
|
|
52
|
+
}, [
|
|
53
|
+
editor,
|
|
54
|
+
element
|
|
55
|
+
]);
|
|
56
|
+
const updateUpload = useCallback((json)=>{
|
|
57
|
+
const { doc } = json;
|
|
58
|
+
const newNode = {
|
|
59
|
+
fields: doc
|
|
60
|
+
};
|
|
61
|
+
const elementPath = ReactEditor.findPath(editor, element);
|
|
62
|
+
Transforms.setNodes(editor, newNode, {
|
|
63
|
+
at: elementPath
|
|
64
|
+
});
|
|
65
|
+
setParams({
|
|
66
|
+
...initialParams,
|
|
67
|
+
cacheBust
|
|
68
|
+
});
|
|
69
|
+
dispatchCacheBust();
|
|
70
|
+
closeDrawer();
|
|
71
|
+
}, [
|
|
72
|
+
editor,
|
|
73
|
+
element,
|
|
74
|
+
setParams,
|
|
75
|
+
cacheBust,
|
|
76
|
+
closeDrawer
|
|
77
|
+
]);
|
|
78
|
+
const swapUpload = useCallback(({ collectionSlug, doc })=>{
|
|
79
|
+
const newNode = {
|
|
80
|
+
type: uploadName,
|
|
81
|
+
children: [
|
|
82
|
+
{
|
|
83
|
+
text: ' '
|
|
84
|
+
}
|
|
85
|
+
],
|
|
86
|
+
relationTo: collectionSlug,
|
|
87
|
+
value: {
|
|
88
|
+
id: doc.id
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
const elementPath = ReactEditor.findPath(editor, element);
|
|
92
|
+
setRelatedCollection(getEntityConfig({
|
|
93
|
+
collectionSlug
|
|
94
|
+
}));
|
|
95
|
+
Transforms.setNodes(editor, newNode, {
|
|
96
|
+
at: elementPath
|
|
97
|
+
});
|
|
98
|
+
dispatchCacheBust();
|
|
99
|
+
closeListDrawer();
|
|
100
|
+
}, [
|
|
101
|
+
closeListDrawer,
|
|
102
|
+
editor,
|
|
103
|
+
element,
|
|
104
|
+
getEntityConfig
|
|
105
|
+
]);
|
|
106
|
+
const relatedFieldSchemaPath = `${uploadFieldsSchemaPath}.${relatedCollection.slug}`;
|
|
107
|
+
const customFieldsMap = fieldProps.componentMap[relatedFieldSchemaPath];
|
|
108
|
+
const alt = data?.alt || data?.filename || '';
|
|
109
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
110
|
+
className: [
|
|
111
|
+
baseClass,
|
|
112
|
+
selected && focused && `${baseClass}--selected`
|
|
113
|
+
].filter(Boolean).join(' '),
|
|
114
|
+
contentEditable: false,
|
|
115
|
+
...attributes,
|
|
116
|
+
children: [
|
|
117
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
118
|
+
className: `${baseClass}__card`,
|
|
119
|
+
children: [
|
|
120
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
121
|
+
className: `${baseClass}__topRow`,
|
|
122
|
+
children: [
|
|
123
|
+
/*#__PURE__*/ _jsx("div", {
|
|
124
|
+
className: `${baseClass}__thumbnail`,
|
|
125
|
+
children: thumbnailSRC ? /*#__PURE__*/ _jsx("img", {
|
|
126
|
+
alt: alt,
|
|
127
|
+
src: thumbnailSRC
|
|
128
|
+
}) : /*#__PURE__*/ _jsx(File, {})
|
|
129
|
+
}),
|
|
130
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
131
|
+
className: `${baseClass}__topRowRightPanel`,
|
|
132
|
+
children: [
|
|
133
|
+
/*#__PURE__*/ _jsx("div", {
|
|
134
|
+
className: `${baseClass}__collectionLabel`,
|
|
135
|
+
children: getTranslation(relatedCollection.labels.singular, i18n)
|
|
136
|
+
}),
|
|
137
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
138
|
+
className: `${baseClass}__actions`,
|
|
139
|
+
children: [
|
|
140
|
+
Boolean(customFieldsMap) && /*#__PURE__*/ _jsxs(_Fragment, {
|
|
141
|
+
children: [
|
|
142
|
+
/*#__PURE__*/ _jsx(DrawerToggler, {
|
|
143
|
+
className: `${baseClass}__upload-drawer-toggler`,
|
|
144
|
+
disabled: fieldProps?.field?.admin?.readOnly,
|
|
145
|
+
slug: drawerSlug,
|
|
146
|
+
children: /*#__PURE__*/ _jsx(Button, {
|
|
147
|
+
buttonStyle: "icon-label",
|
|
148
|
+
el: "div",
|
|
149
|
+
icon: "edit",
|
|
150
|
+
onClick: (e)=>{
|
|
151
|
+
e.preventDefault();
|
|
152
|
+
},
|
|
153
|
+
round: true,
|
|
154
|
+
tooltip: t('fields:editRelationship')
|
|
155
|
+
})
|
|
156
|
+
}),
|
|
157
|
+
/*#__PURE__*/ _jsx(UploadDrawer, {
|
|
158
|
+
drawerSlug,
|
|
159
|
+
element,
|
|
160
|
+
fieldProps,
|
|
161
|
+
relatedCollection,
|
|
162
|
+
schemaPath
|
|
163
|
+
})
|
|
164
|
+
]
|
|
165
|
+
}),
|
|
166
|
+
/*#__PURE__*/ _jsx(ListDrawerToggler, {
|
|
167
|
+
className: `${baseClass}__list-drawer-toggler`,
|
|
168
|
+
disabled: fieldProps?.field?.admin?.readOnly,
|
|
169
|
+
children: /*#__PURE__*/ _jsx(Button, {
|
|
170
|
+
buttonStyle: "icon-label",
|
|
171
|
+
disabled: fieldProps?.field?.admin?.readOnly,
|
|
172
|
+
el: "div",
|
|
173
|
+
icon: "swap",
|
|
174
|
+
onClick: ()=>{
|
|
175
|
+
// do nothing
|
|
176
|
+
},
|
|
177
|
+
round: true,
|
|
178
|
+
tooltip: t('fields:swapUpload')
|
|
179
|
+
})
|
|
180
|
+
}),
|
|
181
|
+
/*#__PURE__*/ _jsx(Button, {
|
|
182
|
+
buttonStyle: "icon-label",
|
|
183
|
+
className: `${baseClass}__removeButton`,
|
|
184
|
+
disabled: fieldProps?.field?.admin?.readOnly,
|
|
185
|
+
icon: "x",
|
|
186
|
+
onClick: (e)=>{
|
|
187
|
+
e.preventDefault();
|
|
188
|
+
removeUpload();
|
|
189
|
+
},
|
|
190
|
+
round: true,
|
|
191
|
+
tooltip: t('fields:removeUpload')
|
|
192
|
+
})
|
|
193
|
+
]
|
|
194
|
+
})
|
|
195
|
+
]
|
|
196
|
+
})
|
|
197
|
+
]
|
|
198
|
+
}),
|
|
199
|
+
/*#__PURE__*/ _jsx("div", {
|
|
200
|
+
className: `${baseClass}__bottomRow`,
|
|
201
|
+
children: /*#__PURE__*/ _jsx(DocumentDrawerToggler, {
|
|
202
|
+
className: `${baseClass}__doc-drawer-toggler`,
|
|
203
|
+
children: /*#__PURE__*/ _jsx("strong", {
|
|
204
|
+
children: data?.filename
|
|
205
|
+
})
|
|
206
|
+
})
|
|
207
|
+
})
|
|
208
|
+
]
|
|
209
|
+
}),
|
|
210
|
+
children,
|
|
211
|
+
value?.id && /*#__PURE__*/ _jsx(DocumentDrawer, {
|
|
212
|
+
onSave: updateUpload
|
|
213
|
+
}),
|
|
214
|
+
/*#__PURE__*/ _jsx(ListDrawer, {
|
|
215
|
+
onSelect: swapUpload
|
|
216
|
+
})
|
|
217
|
+
]
|
|
218
|
+
});
|
|
219
|
+
};
|
|
220
|
+
export const UploadElement = (props)=>{
|
|
221
|
+
return /*#__PURE__*/ _jsx(EnabledRelationshipsCondition, {
|
|
222
|
+
...props,
|
|
223
|
+
uploads: true,
|
|
224
|
+
children: /*#__PURE__*/ _jsx(UploadElementComponent, {
|
|
225
|
+
...props
|
|
226
|
+
})
|
|
227
|
+
});
|
|
228
|
+
};
|
|
229
|
+
|
|
230
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/field/elements/upload/Element/index.tsx"],"sourcesContent":["'use client'\n\nimport type { ListDrawerProps } from '@ruya.sa/ui'\nimport type { ClientCollectionConfig } from '@ruya.sa/payload'\n\nimport { getTranslation } from '@ruya.sa/translations'\nimport {\n Button,\n DrawerToggler,\n File,\n useConfig,\n useDocumentDrawer,\n useDrawerSlug,\n useListDrawer,\n usePayloadAPI,\n useTranslation,\n} from '@ruya.sa/ui'\nimport { formatAdminURL } from '@ruya.sa/payload/shared'\nimport React, { useCallback, useReducer, useState } from 'react'\nimport { Transforms } from 'slate'\nimport { ReactEditor, useFocused, useSelected, useSlateStatic } from 'slate-react'\n\nimport type { UploadElementType } from '../types.js'\n\nimport { useElement } from '../../../providers/ElementProvider.js'\nimport { EnabledRelationshipsCondition } from '../../EnabledRelationshipsCondition.js'\nimport { uploadFieldsSchemaPath, uploadName } from '../shared.js'\nimport './index.scss'\nimport { UploadDrawer } from './UploadDrawer/index.js'\n\nconst baseClass = 'rich-text-upload'\n\nconst initialParams = {\n depth: 0,\n}\n\nconst UploadElementComponent: React.FC<{ enabledCollectionSlugs?: string[] }> = ({\n enabledCollectionSlugs,\n}) => {\n const {\n attributes,\n children,\n element: { relationTo, value },\n element,\n fieldProps,\n schemaPath,\n } = useElement<UploadElementType>()\n\n const {\n config: {\n routes: { api },\n serverURL,\n },\n getEntityConfig,\n } = useConfig()\n const { i18n, t } = useTranslation()\n const [cacheBust, dispatchCacheBust] = useReducer((state) => state + 1, 0)\n const [relatedCollection, setRelatedCollection] = useState<ClientCollectionConfig>(() =>\n getEntityConfig({ collectionSlug: relationTo }),\n )\n\n const drawerSlug = useDrawerSlug('upload-drawer')\n\n const [ListDrawer, ListDrawerToggler, { closeDrawer: closeListDrawer }] = useListDrawer({\n collectionSlugs: enabledCollectionSlugs,\n selectedCollection: relatedCollection.slug,\n })\n\n const [DocumentDrawer, DocumentDrawerToggler, { closeDrawer }] = useDocumentDrawer({\n id: value?.id,\n collectionSlug: relatedCollection.slug,\n })\n\n const editor = useSlateStatic()\n const selected = useSelected()\n const focused = useFocused()\n\n // Get the referenced document\n const [{ data }, { setParams }] = usePayloadAPI(\n formatAdminURL({ apiRoute: api, path: `/${relatedCollection.slug}/${value?.id}`, serverURL }),\n { initialParams },\n )\n\n const thumbnailSRC = data?.thumbnailURL || data?.url\n\n const removeUpload = useCallback(() => {\n const elementPath = ReactEditor.findPath(editor, element)\n\n Transforms.removeNodes(editor, { at: elementPath })\n }, [editor, element])\n\n const updateUpload = useCallback(\n (json) => {\n const { doc } = json\n\n const newNode = {\n fields: doc,\n }\n\n const elementPath = ReactEditor.findPath(editor, element)\n\n Transforms.setNodes(editor, newNode, { at: elementPath })\n\n setParams({\n ...initialParams,\n cacheBust, // do this to get the usePayloadAPI to re-fetch the data even though the URL string hasn't changed\n })\n\n dispatchCacheBust()\n closeDrawer()\n },\n [editor, element, setParams, cacheBust, closeDrawer],\n )\n\n const swapUpload = useCallback<NonNullable<ListDrawerProps['onSelect']>>(\n ({ collectionSlug, doc }) => {\n const newNode = {\n type: uploadName,\n children: [{ text: ' ' }],\n relationTo: collectionSlug,\n value: { id: doc.id },\n }\n\n const elementPath = ReactEditor.findPath(editor, element)\n\n setRelatedCollection(getEntityConfig({ collectionSlug }))\n\n Transforms.setNodes(editor, newNode, { at: elementPath })\n\n dispatchCacheBust()\n closeListDrawer()\n },\n [closeListDrawer, editor, element, getEntityConfig],\n )\n\n const relatedFieldSchemaPath = `${uploadFieldsSchemaPath}.${relatedCollection.slug}`\n const customFieldsMap = fieldProps.componentMap[relatedFieldSchemaPath]\n\n const alt = (data as { alt?: string })?.alt || data?.filename || ''\n\n return (\n <div\n className={[baseClass, selected && focused && `${baseClass}--selected`]\n .filter(Boolean)\n .join(' ')}\n contentEditable={false}\n {...attributes}\n >\n <div className={`${baseClass}__card`}>\n <div className={`${baseClass}__topRow`}>\n {/* TODO: migrate to use Thumbnail component */}\n <div className={`${baseClass}__thumbnail`}>\n {thumbnailSRC ? <img alt={alt} src={thumbnailSRC} /> : <File />}\n </div>\n <div className={`${baseClass}__topRowRightPanel`}>\n <div className={`${baseClass}__collectionLabel`}>\n {getTranslation(relatedCollection.labels.singular, i18n)}\n </div>\n <div className={`${baseClass}__actions`}>\n {Boolean(customFieldsMap) && (\n <>\n <DrawerToggler\n className={`${baseClass}__upload-drawer-toggler`}\n disabled={fieldProps?.field?.admin?.readOnly}\n slug={drawerSlug}\n >\n <Button\n buttonStyle=\"icon-label\"\n el=\"div\"\n icon=\"edit\"\n onClick={(e) => {\n e.preventDefault()\n }}\n round\n tooltip={t('fields:editRelationship')}\n />\n </DrawerToggler>\n <UploadDrawer\n {...{ drawerSlug, element, fieldProps, relatedCollection, schemaPath }}\n />\n </>\n )}\n <ListDrawerToggler\n className={`${baseClass}__list-drawer-toggler`}\n disabled={fieldProps?.field?.admin?.readOnly}\n >\n <Button\n buttonStyle=\"icon-label\"\n disabled={fieldProps?.field?.admin?.readOnly}\n el=\"div\"\n icon=\"swap\"\n onClick={() => {\n // do nothing\n }}\n round\n tooltip={t('fields:swapUpload')}\n />\n </ListDrawerToggler>\n <Button\n buttonStyle=\"icon-label\"\n className={`${baseClass}__removeButton`}\n disabled={fieldProps?.field?.admin?.readOnly}\n icon=\"x\"\n onClick={(e) => {\n e.preventDefault()\n removeUpload()\n }}\n round\n tooltip={t('fields:removeUpload')}\n />\n </div>\n </div>\n </div>\n <div className={`${baseClass}__bottomRow`}>\n <DocumentDrawerToggler className={`${baseClass}__doc-drawer-toggler`}>\n <strong>{data?.filename}</strong>\n </DocumentDrawerToggler>\n </div>\n </div>\n {children}\n {value?.id && <DocumentDrawer onSave={updateUpload} />}\n <ListDrawer onSelect={swapUpload} />\n </div>\n )\n}\n\nexport const UploadElement = (props: any): React.ReactNode => {\n return (\n <EnabledRelationshipsCondition {...props} uploads>\n <UploadElementComponent {...props} />\n </EnabledRelationshipsCondition>\n )\n}\n"],"names":["getTranslation","Button","DrawerToggler","File","useConfig","useDocumentDrawer","useDrawerSlug","useListDrawer","usePayloadAPI","useTranslation","formatAdminURL","React","useCallback","useReducer","useState","Transforms","ReactEditor","useFocused","useSelected","useSlateStatic","useElement","EnabledRelationshipsCondition","uploadFieldsSchemaPath","uploadName","UploadDrawer","baseClass","initialParams","depth","UploadElementComponent","enabledCollectionSlugs","attributes","children","element","relationTo","value","fieldProps","schemaPath","config","routes","api","serverURL","getEntityConfig","i18n","t","cacheBust","dispatchCacheBust","state","relatedCollection","setRelatedCollection","collectionSlug","drawerSlug","ListDrawer","ListDrawerToggler","closeDrawer","closeListDrawer","collectionSlugs","selectedCollection","slug","DocumentDrawer","DocumentDrawerToggler","id","editor","selected","focused","data","setParams","apiRoute","path","thumbnailSRC","thumbnailURL","url","removeUpload","elementPath","findPath","removeNodes","at","updateUpload","json","doc","newNode","fields","setNodes","swapUpload","type","text","relatedFieldSchemaPath","customFieldsMap","componentMap","alt","filename","div","className","filter","Boolean","join","contentEditable","img","src","labels","singular","disabled","field","admin","readOnly","buttonStyle","el","icon","onClick","e","preventDefault","round","tooltip","strong","onSave","onSelect","UploadElement","props","uploads"],"mappings":"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"}
|