@dsn-starter-kit/components-react 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +181 -0
- package/dist/ActionGroup/ActionGroup.css +55 -0
- package/dist/ActionGroup/ActionGroup.d.ts +41 -0
- package/dist/ActionGroup/ActionGroup.d.ts.map +1 -0
- package/dist/ActionGroup/ActionGroup.js +36 -0
- package/dist/ActionGroup/ActionGroup.js.map +1 -0
- package/dist/ActionGroup/index.d.ts +3 -0
- package/dist/ActionGroup/index.d.ts.map +1 -0
- package/dist/ActionGroup/index.js +2 -0
- package/dist/ActionGroup/index.js.map +1 -0
- package/dist/Alert/Alert.css +145 -0
- package/dist/Alert/Alert.d.ts +69 -0
- package/dist/Alert/Alert.d.ts.map +1 -0
- package/dist/Alert/Alert.js +57 -0
- package/dist/Alert/Alert.js.map +1 -0
- package/dist/Alert/index.d.ts +3 -0
- package/dist/Alert/index.d.ts.map +1 -0
- package/dist/Alert/index.js +2 -0
- package/dist/Alert/index.js.map +1 -0
- package/dist/Backdrop/Backdrop.css +30 -0
- package/dist/Backdrop/Backdrop.d.ts +26 -0
- package/dist/Backdrop/Backdrop.d.ts.map +1 -0
- package/dist/Backdrop/Backdrop.js +23 -0
- package/dist/Backdrop/Backdrop.js.map +1 -0
- package/dist/Backdrop/index.d.ts +3 -0
- package/dist/Backdrop/index.d.ts.map +1 -0
- package/dist/Backdrop/index.js +2 -0
- package/dist/Backdrop/index.js.map +1 -0
- package/dist/Body/Body.css +14 -0
- package/dist/Body/Body.d.ts +27 -0
- package/dist/Body/Body.d.ts.map +1 -0
- package/dist/Body/Body.js +27 -0
- package/dist/Body/Body.js.map +1 -0
- package/dist/Body/index.d.ts +3 -0
- package/dist/Body/index.d.ts.map +1 -0
- package/dist/Body/index.js +2 -0
- package/dist/Body/index.js.map +1 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigation.css +216 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigation.d.ts +43 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigation.d.ts.map +1 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigation.js +42 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigation.js.map +1 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.d.ts +32 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.d.ts.map +1 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.js +20 -0
- package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.js.map +1 -0
- package/dist/BreadcrumbNavigation/index.d.ts +3 -0
- package/dist/BreadcrumbNavigation/index.d.ts.map +1 -0
- package/dist/BreadcrumbNavigation/index.js +3 -0
- package/dist/BreadcrumbNavigation/index.js.map +1 -0
- package/dist/BreakoutSection/BreakoutSection.css +19 -0
- package/dist/BreakoutSection/BreakoutSection.d.ts +30 -0
- package/dist/BreakoutSection/BreakoutSection.d.ts.map +1 -0
- package/dist/BreakoutSection/BreakoutSection.js +27 -0
- package/dist/BreakoutSection/BreakoutSection.js.map +1 -0
- package/dist/BreakoutSection/index.d.ts +3 -0
- package/dist/BreakoutSection/index.d.ts.map +1 -0
- package/dist/BreakoutSection/index.js +2 -0
- package/dist/BreakoutSection/index.js.map +1 -0
- package/dist/Button/Button.css +337 -0
- package/dist/Button/Button.d.ts +90 -0
- package/dist/Button/Button.d.ts.map +1 -0
- package/dist/Button/Button.js +53 -0
- package/dist/Button/Button.js.map +1 -0
- package/dist/Button/index.d.ts +3 -0
- package/dist/Button/index.d.ts.map +1 -0
- package/dist/Button/index.js +2 -0
- package/dist/Button/index.js.map +1 -0
- package/dist/ButtonLink/ButtonLink.css +29 -0
- package/dist/ButtonLink/ButtonLink.d.ts +92 -0
- package/dist/ButtonLink/ButtonLink.d.ts.map +1 -0
- package/dist/ButtonLink/ButtonLink.js +50 -0
- package/dist/ButtonLink/ButtonLink.js.map +1 -0
- package/dist/ButtonLink/index.d.ts +3 -0
- package/dist/ButtonLink/index.d.ts.map +1 -0
- package/dist/ButtonLink/index.js +2 -0
- package/dist/ButtonLink/index.js.map +1 -0
- package/dist/Card/Card.css +169 -0
- package/dist/Card/Card.d.ts +105 -0
- package/dist/Card/Card.d.ts.map +1 -0
- package/dist/Card/Card.js +80 -0
- package/dist/Card/Card.js.map +1 -0
- package/dist/Card/index.d.ts +3 -0
- package/dist/Card/index.d.ts.map +1 -0
- package/dist/Card/index.js +2 -0
- package/dist/Card/index.js.map +1 -0
- package/dist/Checkbox/Checkbox.css +239 -0
- package/dist/Checkbox/Checkbox.d.ts +18 -0
- package/dist/Checkbox/Checkbox.d.ts.map +1 -0
- package/dist/Checkbox/Checkbox.js +24 -0
- package/dist/Checkbox/Checkbox.js.map +1 -0
- package/dist/Checkbox/index.d.ts +3 -0
- package/dist/Checkbox/index.d.ts.map +1 -0
- package/dist/Checkbox/index.js +2 -0
- package/dist/Checkbox/index.js.map +1 -0
- package/dist/CheckboxGroup/CheckboxGroup.css +10 -0
- package/dist/CheckboxGroup/CheckboxGroup.d.ts +37 -0
- package/dist/CheckboxGroup/CheckboxGroup.d.ts.map +1 -0
- package/dist/CheckboxGroup/CheckboxGroup.js +37 -0
- package/dist/CheckboxGroup/CheckboxGroup.js.map +1 -0
- package/dist/CheckboxGroup/index.d.ts +3 -0
- package/dist/CheckboxGroup/index.d.ts.map +1 -0
- package/dist/CheckboxGroup/index.js +2 -0
- package/dist/CheckboxGroup/index.js.map +1 -0
- package/dist/CheckboxOption/CheckboxOption.css +17 -0
- package/dist/CheckboxOption/CheckboxOption.d.ts +14 -0
- package/dist/CheckboxOption/CheckboxOption.d.ts.map +1 -0
- package/dist/CheckboxOption/CheckboxOption.js +15 -0
- package/dist/CheckboxOption/CheckboxOption.js.map +1 -0
- package/dist/CheckboxOption/index.d.ts +3 -0
- package/dist/CheckboxOption/index.d.ts.map +1 -0
- package/dist/CheckboxOption/index.js +2 -0
- package/dist/CheckboxOption/index.js.map +1 -0
- package/dist/Container/Container.css +48 -0
- package/dist/Container/Container.d.ts +41 -0
- package/dist/Container/Container.d.ts.map +1 -0
- package/dist/Container/Container.js +33 -0
- package/dist/Container/Container.js.map +1 -0
- package/dist/Container/index.d.ts +3 -0
- package/dist/Container/index.d.ts.map +1 -0
- package/dist/Container/index.js +2 -0
- package/dist/Container/index.js.map +1 -0
- package/dist/DateInput/DateInput.css +37 -0
- package/dist/DateInput/DateInput.d.ts +37 -0
- package/dist/DateInput/DateInput.d.ts.map +1 -0
- package/dist/DateInput/DateInput.js +52 -0
- package/dist/DateInput/DateInput.js.map +1 -0
- package/dist/DateInput/index.d.ts +3 -0
- package/dist/DateInput/index.d.ts.map +1 -0
- package/dist/DateInput/index.js +2 -0
- package/dist/DateInput/index.js.map +1 -0
- package/dist/DateInputGroup/DateInputGroup.css +30 -0
- package/dist/DateInputGroup/DateInputGroup.d.ts +65 -0
- package/dist/DateInputGroup/DateInputGroup.d.ts.map +1 -0
- package/dist/DateInputGroup/DateInputGroup.js +53 -0
- package/dist/DateInputGroup/DateInputGroup.js.map +1 -0
- package/dist/DateInputGroup/index.d.ts +3 -0
- package/dist/DateInputGroup/index.d.ts.map +1 -0
- package/dist/DateInputGroup/index.js +2 -0
- package/dist/DateInputGroup/index.js.map +1 -0
- package/dist/Details/Details.css +134 -0
- package/dist/Details/Details.d.ts +46 -0
- package/dist/Details/Details.d.ts.map +1 -0
- package/dist/Details/Details.js +37 -0
- package/dist/Details/Details.js.map +1 -0
- package/dist/Details/index.d.ts +3 -0
- package/dist/Details/index.d.ts.map +1 -0
- package/dist/Details/index.js +2 -0
- package/dist/Details/index.js.map +1 -0
- package/dist/DotBadge/DotBadge.css +98 -0
- package/dist/DotBadge/DotBadge.d.ts +40 -0
- package/dist/DotBadge/DotBadge.d.ts.map +1 -0
- package/dist/DotBadge/DotBadge.js +33 -0
- package/dist/DotBadge/DotBadge.js.map +1 -0
- package/dist/DotBadge/index.d.ts +2 -0
- package/dist/DotBadge/index.d.ts.map +1 -0
- package/dist/DotBadge/index.js +2 -0
- package/dist/DotBadge/index.js.map +1 -0
- package/dist/Drawer/Drawer.css +258 -0
- package/dist/Drawer/Drawer.d.ts +109 -0
- package/dist/Drawer/Drawer.d.ts.map +1 -0
- package/dist/Drawer/Drawer.js +115 -0
- package/dist/Drawer/Drawer.js.map +1 -0
- package/dist/Drawer/index.d.ts +3 -0
- package/dist/Drawer/index.d.ts.map +1 -0
- package/dist/Drawer/index.js +2 -0
- package/dist/Drawer/index.js.map +1 -0
- package/dist/EmailInput/EmailInput.css +4 -0
- package/dist/EmailInput/EmailInput.d.ts +38 -0
- package/dist/EmailInput/EmailInput.d.ts.map +1 -0
- package/dist/EmailInput/EmailInput.js +27 -0
- package/dist/EmailInput/EmailInput.js.map +1 -0
- package/dist/EmailInput/index.d.ts +3 -0
- package/dist/EmailInput/index.d.ts.map +1 -0
- package/dist/EmailInput/index.js +2 -0
- package/dist/EmailInput/index.js.map +1 -0
- package/dist/File/File.css +206 -0
- package/dist/File/File.d.ts +116 -0
- package/dist/File/File.d.ts.map +1 -0
- package/dist/File/File.js +100 -0
- package/dist/File/File.js.map +1 -0
- package/dist/File/index.d.ts +3 -0
- package/dist/File/index.d.ts.map +1 -0
- package/dist/File/index.js +2 -0
- package/dist/File/index.js.map +1 -0
- package/dist/FileInput/FileInput.css +112 -0
- package/dist/FileInput/FileInput.d.ts +36 -0
- package/dist/FileInput/FileInput.d.ts.map +1 -0
- package/dist/FileInput/FileInput.js +31 -0
- package/dist/FileInput/FileInput.js.map +1 -0
- package/dist/FileInput/index.d.ts +3 -0
- package/dist/FileInput/index.d.ts.map +1 -0
- package/dist/FileInput/index.js +2 -0
- package/dist/FileInput/index.js.map +1 -0
- package/dist/FormField/FormField.css +16 -0
- package/dist/FormField/FormField.d.ts +85 -0
- package/dist/FormField/FormField.d.ts.map +1 -0
- package/dist/FormField/FormField.js +60 -0
- package/dist/FormField/FormField.js.map +1 -0
- package/dist/FormField/index.d.ts +3 -0
- package/dist/FormField/index.d.ts.map +1 -0
- package/dist/FormField/index.js +2 -0
- package/dist/FormField/index.js.map +1 -0
- package/dist/FormFieldDescription/FormFieldDescription.css +25 -0
- package/dist/FormFieldDescription/FormFieldDescription.d.ts +47 -0
- package/dist/FormFieldDescription/FormFieldDescription.d.ts.map +1 -0
- package/dist/FormFieldDescription/FormFieldDescription.js +37 -0
- package/dist/FormFieldDescription/FormFieldDescription.js.map +1 -0
- package/dist/FormFieldDescription/index.d.ts +3 -0
- package/dist/FormFieldDescription/index.d.ts.map +1 -0
- package/dist/FormFieldDescription/index.js +2 -0
- package/dist/FormFieldDescription/index.js.map +1 -0
- package/dist/FormFieldErrorMessage/FormFieldErrorMessage.css +38 -0
- package/dist/FormFieldErrorMessage/FormFieldErrorMessage.d.ts +40 -0
- package/dist/FormFieldErrorMessage/FormFieldErrorMessage.d.ts.map +1 -0
- package/dist/FormFieldErrorMessage/FormFieldErrorMessage.js +32 -0
- package/dist/FormFieldErrorMessage/FormFieldErrorMessage.js.map +1 -0
- package/dist/FormFieldErrorMessage/index.d.ts +3 -0
- package/dist/FormFieldErrorMessage/index.d.ts.map +1 -0
- package/dist/FormFieldErrorMessage/index.js +2 -0
- package/dist/FormFieldErrorMessage/index.js.map +1 -0
- package/dist/FormFieldLabel/FormFieldLabel.css +48 -0
- package/dist/FormFieldLabel/FormFieldLabel.d.ts +38 -0
- package/dist/FormFieldLabel/FormFieldLabel.d.ts.map +1 -0
- package/dist/FormFieldLabel/FormFieldLabel.js +30 -0
- package/dist/FormFieldLabel/FormFieldLabel.js.map +1 -0
- package/dist/FormFieldLabel/index.d.ts +3 -0
- package/dist/FormFieldLabel/index.d.ts.map +1 -0
- package/dist/FormFieldLabel/index.js +2 -0
- package/dist/FormFieldLabel/index.js.map +1 -0
- package/dist/FormFieldLegend/FormFieldLegend.css +7 -0
- package/dist/FormFieldLegend/FormFieldLegend.d.ts +39 -0
- package/dist/FormFieldLegend/FormFieldLegend.d.ts.map +1 -0
- package/dist/FormFieldLegend/FormFieldLegend.js +31 -0
- package/dist/FormFieldLegend/FormFieldLegend.js.map +1 -0
- package/dist/FormFieldLegend/index.d.ts +2 -0
- package/dist/FormFieldLegend/index.d.ts.map +1 -0
- package/dist/FormFieldLegend/index.js +2 -0
- package/dist/FormFieldLegend/index.js.map +1 -0
- package/dist/FormFieldStatus/FormFieldStatus.css +66 -0
- package/dist/FormFieldStatus/FormFieldStatus.d.ts +52 -0
- package/dist/FormFieldStatus/FormFieldStatus.d.ts.map +1 -0
- package/dist/FormFieldStatus/FormFieldStatus.js +44 -0
- package/dist/FormFieldStatus/FormFieldStatus.js.map +1 -0
- package/dist/FormFieldStatus/index.d.ts +3 -0
- package/dist/FormFieldStatus/index.d.ts.map +1 -0
- package/dist/FormFieldStatus/index.js +2 -0
- package/dist/FormFieldStatus/index.js.map +1 -0
- package/dist/FormFieldset/FormFieldset.css +24 -0
- package/dist/FormFieldset/FormFieldset.d.ts +83 -0
- package/dist/FormFieldset/FormFieldset.d.ts.map +1 -0
- package/dist/FormFieldset/FormFieldset.js +59 -0
- package/dist/FormFieldset/FormFieldset.js.map +1 -0
- package/dist/FormFieldset/index.d.ts +2 -0
- package/dist/FormFieldset/index.d.ts.map +1 -0
- package/dist/FormFieldset/index.js +2 -0
- package/dist/FormFieldset/index.js.map +1 -0
- package/dist/Grid/Grid.css +573 -0
- package/dist/Grid/Grid.d.ts +35 -0
- package/dist/Grid/Grid.d.ts.map +1 -0
- package/dist/Grid/Grid.js +29 -0
- package/dist/Grid/Grid.js.map +1 -0
- package/dist/Grid/GridItem.d.ts +84 -0
- package/dist/Grid/GridItem.d.ts.map +1 -0
- package/dist/Grid/GridItem.js +39 -0
- package/dist/Grid/GridItem.js.map +1 -0
- package/dist/Grid/index.d.ts +5 -0
- package/dist/Grid/index.d.ts.map +1 -0
- package/dist/Grid/index.js +3 -0
- package/dist/Grid/index.js.map +1 -0
- package/dist/Heading/Heading.css +81 -0
- package/dist/Heading/Heading.d.ts +38 -0
- package/dist/Heading/Heading.d.ts.map +1 -0
- package/dist/Heading/Heading.js +24 -0
- package/dist/Heading/Heading.js.map +1 -0
- package/dist/Heading/index.d.ts +3 -0
- package/dist/Heading/index.d.ts.map +1 -0
- package/dist/Heading/index.js +2 -0
- package/dist/Heading/index.js.map +1 -0
- package/dist/Hero/Hero.css +205 -0
- package/dist/Hero/Hero.d.ts +45 -0
- package/dist/Hero/Hero.d.ts.map +1 -0
- package/dist/Hero/Hero.js +33 -0
- package/dist/Hero/Hero.js.map +1 -0
- package/dist/Hero/index.d.ts +3 -0
- package/dist/Hero/index.d.ts.map +1 -0
- package/dist/Hero/index.js +2 -0
- package/dist/Hero/index.js.map +1 -0
- package/dist/Icon/Icon.css +57 -0
- package/dist/Icon/Icon.d.ts +48 -0
- package/dist/Icon/Icon.d.ts.map +1 -0
- package/dist/Icon/Icon.js +42 -0
- package/dist/Icon/Icon.js.map +1 -0
- package/dist/Icon/icon-registry.generated.d.ts +4 -0
- package/dist/Icon/icon-registry.generated.d.ts.map +1 -0
- package/dist/Icon/icon-registry.generated.js +105 -0
- package/dist/Icon/icon-registry.generated.js.map +1 -0
- package/dist/Icon/index.d.ts +3 -0
- package/dist/Icon/index.d.ts.map +1 -0
- package/dist/Icon/index.js +2 -0
- package/dist/Icon/index.js.map +1 -0
- package/dist/Image/Image.css +123 -0
- package/dist/Image/Image.d.ts +54 -0
- package/dist/Image/Image.d.ts.map +1 -0
- package/dist/Image/Image.js +53 -0
- package/dist/Image/Image.js.map +1 -0
- package/dist/Image/index.d.ts +3 -0
- package/dist/Image/index.d.ts.map +1 -0
- package/dist/Image/index.js +2 -0
- package/dist/Image/index.js.map +1 -0
- package/dist/Link/Link.css +113 -0
- package/dist/Link/Link.d.ts +80 -0
- package/dist/Link/Link.d.ts.map +1 -0
- package/dist/Link/Link.js +58 -0
- package/dist/Link/Link.js.map +1 -0
- package/dist/Link/index.d.ts +3 -0
- package/dist/Link/index.d.ts.map +1 -0
- package/dist/Link/index.js +2 -0
- package/dist/Link/index.js.map +1 -0
- package/dist/LinkButton/LinkButton.css +40 -0
- package/dist/LinkButton/LinkButton.d.ts +52 -0
- package/dist/LinkButton/LinkButton.d.ts.map +1 -0
- package/dist/LinkButton/LinkButton.js +34 -0
- package/dist/LinkButton/LinkButton.js.map +1 -0
- package/dist/LinkButton/index.d.ts +3 -0
- package/dist/LinkButton/index.d.ts.map +1 -0
- package/dist/LinkButton/index.js +2 -0
- package/dist/LinkButton/index.js.map +1 -0
- package/dist/Logo/Logo.css +33 -0
- package/dist/Logo/Logo.d.ts +33 -0
- package/dist/Logo/Logo.d.ts.map +1 -0
- package/dist/Logo/Logo.js +32 -0
- package/dist/Logo/Logo.js.map +1 -0
- package/dist/Logo/index.d.ts +2 -0
- package/dist/Logo/index.d.ts.map +1 -0
- package/dist/Logo/index.js +2 -0
- package/dist/Logo/index.js.map +1 -0
- package/dist/Menu/Menu.css +57 -0
- package/dist/Menu/Menu.d.ts +56 -0
- package/dist/Menu/Menu.d.ts.map +1 -0
- package/dist/Menu/Menu.js +38 -0
- package/dist/Menu/Menu.js.map +1 -0
- package/dist/Menu/index.d.ts +2 -0
- package/dist/Menu/index.d.ts.map +1 -0
- package/dist/Menu/index.js +2 -0
- package/dist/Menu/index.js.map +1 -0
- package/dist/MenuButton/MenuButton.css +106 -0
- package/dist/MenuButton/MenuButton.d.ts +54 -0
- package/dist/MenuButton/MenuButton.d.ts.map +1 -0
- package/dist/MenuButton/MenuButton.js +37 -0
- package/dist/MenuButton/MenuButton.js.map +1 -0
- package/dist/MenuButton/index.d.ts +2 -0
- package/dist/MenuButton/index.d.ts.map +1 -0
- package/dist/MenuButton/index.js +2 -0
- package/dist/MenuButton/index.js.map +1 -0
- package/dist/MenuLink/MenuLink.css +212 -0
- package/dist/MenuLink/MenuLink.d.ts +96 -0
- package/dist/MenuLink/MenuLink.d.ts.map +1 -0
- package/dist/MenuLink/MenuLink.js +50 -0
- package/dist/MenuLink/MenuLink.js.map +1 -0
- package/dist/MenuLink/index.d.ts +2 -0
- package/dist/MenuLink/index.d.ts.map +1 -0
- package/dist/MenuLink/index.js +2 -0
- package/dist/MenuLink/index.js.map +1 -0
- package/dist/ModalDialog/ModalDialog.css +199 -0
- package/dist/ModalDialog/ModalDialog.d.ts +95 -0
- package/dist/ModalDialog/ModalDialog.d.ts.map +1 -0
- package/dist/ModalDialog/ModalDialog.js +93 -0
- package/dist/ModalDialog/ModalDialog.js.map +1 -0
- package/dist/ModalDialog/index.d.ts +3 -0
- package/dist/ModalDialog/index.d.ts.map +1 -0
- package/dist/ModalDialog/index.js +2 -0
- package/dist/ModalDialog/index.js.map +1 -0
- package/dist/Note/Note.css +169 -0
- package/dist/Note/Note.d.ts +78 -0
- package/dist/Note/Note.d.ts.map +1 -0
- package/dist/Note/Note.js +68 -0
- package/dist/Note/Note.js.map +1 -0
- package/dist/Note/index.d.ts +3 -0
- package/dist/Note/index.d.ts.map +1 -0
- package/dist/Note/index.js +2 -0
- package/dist/Note/index.js.map +1 -0
- package/dist/NumberBadge/NumberBadge.css +83 -0
- package/dist/NumberBadge/NumberBadge.d.ts +42 -0
- package/dist/NumberBadge/NumberBadge.d.ts.map +1 -0
- package/dist/NumberBadge/NumberBadge.js +46 -0
- package/dist/NumberBadge/NumberBadge.js.map +1 -0
- package/dist/NumberBadge/index.d.ts +2 -0
- package/dist/NumberBadge/index.d.ts.map +1 -0
- package/dist/NumberBadge/index.js +2 -0
- package/dist/NumberBadge/index.js.map +1 -0
- package/dist/NumberInput/NumberInput.css +4 -0
- package/dist/NumberInput/NumberInput.d.ts +45 -0
- package/dist/NumberInput/NumberInput.d.ts.map +1 -0
- package/dist/NumberInput/NumberInput.js +27 -0
- package/dist/NumberInput/NumberInput.js.map +1 -0
- package/dist/NumberInput/index.d.ts +3 -0
- package/dist/NumberInput/index.d.ts.map +1 -0
- package/dist/NumberInput/index.js +2 -0
- package/dist/NumberInput/index.js.map +1 -0
- package/dist/OptionLabel/OptionLabel.css +18 -0
- package/dist/OptionLabel/OptionLabel.d.ts +13 -0
- package/dist/OptionLabel/OptionLabel.d.ts.map +1 -0
- package/dist/OptionLabel/OptionLabel.js +13 -0
- package/dist/OptionLabel/OptionLabel.js.map +1 -0
- package/dist/OptionLabel/index.d.ts +3 -0
- package/dist/OptionLabel/index.d.ts.map +1 -0
- package/dist/OptionLabel/index.js +2 -0
- package/dist/OptionLabel/index.js.map +1 -0
- package/dist/OrderedList/OrderedList.css +37 -0
- package/dist/OrderedList/OrderedList.d.ts +32 -0
- package/dist/OrderedList/OrderedList.d.ts.map +1 -0
- package/dist/OrderedList/OrderedList.js +28 -0
- package/dist/OrderedList/OrderedList.js.map +1 -0
- package/dist/OrderedList/index.d.ts +3 -0
- package/dist/OrderedList/index.d.ts.map +1 -0
- package/dist/OrderedList/index.js +2 -0
- package/dist/OrderedList/index.js.map +1 -0
- package/dist/PageBody/PageBody.css +69 -0
- package/dist/PageBody/PageBody.d.ts +33 -0
- package/dist/PageBody/PageBody.d.ts.map +1 -0
- package/dist/PageBody/PageBody.js +28 -0
- package/dist/PageBody/PageBody.js.map +1 -0
- package/dist/PageBody/index.d.ts +2 -0
- package/dist/PageBody/index.d.ts.map +1 -0
- package/dist/PageBody/index.js +2 -0
- package/dist/PageBody/index.js.map +1 -0
- package/dist/PageFooter/PageFooter.css +102 -0
- package/dist/PageFooter/PageFooter.d.ts +55 -0
- package/dist/PageFooter/PageFooter.d.ts.map +1 -0
- package/dist/PageFooter/PageFooter.js +45 -0
- package/dist/PageFooter/PageFooter.js.map +1 -0
- package/dist/PageFooter/index.d.ts +2 -0
- package/dist/PageFooter/index.d.ts.map +1 -0
- package/dist/PageFooter/index.js +2 -0
- package/dist/PageFooter/index.js.map +1 -0
- package/dist/PageHeader/PageHeader.css +517 -0
- package/dist/PageHeader/PageHeader.d.ts +190 -0
- package/dist/PageHeader/PageHeader.d.ts.map +1 -0
- package/dist/PageHeader/PageHeader.js +115 -0
- package/dist/PageHeader/PageHeader.js.map +1 -0
- package/dist/PageHeader/index.d.ts +2 -0
- package/dist/PageHeader/index.d.ts.map +1 -0
- package/dist/PageHeader/index.js +2 -0
- package/dist/PageHeader/index.js.map +1 -0
- package/dist/PageLayout/PageLayout.css +6 -0
- package/dist/PageLayout/PageLayout.d.ts +38 -0
- package/dist/PageLayout/PageLayout.d.ts.map +1 -0
- package/dist/PageLayout/PageLayout.js +33 -0
- package/dist/PageLayout/PageLayout.js.map +1 -0
- package/dist/PageLayout/index.d.ts +2 -0
- package/dist/PageLayout/index.d.ts.map +1 -0
- package/dist/PageLayout/index.js +2 -0
- package/dist/PageLayout/index.js.map +1 -0
- package/dist/Paragraph/Paragraph.css +38 -0
- package/dist/Paragraph/Paragraph.d.ts +35 -0
- package/dist/Paragraph/Paragraph.d.ts.map +1 -0
- package/dist/Paragraph/Paragraph.js +25 -0
- package/dist/Paragraph/Paragraph.js.map +1 -0
- package/dist/Paragraph/index.d.ts +3 -0
- package/dist/Paragraph/index.d.ts.map +1 -0
- package/dist/Paragraph/index.js +2 -0
- package/dist/Paragraph/index.js.map +1 -0
- package/dist/PasswordInput/PasswordInput.css +4 -0
- package/dist/PasswordInput/PasswordInput.d.ts +52 -0
- package/dist/PasswordInput/PasswordInput.d.ts.map +1 -0
- package/dist/PasswordInput/PasswordInput.js +32 -0
- package/dist/PasswordInput/PasswordInput.js.map +1 -0
- package/dist/PasswordInput/index.d.ts +3 -0
- package/dist/PasswordInput/index.d.ts.map +1 -0
- package/dist/PasswordInput/index.js +2 -0
- package/dist/PasswordInput/index.js.map +1 -0
- package/dist/Popover/Popover.css +233 -0
- package/dist/Popover/Popover.d.ts +117 -0
- package/dist/Popover/Popover.d.ts.map +1 -0
- package/dist/Popover/Popover.js +219 -0
- package/dist/Popover/Popover.js.map +1 -0
- package/dist/Popover/index.d.ts +3 -0
- package/dist/Popover/index.d.ts.map +1 -0
- package/dist/Popover/index.js +2 -0
- package/dist/Popover/index.js.map +1 -0
- package/dist/ProgressBar/ProgressBar.css +91 -0
- package/dist/ProgressBar/ProgressBar.d.ts +53 -0
- package/dist/ProgressBar/ProgressBar.d.ts.map +1 -0
- package/dist/ProgressBar/ProgressBar.js +36 -0
- package/dist/ProgressBar/ProgressBar.js.map +1 -0
- package/dist/ProgressBar/index.d.ts +2 -0
- package/dist/ProgressBar/index.d.ts.map +1 -0
- package/dist/ProgressBar/index.js +2 -0
- package/dist/ProgressBar/index.js.map +1 -0
- package/dist/Radio/Radio.css +169 -0
- package/dist/Radio/Radio.d.ts +14 -0
- package/dist/Radio/Radio.d.ts.map +1 -0
- package/dist/Radio/Radio.js +14 -0
- package/dist/Radio/Radio.js.map +1 -0
- package/dist/Radio/index.d.ts +3 -0
- package/dist/Radio/index.d.ts.map +1 -0
- package/dist/Radio/index.js +2 -0
- package/dist/Radio/index.js.map +1 -0
- package/dist/RadioGroup/RadioGroup.css +10 -0
- package/dist/RadioGroup/RadioGroup.d.ts +37 -0
- package/dist/RadioGroup/RadioGroup.d.ts.map +1 -0
- package/dist/RadioGroup/RadioGroup.js +37 -0
- package/dist/RadioGroup/RadioGroup.js.map +1 -0
- package/dist/RadioGroup/index.d.ts +3 -0
- package/dist/RadioGroup/index.d.ts.map +1 -0
- package/dist/RadioGroup/index.js +2 -0
- package/dist/RadioGroup/index.js.map +1 -0
- package/dist/RadioOption/RadioOption.css +17 -0
- package/dist/RadioOption/RadioOption.d.ts +14 -0
- package/dist/RadioOption/RadioOption.d.ts.map +1 -0
- package/dist/RadioOption/RadioOption.js +15 -0
- package/dist/RadioOption/RadioOption.js.map +1 -0
- package/dist/RadioOption/index.d.ts +3 -0
- package/dist/RadioOption/index.d.ts.map +1 -0
- package/dist/RadioOption/index.js +2 -0
- package/dist/RadioOption/index.js.map +1 -0
- package/dist/SearchInput/SearchInput.css +59 -0
- package/dist/SearchInput/SearchInput.d.ts +40 -0
- package/dist/SearchInput/SearchInput.d.ts.map +1 -0
- package/dist/SearchInput/SearchInput.js +31 -0
- package/dist/SearchInput/SearchInput.js.map +1 -0
- package/dist/SearchInput/index.d.ts +3 -0
- package/dist/SearchInput/index.d.ts.map +1 -0
- package/dist/SearchInput/index.js +2 -0
- package/dist/SearchInput/index.js.map +1 -0
- package/dist/Select/Select.css +86 -0
- package/dist/Select/Select.d.ts +52 -0
- package/dist/Select/Select.d.ts.map +1 -0
- package/dist/Select/Select.js +43 -0
- package/dist/Select/Select.js.map +1 -0
- package/dist/Select/index.d.ts +3 -0
- package/dist/Select/index.d.ts.map +1 -0
- package/dist/Select/index.js +2 -0
- package/dist/Select/index.js.map +1 -0
- package/dist/SkipLink/SkipLink.css +58 -0
- package/dist/SkipLink/SkipLink.d.ts +35 -0
- package/dist/SkipLink/SkipLink.d.ts.map +1 -0
- package/dist/SkipLink/SkipLink.js +23 -0
- package/dist/SkipLink/SkipLink.js.map +1 -0
- package/dist/SkipLink/index.d.ts +2 -0
- package/dist/SkipLink/index.d.ts.map +1 -0
- package/dist/SkipLink/index.js +2 -0
- package/dist/SkipLink/index.js.map +1 -0
- package/dist/Spinner/Spinner.css +101 -0
- package/dist/Spinner/Spinner.d.ts +43 -0
- package/dist/Spinner/Spinner.d.ts.map +1 -0
- package/dist/Spinner/Spinner.js +30 -0
- package/dist/Spinner/Spinner.js.map +1 -0
- package/dist/Spinner/index.d.ts +2 -0
- package/dist/Spinner/index.d.ts.map +1 -0
- package/dist/Spinner/index.js +2 -0
- package/dist/Spinner/index.js.map +1 -0
- package/dist/Stack/Stack.css +59 -0
- package/dist/Stack/Stack.d.ts +35 -0
- package/dist/Stack/Stack.d.ts.map +1 -0
- package/dist/Stack/Stack.js +29 -0
- package/dist/Stack/Stack.js.map +1 -0
- package/dist/Stack/index.d.ts +3 -0
- package/dist/Stack/index.d.ts.map +1 -0
- package/dist/Stack/index.js +2 -0
- package/dist/Stack/index.js.map +1 -0
- package/dist/StatusBadge/StatusBadge.css +87 -0
- package/dist/StatusBadge/StatusBadge.d.ts +50 -0
- package/dist/StatusBadge/StatusBadge.d.ts.map +1 -0
- package/dist/StatusBadge/StatusBadge.js +40 -0
- package/dist/StatusBadge/StatusBadge.js.map +1 -0
- package/dist/StatusBadge/index.d.ts +2 -0
- package/dist/StatusBadge/index.d.ts.map +1 -0
- package/dist/StatusBadge/index.js +2 -0
- package/dist/StatusBadge/index.js.map +1 -0
- package/dist/SummaryList/SummaryList.css +151 -0
- package/dist/SummaryList/SummaryList.d.ts +49 -0
- package/dist/SummaryList/SummaryList.d.ts.map +1 -0
- package/dist/SummaryList/SummaryList.js +31 -0
- package/dist/SummaryList/SummaryList.js.map +1 -0
- package/dist/SummaryList/index.d.ts +3 -0
- package/dist/SummaryList/index.d.ts.map +1 -0
- package/dist/SummaryList/index.js +2 -0
- package/dist/SummaryList/index.js.map +1 -0
- package/dist/Table/Table.css +243 -0
- package/dist/Table/Table.d.ts +61 -0
- package/dist/Table/Table.d.ts.map +1 -0
- package/dist/Table/Table.js +37 -0
- package/dist/Table/Table.js.map +1 -0
- package/dist/Table/index.d.ts +3 -0
- package/dist/Table/index.d.ts.map +1 -0
- package/dist/Table/index.js +2 -0
- package/dist/Table/index.js.map +1 -0
- package/dist/TelephoneInput/TelephoneInput.css +4 -0
- package/dist/TelephoneInput/TelephoneInput.d.ts +38 -0
- package/dist/TelephoneInput/TelephoneInput.d.ts.map +1 -0
- package/dist/TelephoneInput/TelephoneInput.js +27 -0
- package/dist/TelephoneInput/TelephoneInput.js.map +1 -0
- package/dist/TelephoneInput/index.d.ts +3 -0
- package/dist/TelephoneInput/index.d.ts.map +1 -0
- package/dist/TelephoneInput/index.js +2 -0
- package/dist/TelephoneInput/index.js.map +1 -0
- package/dist/TextArea/TextArea.css +126 -0
- package/dist/TextArea/TextArea.d.ts +44 -0
- package/dist/TextArea/TextArea.d.ts.map +1 -0
- package/dist/TextArea/TextArea.js +33 -0
- package/dist/TextArea/TextArea.js.map +1 -0
- package/dist/TextArea/index.d.ts +3 -0
- package/dist/TextArea/index.d.ts.map +1 -0
- package/dist/TextArea/index.js +2 -0
- package/dist/TextArea/index.js.map +1 -0
- package/dist/TextInput/TextInput.css +122 -0
- package/dist/TextInput/TextInput.d.ts +44 -0
- package/dist/TextInput/TextInput.d.ts.map +1 -0
- package/dist/TextInput/TextInput.js +33 -0
- package/dist/TextInput/TextInput.js.map +1 -0
- package/dist/TextInput/index.d.ts +3 -0
- package/dist/TextInput/index.d.ts.map +1 -0
- package/dist/TextInput/index.js +2 -0
- package/dist/TextInput/index.js.map +1 -0
- package/dist/TimeInput/TimeInput.css +37 -0
- package/dist/TimeInput/TimeInput.d.ts +37 -0
- package/dist/TimeInput/TimeInput.d.ts.map +1 -0
- package/dist/TimeInput/TimeInput.js +52 -0
- package/dist/TimeInput/TimeInput.js.map +1 -0
- package/dist/TimeInput/index.d.ts +3 -0
- package/dist/TimeInput/index.d.ts.map +1 -0
- package/dist/TimeInput/index.js +2 -0
- package/dist/TimeInput/index.js.map +1 -0
- package/dist/UnorderedList/UnorderedList.css +38 -0
- package/dist/UnorderedList/UnorderedList.d.ts +26 -0
- package/dist/UnorderedList/UnorderedList.d.ts.map +1 -0
- package/dist/UnorderedList/UnorderedList.js +22 -0
- package/dist/UnorderedList/UnorderedList.js.map +1 -0
- package/dist/UnorderedList/index.d.ts +3 -0
- package/dist/UnorderedList/index.d.ts.map +1 -0
- package/dist/UnorderedList/index.js +2 -0
- package/dist/UnorderedList/index.js.map +1 -0
- package/dist/index.css +7036 -0
- package/dist/index.d.ts +76 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +86 -0
- package/dist/index.js.map +1 -0
- package/package.json +57 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { classNames } from '@dsn-starter-kit/core';
|
|
4
|
+
import { iconMap } from './icon-registry.generated';
|
|
5
|
+
import './Icon.css';
|
|
6
|
+
export { iconMap };
|
|
7
|
+
/**
|
|
8
|
+
* Icon component using individual Tabler Icon SVG imports
|
|
9
|
+
* Only icons you use will be included in your bundle (tree-shaking)
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```tsx
|
|
13
|
+
* // Decorative icon (no label needed)
|
|
14
|
+
* <Icon name="check" size="md" />
|
|
15
|
+
*
|
|
16
|
+
* // Standalone icon (needs label)
|
|
17
|
+
* <Icon name="settings" size="lg" aria-label="Open settings" />
|
|
18
|
+
*
|
|
19
|
+
* // Icon with text (mark as decorative)
|
|
20
|
+
* <span>
|
|
21
|
+
* <Icon name="check" size="sm" />
|
|
22
|
+
* Task complete
|
|
23
|
+
* </span>
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export const Icon = React.forwardRef(({ name, size = 'md', className, 'aria-label': ariaLabel, ...props }, ref) => {
|
|
27
|
+
const IconComponent = iconMap[name];
|
|
28
|
+
if (!IconComponent) {
|
|
29
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
30
|
+
console.warn(`[DSN Icon] Icon "${name}" not found. Available icons: ${Object.keys(iconMap).join(', ')}`);
|
|
31
|
+
}
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
const classes = classNames('dsn-icon', size !== 'md' && `dsn-icon--${size}`, className);
|
|
35
|
+
// If no aria-label is provided, mark as decorative
|
|
36
|
+
const ariaProps = ariaLabel
|
|
37
|
+
? { 'aria-label': ariaLabel, role: 'img' }
|
|
38
|
+
: { 'aria-hidden': true };
|
|
39
|
+
return (_jsx(IconComponent, { ref: ref, className: classes, ...ariaProps, ...props }));
|
|
40
|
+
});
|
|
41
|
+
Icon.displayName = 'Icon';
|
|
42
|
+
//# sourceMappingURL=Icon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Icon.js","sourceRoot":"","sources":["../../src/Icon/Icon.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAGpD,OAAO,YAAY,CAAC;AAGpB,OAAO,EAAE,OAAO,EAAE,CAAC;AA8BnB;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,CAClC,CACE,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EACnE,GAAG,EACH,EAAE;IACF,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpC,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,EAAE,CAAC;YAC1C,OAAO,CAAC,IAAI,CACV,oBAAoB,IAAI,iCAAiC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAC3F,CAAC;QACJ,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,OAAO,GAAG,UAAU,CACxB,UAAU,EACV,IAAI,KAAK,IAAI,IAAI,aAAa,IAAI,EAAE,EACpC,SAAS,CACV,CAAC;IAEF,mDAAmD;IACnD,MAAM,SAAS,GAAG,SAAS;QACzB,CAAC,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE;QAC1C,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;IAE5B,OAAO,CACL,KAAC,aAAa,IAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,OAAO,KAAM,SAAS,KAAM,KAAK,GAAI,CAC1E,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type IconName = 'alert-triangle' | 'archive' | 'arrow-down' | 'arrow-left' | 'arrow-narrow-down' | 'arrow-narrow-up' | 'arrow-right' | 'arrow-up' | 'arrows-sort' | 'bell' | 'calendar-event' | 'check' | 'chevron-down' | 'chevron-left' | 'chevron-right' | 'chevron-up' | 'circle-check' | 'clock' | 'dots-vertical' | 'download' | 'edit' | 'exclamation-circle' | 'external-link' | 'eye' | 'file-description' | 'folder' | 'heart-filled' | 'heart' | 'home' | 'info-circle' | 'loader' | 'mail' | 'menu' | 'message-circle' | 'minus' | 'paperclip' | 'pencil' | 'photo' | 'plus' | 'printer' | 'search' | 'selector' | 'settings' | 'sort-ascending' | 'sort-descending' | 'star-filled' | 'star' | 'trash' | 'upload' | 'user' | 'x';
|
|
3
|
+
export declare const iconMap: Record<IconName, React.FC<React.SVGProps<SVGSVGElement>>>;
|
|
4
|
+
//# sourceMappingURL=icon-registry.generated.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"icon-registry.generated.d.ts","sourceRoot":"","sources":["../../src/Icon/icon-registry.generated.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAsD1B,MAAM,MAAM,QAAQ,GAChB,gBAAgB,GAChB,SAAS,GACT,YAAY,GACZ,YAAY,GACZ,mBAAmB,GACnB,iBAAiB,GACjB,aAAa,GACb,UAAU,GACV,aAAa,GACb,MAAM,GACN,gBAAgB,GAChB,OAAO,GACP,cAAc,GACd,cAAc,GACd,eAAe,GACf,YAAY,GACZ,cAAc,GACd,OAAO,GACP,eAAe,GACf,UAAU,GACV,MAAM,GACN,oBAAoB,GACpB,eAAe,GACf,KAAK,GACL,kBAAkB,GAClB,QAAQ,GACR,cAAc,GACd,OAAO,GACP,MAAM,GACN,aAAa,GACb,QAAQ,GACR,MAAM,GACN,MAAM,GACN,gBAAgB,GAChB,OAAO,GACP,WAAW,GACX,QAAQ,GACR,OAAO,GACP,MAAM,GACN,SAAS,GACT,QAAQ,GACR,UAAU,GACV,UAAU,GACV,gBAAgB,GAChB,iBAAiB,GACjB,aAAa,GACb,MAAM,GACN,OAAO,GACP,QAAQ,GACR,MAAM,GACN,GAAG,CAAC;AAER,eAAO,MAAM,OAAO,EAAE,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAoD7E,CAAC"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import AlertTriangleIcon from '../../../components-html/assets/icons/alert-triangle.svg?react';
|
|
2
|
+
import ArchiveIcon from '../../../components-html/assets/icons/archive.svg?react';
|
|
3
|
+
import ArrowDownIcon from '../../../components-html/assets/icons/arrow-down.svg?react';
|
|
4
|
+
import ArrowLeftIcon from '../../../components-html/assets/icons/arrow-left.svg?react';
|
|
5
|
+
import ArrowNarrowDownIcon from '../../../components-html/assets/icons/arrow-narrow-down.svg?react';
|
|
6
|
+
import ArrowNarrowUpIcon from '../../../components-html/assets/icons/arrow-narrow-up.svg?react';
|
|
7
|
+
import ArrowRightIcon from '../../../components-html/assets/icons/arrow-right.svg?react';
|
|
8
|
+
import ArrowUpIcon from '../../../components-html/assets/icons/arrow-up.svg?react';
|
|
9
|
+
import ArrowsSortIcon from '../../../components-html/assets/icons/arrows-sort.svg?react';
|
|
10
|
+
import BellIcon from '../../../components-html/assets/icons/bell.svg?react';
|
|
11
|
+
import CalendarEventIcon from '../../../components-html/assets/icons/calendar-event.svg?react';
|
|
12
|
+
import CheckIcon from '../../../components-html/assets/icons/check.svg?react';
|
|
13
|
+
import ChevronDownIcon from '../../../components-html/assets/icons/chevron-down.svg?react';
|
|
14
|
+
import ChevronLeftIcon from '../../../components-html/assets/icons/chevron-left.svg?react';
|
|
15
|
+
import ChevronRightIcon from '../../../components-html/assets/icons/chevron-right.svg?react';
|
|
16
|
+
import ChevronUpIcon from '../../../components-html/assets/icons/chevron-up.svg?react';
|
|
17
|
+
import CircleCheckIcon from '../../../components-html/assets/icons/circle-check.svg?react';
|
|
18
|
+
import ClockIcon from '../../../components-html/assets/icons/clock.svg?react';
|
|
19
|
+
import DotsVerticalIcon from '../../../components-html/assets/icons/dots-vertical.svg?react';
|
|
20
|
+
import DownloadIcon from '../../../components-html/assets/icons/download.svg?react';
|
|
21
|
+
import EditIcon from '../../../components-html/assets/icons/edit.svg?react';
|
|
22
|
+
import ExclamationCircleIcon from '../../../components-html/assets/icons/exclamation-circle.svg?react';
|
|
23
|
+
import ExternalLinkIcon from '../../../components-html/assets/icons/external-link.svg?react';
|
|
24
|
+
import EyeIcon from '../../../components-html/assets/icons/eye.svg?react';
|
|
25
|
+
import FileDescriptionIcon from '../../../components-html/assets/icons/file-description.svg?react';
|
|
26
|
+
import FolderIcon from '../../../components-html/assets/icons/folder.svg?react';
|
|
27
|
+
import HeartFilledIcon from '../../../components-html/assets/icons/heart-filled.svg?react';
|
|
28
|
+
import HeartIcon from '../../../components-html/assets/icons/heart.svg?react';
|
|
29
|
+
import HomeIcon from '../../../components-html/assets/icons/home.svg?react';
|
|
30
|
+
import InfoCircleIcon from '../../../components-html/assets/icons/info-circle.svg?react';
|
|
31
|
+
import LoaderIcon from '../../../components-html/assets/icons/loader.svg?react';
|
|
32
|
+
import MailIcon from '../../../components-html/assets/icons/mail.svg?react';
|
|
33
|
+
import MenuIcon from '../../../components-html/assets/icons/menu.svg?react';
|
|
34
|
+
import MessageCircleIcon from '../../../components-html/assets/icons/message-circle.svg?react';
|
|
35
|
+
import MinusIcon from '../../../components-html/assets/icons/minus.svg?react';
|
|
36
|
+
import PaperclipIcon from '../../../components-html/assets/icons/paperclip.svg?react';
|
|
37
|
+
import PencilIcon from '../../../components-html/assets/icons/pencil.svg?react';
|
|
38
|
+
import PhotoIcon from '../../../components-html/assets/icons/photo.svg?react';
|
|
39
|
+
import PlusIcon from '../../../components-html/assets/icons/plus.svg?react';
|
|
40
|
+
import PrinterIcon from '../../../components-html/assets/icons/printer.svg?react';
|
|
41
|
+
import SearchIcon from '../../../components-html/assets/icons/search.svg?react';
|
|
42
|
+
import SelectorIcon from '../../../components-html/assets/icons/selector.svg?react';
|
|
43
|
+
import SettingsIcon from '../../../components-html/assets/icons/settings.svg?react';
|
|
44
|
+
import SortAscendingIcon from '../../../components-html/assets/icons/sort-ascending.svg?react';
|
|
45
|
+
import SortDescendingIcon from '../../../components-html/assets/icons/sort-descending.svg?react';
|
|
46
|
+
import StarFilledIcon from '../../../components-html/assets/icons/star-filled.svg?react';
|
|
47
|
+
import StarIcon from '../../../components-html/assets/icons/star.svg?react';
|
|
48
|
+
import TrashIcon from '../../../components-html/assets/icons/trash.svg?react';
|
|
49
|
+
import UploadIcon from '../../../components-html/assets/icons/upload.svg?react';
|
|
50
|
+
import UserIcon from '../../../components-html/assets/icons/user.svg?react';
|
|
51
|
+
import XIcon from '../../../components-html/assets/icons/x.svg?react';
|
|
52
|
+
export const iconMap = {
|
|
53
|
+
'alert-triangle': AlertTriangleIcon,
|
|
54
|
+
'archive': ArchiveIcon,
|
|
55
|
+
'arrow-down': ArrowDownIcon,
|
|
56
|
+
'arrow-left': ArrowLeftIcon,
|
|
57
|
+
'arrow-narrow-down': ArrowNarrowDownIcon,
|
|
58
|
+
'arrow-narrow-up': ArrowNarrowUpIcon,
|
|
59
|
+
'arrow-right': ArrowRightIcon,
|
|
60
|
+
'arrow-up': ArrowUpIcon,
|
|
61
|
+
'arrows-sort': ArrowsSortIcon,
|
|
62
|
+
'bell': BellIcon,
|
|
63
|
+
'calendar-event': CalendarEventIcon,
|
|
64
|
+
'check': CheckIcon,
|
|
65
|
+
'chevron-down': ChevronDownIcon,
|
|
66
|
+
'chevron-left': ChevronLeftIcon,
|
|
67
|
+
'chevron-right': ChevronRightIcon,
|
|
68
|
+
'chevron-up': ChevronUpIcon,
|
|
69
|
+
'circle-check': CircleCheckIcon,
|
|
70
|
+
'clock': ClockIcon,
|
|
71
|
+
'dots-vertical': DotsVerticalIcon,
|
|
72
|
+
'download': DownloadIcon,
|
|
73
|
+
'edit': EditIcon,
|
|
74
|
+
'exclamation-circle': ExclamationCircleIcon,
|
|
75
|
+
'external-link': ExternalLinkIcon,
|
|
76
|
+
'eye': EyeIcon,
|
|
77
|
+
'file-description': FileDescriptionIcon,
|
|
78
|
+
'folder': FolderIcon,
|
|
79
|
+
'heart-filled': HeartFilledIcon,
|
|
80
|
+
'heart': HeartIcon,
|
|
81
|
+
'home': HomeIcon,
|
|
82
|
+
'info-circle': InfoCircleIcon,
|
|
83
|
+
'loader': LoaderIcon,
|
|
84
|
+
'mail': MailIcon,
|
|
85
|
+
'menu': MenuIcon,
|
|
86
|
+
'message-circle': MessageCircleIcon,
|
|
87
|
+
'minus': MinusIcon,
|
|
88
|
+
'paperclip': PaperclipIcon,
|
|
89
|
+
'pencil': PencilIcon,
|
|
90
|
+
'photo': PhotoIcon,
|
|
91
|
+
'plus': PlusIcon,
|
|
92
|
+
'printer': PrinterIcon,
|
|
93
|
+
'search': SearchIcon,
|
|
94
|
+
'selector': SelectorIcon,
|
|
95
|
+
'settings': SettingsIcon,
|
|
96
|
+
'sort-ascending': SortAscendingIcon,
|
|
97
|
+
'sort-descending': SortDescendingIcon,
|
|
98
|
+
'star-filled': StarFilledIcon,
|
|
99
|
+
'star': StarIcon,
|
|
100
|
+
'trash': TrashIcon,
|
|
101
|
+
'upload': UploadIcon,
|
|
102
|
+
'user': UserIcon,
|
|
103
|
+
'x': XIcon,
|
|
104
|
+
};
|
|
105
|
+
//# sourceMappingURL=icon-registry.generated.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"icon-registry.generated.js","sourceRoot":"","sources":["../../src/Icon/icon-registry.generated.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Icon/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AACvC,YAAY,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Icon/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Image component styles for React
|
|
3
|
+
* Re-exports the base Image styles from components-html
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Image Component
|
|
8
|
+
* Performante, toegankelijke wrapper rond het native <img> element.
|
|
9
|
+
* Ondersteunt vaste beeldverhoudingen, lazy loading en optioneel bijschrift.
|
|
10
|
+
*
|
|
11
|
+
* Usage:
|
|
12
|
+
* <!-- Basis -->
|
|
13
|
+
* <figure class="dsn-image">
|
|
14
|
+
* <img
|
|
15
|
+
* class="dsn-image__img"
|
|
16
|
+
* src="afbeelding.jpg"
|
|
17
|
+
* alt="Beschrijving van de afbeelding"
|
|
18
|
+
* width="800"
|
|
19
|
+
* height="600"
|
|
20
|
+
* loading="lazy"
|
|
21
|
+
* decoding="async"
|
|
22
|
+
* />
|
|
23
|
+
* </figure>
|
|
24
|
+
*
|
|
25
|
+
* <!-- Met vaste beeldverhouding -->
|
|
26
|
+
* <figure class="dsn-image dsn-image--ratio-16-9">
|
|
27
|
+
* <img
|
|
28
|
+
* class="dsn-image__img"
|
|
29
|
+
* src="hero.jpg"
|
|
30
|
+
* alt="Beschrijving"
|
|
31
|
+
* width="1600"
|
|
32
|
+
* height="900"
|
|
33
|
+
* loading="lazy"
|
|
34
|
+
* decoding="async"
|
|
35
|
+
* />
|
|
36
|
+
* </figure>
|
|
37
|
+
*
|
|
38
|
+
* <!-- Met bijschrift -->
|
|
39
|
+
* <figure class="dsn-image">
|
|
40
|
+
* <img
|
|
41
|
+
* class="dsn-image__img"
|
|
42
|
+
* src="foto.jpg"
|
|
43
|
+
* alt="Beschrijving van de foto"
|
|
44
|
+
* width="800"
|
|
45
|
+
* height="600"
|
|
46
|
+
* loading="lazy"
|
|
47
|
+
* decoding="async"
|
|
48
|
+
* />
|
|
49
|
+
* <figcaption class="dsn-image__caption">Bijschrift bij de afbeelding</figcaption>
|
|
50
|
+
* </figure>
|
|
51
|
+
*
|
|
52
|
+
* <!-- Decoratief (aria-hidden op figure) -->
|
|
53
|
+
* <figure class="dsn-image" aria-hidden="true">
|
|
54
|
+
* <img
|
|
55
|
+
* class="dsn-image__img"
|
|
56
|
+
* src="decoratief.jpg"
|
|
57
|
+
* alt=""
|
|
58
|
+
* width="800"
|
|
59
|
+
* height="600"
|
|
60
|
+
* loading="lazy"
|
|
61
|
+
* decoding="async"
|
|
62
|
+
* />
|
|
63
|
+
* </figure>
|
|
64
|
+
*/
|
|
65
|
+
|
|
66
|
+
/* ===========================
|
|
67
|
+
Root container
|
|
68
|
+
=========================== */
|
|
69
|
+
.dsn-image {
|
|
70
|
+
display: block;
|
|
71
|
+
margin: 0;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/* ===========================
|
|
75
|
+
Image element
|
|
76
|
+
=========================== */
|
|
77
|
+
.dsn-image__img {
|
|
78
|
+
display: block;
|
|
79
|
+
width: 100%;
|
|
80
|
+
height: auto;
|
|
81
|
+
object-fit: cover;
|
|
82
|
+
border-radius: var(--dsn-image-border-radius);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/* ===========================
|
|
86
|
+
Aspect ratio modifiers
|
|
87
|
+
Aspect-ratio forceert de weergaveverhouding;
|
|
88
|
+
object-fit: cover snijdt de rest bij.
|
|
89
|
+
=========================== */
|
|
90
|
+
.dsn-image--ratio-16-9 .dsn-image__img {
|
|
91
|
+
aspect-ratio: 16 / 9;
|
|
92
|
+
height: 100%;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
.dsn-image--ratio-4-3 .dsn-image__img {
|
|
96
|
+
aspect-ratio: 4 / 3;
|
|
97
|
+
height: 100%;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
.dsn-image--ratio-1-1 .dsn-image__img {
|
|
101
|
+
aspect-ratio: 1 / 1;
|
|
102
|
+
height: 100%;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/* ===========================
|
|
106
|
+
Object-fit: contain modifier
|
|
107
|
+
Toont de volledige afbeelding zonder bijsnijden.
|
|
108
|
+
=========================== */
|
|
109
|
+
.dsn-image--object-fit-contain .dsn-image__img {
|
|
110
|
+
object-fit: contain;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
/* ===========================
|
|
114
|
+
Caption
|
|
115
|
+
=========================== */
|
|
116
|
+
.dsn-image__caption {
|
|
117
|
+
display: block;
|
|
118
|
+
margin-block-start: var(--dsn-image-caption-margin-block-start);
|
|
119
|
+
color: var(--dsn-image-caption-color);
|
|
120
|
+
font-size: var(--dsn-image-caption-font-size);
|
|
121
|
+
line-height: var(--dsn-image-caption-line-height);
|
|
122
|
+
}
|
|
123
|
+
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './Image.css';
|
|
3
|
+
export interface ImageProps extends React.HTMLAttributes<HTMLElement> {
|
|
4
|
+
/** Verplicht. URL van de afbeelding */
|
|
5
|
+
src: string;
|
|
6
|
+
/** Verplicht. Alternatieve tekst. Lege string (`""`) voor decoratieve afbeeldingen — activeert automatisch `aria-hidden="true"` op de figure */
|
|
7
|
+
alt: string;
|
|
8
|
+
/** Verplicht. Intrinsieke breedte in pixels (voorkomt CLS) */
|
|
9
|
+
width: number;
|
|
10
|
+
/** Verplicht. Intrinsieke hoogte in pixels (voorkomt CLS) */
|
|
11
|
+
height: number;
|
|
12
|
+
/** Forceert beeldverhouding via CSS `aspect-ratio` + `object-fit: cover` */
|
|
13
|
+
ratio?: '16:9' | '4:3' | '1:1';
|
|
14
|
+
/** Hoe de afbeelding het ratio-kader vult. @default 'cover' */
|
|
15
|
+
objectFit?: 'cover' | 'contain';
|
|
16
|
+
/**
|
|
17
|
+
* LCP-modus: `loading="eager"` + `fetchpriority="high"`.
|
|
18
|
+
* Gebruik maximaal één keer per pagina voor de primaire LCP-afbeelding.
|
|
19
|
+
* @default false
|
|
20
|
+
*/
|
|
21
|
+
priority?: boolean;
|
|
22
|
+
/** Optioneel bijschrift, rendert als `<figcaption>` */
|
|
23
|
+
caption?: React.ReactNode;
|
|
24
|
+
/** Pass-through naar native `srcset` attribuut */
|
|
25
|
+
srcSet?: string;
|
|
26
|
+
/** Pass-through naar native `sizes` attribuut */
|
|
27
|
+
sizes?: string;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Image component
|
|
31
|
+
* Performante, toegankelijke wrapper rond het native `<img>` element.
|
|
32
|
+
* Biedt ingebakken lazy loading, expliciete ondersteuning voor LCP/hero-afbeeldingen
|
|
33
|
+
* via een `priority` prop, en vaste beeldverhoudingen via de CSS `aspect-ratio` property.
|
|
34
|
+
*
|
|
35
|
+
* @example
|
|
36
|
+
* ```tsx
|
|
37
|
+
* // Basis
|
|
38
|
+
* <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} />
|
|
39
|
+
*
|
|
40
|
+
* // Met vaste beeldverhouding
|
|
41
|
+
* <Image src="/hero.jpg" alt="Hero" width={1600} height={900} ratio="16:9" />
|
|
42
|
+
*
|
|
43
|
+
* // LCP / hero-afbeelding — max. één keer per pagina
|
|
44
|
+
* <Image src="/hero.jpg" alt="Pagina hero" width={1600} height={900} ratio="16:9" priority />
|
|
45
|
+
*
|
|
46
|
+
* // Met bijschrift
|
|
47
|
+
* <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} caption="Bijschrift" />
|
|
48
|
+
*
|
|
49
|
+
* // Decoratief — alt="" activeert automatisch aria-hidden="true" op de figure
|
|
50
|
+
* <Image src="/decoratief.jpg" alt="" width={800} height={600} />
|
|
51
|
+
* ```
|
|
52
|
+
*/
|
|
53
|
+
export declare const Image: React.ForwardRefExoticComponent<ImageProps & React.RefAttributes<HTMLElement>>;
|
|
54
|
+
//# sourceMappingURL=Image.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Image.d.ts","sourceRoot":"","sources":["../../src/Image/Image.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,aAAa,CAAC;AAQrB,MAAM,WAAW,UAAW,SAAQ,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC;IACnE,uCAAuC;IACvC,GAAG,EAAE,MAAM,CAAC;IAEZ,gJAAgJ;IAChJ,GAAG,EAAE,MAAM,CAAC;IAEZ,8DAA8D;IAC9D,KAAK,EAAE,MAAM,CAAC;IAEd,6DAA6D;IAC7D,MAAM,EAAE,MAAM,CAAC;IAEf,4EAA4E;IAC5E,KAAK,CAAC,EAAE,MAAM,GAAG,KAAK,GAAG,KAAK,CAAC;IAE/B,+DAA+D;IAC/D,SAAS,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAEhC;;;;OAIG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB,uDAAuD;IACvD,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE1B,kDAAkD;IAClD,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,iDAAiD;IACjD,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAQD;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,eAAO,MAAM,KAAK,gFAuDjB,CAAC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { classNames } from '@dsn-starter-kit/core';
|
|
4
|
+
import './Image.css';
|
|
5
|
+
const ratioClassMap = {
|
|
6
|
+
'16:9': 'dsn-image--ratio-16-9',
|
|
7
|
+
'4:3': 'dsn-image--ratio-4-3',
|
|
8
|
+
'1:1': 'dsn-image--ratio-1-1',
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* Image component
|
|
12
|
+
* Performante, toegankelijke wrapper rond het native `<img>` element.
|
|
13
|
+
* Biedt ingebakken lazy loading, expliciete ondersteuning voor LCP/hero-afbeeldingen
|
|
14
|
+
* via een `priority` prop, en vaste beeldverhoudingen via de CSS `aspect-ratio` property.
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```tsx
|
|
18
|
+
* // Basis
|
|
19
|
+
* <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} />
|
|
20
|
+
*
|
|
21
|
+
* // Met vaste beeldverhouding
|
|
22
|
+
* <Image src="/hero.jpg" alt="Hero" width={1600} height={900} ratio="16:9" />
|
|
23
|
+
*
|
|
24
|
+
* // LCP / hero-afbeelding — max. één keer per pagina
|
|
25
|
+
* <Image src="/hero.jpg" alt="Pagina hero" width={1600} height={900} ratio="16:9" priority />
|
|
26
|
+
*
|
|
27
|
+
* // Met bijschrift
|
|
28
|
+
* <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} caption="Bijschrift" />
|
|
29
|
+
*
|
|
30
|
+
* // Decoratief — alt="" activeert automatisch aria-hidden="true" op de figure
|
|
31
|
+
* <Image src="/decoratief.jpg" alt="" width={800} height={600} />
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
export const Image = React.forwardRef(({ className, src, alt, width, height, ratio, objectFit = 'cover', priority = false, caption, srcSet, sizes, ...props }, ref) => {
|
|
35
|
+
const isDecorative = alt === '';
|
|
36
|
+
const figureClasses = classNames('dsn-image', ratio && ratioClassMap[ratio], objectFit === 'contain' && 'dsn-image--object-fit-contain', className);
|
|
37
|
+
const imgProps = {
|
|
38
|
+
className: 'dsn-image__img',
|
|
39
|
+
src,
|
|
40
|
+
alt,
|
|
41
|
+
width,
|
|
42
|
+
height,
|
|
43
|
+
decoding: 'async',
|
|
44
|
+
...(priority
|
|
45
|
+
? { loading: 'eager', fetchpriority: 'high' }
|
|
46
|
+
: { loading: 'lazy' }),
|
|
47
|
+
...(srcSet && { srcSet }),
|
|
48
|
+
...(sizes && { sizes }),
|
|
49
|
+
};
|
|
50
|
+
return (_jsxs("figure", { ref: ref, className: figureClasses, ...(isDecorative && { 'aria-hidden': true }), ...props, children: [_jsx("img", { ...imgProps }), caption && (_jsx("figcaption", { className: "dsn-image__caption", children: caption }))] }));
|
|
51
|
+
});
|
|
52
|
+
Image.displayName = 'Image';
|
|
53
|
+
//# sourceMappingURL=Image.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Image.js","sourceRoot":"","sources":["../../src/Image/Image.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,aAAa,CAAC;AA4CrB,MAAM,aAAa,GAAqD;IACtE,MAAM,EAAE,uBAAuB;IAC/B,KAAK,EAAE,sBAAsB;IAC7B,KAAK,EAAE,sBAAsB;CAC9B,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CACnC,CACE,EACE,SAAS,EACT,GAAG,EACH,GAAG,EACH,KAAK,EACL,MAAM,EACN,KAAK,EACL,SAAS,GAAG,OAAO,EACnB,QAAQ,GAAG,KAAK,EAChB,OAAO,EACP,MAAM,EACN,KAAK,EACL,GAAG,KAAK,EACT,EACD,GAAG,EACH,EAAE;IACF,MAAM,YAAY,GAAG,GAAG,KAAK,EAAE,CAAC;IAEhC,MAAM,aAAa,GAAG,UAAU,CAC9B,WAAW,EACX,KAAK,IAAI,aAAa,CAAC,KAAK,CAAC,EAC7B,SAAS,KAAK,SAAS,IAAI,+BAA+B,EAC1D,SAAS,CACV,CAAC;IAEF,MAAM,QAAQ,GAAa;QACzB,SAAS,EAAE,gBAAgB;QAC3B,GAAG;QACH,GAAG;QACH,KAAK;QACL,MAAM;QACN,QAAQ,EAAE,OAAO;QACjB,GAAG,CAAC,QAAQ;YACV,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE;YAC7C,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;QACxB,GAAG,CAAC,MAAM,IAAI,EAAE,MAAM,EAAE,CAAC;QACzB,GAAG,CAAC,KAAK,IAAI,EAAE,KAAK,EAAE,CAAC;KACxB,CAAC;IAEF,OAAO,CACL,kBACE,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,aAAa,KACpB,CAAC,YAAY,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,KACzC,KAAK,aAET,iBAAS,QAAQ,GAAI,EACpB,OAAO,IAAI,CACV,qBAAY,SAAS,EAAC,oBAAoB,YAAE,OAAO,GAAc,CAClE,IACM,CACV,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,KAAK,CAAC,WAAW,GAAG,OAAO,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Image/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Image/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Link Component Styles for React
|
|
3
|
+
* Re-exports the base Link styles from components-html
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Link Component
|
|
8
|
+
* Uses component tokens for consistent styling
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
.dsn-link {
|
|
12
|
+
/* Layout */
|
|
13
|
+
display: inline-flex;
|
|
14
|
+
align-self: flex-start;
|
|
15
|
+
align-items: center;
|
|
16
|
+
gap: var(--dsn-link-gap);
|
|
17
|
+
position: relative; /* Ankerpunt voor DotBadge */
|
|
18
|
+
|
|
19
|
+
/* Typography */
|
|
20
|
+
color: var(--dsn-link-color);
|
|
21
|
+
text-decoration-line: var(--dsn-link-text-decoration-line);
|
|
22
|
+
text-decoration-color: var(--dsn-link-text-decoration-color);
|
|
23
|
+
text-decoration-thickness: var(--dsn-link-text-decoration-thickness);
|
|
24
|
+
text-underline-offset: var(--dsn-link-text-underline-offset);
|
|
25
|
+
font: inherit;
|
|
26
|
+
|
|
27
|
+
/* Interaction */
|
|
28
|
+
cursor: pointer;
|
|
29
|
+
transition:
|
|
30
|
+
color var(--dsn-transition-duration-normal)
|
|
31
|
+
var(--dsn-transition-easing-default),
|
|
32
|
+
text-decoration-color var(--dsn-transition-duration-normal)
|
|
33
|
+
var(--dsn-transition-easing-default);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/* Icon sizing */
|
|
37
|
+
.dsn-link > .dsn-icon {
|
|
38
|
+
width: var(--dsn-link-icon-size);
|
|
39
|
+
height: var(--dsn-link-icon-size);
|
|
40
|
+
flex-shrink: 0;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/* Size Variants */
|
|
44
|
+
.dsn-link--size-small {
|
|
45
|
+
font-size: var(--dsn-link-size-small-font-size);
|
|
46
|
+
gap: var(--dsn-link-size-small-gap);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.dsn-link--size-default {
|
|
50
|
+
font-size: var(--dsn-link-size-default-font-size);
|
|
51
|
+
gap: var(--dsn-link-size-default-gap);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.dsn-link--size-large {
|
|
55
|
+
font-size: var(--dsn-link-size-large-font-size);
|
|
56
|
+
gap: var(--dsn-link-size-large-gap);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/* Icon sizing per link size */
|
|
60
|
+
.dsn-link--size-small > .dsn-icon {
|
|
61
|
+
width: var(--dsn-link-size-small-icon-size);
|
|
62
|
+
height: var(--dsn-link-size-small-icon-size);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.dsn-link--size-default > .dsn-icon {
|
|
66
|
+
width: var(--dsn-link-size-default-icon-size);
|
|
67
|
+
height: var(--dsn-link-size-default-icon-size);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.dsn-link--size-large > .dsn-icon {
|
|
71
|
+
width: var(--dsn-link-size-large-icon-size);
|
|
72
|
+
height: var(--dsn-link-size-large-icon-size);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/* Hover */
|
|
76
|
+
.dsn-link:hover:not([aria-disabled='true']) {
|
|
77
|
+
color: var(--dsn-link-hover-color);
|
|
78
|
+
text-decoration-line: var(--dsn-link-hover-text-decoration-line);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/* Active */
|
|
82
|
+
.dsn-link:active:not([aria-disabled='true']) {
|
|
83
|
+
color: var(--dsn-link-active-color);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/* Focus */
|
|
87
|
+
.dsn-link:focus-visible {
|
|
88
|
+
background-color: var(--dsn-focus-background-color);
|
|
89
|
+
color: var(--dsn-focus-color);
|
|
90
|
+
text-decoration: none;
|
|
91
|
+
outline: var(--dsn-focus-outline-width) var(--dsn-focus-outline-style)
|
|
92
|
+
var(--dsn-focus-outline-color);
|
|
93
|
+
outline-offset: var(--dsn-focus-outline-offset);
|
|
94
|
+
box-shadow: 0 0 0
|
|
95
|
+
calc(var(--dsn-focus-outline-offset) + var(--dsn-focus-outline-width))
|
|
96
|
+
var(--dsn-focus-inverse-outline-color);
|
|
97
|
+
box-decoration-break: clone;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/* Current page */
|
|
101
|
+
.dsn-link[aria-current='page'] {
|
|
102
|
+
cursor: default;
|
|
103
|
+
text-decoration-line: none;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/* Disabled */
|
|
107
|
+
.dsn-link[aria-disabled='true'] {
|
|
108
|
+
color: var(--dsn-link-disabled-color);
|
|
109
|
+
text-decoration-line: none;
|
|
110
|
+
cursor: not-allowed;
|
|
111
|
+
pointer-events: none;
|
|
112
|
+
}
|
|
113
|
+
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './Link.css';
|
|
3
|
+
export type LinkSize = 'small' | 'default' | 'large';
|
|
4
|
+
export interface LinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {
|
|
5
|
+
/**
|
|
6
|
+
* Whether the link is disabled
|
|
7
|
+
* @default false
|
|
8
|
+
*/
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
/**
|
|
11
|
+
* Whether the link represents the current page
|
|
12
|
+
* @default false
|
|
13
|
+
*/
|
|
14
|
+
current?: boolean;
|
|
15
|
+
/**
|
|
16
|
+
* Link size — controls font-size, gap, and icon size.
|
|
17
|
+
* When omitted, the link inherits the surrounding font (ideal for inline usage in paragraphs).
|
|
18
|
+
*/
|
|
19
|
+
size?: LinkSize;
|
|
20
|
+
/**
|
|
21
|
+
* Icon element rendered before the link text
|
|
22
|
+
*/
|
|
23
|
+
iconStart?: React.ReactNode;
|
|
24
|
+
/**
|
|
25
|
+
* Icon element rendered after the link text
|
|
26
|
+
*/
|
|
27
|
+
iconEnd?: React.ReactNode;
|
|
28
|
+
/**
|
|
29
|
+
* Whether the link opens in a new tab.
|
|
30
|
+
* Automatically adds target="_blank", rel="noopener noreferrer",
|
|
31
|
+
* and an inline "(opent nieuw tabblad)" hint.
|
|
32
|
+
* @default false
|
|
33
|
+
*/
|
|
34
|
+
external?: boolean;
|
|
35
|
+
/**
|
|
36
|
+
* Additional CSS class names
|
|
37
|
+
*/
|
|
38
|
+
className?: string;
|
|
39
|
+
/**
|
|
40
|
+
* Link content
|
|
41
|
+
*/
|
|
42
|
+
children?: React.ReactNode;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Link component with icon support and size variants
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* ```tsx
|
|
49
|
+
* // Basic usage (inherits font from parent)
|
|
50
|
+
* <Link href="/about">About us</Link>
|
|
51
|
+
*
|
|
52
|
+
* // With explicit size
|
|
53
|
+
* <Link href="/about" size="small">Small link</Link>
|
|
54
|
+
* <Link href="/about" size="default">Default link</Link>
|
|
55
|
+
* <Link href="/about" size="large">Large link</Link>
|
|
56
|
+
*
|
|
57
|
+
* // With icon before text
|
|
58
|
+
* <Link href="/download" iconStart={<Icon name="download" />}>
|
|
59
|
+
* Download
|
|
60
|
+
* </Link>
|
|
61
|
+
*
|
|
62
|
+
* // With icon after text
|
|
63
|
+
* <Link href="/next" iconEnd={<Icon name="arrow-right" />}>
|
|
64
|
+
* Next page
|
|
65
|
+
* </Link>
|
|
66
|
+
*
|
|
67
|
+
* // External link (opens in new tab with visible hint)
|
|
68
|
+
* <Link href="https://example.com" external>
|
|
69
|
+
* External site
|
|
70
|
+
* </Link>
|
|
71
|
+
*
|
|
72
|
+
* // Current page
|
|
73
|
+
* <Link href="/dashboard" current>Dashboard</Link>
|
|
74
|
+
*
|
|
75
|
+
* // Disabled
|
|
76
|
+
* <Link disabled>Unavailable</Link>
|
|
77
|
+
* ```
|
|
78
|
+
*/
|
|
79
|
+
export declare const Link: React.ForwardRefExoticComponent<LinkProps & React.RefAttributes<HTMLAnchorElement>>;
|
|
80
|
+
//# sourceMappingURL=Link.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Link.d.ts","sourceRoot":"","sources":["../../src/Link/Link.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,YAAY,CAAC;AAEpB,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,SAAS,GAAG,OAAO,CAAC;AAErD,MAAM,WAAW,SAAU,SAAQ,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC;IAC9E;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;;OAGG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;IAElB;;;OAGG;IACH,IAAI,CAAC,EAAE,QAAQ,CAAC;IAEhB;;OAEG;IACH,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE5B;;OAEG;IACH,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE1B;;;;;OAKG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC5B;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AACH,eAAO,MAAM,IAAI,qFA6DhB,CAAC"}
|