@dxc-technology/halstack-react 0.0.0-90f64ff → 0.0.0-9427b76

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 (38) hide show
  1. package/dist/ThemeContext.js +66 -58
  2. package/dist/alert/Alert.js +1 -1
  3. package/dist/alert/index.d.ts +51 -0
  4. package/dist/common/variables.js +141 -58
  5. package/dist/date/Date.js +4 -6
  6. package/dist/file-input/FileInput.js +641 -0
  7. package/dist/file-input/FileItem.js +280 -0
  8. package/dist/file-input/index.d.ts +81 -0
  9. package/dist/layout/ApplicationLayout.js +1 -1
  10. package/dist/link/Link.js +4 -8
  11. package/dist/main.d.ts +7 -0
  12. package/dist/main.js +8 -0
  13. package/dist/new-date/NewDate.js +64 -67
  14. package/dist/new-date/index.d.ts +95 -0
  15. package/dist/new-input-text/NewInputText.js +160 -157
  16. package/dist/new-input-text/index.d.ts +135 -0
  17. package/dist/new-textarea/NewTextarea.js +53 -37
  18. package/dist/new-textarea/index.d.ts +117 -0
  19. package/dist/number/Number.js +1 -3
  20. package/dist/number/index.d.ts +113 -0
  21. package/dist/password/Password.js +3 -3
  22. package/dist/password/index.d.ts +94 -0
  23. package/dist/progress-bar/ProgressBar.js +1 -1
  24. package/dist/select/Select.js +122 -158
  25. package/dist/sidenav/Sidenav.js +6 -4
  26. package/dist/tag/Tag.js +26 -32
  27. package/package.json +2 -1
  28. package/test/FileInput.test.js +201 -0
  29. package/test/NewDate.test.js +41 -12
  30. package/test/NewInputText.test.js +104 -187
  31. package/test/NewTextarea.test.js +95 -101
  32. package/test/Number.test.js +44 -28
  33. package/test/Paginator.test.js +1 -1
  34. package/test/Password.test.js +15 -8
  35. package/test/ResultsetTable.test.js +1 -2
  36. package/test/Select.test.js +40 -17
  37. package/dist/select/Select.stories.js +0 -235
  38. package/dist/select/readme.md +0 -72
package/dist/tag/Tag.js CHANGED
@@ -30,7 +30,7 @@ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
30
30
  var _Box = _interopRequireDefault(require("../box/Box"));
31
31
 
