@dxc-technology/halstack-react 0.0.0-a9032ad → 0.0.0-a9c6846

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 (123) hide show
  1. package/babel.config.js +6 -2
  2. package/dist/BackgroundColorContext.js +46 -0
  3. package/dist/ThemeContext.js +235 -2
  4. package/dist/accordion/Accordion.js +170 -65
  5. package/dist/accordion-group/AccordionGroup.js +186 -0
  6. package/dist/alert/Alert.js +180 -81
  7. package/dist/alert/index.d.ts +51 -0
  8. package/dist/badge/Badge.js +63 -0
  9. package/dist/box/Box.js +31 -23
  10. package/dist/button/Button.js +83 -26
  11. package/dist/card/Card.js +72 -35
  12. package/dist/checkbox/Checkbox.js +98 -38
  13. package/dist/chip/Chip.js +128 -36
  14. package/dist/common/RequiredComponent.js +2 -8
  15. package/dist/common/utils.js +2 -22
  16. package/dist/common/variables.js +1311 -308
  17. package/dist/date/Date.js +75 -52
  18. package/dist/dialog/Dialog.js +58 -37
  19. package/dist/dropdown/Dropdown.js +199 -71
  20. package/dist/file-input/FileInput.js +641 -0
  21. package/dist/file-input/FileItem.js +280 -0
  22. package/dist/file-input/index.d.ts +81 -0
  23. package/dist/footer/Footer.js +85 -36
  24. package/dist/footer/dxc_logo.svg +15 -0
  25. package/dist/header/Header.js +111 -68
  26. package/dist/header/dxc_logo_black.svg +8 -0
  27. package/dist/heading/Heading.js +81 -16
  28. package/dist/input-text/InputText.js +288 -100
  29. package/dist/layout/ApplicationLayout.js +105 -50
  30. package/dist/link/Link.js +136 -35
  31. package/dist/main.d.ts +7 -0
  32. package/dist/main.js +81 -1
  33. package/dist/new-date/NewDate.js +400 -0
  34. package/dist/new-date/index.d.ts +95 -0
  35. package/dist/new-input-text/NewInputText.js +982 -0
  36. package/dist/new-input-text/index.d.ts +135 -0
  37. package/dist/new-textarea/NewTextarea.js +362 -0
  38. package/dist/new-textarea/index.d.ts +117 -0
  39. package/dist/number/Number.js +138 -0
  40. package/dist/number/NumberContext.js +16 -0
  41. package/dist/number/index.d.ts +113 -0
  42. package/dist/paginator/Paginator.js +149 -56
  43. package/dist/password/Password.js +200 -0
  44. package/dist/password/index.d.ts +94 -0
  45. package/dist/password/styles.css +3 -0
  46. package/dist/progress-bar/ProgressBar.js +95 -38
  47. package/dist/radio/Radio.js +31 -17
  48. package/dist/resultsetTable/ResultsetTable.js +93 -68
  49. package/dist/select/Select.js +244 -146
  50. package/dist/sidenav/Sidenav.js +86 -129
  51. package/dist/slider/Slider.js +125 -64
  52. package/dist/spinner/Spinner.js +247 -59
  53. package/dist/switch/Switch.js +50 -27
  54. package/dist/table/Table.js +52 -13
  55. package/dist/tabs/Tabs.js +206 -35
  56. package/dist/tabs-for-sections/TabsForSections.js +1 -16
  57. package/dist/tag/Tag.js +100 -35
  58. package/dist/textarea/Textarea.js +77 -40
  59. package/dist/toggle/Toggle.js +16 -19
  60. package/dist/toggle-group/ToggleGroup.js +64 -55
  61. package/dist/upload/Upload.js +13 -8
  62. package/dist/upload/buttons-upload/ButtonsUpload.js +31 -14
  63. package/dist/upload/dragAndDropArea/DragAndDropArea.js +78 -28
  64. package/dist/upload/file-upload/FileToUpload.js +50 -24
  65. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  66. package/dist/upload/transaction/Transaction.js +44 -24
  67. package/dist/upload/transactions/Transactions.js +38 -20
  68. package/dist/useTheme.js +22 -0
  69. package/dist/wizard/Wizard.js +139 -55
  70. package/dist/wizard/invalid_icon.svg +4 -5
  71. package/dist/wizard/valid_icon.svg +4 -5
  72. package/package.json +13 -5
  73. package/test/AccordionGroup.test.js +125 -0
  74. package/test/Date.test.js +13 -13
  75. package/test/Dropdown.test.js +15 -0
  76. package/test/FileInput.test.js +201 -0
  77. package/test/InputText.test.js +30 -26
  78. package/test/Link.test.js +25 -7
  79. package/test/NewDate.test.js +232 -0
  80. package/test/NewInputText.test.js +734 -0
  81. package/test/NewTextarea.test.js +195 -0
  82. package/test/Number.test.js +257 -0
  83. package/test/Paginator.test.js +72 -60
  84. package/test/Password.test.js +83 -0
  85. package/test/ResultsetTable.test.js +66 -19
  86. package/test/Select.test.js +55 -34
  87. package/test/Sidenav.test.js +22 -64
  88. package/test/Slider.test.js +17 -0
  89. package/test/Spinner.test.js +5 -0
  90. package/test/Tabs.test.js +21 -0
  91. package/dist/accordion/Accordion.stories.js +0 -207
  92. package/dist/accordion/readme.md +0 -96
  93. package/dist/alert/Alert.stories.js +0 -158
  94. package/dist/alert/close.svg +0 -4
  95. package/dist/alert/error.svg +0 -4
  96. package/dist/alert/info.svg +0 -4
  97. package/dist/alert/readme.md +0 -43
  98. package/dist/alert/success.svg +0 -4
  99. package/dist/alert/warning.svg +0 -4
  100. package/dist/button/Button.stories.js +0 -224
  101. package/dist/button/readme.md +0 -93
  102. package/dist/common/services/example-service.js +0 -10
  103. package/dist/common/services/example-service.test.js +0 -12
  104. package/dist/date/calendar.svg +0 -1
  105. package/dist/date/calendar_dark.svg +0 -1
  106. package/dist/dialog/Dialog.stories.js +0 -217
  107. package/dist/dialog/readme.md +0 -32
  108. package/dist/dropdown/Dropdown.stories.js +0 -249
  109. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  110. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  111. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  112. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  113. package/dist/dropdown/readme.md +0 -69
  114. package/dist/footer/dxc_logo_wht.png +0 -0
  115. package/dist/header/dxc_logo_black.png +0 -0
  116. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  117. package/dist/header/dxc_logo_white.png +0 -0
  118. package/dist/layout/SideNav.js +0 -67
  119. package/dist/select/Select.stories.js +0 -235
  120. package/dist/select/readme.md +0 -72
  121. package/dist/sidenav/arrow_icon.svg +0 -3
  122. package/dist/toggle-group/readme.md +0 -82
  123. package/test/Toggle.test.js +0 -43
