@dxc-technology/halstack-react 0.0.0-b1729d7 → 0.0.0-b39a2d8

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.
Files changed (313) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/{dist/select/Select.js → V3Select/V3Select.js} +38 -132
  4. package/V3Select/index.d.ts +27 -0
  5. package/{dist/V3Textarea → V3Textarea}/V3Textarea.js +10 -14
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/{dist/accordion → accordion}/Accordion.js +35 -130
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/types.d.ts +72 -0
  14. package/accordion-group/types.js +5 -0
  15. package/alert/Alert.d.ts +4 -0
  16. package/{dist/alert → alert}/Alert.js +38 -151
  17. package/alert/Alert.stories.tsx +170 -0
  18. package/alert/types.d.ts +49 -0
  19. package/alert/types.js +5 -0
  20. package/badge/Badge.js +59 -0
  21. package/box/Box.d.ts +4 -0
  22. package/{dist/box → box}/Box.js +13 -43
  23. package/box/Box.stories.tsx +132 -0
  24. package/box/types.d.ts +43 -0
  25. package/box/types.js +5 -0
  26. package/button/Button.d.ts +4 -0
  27. package/{dist/button → button}/Button.js +23 -84
  28. package/button/Button.stories.tsx +276 -0
  29. package/button/types.d.ts +57 -0
  30. package/button/types.js +5 -0
  31. package/card/Card.d.ts +4 -0
  32. package/{dist/card → card}/Card.js +33 -123
  33. package/card/Card.stories.tsx +201 -0
  34. package/card/ice-cream.jpg +0 -0
  35. package/card/types.d.ts +67 -0
  36. package/card/types.js +5 -0
  37. package/checkbox/Checkbox.d.ts +4 -0
  38. package/{dist/checkbox → checkbox}/Checkbox.js +16 -63
  39. package/checkbox/Checkbox.stories.tsx +192 -0
  40. package/checkbox/types.d.ts +60 -0
  41. package/checkbox/types.js +5 -0
  42. package/{dist/chip → chip}/Chip.js +17 -61
  43. package/chip/Chip.stories.tsx +121 -0
  44. package/chip/index.d.ts +22 -0
  45. package/{dist/common → common}/OpenSans.css +0 -0
  46. package/{dist/common → common}/RequiredComponent.js +3 -11
  47. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  53. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  54. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  55. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  56. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  57. package/{dist/common → common}/utils.js +0 -0
  58. package/{dist/common → common}/variables.js +160 -152
  59. package/{dist/date → date}/Date.js +21 -27
  60. package/date/index.d.ts +27 -0
  61. package/date-input/DateInput.d.ts +4 -0
  62. package/{dist/date-input → date-input}/DateInput.js +22 -61
  63. package/date-input/DateInput.stories.tsx +138 -0
  64. package/date-input/types.d.ts +100 -0
  65. package/date-input/types.js +5 -0
  66. package/dialog/Dialog.d.ts +4 -0
  67. package/{dist/dialog → dialog}/Dialog.js +20 -73
  68. package/dialog/Dialog.stories.tsx +212 -0
  69. package/dialog/types.d.ts +43 -0
  70. package/dialog/types.js +5 -0
  71. package/dropdown/Dropdown.d.ts +4 -0
  72. package/{dist/dropdown → dropdown}/Dropdown.js +44 -171
  73. package/dropdown/types.d.ts +89 -0
  74. package/dropdown/types.js +5 -0
  75. package/file-input/FileInput.d.ts +4 -0
  76. package/{dist/file-input → file-input}/FileInput.js +56 -189
  77. package/file-input/FileItem.d.ts +14 -0
  78. package/file-input/FileItem.js +182 -0
  79. package/file-input/types.d.ts +87 -0
  80. package/file-input/types.js +5 -0
  81. package/footer/Footer.d.ts +4 -0
  82. package/{dist/footer → footer}/Footer.js +38 -193
  83. package/footer/Footer.stories.jsx +151 -0
  84. package/{dist/footer → footer}/Icons.js +13 -13
  85. package/footer/types.d.ts +61 -0
  86. package/footer/types.js +5 -0
  87. package/header/Header.d.ts +7 -0
  88. package/header/Header.js +324 -0
  89. package/header/Header.stories.tsx +162 -0
  90. package/{dist/header → header}/Icons.js +7 -32
  91. package/header/types.d.ts +47 -0
  92. package/header/types.js +5 -0
  93. package/heading/Heading.d.ts +4 -0
  94. package/{dist/heading → heading}/Heading.js +30 -89
  95. package/heading/types.d.ts +33 -0
  96. package/heading/types.js +5 -0
  97. package/{dist/input-text → input-text}/Icons.js +2 -2
  98. package/{dist/input-text → input-text}/InputText.js +36 -130
  99. package/input-text/index.d.ts +36 -0
  100. package/{dist/layout → layout}/ApplicationLayout.js +31 -123
  101. package/{dist/layout → layout}/Icons.js +7 -7
  102. package/link/Link.d.ts +3 -0
  103. package/{dist/link → link}/Link.js +18 -94
  104. package/link/Link.stories.tsx +146 -0
  105. package/link/types.d.ts +74 -0
  106. package/link/types.js +5 -0
  107. package/main.d.ts +44 -0
  108. package/{dist/main.js → main.js} +93 -97
  109. package/number-input/NumberInput.d.ts +4 -0
  110. package/number-input/NumberInput.js +86 -0
  111. package/number-input/NumberInput.stories.tsx +115 -0
  112. package/{dist/number-input → number-input}/NumberInputContext.js +1 -1
  113. package/number-input/types.d.ts +117 -0
  114. package/number-input/types.js +5 -0
  115. package/package.json +32 -25
  116. package/{dist/paginator → paginator}/Icons.js +9 -9
  117. package/paginator/Paginator.d.ts +4 -0
  118. package/paginator/Paginator.js +198 -0
  119. package/paginator/Paginator.stories.tsx +63 -0
  120. package/paginator/types.d.ts +38 -0
  121. package/paginator/types.js +5 -0
  122. package/password-input/PasswordInput.d.ts +4 -0
  123. package/{dist/password-input → password-input}/PasswordInput.js +24 -60
  124. package/password-input/PasswordInput.stories.tsx +131 -0
  125. package/password-input/types.d.ts +100 -0
  126. package/password-input/types.js +5 -0
  127. package/progress-bar/ProgressBar.d.ts +4 -0
  128. package/{dist/progress-bar → progress-bar}/ProgressBar.js +20 -92
  129. package/progress-bar/ProgressBar.stories.jsx +58 -0
  130. package/progress-bar/types.d.ts +37 -0
  131. package/progress-bar/types.js +5 -0
  132. package/radio/Radio.d.ts +4 -0
  133. package/{dist/radio → radio}/Radio.js +15 -50
  134. package/radio/Radio.stories.tsx +192 -0
  135. package/radio/types.d.ts +54 -0
  136. package/radio/types.js +5 -0
  137. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +35 -119
  138. package/resultsetTable/index.d.ts +19 -0
  139. package/select/Select.js +865 -0
  140. package/select/Select.stories.tsx +572 -0
  141. package/select/index.d.ts +131 -0
  142. package/sidenav/Sidenav.d.ts +9 -0
  143. package/{dist/sidenav → sidenav}/Sidenav.js +19 -62
  144. package/sidenav/types.d.ts +50 -0
  145. package/sidenav/types.js +5 -0
  146. package/slider/Slider.d.ts +4 -0
  147. package/{dist/slider → slider}/Slider.js +71 -158
  148. package/slider/Slider.stories.tsx +177 -0
  149. package/slider/types.d.ts +78 -0
  150. package/slider/types.js +5 -0
  151. package/spinner/Spinner.d.ts +4 -0
  152. package/spinner/Spinner.js +250 -0
  153. package/spinner/Spinner.stories.jsx +102 -0
  154. package/spinner/types.d.ts +32 -0
  155. package/spinner/types.js +5 -0
  156. package/switch/Switch.d.ts +4 -0
  157. package/{dist/switch → switch}/Switch.js +26 -69
  158. package/switch/Switch.stories.tsx +160 -0
  159. package/switch/types.d.ts +58 -0
  160. package/switch/types.js +5 -0
  161. package/table/Table.d.ts +4 -0
  162. package/{dist/table → table}/Table.js +10 -24
  163. package/table/Table.stories.jsx +276 -0
  164. package/table/types.d.ts +21 -0
  165. package/table/types.js +5 -0
  166. package/tabs/Tabs.d.ts +4 -0
  167. package/tabs/Tabs.js +211 -0
  168. package/tabs/types.d.ts +70 -0
  169. package/tabs/types.js +5 -0
  170. package/tag/Tag.d.ts +4 -0
  171. package/tag/Tag.js +193 -0
  172. package/tag/Tag.stories.tsx +145 -0
  173. package/tag/types.d.ts +60 -0
  174. package/tag/types.js +5 -0
  175. package/{dist/text-input → text-input}/TextInput.js +244 -390
  176. package/{dist/text-input → text-input}/index.d.ts +2 -2
  177. package/{dist/textarea → textarea}/Textarea.js +20 -72
  178. package/textarea/Textarea.stories.jsx +135 -0
  179. package/{dist/textarea → textarea}/index.d.ts +0 -0
  180. package/{dist/toggle → toggle}/Toggle.js +15 -49
  181. package/toggle/index.d.ts +21 -0
  182. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +23 -107
  183. package/toggle-group/ToggleGroup.stories.tsx +178 -0
  184. package/toggle-group/index.d.ts +21 -0
  185. package/{dist/upload → upload}/Upload.js +14 -18
  186. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  187. package/upload/buttons-upload/Icons.js +40 -0
  188. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  189. package/upload/dragAndDropArea/Icons.js +39 -0
  190. package/upload/file-upload/FileToUpload.js +115 -0
  191. package/upload/file-upload/Icons.js +66 -0
  192. package/{dist/upload → upload}/files-upload/FilesToUpload.js +12 -26
  193. package/upload/index.d.ts +15 -0
  194. package/upload/transaction/Icons.js +160 -0
  195. package/upload/transaction/Transaction.js +104 -0
  196. package/upload/transactions/Transactions.js +94 -0
  197. package/{dist/useTheme.js → useTheme.js} +0 -0
  198. package/wizard/Icons.js +65 -0
  199. package/wizard/Wizard.d.ts +4 -0
  200. package/{dist/wizard → wizard}/Wizard.js +33 -213
  201. package/wizard/Wizard.stories.jsx +224 -0
  202. package/wizard/types.d.ts +64 -0
  203. package/wizard/types.js +5 -0
  204. package/README.md +0 -66
  205. package/babel.config.js +0 -8
  206. package/dist/BackgroundColorContext.js +0 -46
  207. package/dist/ThemeContext.js +0 -248
  208. package/dist/accordion-group/AccordionGroup.js +0 -186
  209. package/dist/alert/index.d.ts +0 -51
  210. package/dist/badge/Badge.js +0 -63
  211. package/dist/checkbox/Checkbox.stories.js +0 -144
  212. package/dist/checkbox/readme.md +0 -116
  213. package/dist/date/Date.stories.js +0 -205
  214. package/dist/date/readme.md +0 -73
  215. package/dist/date-input/index.d.ts +0 -95
  216. package/dist/file-input/FileItem.js +0 -280
  217. package/dist/file-input/index.d.ts +0 -81
  218. package/dist/header/Header.js +0 -434
  219. package/dist/link/readme.md +0 -51
  220. package/dist/main.d.ts +0 -8
  221. package/dist/new-select/NewSelect.js +0 -836
  222. package/dist/new-select/index.d.ts +0 -53
  223. package/dist/number-input/NumberInput.js +0 -136
  224. package/dist/number-input/index.d.ts +0 -113
  225. package/dist/paginator/Paginator.js +0 -283
  226. package/dist/password-input/index.d.ts +0 -94
  227. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  228. package/dist/progress-bar/readme.md +0 -63
  229. package/dist/radio/Radio.stories.js +0 -166
  230. package/dist/radio/readme.md +0 -70
  231. package/dist/slider/readme.md +0 -64
  232. package/dist/spinner/Spinner.js +0 -381
  233. package/dist/spinner/Spinner.stories.js +0 -183
  234. package/dist/spinner/readme.md +0 -65
  235. package/dist/switch/Switch.stories.js +0 -134
  236. package/dist/switch/readme.md +0 -133
  237. package/dist/tabs/Tabs.js +0 -343
  238. package/dist/tabs/Tabs.stories.js +0 -130
  239. package/dist/tabs/readme.md +0 -78
  240. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  241. package/dist/tabs-for-sections/readme.md +0 -78
  242. package/dist/tag/Tag.js +0 -282
  243. package/dist/toggle/Toggle.stories.js +0 -297
  244. package/dist/toggle/readme.md +0 -80
  245. package/dist/upload/Upload.stories.js +0 -72
  246. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  247. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  248. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  249. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  250. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  251. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  252. package/dist/upload/file-upload/FileToUpload.js +0 -184
  253. package/dist/upload/file-upload/audio-icon.svg +0 -4
  254. package/dist/upload/file-upload/close.svg +0 -4
  255. package/dist/upload/file-upload/file-icon.svg +0 -4
  256. package/dist/upload/file-upload/video-icon.svg +0 -4
  257. package/dist/upload/readme.md +0 -37
  258. package/dist/upload/transaction/Transaction.js +0 -175
  259. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  260. package/dist/upload/transaction/audio-icon.svg +0 -4
  261. package/dist/upload/transaction/error-icon.svg +0 -4
  262. package/dist/upload/transaction/file-icon-err.svg +0 -4
  263. package/dist/upload/transaction/file-icon.svg +0 -4
  264. package/dist/upload/transaction/image-icon-err.svg +0 -4
  265. package/dist/upload/transaction/image-icon.svg +0 -4
  266. package/dist/upload/transaction/success-icon.svg +0 -4
  267. package/dist/upload/transaction/video-icon-err.svg +0 -4
  268. package/dist/upload/transaction/video-icon.svg +0 -4
  269. package/dist/upload/transactions/Transactions.js +0 -138
  270. package/dist/wizard/invalid_icon.svg +0 -5
  271. package/dist/wizard/valid_icon.svg +0 -5
  272. package/dist/wizard/validation-wrong.svg +0 -6
  273. package/test/Accordion.test.js +0 -33
  274. package/test/AccordionGroup.test.js +0 -125
  275. package/test/Alert.test.js +0 -53
  276. package/test/Box.test.js +0 -10
  277. package/test/Button.test.js +0 -18
  278. package/test/Card.test.js +0 -30
  279. package/test/Checkbox.test.js +0 -45
  280. package/test/Chip.test.js +0 -25
  281. package/test/Date.test.js +0 -397
  282. package/test/DateInput.test.js +0 -242
  283. package/test/Dialog.test.js +0 -23
  284. package/test/Dropdown.test.js +0 -145
  285. package/test/FileInput.test.js +0 -201
  286. package/test/Footer.test.js +0 -94
  287. package/test/Header.test.js +0 -34
  288. package/test/Heading.test.js +0 -35
  289. package/test/InputText.test.js +0 -248
  290. package/test/Link.test.js +0 -43
  291. package/test/NumberInput.test.js +0 -259
  292. package/test/Paginator.test.js +0 -177
  293. package/test/PasswordInput.test.js +0 -83
  294. package/test/ProgressBar.test.js +0 -35
  295. package/test/Radio.test.js +0 -37
  296. package/test/ResultsetTable.test.js +0 -329
  297. package/test/Select.test.js +0 -212
  298. package/test/Sidenav.test.js +0 -45
  299. package/test/Slider.test.js +0 -74
  300. package/test/Spinner.test.js +0 -32
  301. package/test/Switch.test.js +0 -45
  302. package/test/Table.test.js +0 -36
  303. package/test/Tabs.test.js +0 -109
  304. package/test/TabsForSections.test.js +0 -34
  305. package/test/Tag.test.js +0 -32
  306. package/test/TextInput.test.js +0 -732
  307. package/test/Textarea.test.js +0 -193
  308. package/test/ToggleGroup.test.js +0 -85
  309. package/test/Upload.test.js +0 -60
  310. package/test/V3TextArea.test.js +0 -51
  311. package/test/Wizard.test.js +0 -130
  312. package/test/mocks/pngMock.js +0 -1
  313. package/test/mocks/svgMock.js +0 -1
