@dxc-technology/halstack-react 3.3.0 → 4.0.1

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 (254) hide show
  1. package/{dist/BackgroundColorContext.js → BackgroundColorContext.js} +0 -0
  2. package/ThemeContext.js +250 -0
  3. package/{dist/select/Select.js → V3Select/V3Select.js} +175 -189
  4. package/V3Select/index.d.ts +27 -0
  5. package/{dist/textarea/Textarea.js → V3Textarea/V3Textarea.js} +30 -26
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/{dist/accordion → accordion}/Accordion.js +66 -59
  8. package/accordion/index.d.ts +28 -0
  9. package/{dist/accordion-group → accordion-group}/AccordionGroup.js +1 -3
  10. package/accordion-group/index.d.ts +16 -0
  11. package/{dist/alert → alert}/Alert.js +126 -111
  12. package/alert/index.d.ts +51 -0
  13. package/{dist/badge → badge}/Badge.js +0 -0
  14. package/{dist/box → box}/Box.js +1 -9
  15. package/box/index.d.ts +25 -0
  16. package/button/Button.js +238 -0
  17. package/button/Button.stories.js +27 -0
  18. package/button/index.d.ts +24 -0
  19. package/{dist/card → card}/Card.js +0 -0
  20. package/card/index.d.ts +22 -0
  21. package/{dist/checkbox → checkbox}/Checkbox.js +26 -21
  22. package/checkbox/index.d.ts +24 -0
  23. package/{dist/chip → chip}/Chip.js +21 -25
  24. package/chip/index.d.ts +22 -0
  25. package/{dist/common → common}/OpenSans.css +0 -0
  26. package/{dist/common → common}/RequiredComponent.js +0 -0
  27. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  28. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  29. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  30. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  31. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  37. package/{dist/common → common}/utils.js +0 -0
  38. package/common/variables.js +1567 -0
  39. package/{dist/date → date}/Date.js +7 -9
  40. package/date/index.d.ts +27 -0
  41. package/date-input/DateInput.js +400 -0
  42. package/date-input/index.d.ts +95 -0
  43. package/{dist/dialog → dialog}/Dialog.js +15 -32
  44. package/dialog/index.d.ts +18 -0
  45. package/{dist/dropdown → dropdown}/Dropdown.js +117 -66
  46. package/dropdown/index.d.ts +26 -0
  47. package/file-input/FileInput.js +644 -0
  48. package/file-input/FileItem.js +287 -0
  49. package/file-input/index.d.ts +81 -0
  50. package/{dist/footer → footer}/Footer.js +63 -49
  51. package/footer/Icons.js +77 -0
  52. package/footer/index.d.ts +25 -0
  53. package/{dist/header → header}/Header.js +123 -84
  54. package/header/Icons.js +59 -0
  55. package/header/index.d.ts +25 -0
  56. package/{dist/heading → heading}/Heading.js +13 -5
  57. package/heading/index.d.ts +17 -0
  58. package/input-text/Icons.js +22 -0
  59. package/{dist/input-text → input-text}/InputText.js +96 -63
  60. package/input-text/index.d.ts +36 -0
  61. package/{dist/layout → layout}/ApplicationLayout.js +5 -9
  62. package/layout/Icons.js +55 -0
  63. package/{dist/link → link}/Link.js +4 -8
  64. package/link/index.d.ts +23 -0
  65. package/main.d.ts +40 -0
  66. package/{dist/main.js → main.js} +62 -14
  67. package/number-input/NumberInput.js +136 -0
  68. package/number-input/NumberInputContext.js +16 -0
  69. package/number-input/index.d.ts +113 -0
  70. package/package.json +23 -17
  71. package/paginator/Icons.js +66 -0
  72. package/{dist/paginator → paginator}/Paginator.js +60 -38
  73. package/paginator/index.d.ts +20 -0
  74. package/password-input/PasswordInput.js +203 -0
  75. package/password-input/index.d.ts +94 -0
  76. package/{dist/progress-bar → progress-bar}/ProgressBar.js +63 -27
  77. package/progress-bar/index.d.ts +18 -0
  78. package/{dist/radio → radio}/Radio.js +0 -0
  79. package/radio/index.d.ts +23 -0
  80. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +1 -1
  81. package/resultsetTable/index.d.ts +19 -0
  82. package/select/Select.js +1138 -0
  83. package/select/index.d.ts +131 -0
  84. package/{dist/sidenav → sidenav}/Sidenav.js +11 -15
  85. package/sidenav/index.d.ts +13 -0
  86. package/{dist/slider → slider}/Slider.js +155 -66
  87. package/slider/index.d.ts +29 -0
  88. package/spinner/Spinner.js +381 -0
  89. package/spinner/index.d.ts +17 -0
  90. package/{dist/switch → switch}/Switch.js +0 -0
  91. package/switch/index.d.ts +24 -0
  92. package/{dist/table → table}/Table.js +5 -1
  93. package/table/index.d.ts +13 -0
  94. package/{dist/tabs → tabs}/Tabs.js +0 -0
  95. package/tabs/index.d.ts +19 -0
  96. package/{dist/tag → tag}/Tag.js +37 -35
  97. package/tag/index.d.ts +24 -0
  98. package/text-input/TextInput.js +992 -0
  99. package/text-input/index.d.ts +135 -0
  100. package/textarea/Textarea.js +369 -0
  101. package/textarea/index.d.ts +117 -0
  102. package/{dist/toggle → toggle}/Toggle.js +0 -0
  103. package/toggle/index.d.ts +21 -0
  104. package/toggle-group/ToggleGroup.js +327 -0
  105. package/toggle-group/index.d.ts +21 -0
  106. package/{dist/upload → upload}/Upload.js +0 -0
  107. package/{dist/upload → upload}/buttons-upload/ButtonsUpload.js +12 -12
  108. package/upload/buttons-upload/Icons.js +40 -0
  109. package/{dist/upload → upload}/dragAndDropArea/DragAndDropArea.js +23 -19
  110. package/upload/dragAndDropArea/Icons.js +39 -0
  111. package/{dist/upload → upload}/file-upload/FileToUpload.js +27 -22
  112. package/upload/file-upload/Icons.js +66 -0
  113. package/{dist/upload → upload}/files-upload/FilesToUpload.js +0 -0
  114. package/upload/index.d.ts +15 -0
  115. package/upload/transaction/Icons.js +160 -0
  116. package/{dist/upload → upload}/transaction/Transaction.js +18 -41
  117. package/{dist/upload → upload}/transactions/Transactions.js +11 -11
  118. package/{dist/useTheme.js → useTheme.js} +0 -0
  119. package/wizard/Icons.js +65 -0
  120. package/{dist/wizard → wizard}/Wizard.js +11 -17
  121. package/wizard/index.d.ts +18 -0
  122. package/README.md +0 -66
  123. package/babel.config.js +0 -8
  124. package/dist/ThemeContext.js +0 -216
  125. package/dist/accordion/Accordion.stories.js +0 -207
  126. package/dist/accordion/readme.md +0 -96
  127. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  128. package/dist/accordion-group/readme.md +0 -70
  129. package/dist/alert/Alert.stories.js +0 -158
  130. package/dist/alert/close.svg +0 -4
  131. package/dist/alert/error.svg +0 -4
  132. package/dist/alert/info.svg +0 -4
  133. package/dist/alert/readme.md +0 -43
  134. package/dist/alert/success.svg +0 -4
  135. package/dist/alert/warning.svg +0 -4
  136. package/dist/button/Button.js +0 -232
  137. package/dist/button/Button.stories.js +0 -224
  138. package/dist/button/readme.md +0 -93
  139. package/dist/checkbox/Checkbox.stories.js +0 -144
  140. package/dist/checkbox/readme.md +0 -116
  141. package/dist/common/variables.js +0 -1158
  142. package/dist/date/Date.stories.js +0 -205
  143. package/dist/date/readme.md +0 -73
  144. package/dist/dialog/Dialog.stories.js +0 -217
  145. package/dist/dialog/readme.md +0 -32
  146. package/dist/dropdown/Dropdown.stories.js +0 -249
  147. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  148. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  149. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  150. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  151. package/dist/dropdown/readme.md +0 -69
  152. package/dist/footer/Footer.stories.js +0 -94
  153. package/dist/footer/dxc_logo.svg +0 -15
  154. package/dist/footer/readme.md +0 -41
  155. package/dist/header/Header.stories.js +0 -176
  156. package/dist/header/close_icon.svg +0 -1
  157. package/dist/header/dxc_logo_black.svg +0 -8
  158. package/dist/header/hamb_menu_black.svg +0 -1
  159. package/dist/header/hamb_menu_white.svg +0 -1
  160. package/dist/header/readme.md +0 -33
  161. package/dist/input-text/InputText.stories.js +0 -209
  162. package/dist/input-text/error.svg +0 -1
  163. package/dist/input-text/readme.md +0 -91
  164. package/dist/layout/facebook.svg +0 -45
  165. package/dist/layout/linkedin.svg +0 -50
  166. package/dist/layout/twitter.svg +0 -53
  167. package/dist/link/readme.md +0 -51
  168. package/dist/paginator/images/next.svg +0 -3
  169. package/dist/paginator/images/nextPage.svg +0 -3
  170. package/dist/paginator/images/previous.svg +0 -3
  171. package/dist/paginator/images/previousPage.svg +0 -3
  172. package/dist/paginator/readme.md +0 -50
  173. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  174. package/dist/progress-bar/readme.md +0 -63
  175. package/dist/radio/Radio.stories.js +0 -166
  176. package/dist/radio/readme.md +0 -70
  177. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  178. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  179. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  180. package/dist/select/Select.stories.js +0 -235
  181. package/dist/select/readme.md +0 -72
  182. package/dist/slider/Slider.stories.js +0 -241
  183. package/dist/slider/readme.md +0 -64
  184. package/dist/spinner/Spinner.js +0 -214
  185. package/dist/spinner/Spinner.stories.js +0 -183
  186. package/dist/spinner/readme.md +0 -65
  187. package/dist/switch/Switch.stories.js +0 -134
  188. package/dist/switch/readme.md +0 -133
  189. package/dist/tabs/Tabs.stories.js +0 -130
  190. package/dist/tabs/readme.md +0 -78
  191. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  192. package/dist/tabs-for-sections/readme.md +0 -78
  193. package/dist/toggle/Toggle.stories.js +0 -297
  194. package/dist/toggle/readme.md +0 -80
  195. package/dist/toggle-group/ToggleGroup.js +0 -241
  196. package/dist/toggle-group/readme.md +0 -82
  197. package/dist/upload/Upload.stories.js +0 -72
  198. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  199. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  200. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  201. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  202. package/dist/upload/file-upload/audio-icon.svg +0 -4
  203. package/dist/upload/file-upload/close.svg +0 -4
  204. package/dist/upload/file-upload/file-icon.svg +0 -4
  205. package/dist/upload/file-upload/video-icon.svg +0 -4
  206. package/dist/upload/readme.md +0 -37
  207. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  208. package/dist/upload/transaction/audio-icon.svg +0 -4
  209. package/dist/upload/transaction/error-icon.svg +0 -4
  210. package/dist/upload/transaction/file-icon-err.svg +0 -4
  211. package/dist/upload/transaction/file-icon.svg +0 -4
  212. package/dist/upload/transaction/image-icon-err.svg +0 -4
  213. package/dist/upload/transaction/image-icon.svg +0 -4
  214. package/dist/upload/transaction/success-icon.svg +0 -4
  215. package/dist/upload/transaction/video-icon-err.svg +0 -4
  216. package/dist/upload/transaction/video-icon.svg +0 -4
  217. package/dist/wizard/invalid_icon.svg +0 -5
  218. package/dist/wizard/valid_icon.svg +0 -5
  219. package/dist/wizard/validation-wrong.svg +0 -6
  220. package/test/Accordion.test.js +0 -33
  221. package/test/AccordionGroup.test.js +0 -125
  222. package/test/Alert.test.js +0 -53
  223. package/test/Box.test.js +0 -10
  224. package/test/Button.test.js +0 -18
  225. package/test/Card.test.js +0 -30
  226. package/test/Checkbox.test.js +0 -45
  227. package/test/Chip.test.js +0 -25
  228. package/test/Date.test.js +0 -393
  229. package/test/Dialog.test.js +0 -23
  230. package/test/Dropdown.test.js +0 -130
  231. package/test/Footer.test.js +0 -99
  232. package/test/Header.test.js +0 -39
  233. package/test/Heading.test.js +0 -35
  234. package/test/InputText.test.js +0 -240
  235. package/test/Link.test.js +0 -43
  236. package/test/Paginator.test.js +0 -177
  237. package/test/ProgressBar.test.js +0 -35
  238. package/test/Radio.test.js +0 -37
  239. package/test/ResultsetTable.test.js +0 -330
  240. package/test/Select.test.js +0 -192
  241. package/test/Sidenav.test.js +0 -45
  242. package/test/Slider.test.js +0 -82
  243. package/test/Spinner.test.js +0 -27
  244. package/test/Switch.test.js +0 -45
  245. package/test/Table.test.js +0 -36
  246. package/test/Tabs.test.js +0 -109
  247. package/test/TabsForSections.test.js +0 -34
  248. package/test/Tag.test.js +0 -32
  249. package/test/TextArea.test.js +0 -52
  250. package/test/ToggleGroup.test.js +0 -81
  251. package/test/Upload.test.js +0 -60
  252. package/test/Wizard.test.js +0 -130
  253. package/test/mocks/pngMock.js +0 -1
  254. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,23 @@
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+
9
+ type Props = {
10
+ inheritColor?: boolean;
11
+ disabled?: boolean;
12
+ iconSrc?: string;
13
+ icon?: any;
14
+ iconPosition?: "before" | "after";
15
+ href?: string;
16
+ newWindow?: boolean;
17
+ onClick?: void;
18
+ text?: string;
19
+ margin?: Space | Margin;
20
+ tabIndex?: number;
21
+ };
22
+
23
+ export default function DxcLink(props: Props): JSX.Element;
package/main.d.ts ADDED
@@ -0,0 +1,40 @@
1
+ export { default as DxcAccordion } from "./accordion/index";
2
+ export { default as DxcAccordionGroup } from "./accordion-group/index";
3
+ export { default as DxcAlert } from "./alert/index";
4
+ export { default as DxcBox } from "./box/index";
5
+ export { default as DxcButton } from "./button/index";
6
+ export { default as DxcCard } from "./card/index";
7
+ export { default as DxcCheckbox } from "./checkbox/index";
8
+ export { default as DxcChip } from "./chip/index";
9
+ export { default as DxcDate } from "./date/index";
10
+ export { default as DxcDateInput } from "./date-input/index";
11
+ export { default as DxcDialog } from "./dialog/index";
12
+ export { default as DxcDropdown } from "./dropdown/index";
13
+ export { default as DxcFileInput } from "./file-input/index";
14
+ export { default as DxcFooter } from "./footer/index";
15
+ export { default as DxcHeader } from "./header/index";
16
+ export { default as DxcHeading } from "./heading/index";
17
+ export { default as DxcInput } from "./input-text/index";
18
+ export { default as DxcLink } from "./link/index";
19
+ export { default as DxcNumberInput } from "./number-input/index";
20
+ export { default as DxcPaginator } from "./paginator/index";
21
+ export { default as DxcPasswordInput } from "./password-input/index";
22
+ export { default as DxcProgressBar } from "./progress-bar/index";
23
+ export { default as DxcRadio } from "./radio/index";
24
+ export { default as DxcResultsetTable } from "./resultsetTable/index";
25
+ export { default as DxcSelect } from "./select/index";
26
+ export { default as DxcSidenav } from "./sidenav/index";
27
+ export { default as DxcSlider } from "./slider/index";
28
+ export { default as DxcSpinner } from "./spinner/index";
29
+ export { default as DxcSwitch } from "./switch/index";
30
+ export { default as DxcTable } from "./table/index";
31
+ export { default as DxcTabs } from "./tabs/index";
32
+ export { default as DxcTag } from "./tag/index";
33
+ export { default as DxcTextInput } from "./text-input/index";
34
+ export { default as DxcTextarea } from "./textarea/index";
35
+ export { default as DxcToggle } from "./toggle/index";
36
+ export { default as DxcToggleGroup } from "./toggle-group/index";
37
+ export { default as DxcUpload } from "./upload/index";
38
+ export { default as V3DxcSelect } from "./V3Select/index";
39
+ export { default as V3DxcTextarea } from "./V3Textarea/index";
40
+ export { default as DxcWizard } from "./wizard/index";
@@ -79,10 +79,10 @@ Object.defineProperty(exports, "DxcRadio", {
79
79
  return _Radio["default"];
80
80
  }
81
81
  });