package/dist/main.js CHANGED
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
+
3
5
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
6
 
5
7
  Object.defineProperty(exports, "__esModule", {
@@ -203,12 +205,72 @@ Object.defineProperty(exports, "DxcToggleGroup", {
203
205
  return _ToggleGroup["default"];
204
206
  }
205
207
  });
208
+ Object.defineProperty(exports, "DxcAccordionGroup", {
209
+ enumerable: true,
210
+ get: function get() {
211
+ return _AccordionGroup["default"];
212
+ }
213
+ });
214
+ Object.defineProperty(exports, "DxcBadge", {
215
+ enumerable: true,
216
+ get: function get() {
217
+ return _Badge["default"];
218
+ }
219
+ });
220
+ Object.defineProperty(exports, "DxcNewInputText", {
221
+ enumerable: true,
222
+ get: function get() {
223
+ return _NewInputText["default"];
224
+ }
225
+ });
226
+ Object.defineProperty(exports, "DxcPassword", {
227
+ enumerable: true,
228
+ get: function get() {
229
+ return _Password["default"];
230
+ }
231
+ });
232
+ Object.defineProperty(exports, "DxcNewDate", {
233
+ enumerable: true,
234
+ get: function get() {
235
+ return _NewDate["default"];
236
+ }
237
+ });
238
+ Object.defineProperty(exports, "DxcNumber", {
239
+ enumerable: true,
240
+ get: function get() {
241
+ return _Number["default"];
242
+ }
243
+ });
244
+ Object.defineProperty(exports, "DxcNewTextarea", {
245
+ enumerable: true,
246
+ get: function get() {
247
+ return _NewTextarea["default"];
248
+ }
249
+ });
250
+ Object.defineProperty(exports, "DxcFileInput", {
251
+ enumerable: true,
252
+ get: function get() {
253
+ return _FileInput["default"];
254
+ }
255
+ });
206
256
  Object.defineProperty(exports, "ThemeContext", {
207
257
  enumerable: true,
208
258
  get: function get() {
209
259
  return _ThemeContext["default"];
210
260
  }
211
261
  });
262
+ Object.defineProperty(exports, "ThemeProvider", {
263
+ enumerable: true,
264
+ get: function get() {
265
+ return _ThemeContext.ThemeProvider;
266
+ }
267
+ });
268
+ Object.defineProperty(exports, "BackgroundColorProvider", {
269
+ enumerable: true,
270
+ get: function get() {
271
+ return _BackgroundColorContext.BackgroundColorProvider;
272
+ }
273
+ });
212
274
 
213
275
  var _Alert = _interopRequireDefault(require("./alert/Alert"));
214
276
 
@@ -276,4 +338,22 @@ var _ApplicationLayout = _interopRequireDefault(require("./layout/ApplicationLay
276
338
 
277
339
  var _ToggleGroup = _interopRequireDefault(require("./toggle-group/ToggleGroup"));
278
340
 
279
- var _ThemeContext = _interopRequireDefault(require("./ThemeContext.js"));
341
+ var _AccordionGroup = _interopRequireDefault(require("./accordion-group/AccordionGroup"));
342
+
343
+ var _Badge = _interopRequireDefault(require("./badge/Badge"));
344
+
345
+ var _NewInputText = _interopRequireDefault(require("./new-input-text/NewInputText"));
346
+
347
+ var _Password = _interopRequireDefault(require("./password/Password"));
348
+
349
+ var _NewDate = _interopRequireDefault(require("./new-date/NewDate"));
350
+
351
+ var _Number = _interopRequireDefault(require("./number/Number"));
352
+
353
+ var _NewTextarea = _interopRequireDefault(require("./new-textarea/NewTextarea"));
354
+
355
+ var _FileInput = _interopRequireDefault(require("./file-input/FileInput"));
356
+
357
+ var _ThemeContext = _interopRequireWildcard(require("./ThemeContext.js"));
358
+
359
+ var _BackgroundColorContext = require("./BackgroundColorContext.js");
@@ -0,0 +1,400 @@
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 _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
+
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _pickers = require("@material-ui/pickers");
21
+
22
+ var _core = require("@material-ui/core");
23
+
24
+ var _ClickAwayListener = _interopRequireDefault(require("@material-ui/core/ClickAwayListener"));
25
+
26
+ var _Popover = _interopRequireDefault(require("@material-ui/core/Popover"));
27
+
28
+ var _moment = _interopRequireDefault(require("moment"));
29
+
30
+ var _dateFns = _interopRequireDefault(require("@date-io/date-fns"));
31
+
32
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
33
+
34
+ var _propTypes = _interopRequireDefault(require("prop-types"));
35
+
36
+ var _variables = require("../common/variables.js");
37
+
38
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
39
+
40
+ var _NewInputText = _interopRequireDefault(require("../new-input-text/NewInputText"));
41
+
42
+ function _templateObject() {
43
+ var data = (0, _taggedTemplateLiteral2["default"])([""]);
44
+
45
+ _templateObject = function _templateObject() {
46
+ return data;
47
+ };
48
+
49
+ return data;
50
+ }
51
+
52
+ var DxcNewDate = _react["default"].forwardRef(function (_ref, ref) {
53
+ var _ref$label = _ref.label,
54
+ label = _ref$label === void 0 ? "" : _ref$label,
55
+ _ref$name = _ref.name,
56
+ name = _ref$name === void 0 ? "" : _ref$name,
57
+ value = _ref.value,
58
+ _ref$format = _ref.format,
59
+ format = _ref$format === void 0 ? "dd-MM-yyyy" : _ref$format,
60
+ _ref$helperText = _ref.helperText,
61
+ helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
62
+ _ref$placeholder = _ref.placeholder,
63
+ placeholder = _ref$placeholder === void 0 ? false : _ref$placeholder,
64
+ _ref$clearable = _ref.clearable,
65
+ clearable = _ref$clearable === void 0 ? false : _ref$clearable,
66
+ _ref$disabled = _ref.disabled,
67
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
68
+ _ref$optional = _ref.optional,
69
+ optional = _ref$optional === void 0 ? false : _ref$optional,
70
+ onChange = _ref.onChange,
71
+ onBlur = _ref.onBlur,
72
+ _ref$error = _ref.error,
73
+ error = _ref$error === void 0 ? "" : _ref$error,
74
+ _ref$autocomplete = _ref.autocomplete,
75
+ autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
76
+ margin = _ref.margin,
77
+ _ref$size = _ref.size,
78
+ size = _ref$size === void 0 ? "medium" : _ref$size,
79
+ _ref$tabIndex = _ref.tabIndex,
80
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
81
+
82
+ var _useState = (0, _react.useState)(""),
83
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
84
+ innerValue = _useState2[0],
85
+ setInnerValue = _useState2[1];
86
+
87
+ var _useState3 = (0, _react.useState)(false),
88
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
89
+ isOpen = _useState4[0],
90
+ setIsOpen = _useState4[1];
91
+
92
+ var _useState5 = (0, _react.useState)(null),
93
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
94
+ anchorEl = _useState6[0],
95
+ setAnchorEl = _useState6[1];
96
+
97
+ var colorsTheme = (0, _useTheme["default"])();
98
+
99
+ var handleCalendarOnKeyDown = function handleCalendarOnKeyDown(event) {
100
+ switch (event.keyCode) {
101
+ case 27:
102
+ // Esc
103
+ event.preventDefault();
104
+ setIsOpen(false);
105
+ break;
106
+ }
107
+ };
108
+
109
+ var handleCalendarOnClick = function handleCalendarOnClick(newDate) {
110
+ var newValue = (0, _moment["default"])(newDate).format(format.toUpperCase());
111
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
112
+ onChange === null || onChange === void 0 ? void 0 : onChange({
113
+ value: newValue,
114
+ error: null,
115
+ date: newDate && newDate.toJSON() ? newDate : null
116
+ });
117
+ };
118
+
119
+ var handleIOnChange = function handleIOnChange(_ref2) {
120
+ var newValue = _ref2.value,
121
+ inputError = _ref2.error;
122
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
123
+ var momentDate = (0, _moment["default"])(newValue, format.toUpperCase(), true);
124
+ var invalidDateMessage = newValue !== "" && !momentDate.isValid() ? "Invalid date." : null;
125
+ onChange === null || onChange === void 0 ? void 0 : onChange({
126
+ value: newValue,
127
+ error: inputError || invalidDateMessage,
128
+ date: momentDate.isValid() ? momentDate._d : null
129
+ });
130
+ };
131
+
132
+ var handleIOnBlur = function handleIOnBlur(_ref3) {
133
+ var value = _ref3.value,
134
+ inputError = _ref3.error;
135
+ var momentDate = (0, _moment["default"])(value, format.toUpperCase(), true);
136
+ var invalidDateMessage = value !== "" && !momentDate.isValid() ? "Invalid date." : null;
137
+ onBlur === null || onBlur === void 0 ? void 0 : onBlur({
138
+ value: value,
139
+ error: inputError || invalidDateMessage,
140
+ date: momentDate.isValid() ? momentDate._d : null
141
+ });
142
+ };
143
+
144
+ var getValueForPicker = function getValueForPicker() {
145
+ return (0, _moment["default"])(value !== null && value !== void 0 ? value : innerValue, format.toUpperCase(), true).format();
146
+ };
147
+
148
+ var openCalendar = function openCalendar(event) {
149
+ if (event) {
150
+ setIsOpen(!isOpen);
151
+ setAnchorEl(event.currentTarget);
152
+ }
153
+ };
154
+
155
+ var closeCalendar = function closeCalendar() {
156
+ setIsOpen(false);
157
+ };
158
+
159
+ var calendarAction = {
160
+ onClick: openCalendar,
161
+ icon: _react["default"].createElement("svg", {
162
+ xmlns: "http://www.w3.org/2000/svg",
163
+ height: "24",
164
+ viewBox: "0 0 24 24",
165
+ width: "24",
166
+ fill: "currentColor"
167
+ }, _react["default"].createElement("path", {
168
+ d: "M0 0h24v24H0z",
169
+ fill: "none"
170
+ }), _react["default"].createElement("path", {
171
+ d: "M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 18H4V8h16v13z"
172
+ }))
173
+ };
174
+ var dateTheme = (0, _core.createMuiTheme)({
175
+ overrides: {
176
+ MuiTypography: {
177
+ root: {
178
+ fontFamily: "".concat(colorsTheme.newDate.pickerFontFamily, " !important")
179
+ }
180
+ },
181
+ MuiPickersYearSelection: {
182
+ container: {
183
+ color: colorsTheme.newDate.pickerYearFontColor,
184
+ "&::-webkit-scrollbar": {
185
+ width: "3px"
186
+ },
187
+ "&::-webkit-scrollbar-track": {
188
+ backgroundColor: "#D9D9D9",
189
+ borderRadius: "3px"
190
+ },
191
+ "&::-webkit-scrollbar-thumb": {
192
+ backgroundColor: "#666666",
193
+ borderRadius: "3px"
194
+ }
195
+ }
196
+ },
197
+ MuiPickersToolbar: {
198
+ toolbar: {
199
+ backgroundColor: colorsTheme.newDate.pickerBackgroundColor,
200
+ color: colorsTheme.newDate.pickerDayFontColor
201
+ }
202
+ },
203
+ MuiIconButton: {
204
+ root: {
205
+ height: "36px",
206
+ width: "36px",
207
+ padding: "0px"
208
+ }
209
+ },
210
+ MuiTouchRipple: {
211
+ child: {
212
+ opacity: "0"
213
+ }
214
+ },
215
+ MuiButtonBase: {
216
+ root: {
217
+ "&:focus": {
218
+ outline: colorsTheme.newDate.pickerFocusColor + " solid 2px"
219
+ }
220
+ }
221
+ },
222
+ MuiPickersBasePicker: {
223
+ pickerView: {
224
+ minWidth: "unset",
225
+ maxWidth: "unset",
226
+ minHeight: "unset",
227
+ padding: "0px 10px",
228
+ height: colorsTheme.newDate.pickerHeight,
229
+ width: colorsTheme.newDate.pickerWidth,
230
+ backgroundColor: colorsTheme.newDate.pickerBackgroundColor,
231
+ fontFamily: colorsTheme.newDate.pickerFontFamily
232
+ }
233
+ },
234
+ MuiPickersToolbarText: {
235
+ toolbarTxt: {
236
+ color: colorsTheme.newDate.pickerActualDateFontColor,
237
+ fontFamily: colorsTheme.newDate.pickerFontFamily,
238
+ fontSize: "2rem"
239
+ },
240
+ toolbarBtnSelected: {
241
+ color: colorsTheme.newDate.pickerActualDateFontColor
242
+ }
243
+ },
244
+ MuiPickersCalendarHeader: {
245
+ transitionContainer: {
246
+ color: colorsTheme.newDate.pickerMonthFontColor
247
+ },
248
+ dayLabel: {
249
+ color: colorsTheme.newDate.pickerWeekFontColor,
250
+ fontFamily: colorsTheme.newDate.pickerFontFamily
251
+ },
252
+ switchHeader: {
253
+ backgroundColor: "#ffffff",
254
+ color: colorsTheme.newDate.pickerDayFontColor
255
+ },
256
+ iconButton: {
257
+ backgroundColor: colorsTheme.newDate.pickerMonthArrowsBackgroundColor,
258
+ "&:hover": {
259
+ backgroundColor: colorsTheme.newDate.pickerMonthArrowsBackgroundColor
260
+ }
261
+ }
262
+ },
263
+ MuiPickersCalendar: {
264
+ week: {
265
+ marginBottom: "2px"
266
+ }
267
+ },
268
+ MuiPickersDay: {
269
+ current: {
270
+ color: colorsTheme.newDate.pickerDayFontColor
271
+ },
272
+ day: {
273
+ fontFamily: colorsTheme.newDate.pickerFontFamily,
274
+ color: colorsTheme.newDate.pickerDayFontColor,
275
+ "&:hover": {
276
+ backgroundColor: colorsTheme.newDate.pickerHoverDateBackgroundColor,
277
+ color: colorsTheme.newDate.pickerHoverDateFontColor
278
+ }
279
+ },
280
+ daySelected: {
281
+ backgroundColor: colorsTheme.newDate.pickerSelectedDateBackgroundColor,
282
+ color: colorsTheme.newDate.pickerSelectedDateColor,
283
+ "&:hover": {
284
+ backgroundColor: colorsTheme.newDate.pickerSelectedDateBackgroundColor,
285
+ color: colorsTheme.newDate.pickerSelectedDateColor,
286
+ opacity: "1"
287
+ }
288
+ }
289
+ },
290
+ MuiPickersYear: {
291
+ yearSelected: {
292
+ color: colorsTheme.newDate.pickerSelectedDateColor,
293
+ backgroundColor: colorsTheme.newDate.pickerSelectedDateBackgroundColor,
294
+ margin: "0px 100px",
295
+ borderRadius: "20px"
296
+ },
297
+ root: {
298
+ "&:focus": {
299
+ color: colorsTheme.newDate.pickerHoverDateFontColor,
300
+ backgroundColor: colorsTheme.newDate.pickerHoverDateBackgroundColor
301
+ }
302
+ }
303
+ },
304
+ MuiPickersModal: {
305
+ dialogAction: {
306
+ color: "pink"
307
+ }
308
+ }
309
+ }
310
+ });
311
+ return _react["default"].createElement(_styledComponents.ThemeProvider, {
312
+ theme: colorsTheme
313
+ }, _react["default"].createElement(_core.MuiThemeProvider, {
314
+ theme: dateTheme
315
+ }, _react["default"].createElement(_pickers.MuiPickersUtilsProvider, {
316
+ utils: _dateFns["default"]
317
+ }, _react["default"].createElement(StyledDPicker, null, _react["default"].createElement(_NewInputText["default"], {
318
+ label: label,
319
+ name: name,
320
+ value: value !== null && value !== void 0 ? value : innerValue,
321
+ helperText: helperText,
322
+ placeholder: placeholder ? format.toUpperCase() : null,
323
+ action: calendarAction,
324
+ clearable: clearable,
325
+ disabled: disabled,
326
+ optional: optional,
327
+ onChange: handleIOnChange,
328
+ onBlur: handleIOnBlur,
329
+ error: error,
330
+ autocomplete: autocomplete,
331
+ margin: margin,
332
+ size: size,
333
+ tabIndex: tabIndex,
334
+ ref: ref
335
+ }), _react["default"].createElement(_Popover["default"], {
336
+ onKeyDown: handleCalendarOnKeyDown,
337
+ open: isOpen,
338
+ anchorEl: anchorEl,
339
+ anchorOrigin: {
340
+ vertical: "bottom",
341
+ horizontal: "left"
342
+ },
343
+ transformOrigin: {
344
+ vertical: "top",
345
+ horizontal: "center"
346
+ },
347
+ PaperProps: {
348
+ style: {
349
+ marginTop: "10px"
350
+ }
351
+ }
352
+ }, _react["default"].createElement(_ClickAwayListener["default"], {
353
+ onClickAway: closeCalendar
354
+ }, _react["default"].createElement(_core.Paper, {
355
+ role: "dialog",
356
+ "aria-modal": "true"
357
+ }, _react["default"].createElement(_pickers.DatePicker, {
358
+ variant: "static",
359
+ value: getValueForPicker(),
360
+ onChange: function onChange(date) {
361
+ return handleCalendarOnClick(date);
362
+ },
363
+ format: format,
364
+ disabled: disabled
365
+ }))))))));
366
+ });
367
+
368
+ var sizes = {
369
+ medium: "360px",
370
+ large: "480px",
371
+ fillParent: "100%"
372
+ };
373
+
374
+ var StyledDPicker = _styledComponents["default"].div(_templateObject());
375
+
376
+ DxcNewDate.propTypes = {
377
+ label: _propTypes["default"].string,
378
+ name: _propTypes["default"].string,
379
+ value: _propTypes["default"].string,
380
+ format: _propTypes["default"].string,
381
+ helperText: _propTypes["default"].string,
382
+ placeholder: _propTypes["default"].bool,
383
+ clearable: _propTypes["default"].bool,
384
+ disabled: _propTypes["default"].bool,
385
+ optional: _propTypes["default"].bool,
386
+ onChange: _propTypes["default"].func,
387
+ onBlur: _propTypes["default"].func,
388
+ error: _propTypes["default"].string,
389
+ autocomplete: _propTypes["default"].string,
390
+ size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
391
+ margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
392
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
393
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
394
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
395
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
396
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
397
+ tabIndex: _propTypes["default"].number
398
+ };
399
+ var _default = DxcNewDate;
400
+ exports["default"] = _default;
@@ -0,0 +1,95 @@
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 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 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 DxcNewDate(props: Props): JSX.Element;