@dropins/tools 0.21.1 → 0.21.2-alpha2
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/components/Accordion/Accordion.d.ts +25 -0
- package/components/Accordion/Accordion.d.ts.map +1 -0
- package/components/Accordion/Accordion.jsx +59 -0
- package/components/Accordion/Accordion.stories.d.ts +22 -0
- package/components/Accordion/Accordion.stories.d.ts.map +1 -0
- package/components/Accordion/Accordion.stories.jsx +320 -0
- package/components/Accordion/Accordion.test.d.ts +3 -0
- package/components/Accordion/Accordion.test.d.ts.map +1 -0
- package/components/Accordion/Accordion.test.jsx +79 -0
- package/components/Accordion/index.d.ts +3 -0
- package/components/Accordion/index.d.ts.map +1 -0
- package/components/Accordion/index.js +2 -0
- package/components/ActionButton/ActionButton.d.ts +11 -0
- package/components/ActionButton/ActionButton.d.ts.map +1 -0
- package/components/ActionButton/ActionButton.jsx +14 -0
- package/components/ActionButton/ActionButton.stories.d.ts +16 -0
- package/components/ActionButton/ActionButton.stories.d.ts.map +1 -0
- package/components/ActionButton/ActionButton.stories.jsx +119 -0
- package/components/ActionButton/ActionButton.test.d.ts +3 -0
- package/components/ActionButton/ActionButton.test.d.ts.map +1 -0
- package/components/ActionButton/ActionButton.test.jsx +47 -0
- package/components/ActionButton/index.d.ts +2 -0
- package/components/ActionButton/index.d.ts.map +1 -0
- package/components/ActionButton/index.js +1 -0
- package/components/ActionButtonGroup/ActionButtonGroup.d.ts +20 -0
- package/components/ActionButtonGroup/ActionButtonGroup.d.ts.map +1 -0
- package/components/ActionButtonGroup/ActionButtonGroup.jsx +39 -0
- package/components/ActionButtonGroup/ActionButtonGroup.stories.d.ts +16 -0
- package/components/ActionButtonGroup/ActionButtonGroup.stories.d.ts.map +1 -0
- package/components/ActionButtonGroup/ActionButtonGroup.stories.jsx +72 -0
- package/components/ActionButtonGroup/ActionButtonGroup.test.d.ts +3 -0
- package/components/ActionButtonGroup/ActionButtonGroup.test.d.ts.map +1 -0
- package/components/ActionButtonGroup/ActionButtonGroup.test.jsx +78 -0
- package/components/ActionButtonGroup/index.d.ts +2 -0
- package/components/ActionButtonGroup/index.d.ts.map +1 -0
- package/components/ActionButtonGroup/index.js +1 -0
- package/components/AlertBanner/AlertBanner.d.ts +15 -0
- package/components/AlertBanner/AlertBanner.d.ts.map +1 -0
- package/components/AlertBanner/AlertBanner.jsx +30 -0
- package/components/AlertBanner/AlertBanner.stories.d.ts +17 -0
- package/components/AlertBanner/AlertBanner.stories.d.ts.map +1 -0
- package/components/AlertBanner/AlertBanner.stories.jsx +128 -0
- package/components/AlertBanner/AlertBanner.test.d.ts +3 -0
- package/components/AlertBanner/AlertBanner.test.d.ts.map +1 -0
- package/components/AlertBanner/AlertBanner.test.jsx +40 -0
- package/components/AlertBanner/index.d.ts +3 -0
- package/components/AlertBanner/index.d.ts.map +1 -0
- package/components/AlertBanner/index.js +2 -0
- package/components/Breadcrumbs/Breadcrumbs.d.ts +9 -0
- package/components/Breadcrumbs/Breadcrumbs.d.ts.map +1 -0
- package/components/Breadcrumbs/Breadcrumbs.jsx +26 -0
- package/components/Breadcrumbs/Breadcrumbs.stories.d.ts +15 -0
- package/components/Breadcrumbs/Breadcrumbs.stories.d.ts.map +1 -0
- package/components/Breadcrumbs/Breadcrumbs.stories.jsx +110 -0
- package/components/Breadcrumbs/Breadcrumbs.test.d.ts +3 -0
- package/components/Breadcrumbs/Breadcrumbs.test.d.ts.map +1 -0
- package/components/Breadcrumbs/Breadcrumbs.test.jsx +67 -0
- package/components/Breadcrumbs/index.d.ts +3 -0
- package/components/Breadcrumbs/index.d.ts.map +1 -0
- package/components/Breadcrumbs/index.js +2 -0
- package/components/Button/Button.d.ts +15 -0
- package/components/Button/Button.d.ts.map +1 -0
- package/components/Button/Button.jsx +59 -0
- package/components/Button/Button.stories.d.ts +135 -0
- package/components/Button/Button.stories.d.ts.map +1 -0
- package/components/Button/Button.stories.jsx +354 -0
- package/components/Button/Button.test.d.ts +2 -0
- package/components/Button/Button.test.d.ts.map +1 -0
- package/components/Button/Button.test.jsx +134 -0
- package/components/Button/index.d.ts +3 -0
- package/components/Button/index.d.ts.map +1 -0
- package/components/Button/index.js +2 -0
- package/components/Card/Card.d.ts +9 -0
- package/components/Card/Card.d.ts.map +1 -0
- package/components/Card/Card.jsx +7 -0
- package/components/Card/Card.stories.d.ts +16 -0
- package/components/Card/Card.stories.d.ts.map +1 -0
- package/components/Card/Card.stories.jsx +47 -0
- package/components/Card/Card.test.d.ts +3 -0
- package/components/Card/Card.test.d.ts.map +1 -0
- package/components/Card/Card.test.jsx +26 -0
- package/components/Card/index.d.ts +2 -0
- package/components/Card/index.d.ts.map +1 -0
- package/components/Card/index.js +1 -0
- package/components/CartItem/CartItem.d.ts +25 -0
- package/components/CartItem/CartItem.d.ts.map +1 -0
- package/components/CartItem/CartItem.jsx +124 -0
- package/components/CartItem/CartItem.stories.d.ts +54 -0
- package/components/CartItem/CartItem.stories.d.ts.map +1 -0
- package/components/CartItem/CartItem.stories.jsx +309 -0
- package/components/CartItem/CartItem.test.d.ts +3 -0
- package/components/CartItem/CartItem.test.d.ts.map +1 -0
- package/components/CartItem/CartItem.test.jsx +71 -0
- package/components/CartItem/CartItemSkeleton.d.ts +3 -0
- package/components/CartItem/CartItemSkeleton.d.ts.map +1 -0
- package/components/CartItem/CartItemSkeleton.jsx +25 -0
- package/components/CartItem/CartItemSkeleton.test.d.ts +3 -0
- package/components/CartItem/CartItemSkeleton.test.d.ts.map +1 -0
- package/components/CartItem/CartItemSkeleton.test.jsx +11 -0
- package/components/CartItem/index.d.ts +4 -0
- package/components/CartItem/index.d.ts.map +1 -0
- package/components/CartItem/index.js +3 -0
- package/components/CartList/CartList.d.ts +7 -0
- package/components/CartList/CartList.d.ts.map +1 -0
- package/components/CartList/CartList.jsx +14 -0
- package/components/CartList/CartList.stories.d.ts +17 -0
- package/components/CartList/CartList.stories.d.ts.map +1 -0
- package/components/CartList/CartList.stories.jsx +54 -0
- package/components/CartList/CartList.test.d.ts +3 -0
- package/components/CartList/CartList.test.d.ts.map +1 -0
- package/components/CartList/CartList.test.jsx +12 -0
- package/components/CartList/index.d.ts +3 -0
- package/components/CartList/index.d.ts.map +1 -0
- package/components/CartList/index.js +2 -0
- package/components/Checkbox/Checkbox.d.ts +13 -0
- package/components/Checkbox/Checkbox.d.ts.map +1 -0
- package/components/Checkbox/Checkbox.jsx +51 -0
- package/components/Checkbox/Checkbox.stories.d.ts +22 -0
- package/components/Checkbox/Checkbox.stories.d.ts.map +1 -0
- package/components/Checkbox/Checkbox.stories.jsx +157 -0
- package/components/Checkbox/Checkbox.test.d.ts +3 -0
- package/components/Checkbox/Checkbox.test.d.ts.map +1 -0
- package/components/Checkbox/Checkbox.test.jsx +136 -0
- package/components/Checkbox/index.d.ts +2 -0
- package/components/Checkbox/index.d.ts.map +1 -0
- package/components/Checkbox/index.js +1 -0
- package/components/ColorSwatch/ColorSwatch.d.ts +20 -0
- package/components/ColorSwatch/ColorSwatch.d.ts.map +1 -0
- package/components/ColorSwatch/ColorSwatch.jsx +57 -0
- package/components/ColorSwatch/ColorSwatch.stories.d.ts +20 -0
- package/components/ColorSwatch/ColorSwatch.stories.d.ts.map +1 -0
- package/components/ColorSwatch/ColorSwatch.stories.jsx +206 -0
- package/components/ColorSwatch/ColorSwatch.test.d.ts +3 -0
- package/components/ColorSwatch/ColorSwatch.test.d.ts.map +1 -0
- package/components/ColorSwatch/ColorSwatch.test.jsx +87 -0
- package/components/ColorSwatch/index.d.ts +3 -0
- package/components/ColorSwatch/index.d.ts.map +1 -0
- package/components/ColorSwatch/index.js +2 -0
- package/components/Divider/Divider.d.ts +8 -0
- package/components/Divider/Divider.d.ts.map +1 -0
- package/components/Divider/Divider.jsx +9 -0
- package/components/Divider/Divider.stories.d.ts +11 -0
- package/components/Divider/Divider.stories.d.ts.map +1 -0
- package/components/Divider/Divider.stories.jsx +43 -0
- package/components/Divider/Divider.test.d.ts +2 -0
- package/components/Divider/Divider.test.d.ts.map +1 -0
- package/components/Divider/Divider.test.jsx +19 -0
- package/components/Divider/index.d.ts +3 -0
- package/components/Divider/index.d.ts.map +1 -0
- package/components/Divider/index.js +2 -0
- package/components/Field/Field.d.ts +14 -0
- package/components/Field/Field.d.ts.map +1 -0
- package/components/Field/Field.jsx +29 -0
- package/components/Field/Field.stories.d.ts +37 -0
- package/components/Field/Field.stories.d.ts.map +1 -0
- package/components/Field/Field.stories.jsx +174 -0
- package/components/Field/Field.test.d.ts +3 -0
- package/components/Field/Field.test.d.ts.map +1 -0
- package/components/Field/Field.test.jsx +91 -0
- package/components/Field/index.d.ts +2 -0
- package/components/Field/index.d.ts.map +1 -0
- package/components/Field/index.js +1 -0
- package/components/Icon/Icon.d.ts +11 -0
- package/components/Icon/Icon.d.ts.map +1 -0
- package/components/Icon/Icon.jsx +57 -0
- package/components/Icon/Icon.stories.d.ts +16 -0
- package/components/Icon/Icon.stories.d.ts.map +1 -0
- package/components/Icon/Icon.stories.helpers.d.ts +4 -0
- package/components/Icon/Icon.stories.helpers.d.ts.map +1 -0
- package/components/Icon/Icon.stories.helpers.jsx +7 -0
- package/components/Icon/Icon.stories.jsx +48 -0
- package/components/Icon/Icon.test.d.ts +3 -0
- package/components/Icon/Icon.test.d.ts.map +1 -0
- package/components/Icon/Icon.test.jsx +67 -0
- package/components/Icon/index.d.ts +2 -0
- package/components/Icon/index.d.ts.map +1 -0
- package/components/Icon/index.js +1 -0
- package/components/IllustratedMessage/IllustratedMessage.d.ts +13 -0
- package/components/IllustratedMessage/IllustratedMessage.d.ts.map +1 -0
- package/components/IllustratedMessage/IllustratedMessage.jsx +21 -0
- package/components/IllustratedMessage/IllustratedMessage.stories.d.ts +10 -0
- package/components/IllustratedMessage/IllustratedMessage.stories.d.ts.map +1 -0
- package/components/IllustratedMessage/IllustratedMessage.stories.jsx +90 -0
- package/components/IllustratedMessage/IllustratedMessage.test.d.ts +3 -0
- package/components/IllustratedMessage/IllustratedMessage.test.d.ts.map +1 -0
- package/components/IllustratedMessage/IllustratedMessage.test.jsx +42 -0
- package/components/IllustratedMessage/index.d.ts +3 -0
- package/components/IllustratedMessage/index.d.ts.map +1 -0
- package/components/IllustratedMessage/index.js +2 -0
- package/components/Image/Image.d.ts +11 -0
- package/components/Image/Image.d.ts.map +1 -0
- package/components/Image/Image.jsx +26 -0
- package/components/Image/Image.stories.d.ts +11 -0
- package/components/Image/Image.stories.d.ts.map +1 -0
- package/components/Image/Image.stories.jsx +66 -0
- package/components/Image/Image.test.d.ts +3 -0
- package/components/Image/Image.test.d.ts.map +1 -0
- package/components/Image/Image.test.jsx +82 -0
- package/components/Image/index.d.ts +2 -0
- package/components/Image/index.d.ts.map +1 -0
- package/components/Image/index.js +1 -0
- package/components/ImageSwatch/ImageSwatch.d.ts +20 -0
- package/components/ImageSwatch/ImageSwatch.d.ts.map +1 -0
- package/components/ImageSwatch/ImageSwatch.jsx +49 -0
- package/components/ImageSwatch/ImageSwatch.stories.d.ts +20 -0
- package/components/ImageSwatch/ImageSwatch.stories.d.ts.map +1 -0
- package/components/ImageSwatch/ImageSwatch.stories.jsx +206 -0
- package/components/ImageSwatch/ImageSwatch.test.d.ts +3 -0
- package/components/ImageSwatch/ImageSwatch.test.d.ts.map +1 -0
- package/components/ImageSwatch/ImageSwatch.test.jsx +64 -0
- package/components/ImageSwatch/index.d.ts +3 -0
- package/components/ImageSwatch/index.d.ts.map +1 -0
- package/components/ImageSwatch/index.js +2 -0
- package/components/InLineAlert/InLineAlert.d.ts +16 -0
- package/components/InLineAlert/InLineAlert.d.ts.map +1 -0
- package/components/InLineAlert/InLineAlert.jsx +38 -0
- package/components/InLineAlert/InLineAlert.stories.d.ts +86 -0
- package/components/InLineAlert/InLineAlert.stories.d.ts.map +1 -0
- package/components/InLineAlert/InLineAlert.stories.jsx +193 -0
- package/components/InLineAlert/InLineAlert.test.d.ts +3 -0
- package/components/InLineAlert/InLineAlert.test.d.ts.map +1 -0
- package/components/InLineAlert/InLineAlert.test.jsx +77 -0
- package/components/InLineAlert/index.d.ts +3 -0
- package/components/InLineAlert/index.d.ts.map +1 -0
- package/components/InLineAlert/index.js +2 -0
- package/components/Incrementer/Incrementer.d.ts +17 -0
- package/components/Incrementer/Incrementer.d.ts.map +1 -0
- package/components/Incrementer/Incrementer.jsx +87 -0
- package/components/Incrementer/Incrementer.stories.d.ts +10 -0
- package/components/Incrementer/Incrementer.stories.d.ts.map +1 -0
- package/components/Incrementer/Incrementer.stories.jsx +68 -0
- package/components/Incrementer/Incrementer.test.d.ts +3 -0
- package/components/Incrementer/Incrementer.test.d.ts.map +1 -0
- package/components/Incrementer/Incrementer.test.jsx +112 -0
- package/components/Incrementer/index.d.ts +2 -0
- package/components/Incrementer/index.d.ts.map +1 -0
- package/components/Incrementer/index.js +1 -0
- package/components/Input/Input.d.ts +19 -0
- package/components/Input/Input.d.ts.map +1 -0
- package/components/Input/Input.jsx +73 -0
- package/components/Input/Input.stories.d.ts +11 -0
- package/components/Input/Input.stories.d.ts.map +1 -0
- package/components/Input/Input.stories.jsx +115 -0
- package/components/Input/Input.test.d.ts +3 -0
- package/components/Input/Input.test.d.ts.map +1 -0
- package/components/Input/Input.test.jsx +111 -0
- package/components/Input/index.d.ts +3 -0
- package/components/Input/index.d.ts.map +1 -0
- package/components/Input/index.js +2 -0
- package/components/Modal/Modal.d.ts +15 -0
- package/components/Modal/Modal.d.ts.map +1 -0
- package/components/Modal/Modal.jsx +93 -0
- package/components/Modal/Modal.stories.d.ts +56 -0
- package/components/Modal/Modal.stories.d.ts.map +1 -0
- package/components/Modal/Modal.stories.jsx +189 -0
- package/components/Modal/Modal.test.d.ts +3 -0
- package/components/Modal/Modal.test.d.ts.map +1 -0
- package/components/Modal/Modal.test.jsx +85 -0
- package/components/Modal/index.d.ts +2 -0
- package/components/Modal/index.d.ts.map +1 -0
- package/components/Modal/index.js +14 -0
- package/components/Picker/Picker.d.ts +26 -0
- package/components/Picker/Picker.d.ts.map +1 -0
- package/components/Picker/Picker.jsx +81 -0
- package/components/Picker/Picker.stories.d.ts +22 -0
- package/components/Picker/Picker.stories.d.ts.map +1 -0
- package/components/Picker/Picker.stories.jsx +236 -0
- package/components/Picker/Picker.test.d.ts +2 -0
- package/components/Picker/Picker.test.d.ts.map +1 -0
- package/components/Picker/Picker.test.jsx +190 -0
- package/components/Picker/index.d.ts +2 -0
- package/components/Picker/index.d.ts.map +1 -0
- package/components/Picker/index.js +1 -0
- package/components/Price/Price.d.ts +17 -0
- package/components/Price/Price.d.ts.map +1 -0
- package/components/Price/Price.jsx +24 -0
- package/components/Price/Price.stories.d.ts +17 -0
- package/components/Price/Price.stories.d.ts.map +1 -0
- package/components/Price/Price.stories.jsx +78 -0
- package/components/Price/Price.test.d.ts +3 -0
- package/components/Price/Price.test.d.ts.map +1 -0
- package/components/Price/Price.test.jsx +68 -0
- package/components/Price/index.d.ts +2 -0
- package/components/Price/index.d.ts.map +1 -0
- package/components/Price/index.js +1 -0
- package/components/PriceRange/PriceRange.d.ts +17 -0
- package/components/PriceRange/PriceRange.d.ts.map +1 -0
- package/components/PriceRange/PriceRange.jsx +75 -0
- package/components/PriceRange/PriceRange.stories.d.ts +107 -0
- package/components/PriceRange/PriceRange.stories.d.ts.map +1 -0
- package/components/PriceRange/PriceRange.stories.jsx +210 -0
- package/components/PriceRange/PriceRange.test.d.ts +3 -0
- package/components/PriceRange/PriceRange.test.d.ts.map +1 -0
- package/components/PriceRange/PriceRange.test.jsx +188 -0
- package/components/PriceRange/index.d.ts +3 -0
- package/components/PriceRange/index.d.ts.map +1 -0
- package/components/PriceRange/index.js +2 -0
- package/components/PriceSummary/PriceSummary.d.ts +43 -0
- package/components/PriceSummary/PriceSummary.d.ts.map +1 -0
- package/components/PriceSummary/PriceSummary.jsx +228 -0
- package/components/PriceSummary/PriceSummary.stories.d.ts +127 -0
- package/components/PriceSummary/PriceSummary.stories.d.ts.map +1 -0
- package/components/PriceSummary/PriceSummary.stories.jsx +456 -0
- package/components/PriceSummary/PriceSummary.test.d.ts +3 -0
- package/components/PriceSummary/PriceSummary.test.d.ts.map +1 -0
- package/components/PriceSummary/PriceSummary.test.jsx +275 -0
- package/components/PriceSummary/index.d.ts +3 -0
- package/components/PriceSummary/index.d.ts.map +1 -0
- package/components/PriceSummary/index.js +2 -0
- package/components/ProgressSpinner/ProgressSpinner.d.ts +14 -0
- package/components/ProgressSpinner/ProgressSpinner.d.ts.map +1 -0
- package/components/ProgressSpinner/ProgressSpinner.jsx +31 -0
- package/components/ProgressSpinner/ProgressSpinner.stories.d.ts +19 -0
- package/components/ProgressSpinner/ProgressSpinner.stories.d.ts.map +1 -0
- package/components/ProgressSpinner/ProgressSpinner.stories.jsx +195 -0
- package/components/ProgressSpinner/ProgressSpinner.test.d.ts +3 -0
- package/components/ProgressSpinner/ProgressSpinner.test.d.ts.map +1 -0
- package/components/ProgressSpinner/ProgressSpinner.test.jsx +40 -0
- package/components/ProgressSpinner/index.d.ts +3 -0
- package/components/ProgressSpinner/index.d.ts.map +1 -0
- package/components/ProgressSpinner/index.js +2 -0
- package/components/RadioButton/RadioButton.d.ts +15 -0
- package/components/RadioButton/RadioButton.d.ts.map +1 -0
- package/components/RadioButton/RadioButton.jsx +31 -0
- package/components/RadioButton/RadioButton.stories.d.ts +15 -0
- package/components/RadioButton/RadioButton.stories.d.ts.map +1 -0
- package/components/RadioButton/RadioButton.stories.jsx +92 -0
- package/components/RadioButton/RadioButton.test.d.ts +3 -0
- package/components/RadioButton/RadioButton.test.d.ts.map +1 -0
- package/components/RadioButton/RadioButton.test.jsx +62 -0
- package/components/RadioButton/index.d.ts +3 -0
- package/components/RadioButton/index.d.ts.map +1 -0
- package/components/RadioButton/index.js +2 -0
- package/components/Skeleton/Skeleton.d.ts +17 -0
- package/components/Skeleton/Skeleton.d.ts.map +1 -0
- package/components/Skeleton/Skeleton.jsx +52 -0
- package/components/Skeleton/Skeleton.stories.d.ts +67 -0
- package/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
- package/components/Skeleton/Skeleton.stories.jsx +184 -0
- package/components/Skeleton/Skeleton.test.d.ts +3 -0
- package/components/Skeleton/Skeleton.test.d.ts.map +1 -0
- package/components/Skeleton/Skeleton.test.jsx +62 -0
- package/components/Skeleton/index.d.ts +2 -0
- package/components/Skeleton/index.d.ts.map +1 -0
- package/components/Skeleton/index.js +1 -0
- package/components/TextSwatch/TextSwatch.d.ts +18 -0
- package/components/TextSwatch/TextSwatch.d.ts.map +1 -0
- package/components/TextSwatch/TextSwatch.jsx +56 -0
- package/components/TextSwatch/TextSwatch.stories.d.ts +21 -0
- package/components/TextSwatch/TextSwatch.stories.d.ts.map +1 -0
- package/components/TextSwatch/TextSwatch.stories.jsx +211 -0
- package/components/TextSwatch/TextSwatch.test.d.ts +3 -0
- package/components/TextSwatch/TextSwatch.test.d.ts.map +1 -0
- package/components/TextSwatch/TextSwatch.test.jsx +85 -0
- package/components/TextSwatch/index.d.ts +3 -0
- package/components/TextSwatch/index.d.ts.map +1 -0
- package/components/TextSwatch/index.js +2 -0
- package/components/UIProvider/UIProvider.d.ts +18 -0
- package/components/UIProvider/UIProvider.d.ts.map +1 -0
- package/components/UIProvider/UIProvider.jsx +26 -0
- package/components/UIProvider/UIProvider.test.d.ts +2 -0
- package/components/UIProvider/UIProvider.test.d.ts.map +1 -0
- package/components/UIProvider/UIProvider.test.jsx +9 -0
- package/components/UIProvider/index.d.ts +2 -0
- package/components/UIProvider/index.d.ts.map +1 -0
- package/components/UIProvider/index.js +1 -0
- package/components/index.d.ts +34 -0
- package/components/index.d.ts.map +1 -0
- package/components/index.js +33 -0
- package/docs/Design/designBlocks.d.ts +21 -0
- package/docs/Design/designBlocks.d.ts.map +1 -0
- package/docs/Design/designBlocks.jsx +59 -0
- package/docs/Design/getTokenData.d.ts +7 -0
- package/docs/Design/getTokenData.d.ts.map +1 -0
- package/docs/Design/getTokenData.js +18 -0
- package/docs/Design/getTokenData.test.d.ts +2 -0
- package/docs/Design/getTokenData.test.d.ts.map +1 -0
- package/docs/Design/getTokenData.test.js +92 -0
- package/event-bus.js +49 -1
- package/fetch-graphql.js +62 -1
- package/i18n/en_US.json +112 -0
- package/i18n/index.d.ts +341 -0
- package/i18n/index.d.ts.map +1 -0
- package/i18n/index.js +12 -0
- package/i18n/index.test.d.ts +2 -0
- package/i18n/index.test.d.ts.map +1 -0
- package/i18n/index.test.js +11 -0
- package/icons/index.d.ts +35 -0
- package/icons/index.d.ts.map +1 -0
- package/icons/index.js +34 -0
- package/initializer.js +61 -1
- package/lib/classes.d.ts +5 -0
- package/lib/classes.d.ts.map +1 -0
- package/lib/classes.js +16 -0
- package/lib/classes.test.d.ts +2 -0
- package/lib/classes.test.d.ts.map +1 -0
- package/lib/classes.test.js +18 -0
- package/lib/config.d.ts +7 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +12 -0
- package/lib/config.test.d.ts +2 -0
- package/lib/config.test.d.ts.map +1 -0
- package/lib/config.test.js +12 -0
- package/lib/debounce.d.ts +2 -0
- package/lib/debounce.d.ts.map +1 -0
- package/lib/debounce.js +7 -0
- package/lib/debounce.test.d.ts +2 -0
- package/lib/debounce.test.d.ts.map +1 -0
- package/lib/debounce.test.js +40 -0
- package/lib/deepmerge.d.ts +2 -0
- package/lib/deepmerge.d.ts.map +1 -0
- package/lib/deepmerge.js +1 -0
- package/lib/form-values.d.ts +5 -0
- package/lib/form-values.d.ts.map +1 -0
- package/lib/form-values.js +17 -0
- package/lib/form-values.test.d.ts +2 -0
- package/lib/form-values.test.d.ts.map +1 -0
- package/lib/form-values.test.jsx +29 -0
- package/lib/i18n.d.ts +8 -0
- package/lib/i18n.d.ts.map +1 -0
- package/lib/i18n.js +9 -0
- package/lib/i18n.test.d.ts +2 -0
- package/lib/i18n.test.d.ts.map +1 -0
- package/lib/i18n.test.jsx +8 -0
- package/lib/image-params-keymap.d.ts +4 -0
- package/lib/image-params-keymap.d.ts.map +1 -0
- package/lib/image-params-keymap.js +19 -0
- package/lib/image-params-keymap.test.d.ts +2 -0
- package/lib/image-params-keymap.test.d.ts.map +1 -0
- package/lib/image-params-keymap.test.js +7 -0
- package/lib/index.d.ts +14 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +13 -0
- package/lib/initializer.d.ts +78 -0
- package/lib/initializer.d.ts.map +1 -0
- package/lib/initializer.js +93 -0
- package/lib/initializer.test.d.ts +2 -0
- package/lib/initializer.test.d.ts.map +1 -0
- package/lib/initializer.test.js +64 -0
- package/lib/render.d.ts +10 -0
- package/lib/render.d.ts.map +1 -0
- package/lib/render.jsx +34 -0
- package/lib/render.test.d.ts +2 -0
- package/lib/render.test.d.ts.map +1 -0
- package/lib/render.test.jsx +70 -0
- package/lib/resolve-image.d.ts +10 -0
- package/lib/resolve-image.d.ts.map +1 -0
- package/lib/resolve-image.js +57 -0
- package/lib/resolve-image.test.d.ts +2 -0
- package/lib/resolve-image.test.d.ts.map +1 -0
- package/lib/resolve-image.test.jsx +146 -0
- package/lib/slot.d.ts +43 -0
- package/lib/slot.d.ts.map +1 -0
- package/lib/slot.jsx +184 -0
- package/lib/slot.test.d.ts +2 -0
- package/lib/slot.test.d.ts.map +1 -0
- package/lib/slot.test.jsx +325 -0
- package/lib/tests.d.ts +4 -0
- package/lib/tests.d.ts.map +1 -0
- package/lib/tests.jsx +19 -0
- package/lib/tests.test.d.ts +2 -0
- package/lib/tests.test.d.ts.map +1 -0
- package/lib/tests.test.jsx +13 -0
- package/lib/types.d.ts +9 -0
- package/lib/types.d.ts.map +1 -0
- package/lib/types.js +1 -0
- package/lib/vcomponent.d.ts +8 -0
- package/lib/vcomponent.d.ts.map +1 -0
- package/lib/vcomponent.jsx +27 -0
- package/lib/vcomponent.test.d.ts +2 -0
- package/lib/vcomponent.test.d.ts.map +1 -0
- package/lib/vcomponent.test.jsx +51 -0
- package/package.json +1 -1
- package/preact-compat.js +93 -1
- package/preact-hooks.js +40 -1
- package/preact-jsx-runtime.js +35 -1
- package/preact.js +21 -1
- package/runtime.js +69 -1
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { getImageParamsKeyMap } from '@adobe/elsie/lib/';
|
|
2
|
+
const BREAKPOINTS = {
|
|
3
|
+
medium: 768,
|
|
4
|
+
large: 1024,
|
|
5
|
+
xlarge: 1366,
|
|
6
|
+
xxlarge: 1920,
|
|
7
|
+
};
|
|
8
|
+
const resolveImageUrl = (url, _opts) => {
|
|
9
|
+
const [base, query] = url.split('?');
|
|
10
|
+
const params = new URLSearchParams(query);
|
|
11
|
+
const keyMapping = getImageParamsKeyMap();
|
|
12
|
+
let opts = {};
|
|
13
|
+
if (keyMapping && Object.keys(keyMapping).length > 0 && _opts) {
|
|
14
|
+
opts = Object.entries(_opts).reduce((acc, [key, value]) => {
|
|
15
|
+
const newKey = keyMapping[key];
|
|
16
|
+
if (newKey) {
|
|
17
|
+
acc[newKey] = value;
|
|
18
|
+
}
|
|
19
|
+
return acc;
|
|
20
|
+
}, {});
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
opts = {
|
|
24
|
+
auto: 'webp',
|
|
25
|
+
quality: 80,
|
|
26
|
+
crop: false,
|
|
27
|
+
fit: 'cover',
|
|
28
|
+
..._opts,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
// Append image optimization parameters
|
|
32
|
+
Object.entries(opts).forEach(([key, value]) => {
|
|
33
|
+
if (value !== undefined && value !== null) {
|
|
34
|
+
params.set(key, String(value));
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
return `${base}?${params.toString()}`;
|
|
38
|
+
};
|
|
39
|
+
export const generateSrcset = (imageURL, options) => {
|
|
40
|
+
if (!imageURL || !options?.width)
|
|
41
|
+
return;
|
|
42
|
+
const generateSrcsetUrl = (options) => {
|
|
43
|
+
return resolveImageUrl(imageURL, {
|
|
44
|
+
...options,
|
|
45
|
+
});
|
|
46
|
+
};
|
|
47
|
+
return Object.entries(BREAKPOINTS)
|
|
48
|
+
.map(([, value]) => {
|
|
49
|
+
// calculate breakpoints width
|
|
50
|
+
const relativeWidth = (options.width * value) / BREAKPOINTS.xxlarge;
|
|
51
|
+
return `${generateSrcsetUrl({
|
|
52
|
+
...options,
|
|
53
|
+
width: relativeWidth,
|
|
54
|
+
})} ${value}w`;
|
|
55
|
+
})
|
|
56
|
+
.join(',\n');
|
|
57
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-image.test.d.ts","sourceRoot":"","sources":["../../src/lib/resolve-image.test.tsx"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { generateSrcset } from '@adobe/elsie/lib/resolve-image';
|
|
2
|
+
import { getImageParamsKeyMap } from './image-params-keymap';
|
|
3
|
+
jest.mock('@adobe/elsie/lib/image-params-keymap', () => ({
|
|
4
|
+
getImageParamsKeyMap: jest.fn(),
|
|
5
|
+
}));
|
|
6
|
+
const imageURL = 'http://example.com/image.jpeg';
|
|
7
|
+
describe('resolve-image', () => {
|
|
8
|
+
beforeEach(() => {
|
|
9
|
+
getImageParamsKeyMap.mockReturnValue(undefined);
|
|
10
|
+
});
|
|
11
|
+
test('generateSrcset should return empty string if either of the arguments are falsey', () => {
|
|
12
|
+
expect(generateSrcset('', { width: 960 })).toBe(undefined);
|
|
13
|
+
// @ts-ignore
|
|
14
|
+
expect(generateSrcset(null, null)).toBe(undefined);
|
|
15
|
+
// @ts-ignore
|
|
16
|
+
expect(generateSrcset(undefined, undefined)).toBe(undefined);
|
|
17
|
+
expect(
|
|
18
|
+
// @ts-ignore
|
|
19
|
+
generateSrcset(imageURL, { width: 90, height: undefined, quality: null })).toMatchInlineSnapshot(`
|
|
20
|
+
"http://example.com/image.jpeg?auto=webp&crop=false&fit=cover&width=36 768w,
|
|
21
|
+
http://example.com/image.jpeg?auto=webp&crop=false&fit=cover&width=48 1024w,
|
|
22
|
+
http://example.com/image.jpeg?auto=webp&crop=false&fit=cover&width=64.03125 1366w,
|
|
23
|
+
http://example.com/image.jpeg?auto=webp&crop=false&fit=cover&width=90 1920w"
|
|
24
|
+
`);
|
|
25
|
+
});
|
|
26
|
+
test('generateSrcset should return srcset for all widths in imageWidths', () => {
|
|
27
|
+
const result = generateSrcset(imageURL, { width: 960 });
|
|
28
|
+
expect(result).toMatchInlineSnapshot(`
|
|
29
|
+
"http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=384 768w,
|
|
30
|
+
http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=512 1024w,
|
|
31
|
+
http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=683 1366w,
|
|
32
|
+
http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=960 1920w"
|
|
33
|
+
`);
|
|
34
|
+
});
|
|
35
|
+
test('resolveImageUrl should accept relative URL', () => {
|
|
36
|
+
const result = generateSrcset('/test.jpg', { width: 960 });
|
|
37
|
+
expect(result).toMatchInlineSnapshot(`
|
|
38
|
+
"/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=384 768w,
|
|
39
|
+
/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=512 1024w,
|
|
40
|
+
/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=683 1366w,
|
|
41
|
+
/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=960 1920w"
|
|
42
|
+
`);
|
|
43
|
+
const result2 = generateSrcset('//domain.com/test.jpg', { width: 960 });
|
|
44
|
+
expect(result2).toMatchInlineSnapshot(`
|
|
45
|
+
"//domain.com/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=384 768w,
|
|
46
|
+
//domain.com/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=512 1024w,
|
|
47
|
+
//domain.com/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=683 1366w,
|
|
48
|
+
//domain.com/test.jpg?auto=webp&quality=80&crop=false&fit=cover&width=960 1920w"
|
|
49
|
+
`);
|
|
50
|
+
});
|
|
51
|
+
describe('custom mappings', () => {
|
|
52
|
+
test('resolveImageUrl should apply custom key mapping when provided', () => {
|
|
53
|
+
getImageParamsKeyMap.mockReturnValue({
|
|
54
|
+
width: 'w',
|
|
55
|
+
quality: 'qual',
|
|
56
|
+
fit: 'f',
|
|
57
|
+
auto: 'a',
|
|
58
|
+
crop: 'cr',
|
|
59
|
+
});
|
|
60
|
+
const result = generateSrcset(imageURL, {
|
|
61
|
+
width: 960,
|
|
62
|
+
quality: 50,
|
|
63
|
+
fit: 'cover',
|
|
64
|
+
auto: 'webp',
|
|
65
|
+
crop: false,
|
|
66
|
+
});
|
|
67
|
+
expect(result).toMatchInlineSnapshot(`
|
|
68
|
+
"http://example.com/image.jpeg?w=384&qual=50&f=cover&a=webp&cr=false 768w,
|
|
69
|
+
http://example.com/image.jpeg?w=512&qual=50&f=cover&a=webp&cr=false 1024w,
|
|
70
|
+
http://example.com/image.jpeg?w=683&qual=50&f=cover&a=webp&cr=false 1366w,
|
|
71
|
+
http://example.com/image.jpeg?w=960&qual=50&f=cover&a=webp&cr=false 1920w"
|
|
72
|
+
`);
|
|
73
|
+
});
|
|
74
|
+
test('resolveImageUrl should ignore custom key mapping if key is not found in options', () => {
|
|
75
|
+
getImageParamsKeyMap.mockReturnValue({
|
|
76
|
+
width: 'w',
|
|
77
|
+
quality: 'qual',
|
|
78
|
+
fit: 'f',
|
|
79
|
+
auto: 'a',
|
|
80
|
+
crop: 'cr',
|
|
81
|
+
height: 'h',
|
|
82
|
+
});
|
|
83
|
+
const result = generateSrcset(imageURL, {
|
|
84
|
+
width: 960,
|
|
85
|
+
quality: 50,
|
|
86
|
+
fit: 'cover',
|
|
87
|
+
auto: 'webp',
|
|
88
|
+
crop: false,
|
|
89
|
+
});
|
|
90
|
+
expect(result).toMatchInlineSnapshot(`
|
|
91
|
+
"http://example.com/image.jpeg?w=384&qual=50&f=cover&a=webp&cr=false 768w,
|
|
92
|
+
http://example.com/image.jpeg?w=512&qual=50&f=cover&a=webp&cr=false 1024w,
|
|
93
|
+
http://example.com/image.jpeg?w=683&qual=50&f=cover&a=webp&cr=false 1366w,
|
|
94
|
+
http://example.com/image.jpeg?w=960&qual=50&f=cover&a=webp&cr=false 1920w"
|
|
95
|
+
`);
|
|
96
|
+
});
|
|
97
|
+
test('resolveImageUrl should ignore option if mapping is not provided', () => {
|
|
98
|
+
getImageParamsKeyMap.mockReturnValue({
|
|
99
|
+
width: 'w',
|
|
100
|
+
quality: 'qual',
|
|
101
|
+
fit: 'f',
|
|
102
|
+
auto: 'a',
|
|
103
|
+
});
|
|
104
|
+
const result = generateSrcset(imageURL, {
|
|
105
|
+
width: 960,
|
|
106
|
+
quality: 50,
|
|
107
|
+
fit: 'cover',
|
|
108
|
+
auto: 'webp',
|
|
109
|
+
crop: false,
|
|
110
|
+
});
|
|
111
|
+
expect(result).toMatchInlineSnapshot(`
|
|
112
|
+
"http://example.com/image.jpeg?w=384&qual=50&f=cover&a=webp 768w,
|
|
113
|
+
http://example.com/image.jpeg?w=512&qual=50&f=cover&a=webp 1024w,
|
|
114
|
+
http://example.com/image.jpeg?w=683&qual=50&f=cover&a=webp 1366w,
|
|
115
|
+
http://example.com/image.jpeg?w=960&qual=50&f=cover&a=webp 1920w"
|
|
116
|
+
`);
|
|
117
|
+
});
|
|
118
|
+
test('resolveImageUrl can support completely custom params', () => {
|
|
119
|
+
getImageParamsKeyMap.mockReturnValue({
|
|
120
|
+
width: 'width',
|
|
121
|
+
scale: 'scale',
|
|
122
|
+
crop: 'crop',
|
|
123
|
+
opacity: 'opacity',
|
|
124
|
+
});
|
|
125
|
+
const result = generateSrcset(imageURL,
|
|
126
|
+
// @ts-ignore
|
|
127
|
+
{ width: 960, scale: 2, crop: 'center', opacity: 75 });
|
|
128
|
+
expect(result).toMatchInlineSnapshot(`
|
|
129
|
+
"http://example.com/image.jpeg?width=384&scale=2&crop=center&opacity=75 768w,
|
|
130
|
+
http://example.com/image.jpeg?width=512&scale=2&crop=center&opacity=75 1024w,
|
|
131
|
+
http://example.com/image.jpeg?width=683&scale=2&crop=center&opacity=75 1366w,
|
|
132
|
+
http://example.com/image.jpeg?width=960&scale=2&crop=center&opacity=75 1920w"
|
|
133
|
+
`);
|
|
134
|
+
});
|
|
135
|
+
test('resolveImageUrl should use default mapping if custom mapping object is empty', () => {
|
|
136
|
+
getImageParamsKeyMap.mockReturnValue({});
|
|
137
|
+
const result = generateSrcset(imageURL, { width: 960 });
|
|
138
|
+
expect(result).toMatchInlineSnapshot(`
|
|
139
|
+
"http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=384 768w,
|
|
140
|
+
http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=512 1024w,
|
|
141
|
+
http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=683 1366w,
|
|
142
|
+
http://example.com/image.jpeg?auto=webp&quality=80&crop=false&fit=cover&width=960 1920w"
|
|
143
|
+
`);
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
});
|
package/lib/slot.d.ts
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { RefObject, VNode } from 'preact';
|
|
2
|
+
import { StateUpdater } from 'preact/hooks';
|
|
3
|
+
import { Lang } from '@adobe/elsie/i18n';
|
|
4
|
+
import { HTMLAttributes } from 'preact/compat';
|
|
5
|
+
type MutateElement = (elem: HTMLElement) => void;
|
|
6
|
+
interface State {
|
|
7
|
+
get: (key: string) => void;
|
|
8
|
+
set: (key: string, value: any) => void;
|
|
9
|
+
}
|
|
10
|
+
interface SlotElement {
|
|
11
|
+
appendChild: MutateElement;
|
|
12
|
+
prependChild: MutateElement;
|
|
13
|
+
appendSibling: MutateElement;
|
|
14
|
+
prependSibling: MutateElement;
|
|
15
|
+
}
|
|
16
|
+
interface PrivateContext<T> {
|
|
17
|
+
_setProps: StateUpdater<{}>;
|
|
18
|
+
_registerMethod: (cb: (next: T & DefaultSlotContext<T>, state: State) => void) => void;
|
|
19
|
+
_htmlElementToVNode: (element: HTMLElement) => VNode;
|
|
20
|
+
}
|
|
21
|
+
interface DefaultSlotContext<T> extends PrivateContext<T> {
|
|
22
|
+
dictionary: Lang;
|
|
23
|
+
getSlotElement: (key: string) => SlotElement;
|
|
24
|
+
replaceWith: MutateElement;
|
|
25
|
+
appendChild: MutateElement;
|
|
26
|
+
prependChild: MutateElement;
|
|
27
|
+
appendSibling: MutateElement;
|
|
28
|
+
prependSibling: MutateElement;
|
|
29
|
+
onChange: (cb: (next: T & DefaultSlotContext<T>) => void) => void;
|
|
30
|
+
}
|
|
31
|
+
type Context<T> = T & ThisType<DefaultSlotContext<T>>;
|
|
32
|
+
export type SlotProps<T = any> = (ctx: T & DefaultSlotContext<T>, element: HTMLDivElement | null) => void;
|
|
33
|
+
export type SlotMethod<P = any> = (callback: (next: unknown, state: State) => P) => void;
|
|
34
|
+
export declare function useSlot<K, V extends HTMLDivElement>(context?: Context<K>, callback?: SlotProps<K>, render?: Function): [RefObject<V>, Record<string, any>];
|
|
35
|
+
interface SlotPropsComponent<T> extends Omit<HTMLAttributes<HTMLDivElement>, 'slot'> {
|
|
36
|
+
name: string;
|
|
37
|
+
slot?: SlotProps<T>;
|
|
38
|
+
context?: Context<T>;
|
|
39
|
+
render?: (props: Record<string, any>) => VNode | VNode[];
|
|
40
|
+
}
|
|
41
|
+
export declare function Slot<T>({ name, slot, context, children, render, ...props }: Readonly<SlotPropsComponent<T>>): import("preact").JSX.Element;
|
|
42
|
+
export {};
|
|
43
|
+
//# sourceMappingURL=slot.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slot.d.ts","sourceRoot":"","sources":["../../src/lib/slot.tsx"],"names":[],"mappings":"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"}
|
package/lib/slot.jsx
ADDED
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { useContext, useState, useRef, useEffect, useMemo, useCallback, } from 'preact/hooks';
|
|
2
|
+
import { IntlContext } from '@adobe/elsie/i18n';
|
|
3
|
+
// Slot Hook
|
|
4
|
+
export function useSlot(
|
|
5
|
+
// @ts-ignore
|
|
6
|
+
context = {}, callback, render) {
|
|
7
|
+
// HTML Element
|
|
8
|
+
const elementRef = useRef(null);
|
|
9
|
+
const loadedRef = useRef(false);
|
|
10
|
+
// Methods
|
|
11
|
+
const methodsRef = useRef([]);
|
|
12
|
+
// Children VNodes
|
|
13
|
+
const [props, _setProps] = useState({
|
|
14
|
+
children: [render?.({})],
|
|
15
|
+
});
|
|
16
|
+
// Attributes
|
|
17
|
+
const [_state, setState] = useState({});
|
|
18
|
+
const state = useMemo(() => ({
|
|
19
|
+
get: (key) => _state[key],
|
|
20
|
+
set: (key, value) => {
|
|
21
|
+
setState({ ...state, [key]: value });
|
|
22
|
+
},
|
|
23
|
+
}), [_state]);
|
|
24
|
+
/** Internationalization */
|
|
25
|
+
const { intl } = useContext(IntlContext);
|
|
26
|
+
// @ts-ignore
|
|
27
|
+
context.dictionary = intl.dictionary;
|
|
28
|
+
/** Privates */
|
|
29
|
+
// @ts-ignore
|
|
30
|
+
context._setProps = _setProps;
|
|
31
|
+
const _registerMethod = useCallback((callback) => {
|
|
32
|
+
if (typeof callback === 'function') {
|
|
33
|
+
methodsRef.current.push(callback);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
console.warn('Skipped: Invalid _registerMethod', callback);
|
|
37
|
+
}
|
|
38
|
+
}, []);
|
|
39
|
+
// @ts-ignore
|
|
40
|
+
context._registerMethod = _registerMethod;
|
|
41
|
+
const _htmlElementToVNode = useCallback((elem) => {
|
|
42
|
+
return (<div data-slot-html-element={elem.tagName.toLowerCase()} ref={(refElem) => {
|
|
43
|
+
refElem?.appendChild(elem);
|
|
44
|
+
}}/>);
|
|
45
|
+
}, []);
|
|
46
|
+
// @ts-ignore
|
|
47
|
+
context._htmlElementToVNode = _htmlElementToVNode;
|
|
48
|
+
/** Prebuilt Methods */
|
|
49
|
+
// @ts-ignore
|
|
50
|
+
context.getSlotElement = useCallback((key) => {
|
|
51
|
+
const element = document.querySelector(`[data-slot-key="${key}"]`);
|
|
52
|
+
if (!element)
|
|
53
|
+
return;
|
|
54
|
+
return {
|
|
55
|
+
appendChild: (elem) => {
|
|
56
|
+
element.appendChild(elem);
|
|
57
|
+
},
|
|
58
|
+
prependChild: (elem) => {
|
|
59
|
+
element.insertBefore(elem, element.firstChild);
|
|
60
|
+
},
|
|
61
|
+
appendSibling: (elem) => {
|
|
62
|
+
const parent = element.parentNode;
|
|
63
|
+
parent?.insertBefore(elem, element.nextSibling);
|
|
64
|
+
},
|
|
65
|
+
prependSibling: (elem) => {
|
|
66
|
+
const parent = element.parentNode;
|
|
67
|
+
parent?.insertBefore(elem, element);
|
|
68
|
+
},
|
|
69
|
+
};
|
|
70
|
+
}, []);
|
|
71
|
+
// @ts-ignore
|
|
72
|
+
context.onChange = useCallback((callback) => {
|
|
73
|
+
methodsRef.current.push(callback);
|
|
74
|
+
}, []);
|
|
75
|
+
// @ts-ignore
|
|
76
|
+
context.replaceWith = useCallback((elem) => {
|
|
77
|
+
// @ts-ignore
|
|
78
|
+
_registerMethod((next) => {
|
|
79
|
+
// @ts-ignore
|
|
80
|
+
const children = _htmlElementToVNode(elem);
|
|
81
|
+
next._setProps({ children: [children] });
|
|
82
|
+
});
|
|
83
|
+
}, [_htmlElementToVNode, _registerMethod]);
|
|
84
|
+
// @ts-ignore
|
|
85
|
+
context.appendChild = useCallback((elem) => {
|
|
86
|
+
// @ts-ignore
|
|
87
|
+
_registerMethod((next) => {
|
|
88
|
+
// @ts-ignore
|
|
89
|
+
const vnode = _htmlElementToVNode(elem);
|
|
90
|
+
next._setProps((prev) => {
|
|
91
|
+
return {
|
|
92
|
+
...prev,
|
|
93
|
+
children: [...prev.children, vnode],
|
|
94
|
+
};
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
}, [_htmlElementToVNode, _registerMethod]);
|
|
98
|
+
// @ts-ignore
|
|
99
|
+
context.prependChild = useCallback((elem) => {
|
|
100
|
+
// @ts-ignore
|
|
101
|
+
_registerMethod((next) => {
|
|
102
|
+
// @ts-ignore
|
|
103
|
+
const vnode = _htmlElementToVNode(elem);
|
|
104
|
+
next._setProps((prev) => {
|
|
105
|
+
return {
|
|
106
|
+
...prev,
|
|
107
|
+
children: [vnode, ...prev.children],
|
|
108
|
+
};
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
}, [_htmlElementToVNode, _registerMethod]);
|
|
112
|
+
// @ts-ignore
|
|
113
|
+
context.appendSibling = useCallback((elem) => {
|
|
114
|
+
// @ts-ignore
|
|
115
|
+
_registerMethod(() => {
|
|
116
|
+
const parent = elementRef.current?.parentNode;
|
|
117
|
+
parent?.insertBefore(elem, elementRef.current?.nextSibling ?? null);
|
|
118
|
+
});
|
|
119
|
+
}, [_registerMethod]);
|
|
120
|
+
// @ts-ignore
|
|
121
|
+
context.prependSibling = useCallback((elem) => {
|
|
122
|
+
// @ts-ignore
|
|
123
|
+
_registerMethod(() => {
|
|
124
|
+
const parent = elementRef.current?.parentNode;
|
|
125
|
+
parent?.insertBefore(elem, elementRef.current);
|
|
126
|
+
});
|
|
127
|
+
}, [_registerMethod]);
|
|
128
|
+
// Initialization
|
|
129
|
+
useEffect(() => {
|
|
130
|
+
const element = elementRef.current;
|
|
131
|
+
if (!callback || !element)
|
|
132
|
+
return;
|
|
133
|
+
// Run callback
|
|
134
|
+
try {
|
|
135
|
+
callback(context, element);
|
|
136
|
+
}
|
|
137
|
+
catch (error) {
|
|
138
|
+
console.error(`Error in "${callback.name}" Slot callback`, error);
|
|
139
|
+
}
|
|
140
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
141
|
+
}, []);
|
|
142
|
+
// Lifecycles
|
|
143
|
+
useEffect(() => {
|
|
144
|
+
// Reset
|
|
145
|
+
_setProps({ children: [render?.(props)] });
|
|
146
|
+
// Run all registered methods
|
|
147
|
+
methodsRef.current.forEach((method) => {
|
|
148
|
+
method(context, state);
|
|
149
|
+
});
|
|
150
|
+
// Required to trigger re-render of render method
|
|
151
|
+
if (render?.name === 'render' && loadedRef.current === false) {
|
|
152
|
+
loadedRef.current = true;
|
|
153
|
+
}
|
|
154
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
155
|
+
}, [JSON.stringify(context), JSON.stringify(_state), loadedRef.current]);
|
|
156
|
+
return [elementRef, props];
|
|
157
|
+
}
|
|
158
|
+
export function Slot({ name, slot, context, children, render, ...props }) {
|
|
159
|
+
const [elementRef, slotProps] = useSlot(context, slot, render ?? (() => children));
|
|
160
|
+
useEffect(() => {
|
|
161
|
+
if (!name)
|
|
162
|
+
console.warn('Slot "name" is required');
|
|
163
|
+
}, [name]);
|
|
164
|
+
return (<div {...props} ref={elementRef} data-slot={name}>
|
|
165
|
+
{slotProps.children}
|
|
166
|
+
</div>);
|
|
167
|
+
}
|
|
168
|
+
// Debugger
|
|
169
|
+
// @ts-ignore
|
|
170
|
+
window.DROPINS = window.DROPINS || {};
|
|
171
|
+
// @ts-ignore
|
|
172
|
+
window.DROPINS.showSlots = async (state) => {
|
|
173
|
+
// cache state in session storage
|
|
174
|
+
window.sessionStorage.setItem('dropin-debugger--show-slots', state.toString());
|
|
175
|
+
document.body.classList.toggle('dropin-debugger--show-slots', state);
|
|
176
|
+
if (state) {
|
|
177
|
+
try {
|
|
178
|
+
await import('@adobe/elsie/components/UIProvider/debugger.css');
|
|
179
|
+
}
|
|
180
|
+
catch (error) { }
|
|
181
|
+
}
|
|
182
|
+
};
|
|
183
|
+
// @ts-ignore
|
|
184
|
+
window.DROPINS.showSlots(window.sessionStorage.getItem('dropin-debugger--show-slots') === 'true');
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slot.test.d.ts","sourceRoot":"","sources":["../../src/lib/slot.test.tsx"],"names":[],"mappings":""}
|