82
- Object.defineProperty(exports, "DxcSelect", {
82
+ Object.defineProperty(exports, "V3DxcSelect", {
83
83
  enumerable: true,
84
84
  get: function get() {
85
- return _Select["default"];
85
+ return _V3Select["default"];
86
86
  }
87
87
  });
88
88
  Object.defineProperty(exports, "DxcSlider", {
@@ -103,12 +103,6 @@ Object.defineProperty(exports, "DxcTabs", {
103
103
  return _Tabs["default"];
104
104
  }
105
105
  });
106
- Object.defineProperty(exports, "DxcTabsForSections", {
107
- enumerable: true,
108
- get: function get() {
109
- return _TabsForSections["default"];
110
- }
111
- });
112
106
  Object.defineProperty(exports, "DxcProgressBar", {
113
107
  enumerable: true,
114
108
  get: function get() {
@@ -175,10 +169,10 @@ Object.defineProperty(exports, "DxcHeading", {
175
169
  return _Heading["default"];
176
170
  }
177
171
  });
178
- Object.defineProperty(exports, "DxcTextarea", {
172
+ Object.defineProperty(exports, "V3DxcTextarea", {
179
173
  enumerable: true,
180
174
  get: function get() {
181
- return _Textarea["default"];
175
+ return _V3Textarea["default"];
182
176
  }
183
177
  });
184
178
  Object.defineProperty(exports, "DxcResultsetTable", {
@@ -217,6 +211,48 @@ Object.defineProperty(exports, "DxcBadge", {
217
211
  return _Badge["default"];
218
212
  }
219
213
  });
214
+ Object.defineProperty(exports, "DxcTextInput", {
215
+ enumerable: true,
216
+ get: function get() {
217
+ return _TextInput["default"];
218
+ }
219
+ });
220
+ Object.defineProperty(exports, "DxcPasswordInput", {
221
+ enumerable: true,
222
+ get: function get() {
223
+ return _PasswordInput["default"];
224
+ }
225
+ });
226
+ Object.defineProperty(exports, "DxcDateInput", {
227
+ enumerable: true,
228
+ get: function get() {
229
+ return _DateInput["default"];
230
+ }
231
+ });
232
+ Object.defineProperty(exports, "DxcNumberInput", {
233
+ enumerable: true,
234
+ get: function get() {
235
+ return _NumberInput["default"];
236
+ }
237
+ });
238
+ Object.defineProperty(exports, "DxcTextarea", {
239
+ enumerable: true,
240
+ get: function get() {
241
+ return _Textarea["default"];
242
+ }
243
+ });
244
+ Object.defineProperty(exports, "DxcSelect", {
245
+ enumerable: true,
246
+ get: function get() {
247
+ return _Select["default"];
248
+ }
249
+ });
250
+ Object.defineProperty(exports, "DxcFileInput", {
251
+ enumerable: true,
252
+ get: function get() {
253
+ return _FileInput["default"];
254
+ }
255
+ });
220
256
  Object.defineProperty(exports, "ThemeContext", {
221
257
  enumerable: true,
222
258
  get: function get() {
@@ -260,7 +296,7 @@ var _InputText = _interopRequireDefault(require("./input-text/InputText"));
260
296
 
261
297
  var _Radio = _interopRequireDefault(require("./radio/Radio"));
262
298
 
263
- var _Select = _interopRequireDefault(require("./select/Select"));
299
+ var _V3Select = _interopRequireDefault(require("./V3Select/V3Select"));
264
300
 
265
301
  var _Slider = _interopRequireDefault(require("./slider/Slider"));
266
302
 
@@ -268,8 +304,6 @@ var _Switch = _interopRequireDefault(require("./switch/Switch"));
268
304
 
269
305
  var _Tabs = _interopRequireDefault(require("./tabs/Tabs"));
270
306
 
271
- var _TabsForSections = _interopRequireDefault(require("./tabs-for-sections/TabsForSections"));
272
-
273
307
  var _ProgressBar = _interopRequireDefault(require("./progress-bar/ProgressBar"));
274
308
 
275
309
  var _Spinner = _interopRequireDefault(require("./spinner/Spinner"));
@@ -292,7 +326,7 @@ var _Link = _interopRequireDefault(require("./link/Link"));
292
326
 
293
327
  var _Heading = _interopRequireDefault(require("./heading/Heading"));
294
328
 
295
- var _Textarea = _interopRequireDefault(require("./textarea/Textarea"));
329
+ var _V3Textarea = _interopRequireDefault(require("./V3Textarea/V3Textarea"));
296
330
 
297
331
  var _ResultsetTable = _interopRequireDefault(require("./resultsetTable/ResultsetTable"));
298
332
 
@@ -306,6 +340,20 @@ var _AccordionGroup = _interopRequireDefault(require("./accordion-group/Accordio
306
340
 
307
341
  var _Badge = _interopRequireDefault(require("./badge/Badge"));
308
342
 
343
+ var _TextInput = _interopRequireDefault(require("./text-input/TextInput"));
344
+
345
+ var _PasswordInput = _interopRequireDefault(require("./password-input/PasswordInput"));
346
+
347
+ var _DateInput = _interopRequireDefault(require("./date-input/DateInput"));
348
+
349
+ var _NumberInput = _interopRequireDefault(require("./number-input/NumberInput"));
350
+
351
+ var _Textarea = _interopRequireDefault(require("./textarea/Textarea"));
352
+
353
+ var _Select = _interopRequireDefault(require("./select/Select"));
354
+
355
+ var _FileInput = _interopRequireDefault(require("./file-input/FileInput"));
356
+
309
357
  var _ThemeContext = _interopRequireWildcard(require("./ThemeContext.js"));
310
358
 
311
359
  var _BackgroundColorContext = require("./BackgroundColorContext.js");
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
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 = _interopRequireDefault(require("styled-components"));
19
+
20
+ var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
21
+
22
+ var _NumberInputContext = _interopRequireDefault(require("./NumberInputContext"));
23
+
24
+ var _variables = require("../common/variables.js");
25
+
26
+ function _templateObject() {
27
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n // Chrome, Safari, Edge, Opera\n input::-webkit-outer-spin-button,\n input::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n // Firefox\n input[type=\"number\"] {\n -moz-appearance: textfield;\n }\n"]);
28
+
29
+ _templateObject = function _templateObject() {
30
+ return data;
31
+ };
32
+
33
+ return data;
34
+ }
35
+
36
+ var DxcNumberInput = _react["default"].forwardRef(function (_ref, ref) {
37
+ var _ref$label = _ref.label,
38
+ label = _ref$label === void 0 ? "" : _ref$label,
39
+ _ref$name = _ref.name,
40
+ name = _ref$name === void 0 ? "" : _ref$name,
41
+ value = _ref.value,
42
+ _ref$helperText = _ref.helperText,
43
+ helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
44
+ _ref$placeholder = _ref.placeholder,
45
+ placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
46
+ _ref$disabled = _ref.disabled,
47
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
48
+ _ref$optional = _ref.optional,
49
+ optional = _ref$optional === void 0 ? false : _ref$optional,
50
+ _ref$prefix = _ref.prefix,
51
+ prefix = _ref$prefix === void 0 ? "" : _ref$prefix,
52
+ _ref$suffix = _ref.suffix,
53
+ suffix = _ref$suffix === void 0 ? "" : _ref$suffix,
54
+ min = _ref.min,
55
+ max = _ref.max,
56
+ step = _ref.step,
57
+ onChange = _ref.onChange,
58
+ onBlur = _ref.onBlur,
59
+ _ref$error = _ref.error,
60
+ error = _ref$error === void 0 ? "" : _ref$error,
61
+ _ref$autocomplete = _ref.autocomplete,
62
+ autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
63
+ margin = _ref.margin,
64
+ _ref$size = _ref.size,
65
+ size = _ref$size === void 0 ? "medium" : _ref$size,
66
+ _ref$tabIndex = _ref.tabIndex,
67
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
68
+ return _react["default"].createElement(_NumberInputContext["default"].Provider, {
69
+ value: {
70
+ typeNumber: "number",
71
+ minNumber: min,
72
+ maxNumber: max,
73
+ stepNumber: step
74
+ }
75
+ }, _react["default"].createElement(NumberInputContainer, null, _react["default"].createElement(_TextInput["default"], {
76
+ label: label,
77
+ name: name,
78
+ value: value,
79
+ helperText: helperText,
80
+ placeholder: placeholder,
81
+ disabled: disabled,
82
+ optional: optional,
83
+ prefix: prefix,
84
+ suffix: suffix,
85
+ error: error,
86
+ onChange: onChange,
87
+ onBlur: onBlur,
88
+ autocomplete: autocomplete,
89
+ margin: margin,
90
+ size: size,
91
+ tabIndex: tabIndex,
92
+ ref: ref
93
+ })));
94
+ });
95
+
96
+ var sizes = {
97
+ small: "240px",
98
+ medium: "360px",
99
+ large: "480px",
100
+ fillParent: "100%"
101
+ };
102
+
103
+ var NumberInputContainer = _styledComponents["default"].div(_templateObject());
104
+
105
+ DxcNumberInput.propTypes = {
106
+ label: _propTypes["default"].string,
107
+ name: _propTypes["default"].string,
108
+ value: _propTypes["default"].string,
109
+ helperText: _propTypes["default"].string,
110
+ placeholder: _propTypes["default"].string,
111
+ error: _propTypes["default"].string,
112
+ disabled: _propTypes["default"].bool,
113
+ optional: _propTypes["default"].bool,
114
+ prefix: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].shape({
115
+ type: _propTypes["default"].oneOf(["svg"])
116
+ })]),
117
+ suffix: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].shape({
118
+ type: _propTypes["default"].oneOf(["svg"])
119
+ })]),
120
+ min: _propTypes["default"].number,
121
+ max: _propTypes["default"].number,
122
+ step: _propTypes["default"].number,
123
+ onChange: _propTypes["default"].func,
124
+ onBlur: _propTypes["default"].func,
125
+ autocomplete: _propTypes["default"].string,
126
+ margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
127
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
128
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
129
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
130
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
131
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
132
+ size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
133
+ tabIndex: _propTypes["default"].number
134
+ };
135
+ var _default = DxcNumberInput;
136
+ exports["default"] = _default;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ /* eslint-disable prefer-template */
13
+ var NumberInputContext = _react["default"].createContext();
14
+
15
+ var _default = NumberInputContext;
16
+ exports["default"] = _default;
@@ -0,0 +1,113 @@
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 Props = {
10
+ /**
11
+ * Text to be placed above the number.
12
+ */
13
+ label?: string;
14
+ /**
15
+ * Name attribute of the input element.
16
+ */
17
+ name?: string;
18
+ /**
19
+ * Value of the input element. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
20
+ */
21
+ value?: string;
22
+ /**
23
+ * Helper text to be placed above the number.
24
+ */
25
+ helperText?: string;
26
+ /**
27
+ * Text to be put as placeholder of the number.
28
+ */
29
+ placeholder?: string;
30
+ /**
31
+ * If true, the component will be disabled.
32
+ */
33
+ disabled?: boolean;
34
+ /**
35
+ * If true, the number will be optional, showing '(Optional)'
36
+ * next to the label. Otherwise, the field will be considered required
37
+ * and an error will be passed as a parameter to the OnBlur and onChange
38
+ * functions when it has not been filled.
39
+ */
40
+ optional?: boolean;
41
+ /**
42
+ * Prefix to be placed before the number value.
43
+ */
44
+ prefix?: string;
45
+ /**
46
+ * Suffix to be placed after the number value.
47
+ */
48
+ suffix?: string;
49
+ /**
50
+ * Minimum value allowed by the number input. If the typed value by the user is
51
+ * lower than min, the onBlur and onChange functions will be called with
52
+ * the current value and an internal error informing that the current
53
+ * value is not correct. If a valid state is reached, the error parameter
54
+ * will be null in both events.
55
+ */
56
+ min?: number;
57
+ /**
58
+ * Maximum value allowed by the number input. If the typed value by the user
59
+ * surpasses max, the onBlur and onChange functions will be called with
60
+ * the current value and an internal error informing that the current
61
+ * value is not correct. If a valid state is reached, the error parameter
62
+ * will be null in both events.
63
+ */
64
+ max?: number;
65
+ /**
66
+ * The step interval to use when using the up and down arrows to adjust the value.
67
+ */
68
+ step?: number;
69
+ /**
70
+ * This function will be called when the user types within the input
71
+ * element of the component. An object including the current value and
72
+ * the error (if the value entered is not valid) will be passed to this
73
+ * function. If there is no error, error will be null.
74
+ */
75
+ onChange?: (val: { value: string; error: string }) => void;
76
+ /**
77
+ * This function will be called when the input element loses the focus.
78
+ * An object including the input value and the error (if the value
79
+ * entered is not valid) will be passed to this function. If there is no error,
80
+ * error will be null.
81
+ */
82
+ onBlur?: (val: { value: string; error: string }) => void;
83
+ /**
84
+ * If it is defined, the component will change its appearance, showing
85
+ * the error below the input component. If it is not defined, the error
86
+ * messages will be managed internally, but never displayed on its own.
87
+ */
88
+ error?: string;
89
+ /**
90
+ * HTML autocomplete attribute. Lets the user specify if any permission the user agent has to provide automated assistance in filling out the input value.
91
+ * Its value must be one of all the possible values of the HTML autocomplete attribute: 'on', 'off', 'email', 'username', 'new-password', ...
92
+ */
93
+ autocomplete?: string;
94
+ /**
95
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
96
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
97
+ */
98
+ margin?: Space | Margin;
99
+ /**
100
+ * Size of the component ('small' | 'medium' | 'large' | 'fillParent').
101
+ */
102
+ size?: Size;
103
+ /**
104
+ * Value of the tabindex attribute.
105
+ */
106
+ tabIndex?: number;
107
+ /**
108
+ * Reference to the component.
109
+ */
110
+ ref?: React.RefObject<HTMLDivElement>;
111
+ };
112
+
113
+ export default function DxcNumberInput(props: Props): JSX.Element;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "3.3.0",
3
+ "version": "4.0.1",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
6
  "homepage": "http://developer.dxc.com/tools/react",
@@ -10,11 +10,12 @@
10
10
  "email": "DigitalInsurance@dxc.com",
11
11
  "url": "https://dxc.com"
12
12
  },
13
- "main": "./dist/main.js",
13
+ "main": "./main.js",
14
+ "types": "./main.d.ts",
14
15
  "peerDependencies": {
15
- "react": "^16.8.6",
16
- "react-dom": "^16.8.6",
17
- "styled-components": ">= 4.3.1"
16
+ "react": "^17.0.1",
17
+ "react-dom": "^17.0.1",
18
+ "styled-components": "^5.0.1"
18
19
  },
19
20
  "dependencies": {
20
21
  "@date-io/date-fns": "^1.3.9",
@@ -28,14 +29,16 @@
28
29
  "date-fns": "^2.0.0-beta.4",
29
30
  "moment": "2.24.0",
30
31
  "prop-types": "^15.7.2",
31
- "react-use-scrollspy": "^2.0.0",
32
- "rgb-hex": "^3.0.0"
32
+ "rgb-hex": "^3.0.0",
33
+ "uuid": "^8.3.2"
33
34
  },
34
35
  "scripts": {
35
36
  "test": "jest",
36
37
  "test:watch": "npm test -- --watch --coverage",
37
- "build": "babel src --out-dir dist --copy-files --verbose && node ../scripts/build/copy-readme.js",
38
- "build:watch": "babel src --watch --out-dir dist --copy-files --verbose"
38
+ "build": "babel src --out-dir ../dist --copy-files --verbose && node ../scripts/build/copy-readme.js",
39
+ "build:watch": "babel src --watch --out-dir ../dist --copy-files --verbose",
40
+ "storybook": "start-storybook -p 6006",
41
+ "build-storybook": "build-storybook"
39
42
  },
40
43
  "devDependencies": {
41
44
  "@babel/cli": "^7.6.2",
@@ -46,9 +49,14 @@
46
49
  "@babel/plugin-transform-runtime": "^7.10.1",
47
50
  "@babel/preset-env": "^7.6.2",
48
51
  "@babel/preset-react": "^7.0.0",
52
+ "@storybook/addon-actions": "^6.4.9",
53
+ "@storybook/addon-essentials": "^6.4.9",
54
+ "@storybook/addon-links": "^6.4.9",
55
+ "@storybook/react": "^6.4.9",
49
56
  "@testing-library/react": "^11.2.5",
50
57
  "babel-jest": "^24.8.0",
51
58
  "babel-loader": "^8.0.6",
59
+ "chromatic": "^6.3.3",
52
60
  "eslint": "^5.16.0",
53
61
  "eslint-config-airbnb": "^17.1.0",
54
62
  "eslint-config-prettier": "^6.7.0",
@@ -57,21 +65,19 @@
57
65
  "eslint-plugin-jsx-a11y": "^6.2.1",
58
66
  "eslint-plugin-react": "^7.13.0",
59
67
  "eslint-plugin-react-hooks": "^4.2.0",
68
+ "eslint-plugin-storybook": "^0.5.5",
60
69
  "identity-obj-proxy": "^3.0.0",
61
70
  "jest": "^25.5.4",
62
- "react": "file:../node_modules/react",
63
- "react-dom": "file:../node_modules/react-dom",
64
- "react-test-renderer": "^16.8.6",
65
- "styled-components": "file:../node_modules/styled-components"
71
+ "react": "^17.0.1",
72
+ "react-dom": "^17.0.1",
73
+ "styled-components": "^5.0.1",
74
+ "react-test-renderer": "^16.8.6"
66
75
  },
67
76
  "jest": {
68
77
  "moduleNameMapper": {
69
78
  "\\.(css|less|scss|sass)$": "identity-obj-proxy",
70
79
  "\\.(svg)$": "<rootDir>/test/mocks/svgMock.js",
71
80
  "\\.(png)$": "<rootDir>/test/mocks/pngMock.js"
72
- },
73
- "transformIgnorePatterns": [
74
- "/node_modules/(?!react-use-scrollspy).+\\.js$"
75
- ]
81
+ }
76
82
  }
77
83
  }
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.lastIcon = exports.nextIcon = exports.previousIcon = exports.firstIcon = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var firstIcon = _react["default"].createElement("svg", {
13
+ xmlns: "http://www.w3.org/2000/svg",
14
+ width: "12.41",
15
+ height: "12",
16
+ viewBox: "0 0 12.41 12"
17
+ }, _react["default"].createElement("path", {
18
+ id: "Path_2463",
19
+ "data-name": "Path 2463",
20
+ d: "M18.41,16.59,13.82,12l4.59-4.59L17,6l-6,6,6,6ZM6,6H8V18H6Z",
21
+ transform: "translate(-6 -6)"
22
+ }));
23
+
24
+ exports.firstIcon = firstIcon;
25
+
26
+ var previousIcon = _react["default"].createElement("svg", {
27
+ xmlns: "http://www.w3.org/2000/svg",
28
+ width: "7.41",
29
+ height: "12",
30
+ viewBox: "0 0 7.41 12"
31
+ }, _react["default"].createElement("path", {
32
+ id: "Path_2459",
33
+ "data-name": "Path 2459",
34
+ d: "M15.41,7.41,14,6,8,12l6,6,1.41-1.41L10.83,12Z",
35
+ transform: "translate(-8 -6)"
36
+ }));
37
+
38
+ exports.previousIcon = previousIcon;
39
+
40
+ var nextIcon = _react["default"].createElement("svg", {
41
+ xmlns: "http://www.w3.org/2000/svg",
42
+ width: "7.41",
43
+ height: "12",
44
+ viewBox: "0 0 7.41 12"
45
+ }, _react["default"].createElement("path", {
46
+ id: "Path_2461",
47
+ "data-name": "Path 2461",
48
+ d: "M10,6,8.59,7.41,13.17,12,8.59,16.59,10,18l6-6Z",
49
+ transform: "translate(-8.59 -6)"
50
+ }));
51
+
52
+ exports.nextIcon = nextIcon;
53
+
54
+ var lastIcon = _react["default"].createElement("svg", {
55
+ xmlns: "http://www.w3.org/2000/svg",
56
+ width: "12.41",
57
+ height: "12",
58
+ viewBox: "0 0 12.41 12"
59
+ }, _react["default"].createElement("path", {
60
+ id: "Path_2465",
61
+ "data-name": "Path 2465",
62
+ d: "M5.59,7.41,10.18,12,5.59,16.59,7,18l6-6L7,6ZM16,6h2V18H16Z",
63
+ transform: "translate(-5.59 -6)"
64
+ }));
65
+
66
+ exports.lastIcon = lastIcon;