32
32
  function _templateObject8() {
33
- var data = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n text-transform: ", ";\n color: ", ";\n padding: 0px 30px;\n letter-spacing: 0.025em;\n flex-grow: 1;\n text-align: center;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n"]);
33
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n flex-grow: 1;\n text-align: center;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n"]);
34
34
 
35
35
  _templateObject8 = function _templateObject8() {
36
36
  return data;
@@ -40,7 +40,7 @@ function _templateObject8() {
40
40
  }
41
41
 
42
42
  function _templateObject7() {
43
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n background: ", ";\n width: ", ";\n justify-content: center;\n align-items: center;\n color: ", ";\n height: ", ";\n"]);
43
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n background: ", ";\n width: ", ";\n height: 100%;\n justify-content: center;\n align-items: center;\n color: ", ";\n"]);
44
44
 
45
45
  _templateObject7 = function _templateObject7() {
46
46
  return data;
@@ -50,7 +50,7 @@ function _templateObject7() {
50
50
  }
51
51
 
52
52
  function _templateObject6() {
53
- var data = (0, _taggedTemplateLiteral2["default"])(["\n height: 43px;\n display: inline-flex;\n justify-content: center;\n align-items: center;\n overflow: hidden;\n img,\n svg {\n height: ", ";\n width: ", ";\n }\n"]);
53
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n overflow: hidden;\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"]);
54
54
 
55
55
  _templateObject6 = function _templateObject6() {
56
56
  return data;
@@ -60,7 +60,7 @@ function _templateObject6() {
60
60
  }
61
61
 
62
62
  function _templateObject5() {
63
- var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 10px 12px;\n height: ", ";\n width: ", ";\n"]);
63
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n overflow: hidden;\n width: ", ";\n height: ", ";\n"]);
64
64
 
65
65
  _templateObject5 = function _templateObject5() {
66
66
  return data;
@@ -70,7 +70,7 @@ function _templateObject5() {
70
70
  }
71
71
 
72
72
  function _templateObject4() {
73
- var data = (0, _taggedTemplateLiteral2["default"])(["\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n outline: 0;\n font-family: inherit;\n"]);
73
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n background: none;\n border-radius: 4px;\n border: none;\n padding: 0;\n cursor: pointer;\n font-family: inherit;\n\n :focus {\n outline: 2px solid ", ";\n }\n"]);
74
74
 
75
75
  _templateObject4 = function _templateObject4() {
76
76
  return data;
@@ -80,7 +80,7 @@ function _templateObject4() {
80
80
  }
81
81
 
82
82
  function _templateObject3() {
83
- var data = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: none;\n"]);
83
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: none;\n border-radius: 4px;\n\n :focus {\n outline: 2px solid ", ";\n outline-offset: 0px;\n }\n"]);
84
84
 
85
85
  _templateObject3 = function _templateObject3() {
86
86
  return data;
@@ -125,7 +125,7 @@ var DxcTag = function DxcTag(_ref) {
125
125
  _ref$size = _ref.size,
126
126
  size = _ref$size === void 0 ? "fitContent" : _ref$size,
127
127
  _ref$tabIndex = _ref.tabIndex,
128
- tabIndex = _ref$tabIndex === void 0 ? 1 : _ref$tabIndex;
128
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
129
129
  var colorsTheme = (0, _useTheme["default"])();
130
130
 
131
131
  var _useState = (0, _react.useState)(false),
@@ -134,9 +134,7 @@ var DxcTag = function DxcTag(_ref) {
134
134
  changeIsHovered = _useState2[1];
135
135
 
136
136
  var clickHandler = function clickHandler() {
137
- if (onClick) {
138
- onClick();
139
- }
137
+ onClick && onClick();
140
138
  };
141
139
 
142
140
  var tagContent = _react["default"].createElement(_Box["default"], {
@@ -144,7 +142,6 @@ var DxcTag = function DxcTag(_ref) {
144
142
  shadowDepth: isHovered && (onClick || linkHref) && 2 || 1
145
143
  }, _react["default"].createElement(TagContent, {
146
144
  labelPosition: labelPosition,
147
- margin: margin,
148
145
  size: size
149
146
  }, _react["default"].createElement(IconContainer, {
150
147
  iconBgColor: iconBgColor
@@ -214,20 +211,24 @@ var TagContent = _styledComponents["default"].div(_templateObject2(), function (
214
211
  return props.theme.height;
215
212
  });
216
213
 
217
- var StyledLink = _styledComponents["default"].a(_templateObject3());
214
+ var StyledLink = _styledComponents["default"].a(_templateObject3(), function (props) {
215
+ return props.theme.focusColor;
216
+ });
218
217
 
219
- var StyledButton = _styledComponents["default"].button(_templateObject4());
218
+ var StyledButton = _styledComponents["default"].button(_templateObject4(), function (props) {
219
+ return props.theme.focusColor;
220
+ });
220
221
 
221
222
  var TagIcon = _styledComponents["default"].img(_templateObject5(), function (props) {
222
- return props.theme.iconHeight;
223
- }, function (props) {
224
223
  return props.theme.iconWidth;
224
+ }, function (props) {
225
+ return props.theme.iconHeight;
225
226
  });
226
227
 
227
228
  var TagIconContainer = _styledComponents["default"].div(_templateObject6(), function (props) {
228
- return props.theme.iconHeight;
229
- }, function (props) {
230
229
  return props.theme.iconWidth;
230
+ }, function (props) {
231
+ return props.theme.iconHeight;
231
232
  });
232
233
 
233
234
  var IconContainer = _styledComponents["default"].div(_templateObject7(), function (_ref9) {
@@ -237,8 +238,6 @@ var IconContainer = _styledComponents["default"].div(_templateObject7(), functio
237
238
  return props.theme.iconSectionWidth;
238
239
  }, function (props) {
239
240
  return props.theme.iconColor;
240
- }, function (props) {
241
- return props.theme.height;
242
241
  });
243
242
 
244
243
  var TagLabel = _styledComponents["default"].div(_templateObject8(), function (props) {
@@ -249,10 +248,16 @@ var TagLabel = _styledComponents["default"].div(_templateObject8(), function (pr
249
248
  return props.theme.fontStyle;
250
249
  }, function (props) {
251
250
  return props.theme.fontWeight;
252
- }, function (props) {
253
- return props.theme.fontTextTransform;
254
251
  }, function (props) {
255
252
  return props.theme.fontColor;
253
+ }, function (props) {
254
+ return props.theme.labelPaddingTop;
255
+ }, function (props) {
256
+ return props.theme.labelPaddingBottom;
257
+ }, function (props) {
258
+ return props.theme.labelPaddingLeft;
259
+ }, function (props) {
260
+ return props.theme.labelPaddingRight;
256
261
  });
257
262
 
258
263
  DxcTag.propTypes = {
@@ -273,16 +278,5 @@ DxcTag.propTypes = {
273
278
  }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
274
279
  tabIndex: _propTypes["default"].number
275
280
  };
276
- DxcTag.defaultProps = {
277
- icon: null,
278
- iconSrc: null,
279
- label: null,
280
- margin: null,
281
- linkHref: null,
282
- onClick: null,
283
- iconBgColor: "#5f249f",
284
- labelPosition: "after",
285
- newWindow: false
286
- };
287
281
  var _default = DxcTag;
288
282
  exports["default"] = _default;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "0.0.0-90f64ff",
3
+ "version": "0.0.0-9427b76",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
6
  "homepage": "http://developer.dxc.com/tools/react",
@@ -11,6 +11,7 @@
11
11
  "url": "https://dxc.com"
12
12
  },
13
13
  "main": "./dist/main.js",
14
+ "types": "./dist/main.d.ts",
14
15
  "peerDependencies": {
15
16
  "react": "^16.8.6",
16
17
  "react-dom": "^16.8.6",
@@ -0,0 +1,201 @@
1
+ import React from "react";
2
+ import { render, fireEvent, waitFor } from "@testing-library/react";
3
+ import userEvent from "@testing-library/user-event";
4
+
5
+ import DxcFileInput from "../src/file-input/FileInput";
6
+
7
+ describe("FileInput component tests", () => {
8
+ const file1 = new File(["file1"], "file1.png", { type: "image/png" });
9
+ const file2 = new File(["file2"], "file2.txt", {
10
+ type: "text/plain",
11
+ });
12
+
13
+ const files = [
14
+ {
15
+ error: null,
16
+ preview: null,
17
+ file: file1,
18
+ },
19
+ {
20
+ error: "Error message",
21
+ preview: null,
22
+ file: file2,
23
+ },
24
+ ];
25
+
26
+ test("Renders with correct labels and helper text in file mode", () => {
27
+ const { getByText } = render(<DxcFileInput label="File input label" helperText="File input helper text" />);
28
+ expect(getByText("File input label")).toBeTruthy();
29
+ expect(getByText("File input helper text")).toBeTruthy();
30
+ });
31
+ test("Renders with correct button label in file mode", () => {
32
+ const { getByText } = render(<DxcFileInput label="File input label" helperText="File input helper text" />);
33
+ expect(getByText("Select files")).toBeTruthy();
34
+ });
35
+ test("Renders with correct labels in filedrop mode", () => {
36
+ const { getByText } = render(
37
+ <DxcFileInput label="File input label" helperText="File input helper text" mode="filedrop" />
38
+ );
39
+ expect(getByText("Select")).toBeTruthy();
40
+ expect(getByText("or drop files")).toBeTruthy();
41
+ });
42
+ test("Renders with correct labels in dropzone mode", () => {
43
+ const { getByText } = render(
44
+ <DxcFileInput label="File input label" helperText="File input helper text" mode="dropzone" />
45
+ );
46
+ expect(getByText("Select")).toBeTruthy();
47
+ expect(getByText("or drop files")).toBeTruthy();
48
+ });
49
+ test("Disabled file input", () => {
50
+ const { getByText, getByRole } = render(
51
+ <DxcFileInput label="File input label" helperText="File input helper text" disabled />
52
+ );
53
+ expect(getByText("Select files")).toBeTruthy();
54
+ const button = getByRole("button");
55
+ expect(button.disabled).toBeTruthy();
56
+ });
57
+ test("Renders file items passed in value when multiple file input", () => {
58
+ const callbackFile = jest.fn();
59
+ const { getByText } = render(
60
+ <DxcFileInput
61
+ label="File input label"
62
+ helperText="File input helper text"
63
+ value={files}
64
+ callbackFile={callbackFile}
65
+ />
66
+ );
67
+ expect(getByText("file1.png")).toBeTruthy();
68
+ expect(getByText("file2.txt")).toBeTruthy();
69
+ expect(getByText("Error message")).toBeTruthy();
70
+ });
71
+ test("Renders file items when single file input", () => {
72
+ const callbackFile = jest.fn();
73
+ const { getByText } = render(
74
+ <DxcFileInput
75
+ label="File input label"
76
+ helperText="File input helper text"
77
+ multiple={false}
78
+ value={files}
79
+ callbackFile={callbackFile}
80
+ />
81
+ );
82
+ expect(getByText("file1.png")).toBeTruthy();
83
+ expect(getByText("file2.txt")).toBeTruthy();
84
+ expect(getByText("Error message")).toBeTruthy();
85
+ });
86
+ test("Add file item when single file input", async () => {
87
+ const newFile = new File(["newFile"], "newFile.pdf", { type: "pdf" });
88
+ const callbackFile = jest.fn();
89
+ const { getByText, getByLabelText } = render(
90
+ <DxcFileInput
91
+ label="File input label"
92
+ helperText="File input helper text"
93
+ value={files}
94
+ callbackFile={callbackFile}
95
+ multiple={false}
96
+ />
97
+ );
98
+ expect(getByText("file1.png")).toBeTruthy();
99
+ expect(getByText("file2.txt")).toBeTruthy();
100
+ expect(getByText("Error message")).toBeTruthy();
101
+ const inputFile = getByLabelText("File input label", { hidden: true });
102
+ fireEvent.change(inputFile, { target: { files: [newFile] } });
103
+ await waitFor(() => {
104
+ expect(callbackFile).toHaveBeenCalledWith([
105
+ {
106
+ error: undefined,
107
+ file: newFile,
108
+ preview: (
109
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="currentColor">
110
+ <path fill="none" d="M0 0h24v24H0V0z" />
111
+ <path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zM6 20V4h7v5h5v11H6z" />
112
+ </svg>
113
+ ),
114
+ },
115
+ ]);
116
+ });
117
+ });
118
+ test("Renders file items and delete one file", async () => {
119
+ const callbackFile = jest.fn();
120
+ const { getByText, getAllByRole } = render(
121
+ <DxcFileInput
122
+ label="File input label"
123
+ helperText="File input helper text"
124
+ value={files}
125
+ callbackFile={callbackFile}
126
+ />
127
+ );
128
+ expect(getByText("file1.png")).toBeTruthy();
129
+ expect(getByText("file2.txt")).toBeTruthy();
130
+ expect(getByText("Error message")).toBeTruthy();
131
+ const removeBtn = getAllByRole("button")[1];
132
+ userEvent.click(removeBtn);
133
+ await waitFor(() => {
134
+ expect(callbackFile).toHaveBeenCalledWith([{ error: "Error message", file: file2, preview: null }]);
135
+ });
136
+ });
137
+
138
+ test("CallbackFile is correctly called", async () => {
139
+ const newFile = new File(["newFile"], "newFile.pdf", { type: "pdf" });
140
+ const callbackFile = jest.fn();
141
+ const { getByLabelText } = render(
142
+ <DxcFileInput
143
+ label="File input label"
144
+ helperText="File input helper text"
145
+ value={files}
146
+ callbackFile={callbackFile}
147
+ />
148
+ );
149
+ const inputFile = getByLabelText("File input label", { hidden: true });
150
+ fireEvent.change(inputFile, { target: { files: [newFile] } });
151
+ await waitFor(() => {
152
+ expect(callbackFile).toHaveBeenCalledWith([
153
+ { error: null, preview: null, file: file1 },
154
+ { error: "Error message", preview: null, file: file2 },
155
+ {
156
+ error: undefined,
157
+ file: newFile,
158
+ preview: (
159
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="currentColor">
160
+ <path fill="none" d="M0 0h24v24H0V0z" />
161
+ <path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zM6 20V4h7v5h5v11H6z" />
162
+ </svg>
163
+ ),
164
+ },
165
+ ]);
166
+ });
167
+ });
168
+
169
+ test("Callback called correctly when a file size does not comply minSize or maxSize", async () => {
170
+ const newFile = new File(["newFile"], "newFile.pdf", { type: "pdf" });
171
+ const callbackFile = jest.fn();
172
+ const { getByLabelText } = render(
173
+ <DxcFileInput
174
+ label="File input label"
175
+ helperText="File input helper text"
176
+ minSize={1000}
177
+ maxSize={20000}
178
+ value={files}
179
+ callbackFile={callbackFile}
180
+ />
181
+ );
182
+ const inputFile = getByLabelText("File input label", { hidden: true });
183
+ fireEvent.change(inputFile, { target: { files: [newFile] } });
184
+ await waitFor(() => {
185
+ expect(callbackFile).toHaveBeenCalledWith([
186
+ { error: null, preview: null, file: file1 },
187
+ { error: "Error message", preview: null, file: file2 },
188
+ {
189
+ error: "File size must be greater than min size.",
190
+ file: newFile,
191
+ preview: (
192
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="currentColor">
193
+ <path fill="none" d="M0 0h24v24H0V0z" />
194
+ <path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zM6 20V4h7v5h5v11H6z" />
195
+ </svg>
196
+ ),
197
+ },
198
+ ]);
199
+ });
200
+ });
201
+ });
@@ -14,7 +14,7 @@ describe("NewDate component tests", () => {
14
14
  expect(getByText("Example of helper text")).toBeTruthy();
15
15
  expect(getByText("(Optional)")).toBeTruthy();
16
16
  expect(input.getAttribute("placeholder")).toBe("DD-MM-YYYY");
17
- userEvent.type(input, "10/90/2010");
17
+ userEvent.type(input, "10/10/2010");
18
18
  const closeAction = getAllByRole("button")[0];
19
19
  userEvent.click(closeAction);
20
20
  expect(input.value).toBe("");
@@ -22,17 +22,29 @@ describe("NewDate component tests", () => {
22
22
 
23
23
  test("Renders with personalized error", () => {
24
24
  const { getByText } = render(<DxcNewDate error="Personalized error." />);
25
-
26
25
  expect(getByText("Personalized error.")).toBeTruthy();
27
26
  });
28
27
 
29
- test("Renders with correct format: user typed date but it's invalid", () => {
30
- const { getByText, getByRole } = render(<DxcNewDate label="With format MM/dd/yyyy" format="MM/dd/yyyy" />);
28
+ test("Renders with correct format: user typed date but it's invalid, onBlur error", () => {
29
+ const onBlur = jest.fn(({ value, error }) => {
30
+ expect(value).toBe("10/90/2010");
31
+ expect(error).toBe("Invalid date.");
32
+ });
33
+ const { getByRole } = render(<DxcNewDate label="With format MM/dd/yyyy" format="MM/dd/yyyy" onBlur={onBlur} />);
31
34
  const input = getByRole("textbox");
32
35
 
33
36
  userEvent.type(input, "10/90/2010");
34
37
  fireEvent.blur(input);
35
- expect(getByText("Invalid date.")).toBeTruthy();
38
+ });
39
+
40
+ test("Renders with correct format: user typed date but it's invalid, onChange error", () => {
41
+ const onChange = jest.fn();
42
+ const { getByRole } = render(<DxcNewDate label="With format MM/dd/yyyy" format="MM/dd/yyyy" onChange={onChange} />);
43
+ const input = getByRole("textbox");
44
+
45
+ userEvent.type(input, "10/90/2010");
46
+ expect(onChange).toHaveBeenCalledTimes(10);
47
+ expect(onChange).toHaveBeenCalledWith({ value: "10/90/2010", error: "Invalid date.", date: null });
36
48
  });
37
49
 
38
50
  test("Calendar renders with correct date: today's date", () => {
@@ -68,7 +80,8 @@ describe("NewDate component tests", () => {
68
80
  });
69
81
 
70
82
  test("Calendar renders with correct date: invalid date, renders with today's date", () => {
71
- const { getByText, getByRole } = render(<DxcNewDate />);
83
+ const onBlur = jest.fn();
84
+ const { getByText, getByRole } = render(<DxcNewDate onBlur={onBlur} />);
72
85
  const calendarAction = getByRole("button");
73
86
  const d = new Date();
74
87
  const options = { weekday: "short", month: "short", day: "numeric" };
@@ -76,7 +89,8 @@ describe("NewDate component tests", () => {
76
89
 
77
90
  userEvent.type(input, "01-01-xxxx");
78
91
  fireEvent.blur(input);
79
- expect(getByText("Invalid date.")).toBeTruthy();
92
+ expect(onBlur).toHaveBeenCalled();
93
+ expect(onBlur).toHaveBeenCalledWith({ value: "01-01-xxxx", error: "Invalid date.", date: null });
80
94
  userEvent.click(calendarAction);
81
95
  expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
82
96
  });
@@ -86,7 +100,7 @@ describe("NewDate component tests", () => {
86
100
  const input = getByRole("textbox");
87
101
  const calendarAction = getByRole("button");
88
102
  userEvent.click(calendarAction);
89
- const dayButton = getByRole("button", { name: "10" });
103
+ const dayButton = getByText("10").closest('button');
90
104
  fireEvent.click(dayButton);
91
105
  const d = new Date();
92
106
  d.setDate(10);
@@ -121,7 +135,7 @@ describe("NewDate component tests", () => {
121
135
  userEvent.type(input, "10-10-2011");
122
136
  expect(input.value).toBe("10-10-2011");
123
137
  expect(onChange).toHaveBeenCalledTimes(10);
124
- expect(onChange).toHaveBeenCalledWith({ value: "10-10-2011", date: d });
138
+ expect(onChange).toHaveBeenCalledWith({ value: "10-10-2011", error: null, date: d });
125
139
  fireEvent.blur(input);
126
140
  expect(onBlur).toHaveBeenCalled();
127
141
  expect(onBlur).toHaveBeenCalledWith({ value: "10-10-2011", error: null, date: d });
@@ -132,12 +146,11 @@ describe("NewDate component tests", () => {
132
146
  const onChange = jest.fn();
133
147
  const { getByRole } = render(<DxcNewDate onChange={onChange} onBlur={onBlur} />);
134
148
  const input = getByRole("textbox");
135
- const d = new Date(2011, 9, 10);
136
149
 
137
150
  userEvent.type(input, "10-10-");
138
151
  expect(input.value).toBe("10-10-");
139
152
  expect(onChange).toHaveBeenCalledTimes(6);
140
- expect(onChange).toHaveBeenCalledWith({ value: "10-10-", date: null });
153
+ expect(onChange).toHaveBeenCalledWith({ value: "10-10-", error: "Invalid date.", date: null });
141
154
  fireEvent.blur(input);
142
155
  expect(onBlur).toHaveBeenCalled();
143
156
  expect(onBlur).toHaveBeenCalledWith({ value: "10-10-", error: "Invalid date.", date: null });
@@ -164,7 +177,7 @@ describe("NewDate component tests", () => {
164
177
 
165
178
  test("onBlur function removes the error when the input is empty", () => {
166
179
  const onBlur = jest.fn();
167
- const { getByRole } = render(<DxcNewDate onBlur={onBlur} />);
180
+ const { getByRole } = render(<DxcNewDate onBlur={onBlur} optional />);
168
181
  const input = getByRole("textbox");
169
182
 
170
183
  userEvent.type(input, "test");
@@ -178,6 +191,22 @@ describe("NewDate component tests", () => {
178
191
  expect(onBlur).toHaveBeenCalledWith({ value: "", error: null, date: null });
179
192
  });
180
193
 
194
+ test("onBlur & onChange functions error: required field (not optional)", () => {
195
+ const onBlur = jest.fn();
196
+ const onChange = jest.fn();
197
+ const { getByRole } = render(<DxcNewDate onBlur={onBlur} onChange={onChange} />);
198
+ const date = getByRole("textbox");
199
+
200
+ userEvent.type(date, "t");
201
+ expect(date.value).toBe("t");
202
+ userEvent.clear(date);
203
+ fireEvent.blur(date);
204
+ expect(onBlur).toHaveBeenCalled();
205
+ expect(onBlur).toHaveBeenCalledWith({ value: "", error: "This field is required. Please, enter a value.", date: null });
206
+ expect(onChange).toHaveBeenCalled();
207
+ expect(onChange).toHaveBeenCalledWith({ value: "", error: "This field is required. Please, enter a value.", date: null });
208
+ });
209
+
181
210
  test("Disabled date (calendar action must be shown but not clickable)", () => {
182
211
  const { getByRole, queryByText } = render(<DxcNewDate disabled />);
183
212
  const calendarAction = getByRole("button");