pixel-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/.prettierrc.js +13 -0
- package/.storybook/main.ts +26 -0
- package/.storybook/preview.ts +26 -0
- package/.yarn/install-state.gz +0 -0
- package/.yarnrc.yml +1 -0
- package/README.md +25 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/index.scss +0 -0
- package/lib/StyleGuide/ColorPalette/ColorPalette.d.ts +3 -0
- package/lib/StyleGuide/ColorPalette/ColorPalette.stories.d.ts +6 -0
- package/lib/StyleGuide/ColorPalette/colorPaletteList.d.ts +3 -0
- package/lib/StyleGuide/ColorPalette/index.d.ts +1 -0
- package/lib/StyleGuide/ColorPalette/types.d.ts +15 -0
- package/lib/StyleGuide/Typography/Typography.d.ts +3 -0
- package/lib/StyleGuide/Typography/Typography.stories.d.ts +6 -0
- package/lib/StyleGuide/Typography/TypographyList.d.ts +5 -0
- package/lib/StyleGuide/Typography/types.d.ts +8 -0
- package/lib/assets/utils/functionUtils.d.ts +1 -0
- package/lib/components/Accordion/Accordion.d.ts +8 -0
- package/lib/components/Accordion/Accordion.stories.d.ts +6 -0
- package/lib/components/Accordion/index.d.ts +1 -0
- package/lib/components/Accordion/types.d.ts +27 -0
- package/lib/components/AddResourceButton/AddButton.d.ts +4 -0
- package/lib/components/AddResourceButton/AddButton.stories.d.ts +8 -0
- package/lib/components/AddResourceButton/ArrowsButton/ArrowsButton.d.ts +6 -0
- package/lib/components/AddResourceButton/index.d.ts +1 -0
- package/lib/components/AddResourceButton/type.d.ts +65 -0
- package/lib/components/Button/Button.d.ts +5 -0
- package/lib/components/Button/Button.stories.d.ts +12 -0
- package/lib/components/Button/index.d.ts +1 -0
- package/lib/components/Button/types.d.ts +61 -0
- package/lib/components/Charts/DonutChart/DonutChart.d.ts +5 -0
- package/lib/components/Charts/DonutChart/DonutChart.stories.d.ts +6 -0
- package/lib/components/Charts/DonutChart/index.d.ts +1 -0
- package/lib/components/Charts/DonutChart/type.d.ts +13 -0
- package/lib/components/Charts/RadialChart/RadialChart.d.ts +5 -0
- package/lib/components/Charts/RadialChart/RadialChart.stories.d.ts +6 -0
- package/lib/components/Charts/RadialChart/index.d.ts +1 -0
- package/lib/components/Charts/RadialChart/types.d.ts +25 -0
- package/lib/components/Checkbox/Checkbox.d.ts +6 -0
- package/lib/components/Checkbox/Checkbox.stories.d.ts +8 -0
- package/lib/components/Checkbox/index.d.ts +1 -0
- package/lib/components/Checkbox/types.d.ts +30 -0
- package/lib/components/Chip/Chip.d.ts +4 -0
- package/lib/components/Chip/Chip.stories.d.ts +14 -0
- package/lib/components/Chip/index.d.ts +1 -0
- package/lib/components/Chip/types.d.ts +18 -0
- package/lib/components/Drawer/Drawer.d.ts +4 -0
- package/lib/components/Drawer/Drawer.stories.d.ts +7 -0
- package/lib/components/Drawer/Types.d.ts +85 -0
- package/lib/components/Drawer/index.d.ts +1 -0
- package/lib/components/ExpandableMenu/ExpandableMenu.d.ts +5 -0
- package/lib/components/ExpandableMenu/ExpandableMenu.stories.d.ts +7 -0
- package/lib/components/ExpandableMenu/index.d.ts +1 -0
- package/lib/components/ExpandableMenu/types.d.ts +34 -0
- package/lib/components/FileDropzone/Dropzone.d.ts +5 -0
- package/lib/components/FileDropzone/FileDropzone.d.ts +4 -0
- package/lib/components/FileDropzone/FileDropzone.stories.d.ts +8 -0
- package/lib/components/FileDropzone/FilePreview.d.ts +4 -0
- package/lib/components/FileDropzone/index.d.ts +1 -0
- package/lib/components/FileDropzone/types.d.ts +103 -0
- package/lib/components/Form/Form.d.ts +16 -0
- package/lib/components/Form/Form.stories.d.ts +6 -0
- package/lib/components/Form/index.d.ts +1 -0
- package/lib/components/Form/types.d.ts +1 -0
- package/lib/components/GridLayout/GridLayout.d.ts +6 -0
- package/lib/components/GridLayout/GridLayout.stories.d.ts +8 -0
- package/lib/components/GridLayout/index.d.ts +2 -0
- package/lib/components/GridLayout/types.d.ts +57 -0
- package/lib/components/HighlightText/HighlightText.d.ts +4 -0
- package/lib/components/HighlightText/HighlightText.stories.d.ts +6 -0
- package/lib/components/HighlightText/index.d.ts +1 -0
- package/lib/components/HighlightText/types.d.ts +4 -0
- package/lib/components/Icon/Icon.d.ts +4 -0
- package/lib/components/Icon/Icon.stories.d.ts +7 -0
- package/lib/components/Icon/iconList.d.ts +2 -0
- package/lib/components/Icon/index.d.ts +1 -0
- package/lib/components/Icon/types.d.ts +10 -0
- package/lib/components/Input/Input.d.ts +4 -0
- package/lib/components/Input/Input.stories.d.ts +9 -0
- package/lib/components/Input/index.d.ts +1 -0
- package/lib/components/Input/types.d.ts +74 -0
- package/lib/components/InputWithDropdown/InputWithDropdown.d.ts +4 -0
- package/lib/components/InputWithDropdown/InputWithDropdown.stories.d.ts +8 -0
- package/lib/components/InputWithDropdown/index.d.ts +1 -0
- package/lib/components/InputWithDropdown/types.d.ts +88 -0
- package/lib/components/LazyLoad/LazyLoad.d.ts +2 -0
- package/lib/components/LazyLoad/LazyLoad.stories.d.ts +6 -0
- package/lib/components/LazyLoad/LazyLoading.d.ts +2 -0
- package/lib/components/LazyLoad/index.d.ts +1 -0
- package/lib/components/MenuOption/MenuOption.d.ts +4 -0
- package/lib/components/MenuOption/MenuOption.stories.d.ts +15 -0
- package/lib/components/MenuOption/index.d.ts +1 -0
- package/lib/components/MenuOption/types.d.ts +134 -0
- package/lib/components/MiniModal/MiniModal.d.ts +4 -0
- package/lib/components/MiniModal/MiniModal.stories.d.ts +9 -0
- package/lib/components/MiniModal/index.d.ts +1 -0
- package/lib/components/MiniModal/types.d.ts +89 -0
- package/lib/components/MultiSelect/Dropdown.d.ts +4 -0
- package/lib/components/MultiSelect/MultiSelect.d.ts +4 -0
- package/lib/components/MultiSelect/MultiSelect.stories.d.ts +9 -0
- package/lib/components/MultiSelect/MultiSelectTypes.d.ts +18 -0
- package/lib/components/MultiSelect/dropdownTypes.d.ts +15 -0
- package/lib/components/MultiSelect/index.d.ts +1 -0
- package/lib/components/RadioButton/RadioButton.d.ts +4 -0
- package/lib/components/RadioButton/RadioButton.stories.d.ts +10 -0
- package/lib/components/RadioButton/index.d.ts +1 -0
- package/lib/components/RadioButton/radioButtonTypes.d.ts +35 -0
- package/lib/components/RadioGroup/RadioGroup.d.ts +4 -0
- package/lib/components/RadioGroup/RadioGroup.stories.d.ts +8 -0
- package/lib/components/RadioGroup/index.d.ts +1 -0
- package/lib/components/RadioGroup/radioGroupTypes.d.ts +47 -0
- package/lib/components/Search/Search.d.ts +4 -0
- package/lib/components/Search/Search.stories.d.ts +6 -0
- package/lib/components/Search/index.d.ts +1 -0
- package/lib/components/Search/types.d.ts +15 -0
- package/lib/components/Select/Select.d.ts +4 -0
- package/lib/components/Select/Select.stories.d.ts +13 -0
- package/lib/components/Select/components/Dropdown/Dropdown.d.ts +4 -0
- package/lib/components/Select/components/Dropdown/dropdownTypes.d.ts +15 -0
- package/lib/components/Select/index.d.ts +1 -0
- package/lib/components/Select/types.d.ts +68 -0
- package/lib/components/Table/Table.d.ts +4 -0
- package/lib/components/Table/Table.stories.d.ts +11 -0
- package/lib/components/Table/Types.d.ts +98 -0
- package/lib/components/Table/index.d.ts +1 -0
- package/lib/components/TableTree/TableTree.d.ts +21 -0
- package/lib/components/TableTree/TableTree.stories.d.ts +7 -0
- package/lib/components/TableTree/data.d.ts +313 -0
- package/lib/components/TableTree/index.d.ts +1 -0
- package/lib/components/Tabs/Tabs.d.ts +5 -0
- package/lib/components/Tabs/Tabs.stories.d.ts +8 -0
- package/lib/components/Tabs/index.d.ts +1 -0
- package/lib/components/Tabs/types.d.ts +40 -0
- package/lib/components/TextArea/Textarea.d.ts +4 -0
- package/lib/components/TextArea/Textarea.stories.d.ts +9 -0
- package/lib/components/TextArea/Types.d.ts +78 -0
- package/lib/components/TextArea/index.d.ts +1 -0
- package/lib/components/ThemeProvider/ThemeProvider.d.ts +7 -0
- package/lib/components/ThemeProvider/index.d.ts +1 -0
- package/lib/components/ThemeProvider/types.d.ts +11 -0
- package/lib/components/Toast/Toast.d.ts +5 -0
- package/lib/components/Toast/Toast.stories.d.ts +6 -0
- package/lib/components/Toast/index.d.ts +1 -0
- package/lib/components/Toast/types.d.ts +20 -0
- package/lib/components/Toggle/Toggle.d.ts +5 -0
- package/lib/components/Toggle/Toggle.stories.d.ts +12 -0
- package/lib/components/Toggle/index.d.ts +1 -0
- package/lib/components/Toggle/types.d.ts +50 -0
- package/lib/components/Tooltip/Tooltip.d.ts +5 -0
- package/lib/components/Tooltip/Tooltip.stories.d.ts +15 -0
- package/lib/components/Tooltip/index.d.ts +1 -0
- package/lib/components/Tooltip/types.d.ts +37 -0
- package/lib/components/Typography/Typography.d.ts +5 -0
- package/lib/components/Typography/Typography.stories.d.ts +10 -0
- package/lib/components/Typography/index.d.ts +1 -0
- package/lib/components/Typography/types.d.ts +47 -0
- package/lib/hooks/keyboardevents/useEscKeyEvent.d.ts +2 -0
- package/lib/hooks/useClickOutside.d.ts +2 -0
- package/lib/hooks/useFileDropzone.d.ts +3 -0
- package/lib/hooks/usePortalPosition.d.ts +9 -0
- package/lib/hooks/useTheme.d.ts +3 -0
- package/lib/index.css +404 -0
- package/lib/index.d.ts +1286 -0
- package/lib/index.esm.css +404 -0
- package/lib/index.esm.js +9317 -0
- package/lib/index.esm.js.map +1 -0
- package/lib/index.js +9376 -0
- package/lib/index.js.map +1 -0
- package/lib/tsconfig.tsbuildinfo +1 -0
- package/lib/utils/TableCell/TableCell.d.ts +1 -0
- package/lib/utils/checkEmpty/checkEmpty.d.ts +3 -0
- package/lib/utils/checkEmpty/checkEmpty.stories.d.ts +6 -0
- package/lib/utils/ffID/ffID.stories.d.ts +6 -0
- package/lib/utils/ffID/ffid.d.ts +2 -0
- package/lib/utils/getExtension/getExtension.d.ts +4 -0
- package/lib/utils/getExtension/getExtension.stories.d.ts +6 -0
- package/lib/utils/truncateText/truncateText.d.ts +1 -0
- package/lib/utils/truncateText/truncateText.stories.d.ts +6 -0
- package/package.json +62 -0
- package/rollup.config.mjs +57 -0
- package/src/StyleGuide/ColorPalette/ColorPalette.scss +58 -0
- package/src/StyleGuide/ColorPalette/ColorPalette.stories.tsx +16 -0
- package/src/StyleGuide/ColorPalette/ColorPalette.tsx +61 -0
- package/src/StyleGuide/ColorPalette/colorPaletteList.ts +97 -0
- package/src/StyleGuide/ColorPalette/index.ts +1 -0
- package/src/StyleGuide/ColorPalette/types.ts +17 -0
- package/src/StyleGuide/Typography/Typography.scss +100 -0
- package/src/StyleGuide/Typography/Typography.stories.tsx +16 -0
- package/src/StyleGuide/Typography/Typography.tsx +60 -0
- package/src/StyleGuide/Typography/TypographyList.ts +3 -0
- package/src/StyleGuide/Typography/types.ts +9 -0
- package/src/assets/Themes/BaseTheme.scss +130 -0
- package/src/assets/Themes/DarkTheme.scss +131 -0
- package/src/assets/Themes/Theme.scss +200 -0
- package/src/assets/icons/Arrow.svg +5 -0
- package/src/assets/icons/accordion_header_icon.svg +10 -0
- package/src/assets/icons/arrow_down.svg +3 -0
- package/src/assets/icons/arrow_right.svg +5 -0
- package/src/assets/icons/arrow_up.svg +3 -0
- package/src/assets/icons/arrows_down_icon.svg +3 -0
- package/src/assets/icons/arrows_right_icon.svg +10 -0
- package/src/assets/icons/arrows_top_icon.svg +3 -0
- package/src/assets/icons/check_mark.svg +3 -0
- package/src/assets/icons/close_pill.svg +3 -0
- package/src/assets/icons/delete.svg +17 -0
- package/src/assets/icons/dropzone_icon.svg +18 -0
- package/src/assets/icons/error.svg +17 -0
- package/src/assets/icons/file.svg +12 -0
- package/src/assets/icons/info.svg +17 -0
- package/src/assets/icons/logo.svg +18 -0
- package/src/assets/icons/manage_apps.svg +3 -0
- package/src/assets/icons/moon_stars.svg +10 -0
- package/src/assets/icons/more.svg +11 -0
- package/src/assets/icons/plus_icon.svg +11 -0
- package/src/assets/icons/remove.svg +12 -0
- package/src/assets/icons/replace.svg +12 -0
- package/src/assets/icons/search.svg +3 -0
- package/src/assets/icons/success.svg +13 -0
- package/src/assets/icons/sun_icon.svg +10 -0
- package/src/assets/icons/tick_icon.svg +5 -0
- package/src/assets/icons/toast_close.svg +3 -0
- package/src/assets/icons/warning.svg +17 -0
- package/src/assets/icons/wrong_mark.svg +3 -0
- package/src/assets/styles/_colors.scss +145 -0
- package/src/assets/styles/_fonts.scss +68 -0
- package/src/assets/styles/_mixins.scss +20 -0
- package/src/assets/utils/functionUtils.ts +5 -0
- package/src/components/Accordion/Accordion.scss +45 -0
- package/src/components/Accordion/Accordion.stories.tsx +31 -0
- package/src/components/Accordion/Accordion.tsx +62 -0
- package/src/components/Accordion/index.ts +1 -0
- package/src/components/Accordion/types.ts +28 -0
- package/src/components/AddResourceButton/AddButton.scss +36 -0
- package/src/components/AddResourceButton/AddButton.stories.tsx +126 -0
- package/src/components/AddResourceButton/AddButton.tsx +121 -0
- package/src/components/AddResourceButton/ArrowsButton/ArrowsButton.scss +160 -0
- package/src/components/AddResourceButton/ArrowsButton/ArrowsButton.tsx +38 -0
- package/src/components/AddResourceButton/index.ts +1 -0
- package/src/components/AddResourceButton/type.ts +60 -0
- package/src/components/Button/Button.scss +148 -0
- package/src/components/Button/Button.stories.tsx +74 -0
- package/src/components/Button/Button.tsx +66 -0
- package/src/components/Button/index.ts +1 -0
- package/src/components/Button/types.ts +65 -0
- package/src/components/Charts/DonutChart/DonutChart.scss +76 -0
- package/src/components/Charts/DonutChart/DonutChart.stories.tsx +30 -0
- package/src/components/Charts/DonutChart/DonutChart.tsx +241 -0
- package/src/components/Charts/DonutChart/index.ts +1 -0
- package/src/components/Charts/DonutChart/type.ts +23 -0
- package/src/components/Charts/RadialChart/RadialChart.scss +12 -0
- package/src/components/Charts/RadialChart/RadialChart.stories.tsx +36 -0
- package/src/components/Charts/RadialChart/RadialChart.tsx +174 -0
- package/src/components/Charts/RadialChart/index.ts +1 -0
- package/src/components/Charts/RadialChart/types.ts +32 -0
- package/src/components/Checkbox/Checkbox.scss +89 -0
- package/src/components/Checkbox/Checkbox.stories.tsx +47 -0
- package/src/components/Checkbox/Checkbox.tsx +61 -0
- package/src/components/Checkbox/index.ts +1 -0
- package/src/components/Checkbox/types.ts +30 -0
- package/src/components/Chip/Chip.scss +70 -0
- package/src/components/Chip/Chip.stories.tsx +88 -0
- package/src/components/Chip/Chip.tsx +35 -0
- package/src/components/Chip/index.ts +1 -0
- package/src/components/Chip/types.ts +19 -0
- package/src/components/Drawer/Drawer.scss +121 -0
- package/src/components/Drawer/Drawer.stories.tsx +88 -0
- package/src/components/Drawer/Drawer.tsx +179 -0
- package/src/components/Drawer/Types.ts +88 -0
- package/src/components/Drawer/index.ts +1 -0
- package/src/components/ExpandableMenu/ExpandableMenu.scss +110 -0
- package/src/components/ExpandableMenu/ExpandableMenu.stories.tsx +67 -0
- package/src/components/ExpandableMenu/ExpandableMenu.tsx +101 -0
- package/src/components/ExpandableMenu/index.ts +1 -0
- package/src/components/ExpandableMenu/types.ts +34 -0
- package/src/components/FileDropzone/Dropzone.tsx +55 -0
- package/src/components/FileDropzone/FileDropzone.scss +134 -0
- package/src/components/FileDropzone/FileDropzone.stories.tsx +83 -0
- package/src/components/FileDropzone/FileDropzone.tsx +98 -0
- package/src/components/FileDropzone/FilePreview.tsx +75 -0
- package/src/components/FileDropzone/index.ts +1 -0
- package/src/components/FileDropzone/types.ts +113 -0
- package/src/components/Form/Form.scss +98 -0
- package/src/components/Form/Form.stories.tsx +177 -0
- package/src/components/Form/Form.tsx +57 -0
- package/src/components/Form/index.ts +1 -0
- package/src/components/Form/types.ts +1 -0
- package/src/components/Form/validation.json +29 -0
- package/src/components/GridLayout/GridLayout.scss +71 -0
- package/src/components/GridLayout/GridLayout.stories.tsx +128 -0
- package/src/components/GridLayout/GridLayout.tsx +30 -0
- package/src/components/GridLayout/GridLayoutStory.scss +25 -0
- package/src/components/GridLayout/index.ts +1 -0
- package/src/components/GridLayout/types.ts +64 -0
- package/src/components/HighlightText/HighlightText.scss +3 -0
- package/src/components/HighlightText/HighlightText.stories.tsx +22 -0
- package/src/components/HighlightText/HighlightText.tsx +33 -0
- package/src/components/HighlightText/index.ts +1 -0
- package/src/components/HighlightText/types.ts +4 -0
- package/src/components/Icon/Icon.stories.tsx +37 -0
- package/src/components/Icon/Icon.tsx +43 -0
- package/src/components/Icon/Icons.scss +34 -0
- package/src/components/Icon/iconList.ts +62 -0
- package/src/components/Icon/index.ts +1 -0
- package/src/components/Icon/types.ts +10 -0
- package/src/components/Input/Input.scss +150 -0
- package/src/components/Input/Input.stories.tsx +96 -0
- package/src/components/Input/Input.tsx +93 -0
- package/src/components/Input/index.ts +1 -0
- package/src/components/Input/types.ts +77 -0
- package/src/components/InputWithDropdown/InputWithDropdown.scss +185 -0
- package/src/components/InputWithDropdown/InputWithDropdown.stories.tsx +114 -0
- package/src/components/InputWithDropdown/InputWithDropdown.tsx +85 -0
- package/src/components/InputWithDropdown/index.ts +1 -0
- package/src/components/InputWithDropdown/types.ts +110 -0
- package/src/components/LazyLoad/LazyLoad.d.ts +3 -0
- package/src/components/LazyLoad/LazyLoad.stories.tsx +33 -0
- package/src/components/LazyLoad/LazyLoad.ts +2 -0
- package/src/components/LazyLoad/LazyLoading.tsx +19 -0
- package/src/components/LazyLoad/index.ts +1 -0
- package/src/components/MenuOption/MenuOption.scss +69 -0
- package/src/components/MenuOption/MenuOption.stories.tsx +259 -0
- package/src/components/MenuOption/MenuOption.tsx +126 -0
- package/src/components/MenuOption/index.ts +1 -0
- package/src/components/MenuOption/types.ts +161 -0
- package/src/components/MiniModal/MiniModal.scss +139 -0
- package/src/components/MiniModal/MiniModal.stories.tsx +475 -0
- package/src/components/MiniModal/MiniModal.tsx +218 -0
- package/src/components/MiniModal/index.ts +1 -0
- package/src/components/MiniModal/types.ts +88 -0
- package/src/components/MultiSelect/Dropdown.scss +66 -0
- package/src/components/MultiSelect/Dropdown.tsx +77 -0
- package/src/components/MultiSelect/MultiSelect.scss +190 -0
- package/src/components/MultiSelect/MultiSelect.stories.tsx +85 -0
- package/src/components/MultiSelect/MultiSelect.tsx +260 -0
- package/src/components/MultiSelect/MultiSelectTypes.ts +19 -0
- package/src/components/MultiSelect/dropdownTypes.ts +15 -0
- package/src/components/MultiSelect/index.ts +1 -0
- package/src/components/RadioButton/RadioButton.scss +99 -0
- package/src/components/RadioButton/RadioButton.stories.tsx +43 -0
- package/src/components/RadioButton/RadioButton.tsx +32 -0
- package/src/components/RadioButton/index.ts +1 -0
- package/src/components/RadioButton/radioButtonTypes.tsx +40 -0
- package/src/components/RadioGroup/RadioGroup.scss +5 -0
- package/src/components/RadioGroup/RadioGroup.stories.tsx +81 -0
- package/src/components/RadioGroup/RadioGroup.tsx +30 -0
- package/src/components/RadioGroup/index.ts +1 -0
- package/src/components/RadioGroup/radioGroupTypes.tsx +54 -0
- package/src/components/Search/Search.scss +87 -0
- package/src/components/Search/Search.stories.tsx +26 -0
- package/src/components/Search/Search.tsx +103 -0
- package/src/components/Search/index.ts +1 -0
- package/src/components/Search/types.ts +15 -0
- package/src/components/Select/Select.scss +247 -0
- package/src/components/Select/Select.stories.tsx +156 -0
- package/src/components/Select/Select.tsx +368 -0
- package/src/components/Select/components/Dropdown/Dropdown.scss +70 -0
- package/src/components/Select/components/Dropdown/Dropdown.tsx +89 -0
- package/src/components/Select/components/Dropdown/dropdownTypes.ts +19 -0
- package/src/components/Select/index.ts +1 -0
- package/src/components/Select/types.ts +122 -0
- package/src/components/Table/Table.scss +101 -0
- package/src/components/Table/Table.stories.tsx +345 -0
- package/src/components/Table/Table.tsx +128 -0
- package/src/components/Table/Types.ts +100 -0
- package/src/components/Table/index.ts +1 -0
- package/src/components/TableTree/TableTree.scss +142 -0
- package/src/components/TableTree/TableTree.stories.tsx +121 -0
- package/src/components/TableTree/TableTree.tsx +216 -0
- package/src/components/TableTree/TableTreeStories.scss +22 -0
- package/src/components/TableTree/data.ts +573 -0
- package/src/components/TableTree/index.ts +1 -0
- package/src/components/Tabs/Tabs.scss +76 -0
- package/src/components/Tabs/Tabs.stories.tsx +104 -0
- package/src/components/Tabs/Tabs.tsx +64 -0
- package/src/components/Tabs/index.ts +1 -0
- package/src/components/Tabs/types.ts +38 -0
- package/src/components/TextArea/Textarea.scss +145 -0
- package/src/components/TextArea/Textarea.stories.tsx +92 -0
- package/src/components/TextArea/Textarea.tsx +84 -0
- package/src/components/TextArea/Types.ts +82 -0
- package/src/components/TextArea/index.tsx +1 -0
- package/src/components/ThemeProvider/ThemeProvider.tsx +24 -0
- package/src/components/ThemeProvider/index.ts +1 -0
- package/src/components/ThemeProvider/types.ts +14 -0
- package/src/components/Toast/Toast.scss +121 -0
- package/src/components/Toast/Toast.stories.tsx +180 -0
- package/src/components/Toast/Toast.tsx +116 -0
- package/src/components/Toast/index.ts +1 -0
- package/src/components/Toast/types.ts +27 -0
- package/src/components/Toggle/Toggle.scss +132 -0
- package/src/components/Toggle/Toggle.stories.tsx +132 -0
- package/src/components/Toggle/Toggle.tsx +96 -0
- package/src/components/Toggle/index.ts +1 -0
- package/src/components/Toggle/types.ts +43 -0
- package/src/components/Tooltip/Tooltip.scss +27 -0
- package/src/components/Tooltip/Tooltip.stories.tsx +97 -0
- package/src/components/Tooltip/Tooltip.tsx +194 -0
- package/src/components/Tooltip/index.ts +1 -0
- package/src/components/Tooltip/types.ts +60 -0
- package/src/components/Typography/Typography.scss +49 -0
- package/src/components/Typography/Typography.stories.tsx +57 -0
- package/src/components/Typography/Typography.tsx +39 -0
- package/src/components/Typography/index.ts +1 -0
- package/src/components/Typography/types.ts +56 -0
- package/src/fonts/Montserrat/Montserrat-Medium.ttf +0 -0
- package/src/fonts/Montserrat/Montserrat-Regular.ttf +0 -0
- package/src/fonts/Montserrat/Montserrat-SemiBold.ttf +0 -0
- package/src/fonts/Poppins/Poppins-Black.ttf +0 -0
- package/src/fonts/Poppins/Poppins-BlackItalic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-Bold.ttf +0 -0
- package/src/fonts/Poppins/Poppins-BoldItalic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-ExtraBold.ttf +0 -0
- package/src/fonts/Poppins/Poppins-ExtraBoldItalic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-ExtraLight.ttf +0 -0
- package/src/fonts/Poppins/Poppins-ExtraLightItalic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-Italic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-Light.ttf +0 -0
- package/src/fonts/Poppins/Poppins-LightItalic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-Medium.ttf +0 -0
- package/src/fonts/Poppins/Poppins-MediumItalic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-Regular.ttf +0 -0
- package/src/fonts/Poppins/Poppins-SemiBold.ttf +0 -0
- package/src/fonts/Poppins/Poppins-SemiBoldItalic.ttf +0 -0
- package/src/fonts/Poppins/Poppins-Thin.ttf +0 -0
- package/src/fonts/Poppins/Poppins-ThinItalic.ttf +0 -0
- package/src/hooks/keyboardevents/useEscKeyEvent.tsx +31 -0
- package/src/hooks/useClickOutside.tsx +30 -0
- package/src/hooks/useFileDropzone.tsx +273 -0
- package/src/hooks/usePortalPosition.tsx +53 -0
- package/src/hooks/useTheme.tsx +13 -0
- package/src/index.ts +91 -0
- package/src/utils/TableCell/TableCell.ts +16 -0
- package/src/utils/checkEmpty/checkEmpty.stories.tsx +34 -0
- package/src/utils/checkEmpty/checkEmpty.ts +10 -0
- package/src/utils/ffID/ffID.stories.tsx +35 -0
- package/src/utils/ffID/ffid.ts +9 -0
- package/src/utils/getExtension/getExtension.stories.tsx +23 -0
- package/src/utils/getExtension/getExtension.ts +28 -0
- package/src/utils/truncateText/truncateText.stories.tsx +37 -0
- package/src/utils/truncateText/truncateText.ts +4 -0
- package/tsconfig.json +55 -0
- package/ui-library.zip +0 -0
- package/vite.config.js +30 -0
@@ -0,0 +1,85 @@
|
|
1
|
+
import { ReactNode } from 'react';
|
2
|
+
export interface BtnPropsCommon {
|
3
|
+
/**
|
4
|
+
* Label for the button
|
5
|
+
*/
|
6
|
+
label?: string;
|
7
|
+
/**
|
8
|
+
* Boolean value to disable the button
|
9
|
+
*/
|
10
|
+
disabled?: boolean;
|
11
|
+
/**
|
12
|
+
* Onclick function for button
|
13
|
+
*/
|
14
|
+
onClick?: () => void;
|
15
|
+
}
|
16
|
+
export interface DrawerProps {
|
17
|
+
/**
|
18
|
+
* To Open the Drawer
|
19
|
+
*/
|
20
|
+
isOpen: boolean;
|
21
|
+
/**
|
22
|
+
* To Expand the Drawer
|
23
|
+
*/
|
24
|
+
_isExpanded?: boolean;
|
25
|
+
/**
|
26
|
+
* To show and hide the back button of the Drawer
|
27
|
+
*/
|
28
|
+
isBackButtonVisible?: boolean;
|
29
|
+
/**
|
30
|
+
* To show and hide the close button of the Drawer
|
31
|
+
*/
|
32
|
+
_isCloseModalButtonVisible?: boolean;
|
33
|
+
/**
|
34
|
+
* Function to close the drawer
|
35
|
+
*/
|
36
|
+
onClose?: () => void;
|
37
|
+
/**
|
38
|
+
* Size of the drawer medium = 550px large = 850px
|
39
|
+
*/
|
40
|
+
size?: 'small' | 'medium' | 'large' | 'x-large';
|
41
|
+
/**
|
42
|
+
* Body Content of the drawer
|
43
|
+
*/
|
44
|
+
children: ReactNode;
|
45
|
+
/**
|
46
|
+
* Header title for the drawer
|
47
|
+
*/
|
48
|
+
title: string | ReactNode;
|
49
|
+
/**
|
50
|
+
* To show the edit button on the header
|
51
|
+
*/
|
52
|
+
showEditButton?: boolean;
|
53
|
+
/**
|
54
|
+
* Primary | Success button props
|
55
|
+
*/
|
56
|
+
primaryButtonProps?: BtnPropsCommon;
|
57
|
+
/**
|
58
|
+
* Secondary | Cancel button props
|
59
|
+
*/
|
60
|
+
secondaryButtonProps?: BtnPropsCommon;
|
61
|
+
/**
|
62
|
+
* Left side Primary Button | Cancel button props
|
63
|
+
*/
|
64
|
+
leftPrimaryButtonProps?: BtnPropsCommon;
|
65
|
+
/**
|
66
|
+
* Left side Secondary | Cancel button props
|
67
|
+
*/
|
68
|
+
leftSecondaryButtonProps?: BtnPropsCommon;
|
69
|
+
/**
|
70
|
+
* Onclick function for edit button
|
71
|
+
*/
|
72
|
+
onEdit?: () => void;
|
73
|
+
/**
|
74
|
+
* Background overlay for the drawer
|
75
|
+
*/
|
76
|
+
overlay?: boolean;
|
77
|
+
/**
|
78
|
+
* displays footer if its true, default true
|
79
|
+
*/
|
80
|
+
isFooterRequired?: boolean;
|
81
|
+
/**
|
82
|
+
* footer Content
|
83
|
+
*/
|
84
|
+
footerContent?: ReactNode;
|
85
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './Drawer';
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
2
|
+
import ExpandableMenu from './ExpandableMenu';
|
3
|
+
declare const meta: Meta<typeof ExpandableMenu>;
|
4
|
+
type Story = StoryObj<typeof ExpandableMenu>;
|
5
|
+
export declare const Primary: Story;
|
6
|
+
export declare const Controlled: Story;
|
7
|
+
export default meta;
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './ExpandableMenu';
|
@@ -0,0 +1,34 @@
|
|
1
|
+
export interface ExpandableMenuProps {
|
2
|
+
/**
|
3
|
+
* mandatory | label for the expandable menu
|
4
|
+
*/
|
5
|
+
label: string;
|
6
|
+
/**
|
7
|
+
* optional | Icon to describe direction of expansion
|
8
|
+
*/
|
9
|
+
icon?: React.ReactNode;
|
10
|
+
/**
|
11
|
+
* optional | variant of the menu
|
12
|
+
*/
|
13
|
+
variant?: 'primary';
|
14
|
+
/**
|
15
|
+
* optional | size of the expandable menu
|
16
|
+
*/
|
17
|
+
size?: 'medium';
|
18
|
+
/**
|
19
|
+
* optional | disable to disable the menu and prevent click events but not hover event
|
20
|
+
*/
|
21
|
+
disable?: boolean;
|
22
|
+
/**
|
23
|
+
* Mandatory | sub menus to be shown inside expandable menu
|
24
|
+
*/
|
25
|
+
subMenus: string[];
|
26
|
+
/**
|
27
|
+
* optional | selected sub menu of the expandable menu
|
28
|
+
*/
|
29
|
+
selectedMenu?: string;
|
30
|
+
/**
|
31
|
+
* optional | onSubMenuClick event to perform action on click of sub menu
|
32
|
+
*/
|
33
|
+
onSubMenuClick?: (subChip: any) => void;
|
34
|
+
}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import { StoryObj, Meta } from '@storybook/react';
|
2
|
+
import FileDropzone from './FileDropzone';
|
3
|
+
declare const meta: Meta<typeof FileDropzone>;
|
4
|
+
type Story = StoryObj<typeof FileDropzone>;
|
5
|
+
export declare const Primary: Story;
|
6
|
+
export declare const withMIMEValidation: Story;
|
7
|
+
export declare const Controlled: Story;
|
8
|
+
export default meta;
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './FileDropzone';
|
@@ -0,0 +1,103 @@
|
|
1
|
+
import { ReactNode } from 'react';
|
2
|
+
export interface FileDropzoneProps {
|
3
|
+
/**
|
4
|
+
* Icon to be displayed in the dropzone.
|
5
|
+
**/
|
6
|
+
icon?: ReactNode;
|
7
|
+
/**
|
8
|
+
* Primary label to be shown in dropzone area
|
9
|
+
**/
|
10
|
+
primaryLabel?: string;
|
11
|
+
/**
|
12
|
+
* Secondary label to be shown
|
13
|
+
**/
|
14
|
+
secondaryLabel?: string;
|
15
|
+
/**
|
16
|
+
* Label to be shown in choose file/input button.
|
17
|
+
**/
|
18
|
+
buttonLabel?: string;
|
19
|
+
/**
|
20
|
+
* . extension needs to be passed to allow the type of file to add or MIME type to be validate MIME type
|
21
|
+
**/
|
22
|
+
accept: string[];
|
23
|
+
/**
|
24
|
+
* To allow multiple selection or drop of files.
|
25
|
+
**/
|
26
|
+
multiple?: boolean;
|
27
|
+
/**
|
28
|
+
* Maximum files to be dropped or selected at once.
|
29
|
+
**/
|
30
|
+
maxFiles?: number;
|
31
|
+
/**
|
32
|
+
* Maximum size of the file in numbers.
|
33
|
+
**/
|
34
|
+
maxSize?: number;
|
35
|
+
/**
|
36
|
+
* Function with state to get the boolean value when the maxFiles is less than dropped files.
|
37
|
+
**/
|
38
|
+
onMaxFilesError?: () => void;
|
39
|
+
/**
|
40
|
+
* To show error message if file size exceeds the max size
|
41
|
+
**/
|
42
|
+
maxSizeErrorMessage?: string;
|
43
|
+
/**
|
44
|
+
* To show error message if file is not of accepted file type
|
45
|
+
**/
|
46
|
+
invalidFileMessage?: string;
|
47
|
+
/**
|
48
|
+
* To show error message if file already exist with same name and type
|
49
|
+
**/
|
50
|
+
fileExistMessage?: string;
|
51
|
+
/**
|
52
|
+
* To validate file type based on MIME type but mandatorily need to pass MIME type in accept props
|
53
|
+
**/
|
54
|
+
validateMIMEType?: boolean;
|
55
|
+
}
|
56
|
+
export interface FileState {
|
57
|
+
accepted: File[];
|
58
|
+
rejected: FileRejection[];
|
59
|
+
}
|
60
|
+
export interface FileError {
|
61
|
+
message: string;
|
62
|
+
code: string;
|
63
|
+
}
|
64
|
+
export interface FileRejection {
|
65
|
+
file: File;
|
66
|
+
errors: FileError[];
|
67
|
+
}
|
68
|
+
export interface DropzoneOptions {
|
69
|
+
accept: string[];
|
70
|
+
multiple?: boolean;
|
71
|
+
maxSize?: number;
|
72
|
+
maxFiles?: number | undefined;
|
73
|
+
onDrop?: (acceptedFiles: File[], rejectedFiles: FileRejection[], event: React.DragEvent<HTMLElement> | React.ChangeEvent<HTMLInputElement>) => void;
|
74
|
+
onMaxFilesError?: () => void;
|
75
|
+
maxSizeErrorMessage?: string;
|
76
|
+
invalidFileMessage?: string;
|
77
|
+
fileExistMessage?: string;
|
78
|
+
validateMIMEType?: boolean;
|
79
|
+
}
|
80
|
+
export interface DropzoneState {
|
81
|
+
getRootProps: () => React.HTMLAttributes<HTMLElement>;
|
82
|
+
getInputProps: () => React.InputHTMLAttributes<HTMLInputElement>;
|
83
|
+
acceptedFiles: File[];
|
84
|
+
rejectedFiles: FileRejection[];
|
85
|
+
isDragActive: boolean;
|
86
|
+
handleRemoveClick: (file: File) => void;
|
87
|
+
handleReplaceClick: (file: File) => void;
|
88
|
+
}
|
89
|
+
export interface DroppableProps {
|
90
|
+
icon: React.ReactNode;
|
91
|
+
primaryLabel: string;
|
92
|
+
secondaryLabel: string;
|
93
|
+
buttonLabel: string;
|
94
|
+
getRootProps: () => any;
|
95
|
+
getInputProps: () => any;
|
96
|
+
isDragActive: boolean;
|
97
|
+
}
|
98
|
+
export interface FilePreviewProps {
|
99
|
+
file: File;
|
100
|
+
error?: string;
|
101
|
+
onRemoveClick: (file: File) => void;
|
102
|
+
onReplaceClick: (file: File) => void;
|
103
|
+
}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { UseFormProps, SubmitHandler, FieldValues, FieldPath, FieldErrors } from 'react-hook-form';
|
3
|
+
import './Form.scss';
|
4
|
+
interface FormProps<T extends FieldValues> extends UseFormProps<T> {
|
5
|
+
onSubmit: SubmitHandler<T>;
|
6
|
+
children: (props: {
|
7
|
+
register: (name: FieldPath<T>, options?: any) => any;
|
8
|
+
errors: FieldErrors<T>;
|
9
|
+
handleBlur: (field: FieldPath<T>) => void;
|
10
|
+
getValues: () => T;
|
11
|
+
watch: (field?: FieldPath<T>) => any;
|
12
|
+
setValue: (field: FieldPath<T>, value: any, options?: object) => void;
|
13
|
+
}) => React.ReactNode;
|
14
|
+
}
|
15
|
+
declare const Form: <T extends FieldValues>({ onSubmit, children, ...rest }: FormProps<T>) => import("react/jsx-runtime").JSX.Element;
|
16
|
+
export default Form;
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './Form';
|
@@ -0,0 +1 @@
|
|
1
|
+
export type FormValues = Record<string, any>;
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import './GridLayout.scss';
|
3
|
+
import { ContainerProps, RowProps, ColProps } from './types';
|
4
|
+
export declare const Container: React.FC<ContainerProps>;
|
5
|
+
export declare const Row: React.FC<RowProps>;
|
6
|
+
export declare const Col: React.FC<ColProps>;
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import { Meta, StoryObj } from '@storybook/react';
|
2
|
+
import { Container } from './GridLayout';
|
3
|
+
import './GridLayoutStory.scss';
|
4
|
+
declare const meta: Meta<typeof Container>;
|
5
|
+
type ContainerStory = StoryObj<typeof Container>;
|
6
|
+
export declare const Grid: ContainerStory;
|
7
|
+
export declare const Grid2: ContainerStory;
|
8
|
+
export default meta;
|
@@ -0,0 +1,57 @@
|
|
1
|
+
import { ReactNode } from 'react';
|
2
|
+
export interface ContainerProps {
|
3
|
+
/**
|
4
|
+
* The content to be displayed inside the container.
|
5
|
+
* Typically consists of rows and columns.
|
6
|
+
*
|
7
|
+
* @type {ReactNode}
|
8
|
+
*/
|
9
|
+
children: ReactNode;
|
10
|
+
/**
|
11
|
+
* Determines if the container should be fluid (expand to 100% width) or fixed width.
|
12
|
+
*
|
13
|
+
* @default false
|
14
|
+
* @type {boolean}
|
15
|
+
*/
|
16
|
+
fluid?: boolean;
|
17
|
+
/**
|
18
|
+
* Defines the gap (spacing) between the rows and columns inside the container.
|
19
|
+
* Accepts any valid CSS size value (e.g., '10px', '1rem', etc.).
|
20
|
+
*
|
21
|
+
* @default '0px'
|
22
|
+
* @type {string}
|
23
|
+
*/
|
24
|
+
gap?: string;
|
25
|
+
}
|
26
|
+
export interface RowProps {
|
27
|
+
/**
|
28
|
+
* The content to be displayed inside the row, usually consisting of columns (`<Col />`).
|
29
|
+
*
|
30
|
+
* @type {ReactNode}
|
31
|
+
*/
|
32
|
+
children: ReactNode;
|
33
|
+
/**
|
34
|
+
* The gap (spacing) between columns within the row.
|
35
|
+
* Accepts any valid CSS size value.
|
36
|
+
*
|
37
|
+
* @default '0px'
|
38
|
+
* @type {string}
|
39
|
+
*/
|
40
|
+
gap?: string;
|
41
|
+
}
|
42
|
+
export interface ColProps {
|
43
|
+
/**
|
44
|
+
* The content to be displayed inside the column.
|
45
|
+
*
|
46
|
+
* @type {ReactNode}
|
47
|
+
*/
|
48
|
+
children: ReactNode;
|
49
|
+
/**
|
50
|
+
* Defines the width of the column as a fraction of 12 (for a 12-column grid system).
|
51
|
+
* For example, `size={6}` would make the column take up half the width of the row.
|
52
|
+
*
|
53
|
+
* @default 12
|
54
|
+
* @type {number}
|
55
|
+
*/
|
56
|
+
size?: number;
|
57
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './HighlightText';
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './Icon';
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import './Input.scss';
|
2
|
+
import { InputProps } from './types';
|
3
|
+
declare const Input: ({ type, variant, name, label, disabled, required, placeholder, value, helperText, error, noBorder, className, onChange, onBlur, onFocus, autoComplete, minValue, maxValue, transparentBackground, ...props }: InputProps) => import("react/jsx-runtime").JSX.Element;
|
4
|
+
export default Input;
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
2
|
+
import Input from './Input';
|
3
|
+
declare const meta: Meta<typeof Input>;
|
4
|
+
type Story = StoryObj<typeof Input>;
|
5
|
+
export declare const Default: Story;
|
6
|
+
export declare const Primary: Story;
|
7
|
+
export declare const DisabledWithValue: Story;
|
8
|
+
export declare const Controlled: Story;
|
9
|
+
export default meta;
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './Input';
|
@@ -0,0 +1,74 @@
|
|
1
|
+
export interface InputProps {
|
2
|
+
/**
|
3
|
+
* Name | name of the input field
|
4
|
+
*/
|
5
|
+
name: string;
|
6
|
+
/**
|
7
|
+
* Label | field label to be displayed
|
8
|
+
*/
|
9
|
+
label: string;
|
10
|
+
/**
|
11
|
+
* value | input field value
|
12
|
+
*/
|
13
|
+
value: string | number;
|
14
|
+
/**
|
15
|
+
* variants to set color/style of the input field
|
16
|
+
*/
|
17
|
+
variant?: 'default' | 'primary';
|
18
|
+
/**
|
19
|
+
* type to set color/style of the input field
|
20
|
+
*/
|
21
|
+
type: 'text' | 'password' | 'number' | 'email' | 'url' | 'time';
|
22
|
+
/**
|
23
|
+
* error | If true, error message will be displayed
|
24
|
+
*/
|
25
|
+
error?: boolean;
|
26
|
+
/**
|
27
|
+
* helperText | error, success, warning message to be shown
|
28
|
+
*/
|
29
|
+
helperText?: string;
|
30
|
+
/**
|
31
|
+
* to disable the input field
|
32
|
+
*/
|
33
|
+
disabled?: boolean;
|
34
|
+
/**
|
35
|
+
* if true, input field will be mandatory
|
36
|
+
*/
|
37
|
+
required?: boolean;
|
38
|
+
/**
|
39
|
+
* placeholder for the input field
|
40
|
+
*/
|
41
|
+
placeholder?: string;
|
42
|
+
/**
|
43
|
+
* classnames to style the input field
|
44
|
+
*/
|
45
|
+
className?: string;
|
46
|
+
/**
|
47
|
+
* noBorder prop 'true' removes border of input
|
48
|
+
*/
|
49
|
+
noBorder?: boolean;
|
50
|
+
/**
|
51
|
+
* onChange, onKeyDown, onBlur, onFocus actions
|
52
|
+
*/
|
53
|
+
onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void;
|
54
|
+
onKeyDown?: (event: React.KeyboardEvent<HTMLInputElement>) => void;
|
55
|
+
onBlur?: (event: React.FocusEvent<HTMLInputElement>) => void;
|
56
|
+
onFocus?: (event: React.FocusEvent<HTMLInputElement>) => void;
|
57
|
+
/**
|
58
|
+
* id to select the input field uniquely
|
59
|
+
*/
|
60
|
+
id?: string;
|
61
|
+
/**
|
62
|
+
* if on, suggestion popup will be displayed
|
63
|
+
*/
|
64
|
+
autoComplete?: 'on' | 'off';
|
65
|
+
/**
|
66
|
+
* minimum and maximum values for the number type input field and their functions
|
67
|
+
*/
|
68
|
+
minValue?: number;
|
69
|
+
maxValue?: number;
|
70
|
+
/**
|
71
|
+
* background of the input field prop
|
72
|
+
*/
|
73
|
+
transparentBackground?: boolean;
|
74
|
+
}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import './InputWithDropdown.scss';
|
2
|
+
import { InputWithDropdownProps } from './types';
|
3
|
+
declare const InputWithDropdown: ({ name, label, value, type, disabled, required, placeholder, error, helperText, optionsList, selectedOption, onDropdownChangeHandler, onInputChangeHandler, }: InputWithDropdownProps) => import("react/jsx-runtime").JSX.Element;
|
4
|
+
export default InputWithDropdown;
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
2
|
+
import InputWithDropdown from './InputWithDropdown';
|
3
|
+
declare const meta: Meta<typeof InputWithDropdown>;
|
4
|
+
type Story = StoryObj<typeof InputWithDropdown>;
|
5
|
+
export declare const Default: Story;
|
6
|
+
export declare const DisabledWithValue: Story;
|
7
|
+
export declare const Controlled: Story;
|
8
|
+
export default meta;
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './InputWithDropdown';
|
@@ -0,0 +1,88 @@
|
|
1
|
+
import { ReactNode } from 'react';
|
2
|
+
export interface Option {
|
3
|
+
label: string | ReactNode;
|
4
|
+
value: string;
|
5
|
+
}
|
6
|
+
export interface InputWithDropdownProps {
|
7
|
+
/**
|
8
|
+
* Name | name of the input field
|
9
|
+
*/
|
10
|
+
name: string;
|
11
|
+
/**
|
12
|
+
* Label | field label to be displayed
|
13
|
+
*/
|
14
|
+
label: string;
|
15
|
+
/**
|
16
|
+
* value | input field value
|
17
|
+
*/
|
18
|
+
value: string | number;
|
19
|
+
/**
|
20
|
+
* variants to set color/style of the input field
|
21
|
+
*/
|
22
|
+
variant?: 'default' | 'primary';
|
23
|
+
/**
|
24
|
+
* type to set the input field type
|
25
|
+
*/
|
26
|
+
type: 'text' | 'password' | 'number' | 'time';
|
27
|
+
/**
|
28
|
+
* error | If true, error message will be displayed
|
29
|
+
*/
|
30
|
+
error?: boolean;
|
31
|
+
/**
|
32
|
+
* helperText | error, success, warning message to be shown
|
33
|
+
*/
|
34
|
+
helperText?: string;
|
35
|
+
/**
|
36
|
+
* to disable the input field
|
37
|
+
*/
|
38
|
+
disabled?: boolean;
|
39
|
+
/**
|
40
|
+
* if true, input field will be mandatory
|
41
|
+
*/
|
42
|
+
required?: boolean;
|
43
|
+
/**
|
44
|
+
* placeholder for the input field
|
45
|
+
*/
|
46
|
+
placeholder?: string;
|
47
|
+
/**
|
48
|
+
* classnames to style the input field
|
49
|
+
*/
|
50
|
+
className?: string;
|
51
|
+
/**
|
52
|
+
* Options for the select dropdown
|
53
|
+
*/
|
54
|
+
optionsList: Option[];
|
55
|
+
/**
|
56
|
+
* Selected option for the select dropdown
|
57
|
+
*/
|
58
|
+
selectedOption?: Option;
|
59
|
+
/**
|
60
|
+
* onChange handler for input changes
|
61
|
+
*/
|
62
|
+
onInputChangeHandler?: (event: React.ChangeEvent<HTMLInputElement>) => void;
|
63
|
+
/**
|
64
|
+
* onChange handler for dropdown changes
|
65
|
+
*/
|
66
|
+
onDropdownChangeHandler?: (option: Option) => void;
|
67
|
+
/**
|
68
|
+
* onFocus action for input field
|
69
|
+
*/
|
70
|
+
onFocus?: (event: React.FocusEvent<HTMLInputElement>) => void;
|
71
|
+
/**
|
72
|
+
* id to select the input field uniquely
|
73
|
+
*/
|
74
|
+
id?: string;
|
75
|
+
/**
|
76
|
+
* if on, suggestion popup will be displayed
|
77
|
+
*/
|
78
|
+
autoComplete?: 'on' | 'off';
|
79
|
+
/**
|
80
|
+
* minimum and maximum values for the number type input field
|
81
|
+
*/
|
82
|
+
minValue?: number;
|
83
|
+
maxValue?: number;
|
84
|
+
/**
|
85
|
+
* background of the input field prop
|
86
|
+
*/
|
87
|
+
isBackgroundTransparent?: boolean;
|
88
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
export * from './LazyLoad';
|