@@ -1,95 +0,0 @@
1
- type Size = "small" | "medium" | "large" | "fillParent";
2
- type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- type Margin = {
4
- top?: Space;
5
- bottom?: Space;
6
- left?: Space;
7
- right?: Space;
8
- };
9
-
10
- type Props = {
11
- /**
12
- * Text to be placed above the date.
13
- */
14
- label?: string;
15
- /**
16
- * Name attribute of the input element.
17
- */
18
- name?: string;
19
- /**
20
- * Value of the input element. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
21
- */
22
- value?: string;
23
- /**
24
- * The format in which the date value will be displayed. User must use this format when editing the value or it will be considered as an invalid date.
25
- */
26
- format?: string;
27
- /**
28
- * Helper text to be placed above the date.
29
- */
30
- helperText?: string;
31
- /**
32
- * If true, the date format will appear as placeholder in the field.
33
- */
34
- placeholder?: boolean;
35
- /**
36
- * If true, the date input will have an action to clear the entered value.
37
- */
38
- clearable?: boolean;
39
- /**
40
- * If true, the component will be disabled.
41
- */
42
- disabled?: boolean;
43
- /**
44
- * If true, the date will be optional, showing '(Optional)'
45
- * next to the label. Otherwise, the field will be considered required and an error will be
46
- * passed as a parameter to the OnBlur and onChange functions when it has
47
- * not been filled.
48
- */
49
- optional?: boolean;
50
- /**
51
- * This function will be called when the user types within the input
52
- * element of the component. An object including the string value, the
53
- * error and the date value will be passed to this function.
54
- * If the string value is a valid date, error will
55
- * be null. Also, if the string value is not a valid date, date will be null.
56
- */
57
- onChange?: (val: { value: string; error: string; date: Date }) => void;
58
- /**
59
- * This function will be called when the input element loses the focus.
60
- * An object including the string value, the error and the date value
61
- * will be passed to this function. If the string value is a valid date, error will
62
- * be null. Also, if the string value is not a valid date, date will be null.
63
- */
64
- onBlur?: (val: { value: string; error: string; date: Date }) => void;
65
- /**
66
- * If it is defined, the component will change its appearance, showing
67
- * the error below the date input component. If it is not defined, the error
68
- * messages will be managed internally, but never displayed on its own.
69
- */
70
- error?: string;
71
- /**
72
- * HTML autocomplete attribute. Lets the user specify if any permission the user agent has to provide automated assistance in filling out the input value.
73
- * Its value must be one of all the possible values of the HTML autocomplete attribute: 'on', 'off', 'email', 'username', 'new-password', ...
74
- */
75
- autocomplete?: string;
76
- /**
77
- * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
78
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
79
- */
80
- margin?: Space | Margin;
81
- /**
82
- * Size of the component ('medium' | 'large' | 'fillParent').
83
- */
84
- size?: Size;
85
- /**
86
- * Value of the tabindex attribute.
87
- */
88
- tabIndex?: number;
89
- /**
90
- * Reference to the component.
91
- */
92
- ref?: React.RefObject<HTMLDivElement>;
93
- };
94
-
95
- export default function DxcDateInput(props: Props): JSX.Element;
@@ -1,280 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports["default"] = void 0;
11
-
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
- var _react = _interopRequireDefault(require("react"));
15
-
16
- var _propTypes = _interopRequireDefault(require("prop-types"));
17
-
18
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
21
-
22
- function _templateObject10() {
23
- var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n"]);
24
-
25
- _templateObject10 = function _templateObject10() {
26
- return data;
27
- };
28
-
29
- return data;
30
- }
31
-
32
- function _templateObject9() {
33
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 24px;\n width: 24px;\n font-size: 1rem;\n font-family: ", ";\n border: 1px solid transparent;\n border-radius: 4px;\n margin-left: 4px;\n background-color: transparent;\n padding: 3px;\n cursor: pointer;\n svg {\n line-height: 18px;\n }\n"]);
34
-
35
- _templateObject9 = function _templateObject9() {
36
- return data;
37
- };
38
-
39
- return data;
40
- }
41
-
42
- function _templateObject8() {
43
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n padding: 3px;\n height: 18px;\n width: 18px;\n color: #d0011b;\n"]);
44
-
45
- _templateObject8 = function _templateObject8() {
46
- return data;
47
- };
48
-
49
- return data;
50
- }
51
-
52
- function _templateObject7() {
53
- var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n width: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n"]);
54
-
55
- _templateObject7 = function _templateObject7() {
56
- return data;
57
- };
58
-
59
- return data;
60
- }
61
-
62
- function _templateObject6() {
63
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
64
-
65
- _templateObject6 = function _templateObject6() {
66
- return data;
67
- };
68
-
69
- return data;
70
- }
71
-
72
- function _templateObject5() {
73
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n margin-right: 12px;\n background-color: ", ";\n width: 48px;\n height: 48px;\n border-radius: 2px;\n color: ", ";\n"]);
74
-
75
- _templateObject5 = function _templateObject5() {
76
- return data;
77
- };
78
-
79
- return data;
80
- }
81
-
82
- function _templateObject4() {
83
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 48px;\n height: 48px;\n object-fit: contain;\n margin-right: 12px;\n border-radius: 2px;\n"]);
84
-
85
- _templateObject4 = function _templateObject4() {
86
- return data;
87
- };
88
-
89
- return data;
90
- }
91
-
92
- function _templateObject3() {
93
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n align-items: center;\n"]);
94
-
95
- _templateObject3 = function _templateObject3() {
96
- return data;
97
- };
98
-
99
- return data;
100
- }
101
-
102
- function _templateObject2() {
103
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n"]);
104
-
105
- _templateObject2 = function _templateObject2() {
106
- return data;
107
- };
108
-
109
- return data;
110
- }
111
-
112
- function _templateObject() {
113
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n padding: ", ";\n background-color: ", ";\n border-radius: ", ";\n width: ", ";\n min-height: ", ";\n border-color: ", ";\n border-width: ", ";\n border-style: ", ";\n display: flex;\n justify-content: center;\n"]);
114
-
115
- _templateObject = function _templateObject() {
116
- return data;
117
- };
118
-
119
- return data;
120
- }
121
-
122
- var deleteIcon = _react["default"].createElement("svg", {
123
- xmlns: "http://www.w3.org/2000/svg",
124
- width: "24",
125
- height: "24",
126
- viewBox: "0 0 24 24",
127
- fill: "currentColor"
128
- }, _react["default"].createElement("path", {
129
- d: "M0 0h24v24H0V0z",
130
- fill: "none"
131
- }), _react["default"].createElement("path", {
132
- d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
133
- }));
134
-
135
- var errorIcon = _react["default"].createElement("svg", {
136
- xmlns: "http://www.w3.org/2000/svg",
137
- height: "24px",
138
- viewBox: "0 0 24 24",
139
- width: "24px",
140
- fill: "currentColor"
141
- }, _react["default"].createElement("path", {
142
- d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"
143
- }));
144
-
145
- var FileItem = function FileItem(_ref) {
146
- var mode = _ref.mode,
147
- multiple = _ref.multiple,
148
- _ref$name = _ref.name,
149
- name = _ref$name === void 0 ? "" : _ref$name,
150
- _ref$error = _ref.error,
151
- error = _ref$error === void 0 ? "" : _ref$error,
152
- showPreview = _ref.showPreview,
153
- preview = _ref.preview,
154
- type = _ref.type,
155
- numFiles = _ref.numFiles,
156
- onDelete = _ref.onDelete;
157
- var colorsTheme = (0, _useTheme["default"])();
158
- var isImage = type.includes("image");
159
-
160
- var getIconAriaLabel = function getIconAriaLabel() {
161
- if (type.includes("video")) {
162
- return "video";
163
- }
164
-
165
- if (type.includes("audio")) {
166
- return "audio";
167
- }
168
-
169
- return "file";
170
- };
171
-
172
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
173
- theme: colorsTheme.fileInput
174
- }, _react["default"].createElement(Container, {
175
- mode: mode,
176
- multiple: multiple,
177
- error: error,
178
- showPreview: showPreview,
179
- numFiles: numFiles
180
- }, showPreview && (isImage ? _react["default"].createElement(ImagePreview, {
181
- src: preview,
182
- alt: name
183
- }) : _react["default"].createElement(IconPreviewContainer, {
184
- error: error,
185
- "aria-label": getIconAriaLabel()
186
- }, _react["default"].createElement(IconPreview, {
187
- error: error
188
- }, preview))), _react["default"].createElement(FileItemContent, null, _react["default"].createElement(FileItemContainer, null, _react["default"].createElement(FileName, {
189
- mode: mode,
190
- multiple: multiple,
191
- error: error,
192
- showPreview: showPreview,
193
- numFiles: numFiles
194
- }, name), error && _react["default"].createElement(ErrorIcon, {
195
- "aria-label": "Error"
196
- }, errorIcon), _react["default"].createElement(DeleteIcon, {
197
- onClick: function onClick() {
198
- return onDelete(name);
199
- },
200
- "aria-label": "Remove ".concat(name)
201
- }, deleteIcon)), error && (multiple || numFiles > 1) && _react["default"].createElement(ErrorMessage, null, error))));
202
- };
203
-
204
- var Container = _styledComponents["default"].div(_templateObject(), function (props) {
205
- return props.showPreview ? "8px" : "8px 8px 8px 16px";
206
- }, function (props) {
207
- return props.error && props.theme.errorFileItemBackgroundColor;
208
- }, function (props) {
209
- return props.theme.fileItemBorderRadius;
210
- }, function (props) {
211
- return props.mode === "file" && !props.multiple && props.numFiles === 1 ? "calc(230px - 26px)" : !props.showPreview ? "calc(320px - 26px)" : props.showPreview && "calc(320px - 18px)";
212
- }, function (props) {
213
- return props.mode === "file" && !props.multiple && props.numFiles === 1 || !props.showPreview && !props.error ? "calc(40px - 18px)" : !props.showPreview && props.error ? "calc(59px - 18px)" : "calc(64px - 18px)";
214
- }, function (props) {
215
- return props.error ? props.theme.errorFileItemBorderColor : props.theme.fileItemBorderColor;
216
- }, function (props) {
217
- return props.theme.fileItemBorderThickness;
218
- }, function (props) {
219
- return props.theme.fileItemBorderStyle;
220
- });
221
-
222
- var FileItemContent = _styledComponents["default"].div(_templateObject2());
223
-
224
- var FileItemContainer = _styledComponents["default"].div(_templateObject3());
225
-
226
- var ImagePreview = _styledComponents["default"].img(_templateObject4());
227
-
228
- var IconPreviewContainer = _styledComponents["default"].div(_templateObject5(), function (props) {
229
- return props.error ? props.theme.errorFileItemIconBackgroundColor : props.theme.fileItemIconBackgroundColor;
230
- }, function (props) {
231
- return props.error ? props.theme.errorFileItemIconColor : props.theme.fileItemIconColor;
232
- });
233
-
234
- var IconPreview = _styledComponents["default"].div(_templateObject6());
235
-
236
- var FileName = _styledComponents["default"].span(_templateObject7(), function (props) {
237
- return props.theme.fileNameFontColor;
238
- }, function (props) {
239
- return props.mode === "file" && !props.multiple && props.error && props.numFiles === 1 ? "calc(230px - 76px)" : props.mode === "file" && !props.multiple && !props.error && props.numFiles === 1 ? "calc(230px - 50px)" : !props.showPreview && !props.error ? "calc(320px - 52px)" : !props.showPreview && props.error ? "calc(320px - 76px)" : props.showPreview && props.error ? "calc(320px - 128px)" : props.showPreview && !props.error && "calc(320px - 102px)";
240
- }, function (props) {
241
- return props.theme.fileItemFontFamily;
242
- }, function (props) {
243
- return props.theme.fileItemFontSize;
244
- }, function (props) {
245
- return props.theme.fileItemFontWeight;
246
- }, function (props) {
247
- return props.theme.fileItemLineHeight;
248
- });
249
-
250
- var ErrorIcon = _styledComponents["default"].span(_templateObject8());
251
-
252
- var DeleteIcon = _styledComponents["default"].button(_templateObject9(), function (props) {
253
- return props.theme.fontFamily;
254
- });
255
-
256
- var ErrorMessage = _styledComponents["default"].span(_templateObject10(), function (props) {
257
- return props.theme.errorMessageFontColor;
258
- }, function (props) {
259
- return props.theme.errorMessageFontFamily;
260
- }, function (props) {
261
- return props.theme.errorMessageFontSize;
262
- }, function (props) {
263
- return props.theme.errorMessageFontWeight;
264
- }, function (props) {
265
- return props.theme.errorMessageLineHeight;
266
- });
267
-
268
- FileItem.propTypes = {
269
- mode: _propTypes["default"].string,
270
- multiple: _propTypes["default"].bool,
271
- name: _propTypes["default"].string,
272
- type: _propTypes["default"].string,
273
- showPreview: _propTypes["default"]["boolean"],
274
- numFiles: _propTypes["default"].number,
275
- preview: _propTypes["default"].string,
276
- error: _propTypes["default"].string,
277
- onDelete: _propTypes["default"].func
278
- };
279
- var _default = FileItem;
280
- exports["default"] = _default;
@@ -1,81 +0,0 @@
1
- type Size = "small" | "medium" | "large" | "fillParent";
2
- type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- type Margin = {
4
- top?: Space;
5
- bottom?: Space;
6
- left?: Space;
7
- right?: Space;
8
- };
9
- type FileData = {
10
- error?: string;
11
- file?: File;
12
- preview?: string;
13
- };
14
-
15
- type Props = {
16
- /**
17
- * Name attribute of the file input element.
18
- */
19
- name?: string;
20
- /**
21
- * Text to be placed above the file input.
22
- */
23
- label?: string;
24
- /**
25
- * Uses one of the available file input modes:
26
- * 'file': Files are selected by clicking the button and selecting it through the file explorer.
27
- * 'filedrop': Files can be selected by clicking the button and selecting it through the file explorer or by dropping them inside the drag and drop area.
28
- * 'dropzone': Files can be selected by clicking the button and selecting it through the file explorer or by dropping them inside the drag and drop area.
29
- * The drag and drop area of this mode is bigger than the one of the filedrop mode.
30
- */
31
- mode?: "file" | "filedrop" | "dropzone";
32
- /**
33
- * Helper text to be placed above the file input.
34
- */
35
- helperText?: string;
36
- /**
37
- * Defines the file types accepted by the component. It is not possible to select a file with a non valid type.
38
- */
39
- accept?: string;
40
- /**
41
- * An array of FileData representing the selected files.
42
- */
43
- value?: FileData[];
44
- /**
45
- * Minimum file size allowed (in bytes). If the file size does not comply the minSize, an error will be passed to the FileData.
46
- */
47
- minSize?: number;
48
- /**
49
- * Maximum file size allowed (in bytes). If the file size does not comply the maxSize, an error will be passed to the FileData.
50
- */
51
- maxSize?: number;
52
- /**
53
- * If true and if the file is an image, a preview of it will be shown. If it is not an image, an icon refering to the file's type will be shown.
54
- * If mode is not multiple and there is one file already selected, the file will be replaced by the last selected one.
55
- */
56
- showPreview?: boolean;
57
- /**
58
- * If true, more than one file can be selected. If false, only one file can be selected.
59
- */
60
- multiple?: boolean;
61
- /**
62
- * If true, the component will be disabled.
63
- */
64
- disabled?: boolean;
65
- /**
66
- * This function will be called when the user selects or drops a file. The list of files will be sent as a parameter.
67
- * In this function, the files can be updated or returned as they come. These files must be passed to the value in order to be shown.
68
- */
69
- callbackFile?: (files: FileData[]) => void;
70
- /**
71
- * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
72
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
73
- */
74
- margin?: Space | Margin;
75
- /**
76
- * Value of the tabindex attribute.
77
- */
78
- tabIndex?: number;
79
- };
80
-
81
- export default function DxcTextInput(props: Props): JSX.Element;