@dxc-technology/halstack-react 0.0.0-d3554d7 → 0.0.0-d3624d0
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/BackgroundColorContext.d.ts +1 -10
- package/BackgroundColorContext.js +5 -22
- package/HalstackContext.d.ts +1246 -0
- package/HalstackContext.js +310 -0
- package/README.md +47 -0
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +105 -181
- package/accordion/Accordion.stories.tsx +83 -149
- package/accordion/Accordion.test.js +32 -33
- package/accordion/types.d.ts +10 -17
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +3 -3
- package/accordion-group/AccordionGroup.js +38 -107
- package/accordion-group/AccordionGroup.stories.tsx +95 -68
- package/accordion-group/AccordionGroup.test.js +55 -90
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +31 -0
- package/accordion-group/AccordionGroupContext.d.ts +3 -0
- package/accordion-group/AccordionGroupContext.js +8 -0
- package/accordion-group/types.d.ts +16 -17
- package/action-icon/ActionIcon.accessibility.test.js +63 -0
- package/action-icon/ActionIcon.d.ts +4 -0
- package/action-icon/ActionIcon.js +48 -0
- package/action-icon/ActionIcon.stories.tsx +41 -0
- package/action-icon/ActionIcon.test.js +64 -0
- package/action-icon/types.d.ts +26 -0
- package/alert/Alert.accessibility.test.js +95 -0
- package/alert/Alert.js +40 -127
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +29 -46
- package/alert/types.d.ts +5 -5
- package/badge/Badge.accessibility.test.js +129 -0
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +142 -40
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -2
- package/bleed/Bleed.js +14 -55
- package/bleed/Bleed.stories.tsx +95 -95
- package/bleed/types.d.ts +26 -2
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.d.ts +1 -1
- package/box/Box.js +30 -81
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +2 -7
- package/box/types.d.ts +3 -14
- package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
- package/breadcrumbs/Breadcrumbs.d.ts +4 -0
- package/breadcrumbs/Breadcrumbs.js +79 -0
- package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
- package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.test.js +169 -0
- package/breadcrumbs/Item.d.ts +4 -0
- package/breadcrumbs/Item.js +52 -0
- package/breadcrumbs/dropdownTheme.d.ts +53 -0
- package/breadcrumbs/dropdownTheme.js +62 -0
- package/breadcrumbs/types.d.ts +16 -0
- package/bulleted-list/BulletedList.accessibility.test.js +119 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +92 -0
- package/bulleted-list/BulletedList.stories.tsx +115 -0
- package/bulleted-list/types.d.ts +38 -0
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +63 -113
- package/button/Button.stories.tsx +151 -100
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +12 -8
- package/card/Card.accessibility.test.js +36 -0
- package/card/Card.d.ts +1 -1
- package/card/Card.js +59 -102
- package/card/Card.stories.tsx +12 -42
- package/card/Card.test.js +11 -22
- package/card/types.d.ts +6 -11
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +143 -181
- package/checkbox/Checkbox.stories.tsx +166 -136
- package/checkbox/Checkbox.test.js +163 -29
- package/checkbox/types.d.ts +18 -6
- package/chip/Chip.accessibility.test.js +67 -0
- package/chip/Chip.js +45 -80
- package/chip/Chip.stories.tsx +107 -27
- package/chip/Chip.test.js +18 -33
- package/chip/types.d.ts +4 -4
- package/common/coreTokens.d.ts +237 -0
- package/common/coreTokens.js +184 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +6 -12
- package/common/variables.d.ts +1392 -0
- package/common/variables.js +1081 -1190
- package/container/Container.d.ts +4 -0
- package/container/Container.js +194 -0
- package/container/Container.stories.tsx +214 -0
- package/container/types.d.ts +74 -0
- package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
- package/contextual-menu/ContextualMenu.d.ts +5 -0
- package/contextual-menu/ContextualMenu.js +88 -0
- package/contextual-menu/ContextualMenu.stories.tsx +232 -0
- package/contextual-menu/ContextualMenu.test.js +205 -0
- package/contextual-menu/GroupItem.d.ts +4 -0
- package/contextual-menu/GroupItem.js +67 -0
- package/contextual-menu/ItemAction.d.ts +4 -0
- package/contextual-menu/ItemAction.js +51 -0
- package/contextual-menu/MenuItem.d.ts +4 -0
- package/contextual-menu/MenuItem.js +29 -0
- package/contextual-menu/SingleItem.d.ts +4 -0
- package/contextual-menu/SingleItem.js +38 -0
- package/contextual-menu/types.d.ts +58 -0
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.accessibility.test.js +228 -0
- package/date-input/DateInput.js +170 -306
- package/date-input/DateInput.stories.tsx +210 -56
- package/date-input/DateInput.test.js +708 -369
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +121 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +100 -0
- package/date-input/types.d.ts +86 -22
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.d.ts +1 -1
- package/dialog/Dialog.js +56 -129
- package/dialog/Dialog.stories.tsx +326 -167
- package/dialog/Dialog.test.js +287 -20
- package/dialog/types.d.ts +18 -25
- package/divider/Divider.accessibility.test.js +33 -0
- package/divider/Divider.d.ts +4 -0
- package/divider/Divider.js +36 -0
- package/divider/Divider.stories.tsx +223 -0
- package/divider/Divider.test.js +38 -0
- package/divider/types.d.ts +21 -0
- package/dropdown/Dropdown.accessibility.test.js +180 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +233 -307
- package/dropdown/Dropdown.stories.tsx +235 -57
- package/dropdown/Dropdown.test.js +575 -165
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +63 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +71 -0
- package/dropdown/types.d.ts +35 -19
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +246 -393
- package/file-input/FileInput.stories.tsx +123 -12
- package/file-input/FileInput.test.js +292 -367
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +61 -120
- package/file-input/types.d.ts +25 -8
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/flex/types.js +5 -0
- package/footer/Footer.accessibility.test.js +125 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +73 -191
- package/footer/Footer.stories.tsx +99 -21
- package/footer/Footer.test.js +33 -57
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +54 -23
- package/footer/types.d.ts +26 -27
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +76 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/grid/types.js +5 -0
- package/header/Header.accessibility.test.js +93 -0
- package/header/Header.d.ts +4 -3
- package/header/Header.js +104 -218
- package/header/Header.stories.tsx +168 -63
- package/header/Header.test.js +31 -28
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +5 -15
- package/header/types.d.ts +7 -21
- package/heading/Heading.accessibility.test.js +33 -0
- package/heading/Heading.js +10 -32
- package/heading/Heading.test.js +71 -88
- package/heading/types.d.ts +7 -7
- package/icon/Icon.accessibility.test.js +30 -0
- package/icon/Icon.d.ts +4 -0
- package/icon/Icon.js +33 -0
- package/icon/Icon.stories.tsx +28 -0
- package/icon/types.d.ts +4 -0
- package/icon/types.js +5 -0
- package/image/Image.accessibility.test.js +56 -0
- package/image/Image.d.ts +4 -0
- package/image/Image.js +70 -0
- package/image/Image.stories.tsx +129 -0
- package/image/types.d.ts +72 -0
- package/image/types.js +5 -0
- package/inset/Inset.js +14 -55
- package/inset/Inset.stories.tsx +37 -36
- package/inset/types.d.ts +26 -2
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +88 -182
- package/layout/ApplicationLayout.stories.tsx +85 -94
- package/layout/Icons.d.ts +7 -0
- package/layout/Icons.js +41 -48
- package/layout/types.d.ts +19 -35
- package/link/Link.accessibility.test.js +108 -0
- package/link/Link.d.ts +3 -2
- package/link/Link.js +65 -101
- package/link/Link.stories.tsx +157 -55
- package/link/Link.test.js +25 -53
- package/link/types.d.ts +15 -31
- package/main.d.ts +17 -13
- package/main.js +86 -101
- package/nav-tabs/NavTabs.accessibility.test.js +44 -0
- package/nav-tabs/NavTabs.d.ts +7 -0
- package/nav-tabs/NavTabs.js +93 -0
- package/nav-tabs/NavTabs.stories.tsx +279 -0
- package/nav-tabs/NavTabs.test.js +77 -0
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +117 -0
- package/nav-tabs/types.d.ts +52 -0
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.js +47 -44
- package/number-input/NumberInput.stories.tsx +44 -28
- package/number-input/NumberInput.test.js +862 -381
- package/number-input/NumberInputContext.d.ts +3 -4
- package/number-input/NumberInputContext.js +3 -14
- package/number-input/types.d.ts +34 -15
- package/package.json +54 -53
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +46 -100
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +280 -211
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.d.ts +5 -0
- package/paragraph/Paragraph.js +22 -0
- package/paragraph/Paragraph.stories.tsx +27 -0
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.js +58 -124
- package/password-input/PasswordInput.stories.tsx +1 -33
- package/password-input/PasswordInput.test.js +162 -147
- package/password-input/types.d.ts +21 -17
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +68 -92
- package/progress-bar/ProgressBar.stories.tsx +93 -0
- package/progress-bar/ProgressBar.test.js +72 -44
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +94 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +59 -76
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +73 -116
- package/radio-group/RadioGroup.stories.tsx +135 -17
- package/radio-group/RadioGroup.test.js +529 -467
- package/radio-group/types.d.ts +86 -9
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
- package/resultset-table/ResultsetTable.d.ts +7 -0
- package/resultset-table/ResultsetTable.js +171 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
- package/resultset-table/ResultsetTable.test.js +381 -0
- package/{resultsetTable → resultset-table}/types.d.ts +44 -11
- package/resultset-table/types.js +5 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +155 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +89 -0
- package/select/Select.accessibility.test.js +228 -0
- package/select/Select.js +237 -504
- package/select/Select.stories.tsx +533 -196
- package/select/Select.test.js +1953 -1588
- package/select/types.d.ts +65 -26
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +136 -71
- package/sidenav/Sidenav.stories.tsx +246 -151
- package/sidenav/Sidenav.test.js +26 -45
- package/sidenav/SidenavContext.d.ts +5 -0
- package/sidenav/SidenavContext.js +13 -0
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +149 -180
- package/slider/Slider.test.js +198 -73
- package/slider/types.d.ts +11 -3
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +34 -74
- package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
- package/spinner/Spinner.test.js +26 -35
- package/spinner/types.d.ts +3 -3
- package/status-light/StatusLight.accessibility.test.js +157 -0
- package/status-light/StatusLight.d.ts +4 -0
- package/status-light/StatusLight.js +51 -0
- package/status-light/StatusLight.stories.tsx +74 -0
- package/status-light/StatusLight.test.js +25 -0
- package/status-light/types.d.ts +17 -0
- package/status-light/types.js +5 -0
- package/switch/Switch.accessibility.test.js +98 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +149 -114
- package/switch/Switch.stories.tsx +56 -67
- package/switch/Switch.test.js +146 -39
- package/switch/types.d.ts +13 -5
- package/table/DropdownTheme.js +62 -0
- package/table/Table.accessibility.test.js +93 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +78 -35
- package/table/Table.stories.tsx +663 -0
- package/table/Table.test.js +95 -8
- package/table/types.d.ts +34 -6
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +117 -0
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +305 -145
- package/tabs/Tabs.stories.tsx +124 -14
- package/tabs/Tabs.test.js +220 -67
- package/tabs/types.d.ts +31 -17
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +42 -79
- package/tag/Tag.stories.tsx +24 -10
- package/tag/Tag.test.js +18 -37
- package/tag/types.d.ts +9 -9
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +67 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +94 -0
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +332 -557
- package/text-input/TextInput.stories.tsx +282 -282
- package/text-input/TextInput.test.js +1442 -1377
- package/text-input/types.d.ts +70 -24
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.js +83 -134
- package/textarea/Textarea.stories.tsx +174 -0
- package/textarea/Textarea.test.js +168 -198
- package/textarea/types.d.ts +27 -16
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +94 -106
- package/toggle-group/ToggleGroup.stories.tsx +56 -11
- package/toggle-group/ToggleGroup.test.js +78 -66
- package/toggle-group/types.d.ts +36 -19
- package/typography/Typography.accessibility.test.js +339 -0
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +23 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1144 -1
- package/useTheme.js +4 -11
- package/useTranslatedLabels.d.ts +85 -0
- package/useTranslatedLabels.js +14 -0
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +94 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +124 -0
- package/wizard/Wizard.accessibility.test.js +55 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +78 -120
- package/wizard/Wizard.stories.tsx +67 -19
- package/wizard/Wizard.test.js +73 -87
- package/wizard/types.d.ts +14 -10
- package/ThemeContext.d.ts +0 -10
- package/ThemeContext.js +0 -243
- package/card/ice-cream.jpg +0 -0
- package/common/OpenSans.css +0 -81
- package/common/RequiredComponent.js +0 -32
- package/common/fonts/OpenSans-Bold.ttf +0 -0
- package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-Italic.ttf +0 -0
- package/common/fonts/OpenSans-Light.ttf +0 -0
- package/common/fonts/OpenSans-LightItalic.ttf +0 -0
- package/common/fonts/OpenSans-Regular.ttf +0 -0
- package/common/fonts/OpenSans-SemiBold.ttf +0 -0
- package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/list/types.d.ts +0 -7
- package/number-input/numberInputContextTypes.d.ts +0 -19
- package/paginator/Icons.js +0 -66
- package/progress-bar/ProgressBar.stories.jsx +0 -58
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/Radio.test.js +0 -71
- package/radio/types.d.ts +0 -54
- package/resultsetTable/ResultsetTable.d.ts +0 -4
- package/resultsetTable/ResultsetTable.js +0 -254
- package/resultsetTable/ResultsetTable.test.js +0 -306
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -10
- package/slider/Slider.stories.tsx +0 -177
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -9
- package/table/Table.stories.jsx +0 -277
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- package/textarea/Textarea.stories.jsx +0 -157
- /package/{list → action-icon}/types.js +0 -0
- /package/{radio → breadcrumbs}/types.js +0 -0
- /package/{resultsetTable → bulleted-list}/types.js +0 -0
- /package/{row → container}/types.js +0 -0
- /package/{stack → contextual-menu}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → divider/types.js} +0 -0
package/file-input/FileInput.js
CHANGED
|
@@ -1,443 +1,328 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
var _typeof3 = require("@babel/runtime/helpers/typeof");
|
|
6
|
-
|
|
7
5
|
Object.defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
8
|
exports["default"] = void 0;
|
|
11
|
-
|
|
12
9
|
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
13
|
-
|
|
14
10
|
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
15
|
-
|
|
16
11
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
17
|
-
|
|
18
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
19
|
-
|
|
20
12
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
21
|
-
|
|
22
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
23
|
-
|
|
13
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
24
14
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
25
|
-
|
|
15
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
26
16
|
var _react = _interopRequireWildcard(require("react"));
|
|
27
|
-
|
|
28
17
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
29
|
-
|
|
30
18
|
var _uuid = require("uuid");
|
|
31
|
-
|
|
32
|
-
var _variables = require("../common/variables.js");
|
|
33
|
-
|
|
19
|
+
var _variables = require("../common/variables");
|
|
34
20
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
35
|
-
|
|
21
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
36
22
|
var _Button = _interopRequireDefault(require("../button/Button"));
|
|
37
|
-
|
|
38
23
|
var _FileItem = _interopRequireDefault(require("./FileItem"));
|
|
39
|
-
|
|
40
|
-
var
|
|
41
|
-
|
|
42
|
-
function
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
})
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
})
|
|
88
|
-
|
|
89
|
-
var
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
24
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11;
|
|
25
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
26
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
27
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
28
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
29
|
+
var getFilePreview = /*#__PURE__*/function () {
|
|
30
|
+
var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(file) {
|
|
31
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
32
|
+
while (1) switch (_context.prev = _context.next) {
|
|
33
|
+
case 0:
|
|
34
|
+
if (!file.type.includes("video")) {
|
|
35
|
+
_context.next = 4;
|
|
36
|
+
break;
|
|
37
|
+
}
|
|
38
|
+
return _context.abrupt("return", "filled_movie");
|
|
39
|
+
case 4:
|
|
40
|
+
if (!file.type.includes("audio")) {
|
|
41
|
+
_context.next = 8;
|
|
42
|
+
break;
|
|
43
|
+
}
|
|
44
|
+
return _context.abrupt("return", "music_video");
|
|
45
|
+
case 8:
|
|
46
|
+
if (!file.type.includes("image")) {
|
|
47
|
+
_context.next = 12;
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
return _context.abrupt("return", new Promise(function (resolve) {
|
|
51
|
+
var reader = new FileReader();
|
|
52
|
+
reader.readAsDataURL(file);
|
|
53
|
+
reader.onload = function (e) {
|
|
54
|
+
resolve(e.target.result);
|
|
55
|
+
};
|
|
56
|
+
}));
|
|
57
|
+
case 12:
|
|
58
|
+
return _context.abrupt("return", "draft");
|
|
59
|
+
case 13:
|
|
60
|
+
case "end":
|
|
61
|
+
return _context.stop();
|
|
62
|
+
}
|
|
63
|
+
}, _callee);
|
|
64
|
+
}));
|
|
65
|
+
return function getFilePreview(_x) {
|
|
66
|
+
return _ref.apply(this, arguments);
|
|
67
|
+
};
|
|
68
|
+
}();
|
|
69
|
+
var isFileIncluded = function isFileIncluded(file, fileList) {
|
|
70
|
+
var fileListInfo = fileList.map(function (existingFile) {
|
|
71
|
+
return existingFile.file;
|
|
72
|
+
});
|
|
73
|
+
return fileListInfo.some(function (_ref2) {
|
|
74
|
+
var name = _ref2.name,
|
|
75
|
+
size = _ref2.size,
|
|
76
|
+
type = _ref2.type,
|
|
77
|
+
lastModified = _ref2.lastModified,
|
|
78
|
+
webkitRelativePath = _ref2.webkitRelativePath;
|
|
79
|
+
return name === file.file.name && size === file.file.size && type === file.file.type && lastModified === file.file.lastModified && webkitRelativePath === file.file.webkitRelativePath;
|
|
80
|
+
});
|
|
81
|
+
};
|
|
82
|
+
var DxcFileInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref3, ref) {
|
|
83
|
+
var _ref3$name = _ref3.name,
|
|
84
|
+
name = _ref3$name === void 0 ? "" : _ref3$name,
|
|
85
|
+
_ref3$mode = _ref3.mode,
|
|
86
|
+
mode = _ref3$mode === void 0 ? "file" : _ref3$mode,
|
|
87
|
+
_ref3$label = _ref3.label,
|
|
88
|
+
label = _ref3$label === void 0 ? "" : _ref3$label,
|
|
89
|
+
buttonLabel = _ref3.buttonLabel,
|
|
90
|
+
dropAreaLabel = _ref3.dropAreaLabel,
|
|
91
|
+
_ref3$helperText = _ref3.helperText,
|
|
92
|
+
helperText = _ref3$helperText === void 0 ? "" : _ref3$helperText,
|
|
93
|
+
accept = _ref3.accept,
|
|
94
|
+
minSize = _ref3.minSize,
|
|
95
|
+
maxSize = _ref3.maxSize,
|
|
96
|
+
_ref3$showPreview = _ref3.showPreview,
|
|
97
|
+
showPreview = _ref3$showPreview === void 0 ? false : _ref3$showPreview,
|
|
98
|
+
_ref3$multiple = _ref3.multiple,
|
|
99
|
+
multiple = _ref3$multiple === void 0 ? true : _ref3$multiple,
|
|
100
|
+
_ref3$disabled = _ref3.disabled,
|
|
101
|
+
disabled = _ref3$disabled === void 0 ? false : _ref3$disabled,
|
|
102
|
+
callbackFile = _ref3.callbackFile,
|
|
103
|
+
value = _ref3.value,
|
|
104
|
+
margin = _ref3.margin,
|
|
105
|
+
_ref3$tabIndex = _ref3.tabIndex,
|
|
106
|
+
tabIndex = _ref3$tabIndex === void 0 ? 0 : _ref3$tabIndex;
|
|
115
107
|
var _useState = (0, _react.useState)(false),
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
108
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
109
|
+
isDragging = _useState2[0],
|
|
110
|
+
setIsDragging = _useState2[1];
|
|
120
111
|
var _useState3 = (0, _react.useState)([]),
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
112
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
113
|
+
files = _useState4[0],
|
|
114
|
+
setFiles = _useState4[1];
|
|
125
115
|
var _useState5 = (0, _react.useState)("file-input-".concat((0, _uuid.v4)())),
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
116
|
+
_useState6 = (0, _slicedToArray2["default"])(_useState5, 1),
|
|
117
|
+
fileInputId = _useState6[0];
|
|
129
118
|
var colorsTheme = (0, _useTheme["default"])();
|
|
130
|
-
(0,
|
|
131
|
-
var getFiles = /*#__PURE__*/function () {
|
|
132
|
-
var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
133
|
-
var valueFiles;
|
|
134
|
-
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
135
|
-
while (1) {
|
|
136
|
-
switch (_context2.prev = _context2.next) {
|
|
137
|
-
case 0:
|
|
138
|
-
if (!value) {
|
|
139
|
-
_context2.next = 5;
|
|
140
|
-
break;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
_context2.next = 3;
|
|
144
|
-
return Promise.all(value.map( /*#__PURE__*/function () {
|
|
145
|
-
var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(file) {
|
|
146
|
-
var preview;
|
|
147
|
-
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
148
|
-
while (1) {
|
|
149
|
-
switch (_context.prev = _context.next) {
|
|
150
|
-
case 0:
|
|
151
|
-
if (!file.preview) {
|
|
152
|
-
_context.next = 4;
|
|
153
|
-
break;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
return _context.abrupt("return", file);
|
|
157
|
-
|
|
158
|
-
case 4:
|
|
159
|
-
_context.next = 6;
|
|
160
|
-
return getFilePreview(file.file);
|
|
161
|
-
|
|
162
|
-
case 6:
|
|
163
|
-
preview = _context.sent;
|
|
164
|
-
return _context.abrupt("return", _objectSpread(_objectSpread({}, file), {}, {
|
|
165
|
-
preview: preview
|
|
166
|
-
}));
|
|
167
|
-
|
|
168
|
-
case 8:
|
|
169
|
-
case "end":
|
|
170
|
-
return _context.stop();
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
}, _callee);
|
|
174
|
-
}));
|
|
175
|
-
|
|
176
|
-
return function (_x) {
|
|
177
|
-
return _ref3.apply(this, arguments);
|
|
178
|
-
};
|
|
179
|
-
}()));
|
|
180
|
-
|
|
181
|
-
case 3:
|
|
182
|
-
valueFiles = _context2.sent;
|
|
183
|
-
setFiles(valueFiles);
|
|
184
|
-
|
|
185
|
-
case 5:
|
|
186
|
-
case "end":
|
|
187
|
-
return _context2.stop();
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
}, _callee2);
|
|
191
|
-
}));
|
|
192
|
-
|
|
193
|
-
return function getFiles() {
|
|
194
|
-
return _ref2.apply(this, arguments);
|
|
195
|
-
};
|
|
196
|
-
}();
|
|
197
|
-
|
|
198
|
-
getFiles();
|
|
199
|
-
}, [value]);
|
|
200
|
-
|
|
201
|
-
var handleClick = function handleClick() {
|
|
202
|
-
document.getElementById(fileInputId).click();
|
|
203
|
-
};
|
|
204
|
-
|
|
119
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
205
120
|
var checkFileSize = function checkFileSize(file) {
|
|
206
|
-
if (file.size < minSize)
|
|
207
|
-
return "File size must be greater than min size.";
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
if (file.size > maxSize) {
|
|
211
|
-
return "File size must be less than max size.";
|
|
212
|
-
}
|
|
121
|
+
if (file.size < minSize) return translatedLabels.fileInput.fileSizeGreaterThanErrorMessage;else if (file.size > maxSize) return translatedLabels.fileInput.fileSizeLessThanErrorMessage;
|
|
213
122
|
};
|
|
214
|
-
|
|
215
|
-
var getFilePreview = function getFilePreview(file) {
|
|
216
|
-
if (file.type.includes("video")) {
|
|
217
|
-
return videoIcon;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
if (file.type.includes("audio")) {
|
|
221
|
-
return audioIcon;
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
if (file.type.includes("image")) {
|
|
225
|
-
return new Promise(function (resolve) {
|
|
226
|
-
var reader = new FileReader();
|
|
227
|
-
reader.readAsDataURL(file);
|
|
228
|
-
|
|
229
|
-
reader.onload = function (e) {
|
|
230
|
-
resolve(e.target.result);
|
|
231
|
-
};
|
|
232
|
-
});
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
return fileIcon;
|
|
236
|
-
};
|
|
237
|
-
|
|
238
123
|
var getFilesToAdd = /*#__PURE__*/function () {
|
|
239
|
-
var _ref4 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
124
|
+
var _ref4 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(selectedFiles) {
|
|
240
125
|
var filesToAdd;
|
|
241
|
-
return _regenerator["default"].wrap(function
|
|
242
|
-
while (1) {
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
return
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
return fileInfo;
|
|
256
|
-
});
|
|
126
|
+
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
127
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
128
|
+
case 0:
|
|
129
|
+
_context2.next = 2;
|
|
130
|
+
return Promise.all(selectedFiles.map(function (selectedFile) {
|
|
131
|
+
return getFilePreview(selectedFile);
|
|
132
|
+
})).then(function (previews) {
|
|
133
|
+
return selectedFiles.map(function (file, index) {
|
|
134
|
+
var fileInfo = {
|
|
135
|
+
file: file,
|
|
136
|
+
error: checkFileSize(file),
|
|
137
|
+
preview: previews[index]
|
|
138
|
+
};
|
|
139
|
+
return fileInfo;
|
|
257
140
|
});
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
141
|
+
});
|
|
142
|
+
case 2:
|
|
143
|
+
filesToAdd = _context2.sent;
|
|
144
|
+
return _context2.abrupt("return", filesToAdd.filter(function (file) {
|
|
145
|
+
return !isFileIncluded(file, files);
|
|
146
|
+
}));
|
|
147
|
+
case 4:
|
|
148
|
+
case "end":
|
|
149
|
+
return _context2.stop();
|
|
267
150
|
}
|
|
268
|
-
},
|
|
151
|
+
}, _callee2);
|
|
269
152
|
}));
|
|
270
|
-
|
|
271
153
|
return function getFilesToAdd(_x2) {
|
|
272
154
|
return _ref4.apply(this, arguments);
|
|
273
155
|
};
|
|
274
156
|
}();
|
|
275
|
-
|
|
276
157
|
var addFile = /*#__PURE__*/function () {
|
|
277
|
-
var _ref5 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
278
|
-
var filesToAdd, finalFiles
|
|
279
|
-
return _regenerator["default"].wrap(function
|
|
280
|
-
while (1) {
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
case 3:
|
|
292
|
-
filesToAdd = _context4.sent;
|
|
293
|
-
finalFiles = [].concat((0, _toConsumableArray2["default"])(files), (0, _toConsumableArray2["default"])(filesToAdd));
|
|
294
|
-
|
|
295
|
-
if (typeof callbackFile === "function") {
|
|
296
|
-
callbackFile(finalFiles);
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
_context4.next = 19;
|
|
300
|
-
break;
|
|
301
|
-
|
|
302
|
-
case 8:
|
|
303
|
-
if (!(selectedFiles.length === 1)) {
|
|
304
|
-
_context4.next = 14;
|
|
305
|
-
break;
|
|
306
|
-
}
|
|
307
|
-
|
|
308
|
-
_context4.next = 11;
|
|
309
|
-
return getFilesToAdd(selectedFiles);
|
|
310
|
-
|
|
311
|
-
case 11:
|
|
312
|
-
_context4.t0 = _context4.sent;
|
|
313
|
-
_context4.next = 17;
|
|
314
|
-
break;
|
|
315
|
-
|
|
316
|
-
case 14:
|
|
317
|
-
_context4.next = 16;
|
|
318
|
-
return getFilesToAdd([selectedFiles[0]]);
|
|
319
|
-
|
|
320
|
-
case 16:
|
|
321
|
-
_context4.t0 = _context4.sent;
|
|
322
|
-
|
|
323
|
-
case 17:
|
|
324
|
-
fileToAdd = _context4.t0;
|
|
325
|
-
|
|
326
|
-
if (typeof callbackFile === "function") {
|
|
327
|
-
callbackFile(fileToAdd);
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
case 19:
|
|
331
|
-
case "end":
|
|
332
|
-
return _context4.stop();
|
|
333
|
-
}
|
|
158
|
+
var _ref5 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3(selectedFiles) {
|
|
159
|
+
var filesToAdd, finalFiles;
|
|
160
|
+
return _regenerator["default"].wrap(function _callee3$(_context3) {
|
|
161
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
162
|
+
case 0:
|
|
163
|
+
_context3.next = 2;
|
|
164
|
+
return getFilesToAdd(multiple ? selectedFiles : selectedFiles.length === 1 ? selectedFiles : [selectedFiles[0]]);
|
|
165
|
+
case 2:
|
|
166
|
+
filesToAdd = _context3.sent;
|
|
167
|
+
finalFiles = multiple ? [].concat((0, _toConsumableArray2["default"])(files), (0, _toConsumableArray2["default"])(filesToAdd)) : filesToAdd;
|
|
168
|
+
callbackFile === null || callbackFile === void 0 ? void 0 : callbackFile(finalFiles);
|
|
169
|
+
case 5:
|
|
170
|
+
case "end":
|
|
171
|
+
return _context3.stop();
|
|
334
172
|
}
|
|
335
|
-
},
|
|
173
|
+
}, _callee3);
|
|
336
174
|
}));
|
|
337
|
-
|
|
338
175
|
return function addFile(_x3) {
|
|
339
176
|
return _ref5.apply(this, arguments);
|
|
340
177
|
};
|
|
341
178
|
}();
|
|
342
|
-
|
|
343
179
|
var selectFiles = function selectFiles(e) {
|
|
344
180
|
var selectedFiles = e.target.files;
|
|
345
181
|
var filesArray = Object.keys(selectedFiles).map(function (key) {
|
|
346
182
|
return selectedFiles[key];
|
|
347
183
|
});
|
|
348
184
|
addFile(filesArray);
|
|
185
|
+
e.target.value = null;
|
|
349
186
|
};
|
|
350
|
-
|
|
351
|
-
var onDelete = function onDelete(fileName) {
|
|
187
|
+
var onDelete = (0, _react.useCallback)(function (fileName) {
|
|
352
188
|
var filesCopy = (0, _toConsumableArray2["default"])(files);
|
|
353
189
|
var fileToRemove = filesCopy.find(function (file) {
|
|
354
190
|
return file.file.name === fileName;
|
|
355
191
|
});
|
|
356
192
|
var fileIndex = filesCopy.indexOf(fileToRemove);
|
|
357
193
|
filesCopy.splice(fileIndex, 1);
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
194
|
+
callbackFile === null || callbackFile === void 0 ? void 0 : callbackFile(filesCopy);
|
|
195
|
+
}, [files, callbackFile]);
|
|
196
|
+
var handleClick = function handleClick() {
|
|
197
|
+
document.getElementById(fileInputId).click();
|
|
362
198
|
};
|
|
363
|
-
|
|
364
199
|
var handleDrag = function handleDrag(e) {
|
|
365
200
|
e.preventDefault();
|
|
366
201
|
e.stopPropagation();
|
|
367
202
|
};
|
|
368
|
-
|
|
369
203
|
var handleDragIn = function handleDragIn(e) {
|
|
370
|
-
|
|
204
|
+
var _e$dataTransfer$items;
|
|
205
|
+
if (((_e$dataTransfer$items = e.dataTransfer.items) === null || _e$dataTransfer$items === void 0 ? void 0 : _e$dataTransfer$items.length) > 0) setIsDragging(true);
|
|
371
206
|
};
|
|
372
|
-
|
|
373
207
|
var handleDragOut = function handleDragOut(e) {
|
|
374
208
|
// only if dragged items leave container (outside, not to childs)
|
|
375
209
|
if (!e.currentTarget.contains(e.relatedTarget)) setIsDragging(false);
|
|
376
210
|
};
|
|
377
|
-
|
|
378
211
|
var handleDrop = function handleDrop(e) {
|
|
379
212
|
e.preventDefault();
|
|
380
213
|
e.stopPropagation();
|
|
381
214
|
setIsDragging(false);
|
|
382
215
|
var filesObject = e.dataTransfer.files;
|
|
383
|
-
|
|
384
|
-
if (filesObject && filesObject.length > 0) {
|
|
216
|
+
if ((filesObject === null || filesObject === void 0 ? void 0 : filesObject.length) > 0) {
|
|
385
217
|
var filesArray = Object.keys(filesObject).map(function (key) {
|
|
386
218
|
return filesObject[key];
|
|
387
219
|
});
|
|
388
220
|
addFile(filesArray);
|
|
389
221
|
}
|
|
390
222
|
};
|
|
391
|
-
|
|
223
|
+
(0, _react.useEffect)(function () {
|
|
224
|
+
var getFiles = /*#__PURE__*/function () {
|
|
225
|
+
var _ref6 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
|
|
226
|
+
var valueFiles;
|
|
227
|
+
return _regenerator["default"].wrap(function _callee5$(_context5) {
|
|
228
|
+
while (1) switch (_context5.prev = _context5.next) {
|
|
229
|
+
case 0:
|
|
230
|
+
if (!value) {
|
|
231
|
+
_context5.next = 5;
|
|
232
|
+
break;
|
|
233
|
+
}
|
|
234
|
+
_context5.next = 3;
|
|
235
|
+
return Promise.all(value.map( /*#__PURE__*/function () {
|
|
236
|
+
var _ref7 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4(file) {
|
|
237
|
+
var preview;
|
|
238
|
+
return _regenerator["default"].wrap(function _callee4$(_context4) {
|
|
239
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
240
|
+
case 0:
|
|
241
|
+
if (!file.preview) {
|
|
242
|
+
_context4.next = 4;
|
|
243
|
+
break;
|
|
244
|
+
}
|
|
245
|
+
return _context4.abrupt("return", file);
|
|
246
|
+
case 4:
|
|
247
|
+
_context4.next = 6;
|
|
248
|
+
return getFilePreview(file.file);
|
|
249
|
+
case 6:
|
|
250
|
+
preview = _context4.sent;
|
|
251
|
+
return _context4.abrupt("return", _objectSpread(_objectSpread({}, file), {}, {
|
|
252
|
+
preview: preview
|
|
253
|
+
}));
|
|
254
|
+
case 8:
|
|
255
|
+
case "end":
|
|
256
|
+
return _context4.stop();
|
|
257
|
+
}
|
|
258
|
+
}, _callee4);
|
|
259
|
+
}));
|
|
260
|
+
return function (_x4) {
|
|
261
|
+
return _ref7.apply(this, arguments);
|
|
262
|
+
};
|
|
263
|
+
}()));
|
|
264
|
+
case 3:
|
|
265
|
+
valueFiles = _context5.sent;
|
|
266
|
+
setFiles(valueFiles);
|
|
267
|
+
case 5:
|
|
268
|
+
case "end":
|
|
269
|
+
return _context5.stop();
|
|
270
|
+
}
|
|
271
|
+
}, _callee5);
|
|
272
|
+
}));
|
|
273
|
+
return function getFiles() {
|
|
274
|
+
return _ref6.apply(this, arguments);
|
|
275
|
+
};
|
|
276
|
+
}();
|
|
277
|
+
getFiles();
|
|
278
|
+
}, [value]);
|
|
392
279
|
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
393
280
|
theme: colorsTheme.fileInput
|
|
394
281
|
}, /*#__PURE__*/_react["default"].createElement(FileInputContainer, {
|
|
395
282
|
margin: margin,
|
|
396
|
-
|
|
283
|
+
ref: ref
|
|
397
284
|
}, /*#__PURE__*/_react["default"].createElement(Label, {
|
|
398
285
|
htmlFor: fileInputId,
|
|
399
286
|
disabled: disabled
|
|
400
287
|
}, label), /*#__PURE__*/_react["default"].createElement(HelperText, {
|
|
401
288
|
disabled: disabled
|
|
402
289
|
}, helperText), mode === "file" ? /*#__PURE__*/_react["default"].createElement(FileContainer, {
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
}, /*#__PURE__*/_react["default"].createElement(HiddenInputFile, {
|
|
290
|
+
singleFileMode: !multiple && files.length === 1
|
|
291
|
+
}, /*#__PURE__*/_react["default"].createElement(ValueInput, {
|
|
406
292
|
id: fileInputId,
|
|
407
293
|
type: "file",
|
|
408
294
|
accept: accept,
|
|
409
295
|
multiple: multiple,
|
|
410
|
-
onChange: selectFiles
|
|
296
|
+
onChange: selectFiles,
|
|
297
|
+
disabled: disabled,
|
|
298
|
+
readOnly: true
|
|
411
299
|
}), /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
412
300
|
mode: "secondary",
|
|
413
|
-
label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel : multiple ?
|
|
301
|
+
label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel : multiple ? translatedLabels.fileInput.multipleButtonLabelDefault : translatedLabels.fileInput.singleButtonLabelDefault,
|
|
414
302
|
onClick: handleClick,
|
|
415
303
|
disabled: disabled,
|
|
416
|
-
size: "
|
|
304
|
+
size: "fitContent",
|
|
417
305
|
tabIndex: tabIndex
|
|
418
|
-
}), files.map(function (file) {
|
|
419
|
-
return /*#__PURE__*/_react["default"].createElement(
|
|
420
|
-
|
|
421
|
-
multiple: multiple,
|
|
422
|
-
files: files
|
|
423
|
-
}, /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
|
|
424
|
-
mode: mode,
|
|
425
|
-
multiple: multiple,
|
|
426
|
-
name: file.file.name,
|
|
306
|
+
}), files.length > 0 && /*#__PURE__*/_react["default"].createElement(FileItemListContainer, null, files.map(function (file, index) {
|
|
307
|
+
return /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
|
|
308
|
+
fileName: file.file.name,
|
|
427
309
|
error: file.error,
|
|
310
|
+
singleFileMode: !multiple && files.length === 1,
|
|
428
311
|
showPreview: mode === "file" && !multiple ? false : showPreview,
|
|
429
|
-
numFiles: files.length,
|
|
430
312
|
preview: file.preview,
|
|
431
313
|
type: file.file.type,
|
|
432
314
|
onDelete: onDelete,
|
|
433
|
-
tabIndex: tabIndex
|
|
434
|
-
|
|
435
|
-
|
|
315
|
+
tabIndex: tabIndex,
|
|
316
|
+
key: "file-".concat(index)
|
|
317
|
+
});
|
|
318
|
+
}))) : /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
|
|
436
319
|
id: fileInputId,
|
|
437
320
|
type: "file",
|
|
438
321
|
accept: accept,
|
|
439
322
|
multiple: multiple,
|
|
440
|
-
onChange: selectFiles
|
|
323
|
+
onChange: selectFiles,
|
|
324
|
+
disabled: disabled,
|
|
325
|
+
readOnly: true
|
|
441
326
|
}), /*#__PURE__*/_react["default"].createElement(DragDropArea, {
|
|
442
327
|
isDragging: isDragging,
|
|
443
328
|
disabled: disabled,
|
|
@@ -446,40 +331,30 @@ var DxcFileInput = function DxcFileInput(_ref) {
|
|
|
446
331
|
onDragEnter: handleDragIn,
|
|
447
332
|
onDragOver: handleDrag,
|
|
448
333
|
onDragLeave: handleDragOut
|
|
449
|
-
}, /*#__PURE__*/_react["default"].createElement(ButtonContainer, {
|
|
450
|
-
mode: mode
|
|
451
334
|
}, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
|
|
452
335
|
mode: "secondary",
|
|
453
|
-
label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel :
|
|
336
|
+
label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel : translatedLabels.fileInput.dropAreaButtonLabelDefault,
|
|
454
337
|
onClick: handleClick,
|
|
455
338
|
disabled: disabled,
|
|
456
339
|
size: "fitContent"
|
|
457
|
-
})
|
|
340
|
+
}), mode === "dropzone" ? /*#__PURE__*/_react["default"].createElement(DropzoneLabel, {
|
|
458
341
|
disabled: disabled
|
|
459
|
-
}, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ?
|
|
342
|
+
}, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ? translatedLabels.fileInput.multipleDropAreaLabelDefault : translatedLabels.fileInput.singleDropAreaLabelDefault) : /*#__PURE__*/_react["default"].createElement(FiledropLabel, {
|
|
460
343
|
disabled: disabled
|
|
461
|
-
}, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ?
|
|
462
|
-
return /*#__PURE__*/_react["default"].createElement(
|
|
463
|
-
|
|
464
|
-
multiple: multiple,
|
|
465
|
-
files: files
|
|
466
|
-
}, /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
|
|
467
|
-
mode: mode,
|
|
468
|
-
multiple: multiple,
|
|
469
|
-
name: file.file.name,
|
|
344
|
+
}, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ? translatedLabels.fileInput.multipleDropAreaLabelDefault : translatedLabels.fileInput.singleDropAreaLabelDefault)), files.length > 0 && /*#__PURE__*/_react["default"].createElement(FileItemListContainer, null, files.map(function (file, index) {
|
|
345
|
+
return /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
|
|
346
|
+
fileName: file.file.name,
|
|
470
347
|
error: file.error,
|
|
348
|
+
singleFileMode: false,
|
|
471
349
|
showPreview: showPreview,
|
|
472
|
-
numFiles: files.length,
|
|
473
350
|
preview: file.preview,
|
|
474
351
|
type: file.file.type,
|
|
475
352
|
onDelete: onDelete,
|
|
476
|
-
tabIndex: tabIndex
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
};
|
|
482
|
-
|
|
353
|
+
tabIndex: tabIndex,
|
|
354
|
+
key: "file-".concat(index)
|
|
355
|
+
});
|
|
356
|
+
}))), mode === "file" && !multiple && files.length === 1 && files[0].error && /*#__PURE__*/_react["default"].createElement(ErrorMessage, null, files[0].error)));
|
|
357
|
+
});
|
|
483
358
|
var FileInputContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: fit-content;\n"])), function (props) {
|
|
484
359
|
return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
|
|
485
360
|
}, function (props) {
|
|
@@ -491,7 +366,6 @@ var FileInputContainer = _styledComponents["default"].div(_templateObject || (_t
|
|
|
491
366
|
}, function (props) {
|
|
492
367
|
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
|
|
493
368
|
});
|
|
494
|
-
|
|
495
369
|
var Label = _styledComponents["default"].label(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
|
|
496
370
|
return props.disabled ? props.theme.disabledLabelFontColor : props.theme.labelFontColor;
|
|
497
371
|
}, function (props) {
|
|
@@ -503,7 +377,6 @@ var Label = _styledComponents["default"].label(_templateObject2 || (_templateObj
|
|
|
503
377
|
}, function (props) {
|
|
504
378
|
return props.theme.labelLineHeight;
|
|
505
379
|
});
|
|
506
|
-
|
|
507
380
|
var HelperText = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
|
|
508
381
|
return props.disabled ? props.theme.disabledHelperTextFontcolor : props.theme.helperTextFontColor;
|
|
509
382
|
}, function (props) {
|
|
@@ -515,13 +388,16 @@ var HelperText = _styledComponents["default"].span(_templateObject3 || (_templat
|
|
|
515
388
|
}, function (props) {
|
|
516
389
|
return props.theme.helperTextLineHeight;
|
|
517
390
|
});
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
391
|
+
var FileContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n ", "\n margin-top: 0.25rem;\n"])), function (props) {
|
|
392
|
+
return props.singleFileMode ? "flex-direction: row; column-gap: 0.25rem;" : "flex-direction: column; row-gap: 0.25rem;";
|
|
393
|
+
});
|
|
394
|
+
var ValueInput = _styledComponents["default"].input(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
|
|
395
|
+
var FileItemListContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n row-gap: 0.25rem;\n"])));
|
|
396
|
+
var Container = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n row-gap: 0.25rem;\n margin-top: 0.25rem;\n"])));
|
|
397
|
+
var DragDropArea = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n ", "\n align-items: center;\n width: 320px;\n padding: ", ";\n overflow: hidden;\n box-shadow: 0 0 0 2px transparent;\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n ", "\n cursor: ", ";\n"])), function (props) {
|
|
398
|
+
return props.mode === "filedrop" ? "flex-direction: row; column-gap: 0.75rem; height: 48px;" : "justify-content: center; flex-direction: column; row-gap: 0.5rem; height: 160px;";
|
|
523
399
|
}, function (props) {
|
|
524
|
-
return props.mode === "filedrop" ? "
|
|
400
|
+
return props.mode === "filedrop" ? "calc(4px - ".concat(props.theme.dropBorderThickness, ") 1rem calc(4px - ").concat(props.theme.dropBorderThickness, ") calc(4px - ").concat(props.theme.dropBorderThickness, ")") : "1rem";
|
|
525
401
|
}, function (props) {
|
|
526
402
|
return props.theme.dropBorderRadius;
|
|
527
403
|
}, function (props) {
|
|
@@ -535,18 +411,7 @@ var DragDropArea = _styledComponents["default"].div(_templateObject4 || (_templa
|
|
|
535
411
|
}, function (props) {
|
|
536
412
|
return props.disabled && "not-allowed";
|
|
537
413
|
});
|
|
538
|
-
|
|
539
|
-
var FileContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n margin-top: 0.25rem;\n"])), function (props) {
|
|
540
|
-
return props.multiple || props.files.length > 1 ? "column" : "row";
|
|
541
|
-
});
|
|
542
|
-
|
|
543
|
-
var HiddenInputFile = _styledComponents["default"].input(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n visibility: hidden;\n position: absolute;\n width: 0px;\n height: 0px;\n"])));
|
|
544
|
-
|
|
545
|
-
var ButtonContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n"])), function (props) {
|
|
546
|
-
return props.mode === "filedrop" && "padding: 2px 12px 2px 3px";
|
|
547
|
-
});
|
|
548
|
-
|
|
549
|
-
var DropzoneLabel = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n -webkit-line-clamp: 3;\n text-align: center;\n margin-top: 0.5rem;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
|
|
414
|
+
var DropzoneLabel = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n -webkit-line-clamp: 3;\n text-align: center;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
|
|
550
415
|
return props.disabled ? props.theme.disabledDropLabelFontColor : props.theme.dropLabelFontColor;
|
|
551
416
|
}, function (props) {
|
|
552
417
|
return props.theme.dropLabelFontFamily;
|
|
@@ -555,8 +420,7 @@ var DropzoneLabel = _styledComponents["default"].div(_templateObject8 || (_templ
|
|
|
555
420
|
}, function (props) {
|
|
556
421
|
return props.theme.dropLabelFontWeight;
|
|
557
422
|
});
|
|
558
|
-
|
|
559
|
-
var FiledropLabel = _styledComponents["default"].span(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n margin-right: 1rem;\n"])), function (props) {
|
|
423
|
+
var FiledropLabel = _styledComponents["default"].span(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
|
|
560
424
|
return props.disabled ? props.theme.disabledDropLabelFontColor : props.theme.dropLabelFontColor;
|
|
561
425
|
}, function (props) {
|
|
562
426
|
return props.theme.dropLabelFontFamily;
|
|
@@ -565,16 +429,7 @@ var FiledropLabel = _styledComponents["default"].span(_templateObject9 || (_temp
|
|
|
565
429
|
}, function (props) {
|
|
566
430
|
return props.theme.dropLabelFontWeight;
|
|
567
431
|
});
|
|
568
|
-
|
|
569
|
-
var Container = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n margin-top: 0.25rem;\n"])));
|
|
570
|
-
|
|
571
|
-
var FileItemContainer = _styledComponents["default"].div(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: ", ";\n margin-left: ", ";\n"])), function (props) {
|
|
572
|
-
return (props.multiple || props.files.length > 1 || props.mode !== "file") && "4px";
|
|
573
|
-
}, function (props) {
|
|
574
|
-
return props.mode === "file" && props.files.length === 1 && !props.multiple && "4px";
|
|
575
|
-
});
|
|
576
|
-
|
|
577
|
-
var ErrorMessage = _styledComponents["default"].div(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-top: 0.25rem;\n"])), function (props) {
|
|
432
|
+
var ErrorMessage = _styledComponents["default"].div(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-top: 0.25rem;\n"])), function (props) {
|
|
578
433
|
return props.theme.errorMessageFontColor;
|
|
579
434
|
}, function (props) {
|
|
580
435
|
return props.theme.errorMessageFontFamily;
|
|
@@ -585,6 +440,4 @@ var ErrorMessage = _styledComponents["default"].div(_templateObject12 || (_templ
|
|
|
585
440
|
}, function (props) {
|
|
586
441
|
return props.theme.errorMessageLineHeight;
|
|
587
442
|
});
|
|
588
|
-
|
|
589
|
-
var _default = DxcFileInput;
|
|
590
|
-
exports["default"] = _default;
|
|
443
|
+
var _default = exports["default"] = DxcFileInput;
|