@dxc-technology/halstack-react 0.0.0-e201636 → 0.0.0-e26622f

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 (152) hide show
  1. package/accordion/Accordion.js +122 -103
  2. package/accordion/Accordion.stories.tsx +2 -3
  3. package/accordion/Accordion.test.js +9 -10
  4. package/accordion/types.d.ts +5 -4
  5. package/accordion-group/AccordionGroup.js +2 -21
  6. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  7. package/accordion-group/AccordionGroup.test.js +20 -45
  8. package/accordion-group/types.d.ts +10 -3
  9. package/alert/Alert.js +1 -1
  10. package/bleed/Bleed.js +1 -34
  11. package/bleed/Bleed.stories.tsx +94 -95
  12. package/bleed/types.d.ts +1 -1
  13. package/box/Box.js +1 -1
  14. package/box/types.d.ts +1 -0
  15. package/bulleted-list/BulletedList.d.ts +7 -0
  16. package/bulleted-list/BulletedList.js +123 -0
  17. package/bulleted-list/BulletedList.stories.tsx +200 -0
  18. package/bulleted-list/types.d.ts +11 -0
  19. package/{list → bulleted-list}/types.js +0 -0
  20. package/button/Button.js +43 -61
  21. package/button/Button.stories.tsx +9 -0
  22. package/button/types.d.ts +7 -7
  23. package/card/Card.js +34 -36
  24. package/card/types.d.ts +1 -0
  25. package/checkbox/Checkbox.js +87 -95
  26. package/checkbox/Checkbox.test.js +93 -16
  27. package/checkbox/types.d.ts +2 -2
  28. package/chip/types.d.ts +1 -1
  29. package/common/variables.js +56 -18
  30. package/date-input/DateInput.js +3 -3
  31. package/dialog/Dialog.js +52 -28
  32. package/dialog/Dialog.stories.tsx +57 -2
  33. package/dialog/Dialog.test.js +34 -4
  34. package/dialog/types.d.ts +3 -2
  35. package/dropdown/Dropdown.d.ts +1 -1
  36. package/dropdown/Dropdown.js +244 -247
  37. package/dropdown/Dropdown.stories.tsx +126 -63
  38. package/dropdown/Dropdown.test.js +509 -108
  39. package/dropdown/DropdownMenu.d.ts +4 -0
  40. package/dropdown/DropdownMenu.js +80 -0
  41. package/dropdown/DropdownMenuItem.d.ts +4 -0
  42. package/dropdown/DropdownMenuItem.js +92 -0
  43. package/dropdown/types.d.ts +25 -5
  44. package/flex/Flex.d.ts +4 -0
  45. package/flex/Flex.js +69 -0
  46. package/flex/Flex.stories.tsx +103 -0
  47. package/flex/types.d.ts +32 -0
  48. package/{row → flex}/types.js +0 -0
  49. package/footer/Footer.stories.tsx +8 -1
  50. package/footer/Icons.js +1 -1
  51. package/footer/types.d.ts +2 -1
  52. package/header/Header.js +74 -72
  53. package/header/Header.stories.tsx +4 -4
  54. package/header/Icons.js +2 -2
  55. package/header/types.d.ts +3 -2
  56. package/inset/Inset.js +1 -34
  57. package/inset/Inset.stories.tsx +36 -36
  58. package/inset/types.d.ts +1 -1
  59. package/layout/ApplicationLayout.d.ts +15 -6
  60. package/layout/ApplicationLayout.js +37 -65
  61. package/layout/ApplicationLayout.stories.tsx +80 -44
  62. package/layout/types.d.ts +17 -27
  63. package/link/Link.js +1 -1
  64. package/link/Link.stories.tsx +13 -6
  65. package/link/types.d.ts +1 -1
  66. package/main.d.ts +5 -8
  67. package/main.js +28 -52
  68. package/number-input/NumberInput.test.js +1 -1
  69. package/package.json +10 -9
  70. package/paginator/Paginator.test.js +42 -0
  71. package/paragraph/Paragraph.d.ts +6 -0
  72. package/paragraph/Paragraph.js +38 -0
  73. package/paragraph/Paragraph.stories.tsx +44 -0
  74. package/password-input/PasswordInput.test.js +13 -12
  75. package/progress-bar/ProgressBar.d.ts +2 -2
  76. package/progress-bar/ProgressBar.js +56 -50
  77. package/progress-bar/ProgressBar.stories.jsx +3 -1
  78. package/progress-bar/ProgressBar.test.js +67 -22
  79. package/progress-bar/types.d.ts +3 -4
  80. package/quick-nav/QuickNav.js +25 -20
  81. package/quick-nav/QuickNav.stories.tsx +131 -26
  82. package/radio-group/Radio.d.ts +1 -1
  83. package/radio-group/Radio.js +43 -28
  84. package/radio-group/RadioGroup.js +26 -29
  85. package/radio-group/RadioGroup.stories.tsx +1 -0
  86. package/radio-group/RadioGroup.test.js +28 -58
  87. package/radio-group/types.d.ts +2 -2
  88. package/resultsetTable/ResultsetTable.test.js +42 -0
  89. package/select/Listbox.d.ts +1 -1
  90. package/select/Listbox.js +53 -7
  91. package/select/Select.js +42 -43
  92. package/select/Select.stories.tsx +131 -98
  93. package/select/Select.test.js +105 -50
  94. package/select/types.d.ts +2 -5
  95. package/sidenav/Sidenav.d.ts +6 -5
  96. package/sidenav/Sidenav.js +176 -55
  97. package/sidenav/Sidenav.stories.tsx +154 -156
  98. package/sidenav/Sidenav.test.js +25 -37
  99. package/sidenav/types.d.ts +50 -27
  100. package/slider/Slider.js +116 -92
  101. package/slider/Slider.stories.tsx +7 -1
  102. package/slider/Slider.test.js +121 -21
  103. package/slider/types.d.ts +2 -2
  104. package/switch/Switch.d.ts +1 -1
  105. package/switch/Switch.js +132 -66
  106. package/switch/Switch.stories.tsx +8 -30
  107. package/switch/Switch.test.js +144 -17
  108. package/switch/types.d.ts +3 -4
  109. package/tabs/Tab.d.ts +4 -0
  110. package/tabs/Tab.js +135 -0
  111. package/tabs/Tabs.js +360 -104
  112. package/tabs/Tabs.stories.tsx +74 -0
  113. package/tabs/Tabs.test.js +217 -6
  114. package/tabs/types.d.ts +15 -5
  115. package/tabs-nav/NavTabs.js +5 -5
  116. package/tabs-nav/Tab.js +3 -5
  117. package/tabs-nav/types.d.ts +1 -1
  118. package/tag/Tag.js +1 -1
  119. package/tag/types.d.ts +1 -1
  120. package/text-input/Icons.d.ts +8 -0
  121. package/text-input/Icons.js +60 -0
  122. package/text-input/Suggestion.js +7 -5
  123. package/text-input/Suggestions.d.ts +4 -0
  124. package/text-input/Suggestions.js +134 -0
  125. package/text-input/TextInput.js +181 -278
  126. package/text-input/TextInput.stories.tsx +189 -182
  127. package/text-input/TextInput.test.js +165 -163
  128. package/text-input/types.d.ts +22 -3
  129. package/toggle-group/types.d.ts +1 -1
  130. package/typography/Typography.d.ts +4 -0
  131. package/typography/Typography.js +131 -0
  132. package/typography/Typography.stories.tsx +198 -0
  133. package/typography/types.d.ts +18 -0
  134. package/{stack → typography}/types.js +0 -0
  135. package/wizard/Wizard.js +9 -16
  136. package/wizard/Wizard.stories.tsx +20 -1
  137. package/wizard/types.d.ts +5 -4
  138. package/list/List.d.ts +0 -4
  139. package/list/List.js +0 -47
  140. package/list/List.stories.tsx +0 -95
  141. package/list/types.d.ts +0 -7
  142. package/row/Row.d.ts +0 -3
  143. package/row/Row.js +0 -127
  144. package/row/Row.stories.tsx +0 -237
  145. package/row/types.d.ts +0 -28
  146. package/stack/Stack.d.ts +0 -3
  147. package/stack/Stack.js +0 -97
  148. package/stack/Stack.stories.tsx +0 -164
  149. package/stack/types.d.ts +0 -24
  150. package/text/Text.d.ts +0 -7
  151. package/text/Text.js +0 -30
  152. package/text/Text.stories.tsx +0 -19
@@ -2,6 +2,10 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
6
+
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+
5
9
  var _react = _interopRequireDefault(require("react"));
6
10
 
7
11
  var _Select = _interopRequireDefault(require("./Select"));
@@ -10,6 +14,44 @@ var _react2 = require("@testing-library/react");
10
14
 
11
15
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
12
16
 
17
+ // Mocking DOMRect for Radix Primitive Popover
18
+ global.globalThis = global;
19
+
20
+ global.ResizeObserver = /*#__PURE__*/function () {
21
+ function ResizeObserver(cb) {
22
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
23
+ this.cb = cb;
24
+ }
25
+
26
+ (0, _createClass2["default"])(ResizeObserver, [{
27
+ key: "observe",
28
+ value: function observe() {
29
+ this.cb([{
30
+ borderBoxSize: {
31
+ inlineSize: 0,
32
+ blockSize: 0
33
+ }
34
+ }]);
35
+ }
36
+ }, {
37
+ key: "unobserve",
38
+ value: function unobserve() {}
39
+ }]);
40
+ return ResizeObserver;
41
+ }();
42
+
43
+ global.DOMRect = {
44
+ fromRect: function fromRect() {
45
+ return {
46
+ top: 0,
47
+ left: 0,
48
+ bottom: 0,
49
+ right: 0,
50
+ width: 0,
51
+ height: 0
52
+ };
53
+ }
54
+ };
13
55
  var single_options = [{
14
56
  label: "Option 01",
15
57
  value: "1"
@@ -264,7 +306,7 @@ var grouped_icon_options = [{
264
306
  }]
265
307
  }];
266
308
  describe("Select component tests", function () {
267
- test("Renders with correct label", function () {
309
+ test("When clicking the label, the focus goes to the select", function () {
268
310
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
269
311
  label: "test-select-label",
270
312
  helperText: "test-select-helper-text",
@@ -275,40 +317,18 @@ describe("Select component tests", function () {
275
317
 
276
318
  var select = getByRole("combobox");
277
319
  var label = getByText("test-select-label");
278
- expect(label).toBeTruthy();
279
320
 
280
321
  _userEvent["default"].click(label);
281
322
 
282
323
  expect(document.activeElement).toEqual(select);
283
324
  });
284
- test("Renders with correct helper text and placeholder", function () {
325
+ test("Renders with correct aria attributes when is in error state", function () {
285
326
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
286
- label: "test-select-label",
287
- helperText: "test-select-helper-text",
288
- placeholder: "Example text"
289
- })),
290
- getByText = _render2.getByText;
291
-
292
- expect(getByText("test-select-helper-text")).toBeTruthy();
293
- expect(getByText("Example text")).toBeTruthy();
294
- });
295
- test("Renders with correct optional label", function () {
296
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
297
- label: "test-select-label",
298
- optional: true
299
- })),
300
- getByText = _render3.getByText;
301
-
302
- expect(getByText("test-select-label")).toBeTruthy();
303
- expect(getByText("(Optional)")).toBeTruthy();
304
- });
305
- test("Renders with error message and correct aria attributes", function () {
306
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
307
327
  label: "Error label",
308
328
  error: "Error message."
309
329
  })),
310
- getByText = _render4.getByText,
311
- getByRole = _render4.getByRole;
330
+ getByText = _render2.getByText,
331
+ getByRole = _render2.getByRole;
312
332
 
313
333
  var select = getByRole("combobox");
314
334
  var errorMessage = getByText("Error message.");
@@ -318,13 +338,13 @@ describe("Select component tests", function () {
318
338
  expect(errorMessage.getAttribute("aria-live")).toBe("assertive");
319
339
  });
320
340
  test("Renders with correct aria attributes", function () {
321
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
341
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
322
342
  label: "test-select-label",
323
343
  placeholder: "Example",
324
344
  options: single_options
325
345
  })),
326
- getByText = _render5.getByText,
327
- getByRole = _render5.getByRole;
346
+ getByText = _render3.getByText,
347
+ getByRole = _render3.getByRole;
328
348
 
329
349
  var select = getByRole("combobox");
330
350
  var label = getByText("test-select-label");
@@ -343,17 +363,17 @@ describe("Select component tests", function () {
343
363
  expect(list.getAttribute("aria-multiselectable")).toBe("false");
344
364
  });
345
365
  test("Single selection: Renders with correct default value", function () {
346
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
366
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
347
367
  label: "test-select-label",
348
368
  name: "test",
349
369
  defaultValue: "4",
350
370
  options: single_options
351
371
  })),
352
- getByText = _render6.getByText,
353
- getByRole = _render6.getByRole,
354
- getAllByRole = _render6.getAllByRole,
355
- queryByRole = _render6.queryByRole,
356
- container = _render6.container;
372
+ getByText = _render4.getByText,
373
+ getByRole = _render4.getByRole,
374
+ getAllByRole = _render4.getAllByRole,
375
+ queryByRole = _render4.queryByRole,
376
+ container = _render4.container;
357
377
 
358
378
  var select = getByRole("combobox");
359
379
  var submitInput = container.querySelector("input[name=\"test\"]");
@@ -371,18 +391,18 @@ describe("Select component tests", function () {
371
391
  expect(submitInput.value).toBe("8");
372
392
  });
373
393
  test("Multiple selection: Renders with correct default value", function () {
374
- var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
394
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
375
395
  label: "test-select-label",
376
396
  name: "test",
377
397
  defaultValue: ["4", "2", "6"],
378
398
  options: single_options,
379
399
  multiple: true
380
400
  })),
381
- getByText = _render7.getByText,
382
- getByRole = _render7.getByRole,
383
- getAllByRole = _render7.getAllByRole,
384
- queryByRole = _render7.queryByRole,
385
- container = _render7.container;
401
+ getByText = _render5.getByText,
402
+ getByRole = _render5.getByRole,
403
+ getAllByRole = _render5.getAllByRole,
404
+ queryByRole = _render5.queryByRole,
405
+ container = _render5.container;
386
406
 
387
407
  var select = getByRole("combobox");
388
408
  var submitInput = container.querySelector("input[name=\"test\"]");
@@ -401,18 +421,15 @@ describe("Select component tests", function () {
401
421
  expect(getByText("Option 02, Option 03, Option 04, Option 06")).toBeTruthy();
402
422
  expect(submitInput.value).toBe("4,2,6,3");
403
423
  });
404
- test("Disabled select - Clear all options action must be shown but not clickable", function () {
405
- var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
424
+ test("Disabled select - Cannot gain focus or open the listbox via click", function () {
425
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
406
426
  label: "test-select-label",
407
427
  value: ["1", "2"],
408
428
  options: single_options,
409
- disabled: true,
410
- searchable: true,
411
- multiple: true
429
+ disabled: true
412
430
  })),
413
- getByRole = _render8.getByRole,
414
- getByText = _render8.getByText,
415
- queryByRole = _render8.queryByRole;
431
+ getByRole = _render6.getByRole,
432
+ queryByRole = _render6.queryByRole;
416
433
 
417
434
  var select = getByRole("combobox");
418
435
  expect(select.getAttribute("aria-disabled")).toBe("true");
@@ -420,12 +437,49 @@ describe("Select component tests", function () {
420
437
  _userEvent["default"].click(select);
421
438
 
422
439
  expect(queryByRole("listbox")).toBeFalsy();
440
+ expect(document.activeElement === select).toBeFalsy();
441
+ });
442
+ test("Disabled select - Clear all options action must be shown but not clickable", function () {
443
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
444
+ label: "test-select-label",
445
+ value: ["1", "2"],
446
+ options: single_options,
447
+ disabled: true,
448
+ searchable: true,
449
+ multiple: true
450
+ })),
451
+ getByRole = _render7.getByRole,
452
+ getByText = _render7.getByText;
423
453
 
424
454
  _userEvent["default"].click(getByRole("button"));
425
455
 
426
456
  expect(getByText("Option 01, Option 02")).toBeTruthy();
427
457
  });
428
- test("Focused select does not open the listbox", function () {
458
+ test("Disabled select - Does not call onBlur event", function () {
459
+ var onBlur = jest.fn();
460
+
461
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
462
+ label: "test-select-label",
463
+ options: single_options,
464
+ disabled: true,
465
+ onBlur: onBlur
466
+ })),
467
+ getByRole = _render8.getByRole;
468
+
469
+ var select = getByRole("combobox");
470
+
471
+ _userEvent["default"].click(select);
472
+
473
+ _react2.fireEvent.keyDown(getByRole("combobox"), {
474
+ key: "Tab",
475
+ code: "Tab",
476
+ keyCode: 9,
477
+ charCode: 9
478
+ });
479
+
480
+ expect(onBlur).not.toHaveBeenCalled();
481
+ });
482
+ test("Disabled select - When the component gains the focus, the listbox does not open", function () {
429
483
  var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Select["default"], {
430
484
  label: "test-select-label",
431
485
  value: ["1", "2"],
@@ -442,6 +496,7 @@ describe("Select component tests", function () {
442
496
  _react2.fireEvent.focus(select);
443
497
 
444
498
  expect(queryByRole("listbox")).toBeFalsy();
499
+ expect(document.activeElement === select).toBeFalsy();
445
500
  });
446
501
  test("Controlled - Single selection - Not optional constraint", function () {
447
502
  var onChange = jest.fn();
package/select/types.d.ts CHANGED
@@ -6,7 +6,7 @@ declare type Margin = {
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement>;
9
+ declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
10
  declare type OptionGroup = {
11
11
  /**
12
12
  * Label of the group to be shown in the select's listbox.
@@ -201,11 +201,8 @@ export declare type ListboxProps = {
201
201
  optionalItem: Option;
202
202
  searchable: boolean;
203
203
  handleOptionOnClick: (option: Option) => void;
204
+ getSelectWidth: () => number;
204
205
  };
205
- /**
206
- * Reference to the listbox component.
207
- */
208
- export declare type ListboxRefType = HTMLUListElement;
209
206
  /**
210
207
  * Reference to the select component.
211
208
  */
@@ -1,9 +1,10 @@
1
- /// <reference types="react" />
2
- import SidenavPropsType, { SidenavTitlePropsType, SidenavSubtitlePropsType, SidenavLinkPropsType } from "./types";
1
+ import React from "react";
2
+ import SidenavPropsType, { SidenavGroupPropsType, SidenavLinkPropsType, SidenavSectionPropsType, SidenavTitlePropsType } from "./types.js";
3
3
  declare const DxcSidenav: {
4
- ({ padding, children }: SidenavPropsType): JSX.Element;
4
+ ({ children, title }: SidenavPropsType): JSX.Element;
5
+ Section: ({ children }: SidenavSectionPropsType) => JSX.Element;
6
+ Group: ({ children, title, collapsable, icon }: SidenavGroupPropsType) => JSX.Element;
7
+ Link: React.ForwardRefExoticComponent<SidenavLinkPropsType & React.RefAttributes<HTMLAnchorElement>>;
5
8
  Title: ({ children }: SidenavTitlePropsType) => JSX.Element;
6
- Subtitle: ({ children }: SidenavSubtitlePropsType) => JSX.Element;
7
- Link: ({ tabIndex, href, onClick, children }: SidenavLinkPropsType) => JSX.Element;
8
9
  };
9
10
  export default DxcSidenav;
@@ -11,137 +11,258 @@ exports["default"] = void 0;
11
11
 
12
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
13
 
14
- var _react = _interopRequireDefault(require("react"));
14
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
15
+
16
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
17
+
18
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
+
20
+ var _react = _interopRequireWildcard(require("react"));
15
21
 
16
22
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
23
 
18
24
  var _variables = require("../common/variables.js");
19
25
 
26
+ var _SidenavContext = require("../layout/SidenavContext");
27
+
20
28
  var _useTheme = _interopRequireDefault(require("../useTheme"));
21
29
 
22
30
  var _BackgroundColorContext = require("../BackgroundColorContext");
23
31
 
24
- var _SidenavContext = require("../layout/SidenavContext");
32
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
33
+
34
+ var _Bleed = _interopRequireDefault(require("../bleed/Bleed"));
25
35
 
26
- var _templateObject, _templateObject2, _templateObject3, _templateObject4;
36
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
37
+
38
+ var _excluded = ["href", "children", "newWindow", "selected", "icon", "tabIndex", "onClick"];
27
39
 
28
40
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
41
 
30
42
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
31
43
 
44
+ var collapsedIcon = /*#__PURE__*/_react["default"].createElement("svg", {
45
+ xmlns: "http://www.w3.org/2000/svg",
46
+ height: "24px",
47
+ viewBox: "0 0 24 24",
48
+ width: "24px",
49
+ fill: "currentColor"
50
+ }, /*#__PURE__*/_react["default"].createElement("path", {
51
+ d: "M0 0h24v24H0z",
52
+ fill: "none"
53
+ }), /*#__PURE__*/_react["default"].createElement("path", {
54
+ d: "M16.59 8.59L12 13.17 7.41 8.59 6 10l6 6 6-6z"
55
+ }));
56
+
57
+ var collapsableIcon = /*#__PURE__*/_react["default"].createElement("svg", {
58
+ xmlns: "http://www.w3.org/2000/svg",
59
+ height: "24px",
60
+ viewBox: "0 0 24 24",
61
+ width: "24px",
62
+ fill: "currentColor"
63
+ }, /*#__PURE__*/_react["default"].createElement("path", {
64
+ d: "M0 0h24v24H0z",
65
+ fill: "none"
66
+ }), /*#__PURE__*/_react["default"].createElement("path", {
67
+ d: "M12 8l-6 6 1.41 1.41L12 10.83l4.59 4.58L18 14z"
68
+ }));
69
+
70
+ var externalLinkIcon = /*#__PURE__*/_react["default"].createElement("svg", {
71
+ xmlns: "http://www.w3.org/2000/svg",
72
+ height: "24",
73
+ viewBox: "0 0 24 24",
74
+ width: "24",
75
+ fill: "currentColor"
76
+ }, /*#__PURE__*/_react["default"].createElement("path", {
77
+ d: "M0 0h24v24H0z",
78
+ fill: "none"
79
+ }), /*#__PURE__*/_react["default"].createElement("path", {
80
+ d: "M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z"
81
+ }));
82
+
32
83
  var DxcSidenav = function DxcSidenav(_ref) {
33
- var padding = _ref.padding,
34
- children = _ref.children;
84
+ var children = _ref.children,
85
+ title = _ref.title;
35
86
  var colorsTheme = (0, _useTheme["default"])();
36
87
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
37
88
  theme: colorsTheme.sidenav
38
- }, /*#__PURE__*/_react["default"].createElement(SidenavContainer, {
39
- padding: padding
40
- }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
89
+ }, /*#__PURE__*/_react["default"].createElement(SidenavContainer, null, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
41
90
  color: colorsTheme.sidenav.backgroundColor
42
- }, children)));
91
+ }, title, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
92
+ direction: "column",
93
+ gap: "1rem"
94
+ }, _react["default"].Children.map(children, function (child, index) {
95
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, child, index !== _react["default"].Children.count(children) - 1 && /*#__PURE__*/_react["default"].createElement(Divider, null));
96
+ })))));
43
97
  };
44
98
 
45
99
  var Title = function Title(_ref2) {
46
100
  var children = _ref2.children;
47
- return /*#__PURE__*/_react["default"].createElement(SidenavMenuTitle, null, children);
101
+ return /*#__PURE__*/_react["default"].createElement(_Bleed["default"], {
102
+ horizontal: "1rem"
103
+ }, /*#__PURE__*/_react["default"].createElement(SidenavTitle, null, children));
48
104
  };
49
105
 
50
- var Subtitle = function Subtitle(_ref3) {
106
+ var Section = function Section(_ref3) {
51
107
  var children = _ref3.children;
52
- return /*#__PURE__*/_react["default"].createElement(SidenavMenuSubTitle, null, children);
108
+ return /*#__PURE__*/_react["default"].createElement(_Bleed["default"], {
109
+ horizontal: "1rem"
110
+ }, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
111
+ direction: "column"
112
+ }, children));
113
+ };
114
+
115
+ var Group = function Group(_ref4) {
116
+ var children = _ref4.children,
117
+ title = _ref4.title,
118
+ _ref4$collapsable = _ref4.collapsable,
119
+ collapsable = _ref4$collapsable === void 0 ? false : _ref4$collapsable,
120
+ icon = _ref4.icon;
121
+
122
+ var _useState = (0, _react.useState)(false),
123
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
124
+ collapsed = _useState2[0],
125
+ setCollapsed = _useState2[1];
126
+
127
+ var selectedGroup = (0, _react.useMemo)(function () {
128
+ return collapsed ? _react["default"].Children.toArray(children).some(function (child) {
129
+ var _child$props;
130
+
131
+ return (_child$props = child["props"]) === null || _child$props === void 0 ? void 0 : _child$props.selected;
132
+ }) : false;
133
+ }, [collapsed, children]);
134
+ return /*#__PURE__*/_react["default"].createElement(SidenavGroup, null, collapsable && title ? /*#__PURE__*/_react["default"].createElement(SidenavGroupTitleButton, {
135
+ role: "button",
136
+ "aria-expanded": !collapsed,
137
+ onClick: function onClick() {
138
+ return setCollapsed(!collapsed);
139
+ },
140
+ selectedGroup: selectedGroup
141
+ }, /*#__PURE__*/_react["default"].createElement(SidenavContent, null, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(SidenavIcon, {
142
+ src: icon
143
+ }) : icon, title), collapsed ? collapsedIcon : collapsableIcon) : title && /*#__PURE__*/_react["default"].createElement(SidenavGroupTitle, null, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(SidenavIcon, {
144
+ src: icon
145
+ }) : icon, title), !collapsed && children);
53
146
  };
54
147
 
55
- var Link = function Link(_ref4) {
56
- var _ref4$tabIndex = _ref4.tabIndex,
57
- tabIndex = _ref4$tabIndex === void 0 ? 0 : _ref4$tabIndex,
58
- href = _ref4.href,
59
- onClick = _ref4.onClick,
60
- children = _ref4.children;
148
+ var Link = /*#__PURE__*/(0, _react.forwardRef)(function (_ref5, ref) {
149
+ var href = _ref5.href,
150
+ children = _ref5.children,
151
+ _ref5$newWindow = _ref5.newWindow,
152
+ newWindow = _ref5$newWindow === void 0 ? false : _ref5$newWindow,
153
+ _ref5$selected = _ref5.selected,
154
+ selected = _ref5$selected === void 0 ? false : _ref5$selected,
155
+ icon = _ref5.icon,
156
+ _ref5$tabIndex = _ref5.tabIndex,
157
+ tabIndex = _ref5$tabIndex === void 0 ? 0 : _ref5$tabIndex,
158
+ onClick = _ref5.onClick,
159
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref5, _excluded);
61
160
  var setIsSidenavVisibleResponsive = (0, _SidenavContext.useResponsiveSidenavVisibility)();
62
161
 
63
- var handleClick = function handleClick() {
64
- onClick === null || onClick === void 0 ? void 0 : onClick();
162
+ var handleClick = function handleClick($event) {
163
+ onClick === null || onClick === void 0 ? void 0 : onClick($event);
65
164
  setIsSidenavVisibleResponsive === null || setIsSidenavVisibleResponsive === void 0 ? void 0 : setIsSidenavVisibleResponsive(false);
66
165
  };
67
166
 
68
- return /*#__PURE__*/_react["default"].createElement(SidenavMenuLink, {
167
+ return /*#__PURE__*/_react["default"].createElement(SidenavLink, (0, _extends2["default"])({
168
+ selected: selected,
169
+ href: href ? href : undefined,
170
+ target: href ? newWindow ? "_blank" : "_self" : undefined,
171
+ ref: ref,
69
172
  tabIndex: tabIndex,
70
- href: href,
71
173
  onClick: handleClick
72
- }, children);
73
- };
174
+ }, otherProps), /*#__PURE__*/_react["default"].createElement(SidenavContent, null, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(SidenavIcon, {
175
+ src: icon
176
+ }) : icon, children), newWindow && externalLinkIcon);
177
+ });
74
178
 
75
- var SidenavContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n background-color: ", ";\n\n @media (max-width: ", "rem) {\n width: ", ";\n }\n\n width: ", ";\n padding: ", ";\n\n overflow-y: auto;\n overflow-x: hidden;\n ::-webkit-scrollbar {\n width: 2px;\n }\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n"])), function (props) {
179
+ var SidenavContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n background-color: ", ";\n box-sizing: border-box;\n width: 280px;\n @media (max-width: ", "rem) {\n width: 100vw;\n }\n\n height: 100%;\n padding: 2rem 1rem;\n\n overflow-y: auto;\n overflow-x: hidden;\n ::-webkit-scrollbar {\n width: 2px;\n }\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n"])), function (props) {
76
180
  return props.theme.backgroundColor;
77
181
  }, _variables.responsiveSizes.medium, function (props) {
78
- return props.padding ? "calc(100vw - ".concat(_variables.spaces[props.padding], " - ").concat(_variables.spaces[props.padding], ")") : "100vw";
79
- }, function (props) {
80
- return props.padding ? "calc(300px - ".concat(_variables.spaces[props.padding], " - ").concat(_variables.spaces[props.padding], ")") : "300px";
81
- }, function (props) {
82
- return props.padding ? _variables.spaces[props.padding] : "";
83
- }, function (props) {
84
182
  return props.theme.scrollBarTrackColor;
85
183
  }, function (props) {
86
184
  return props.theme.scrollBarThumbColor;
87
185
  });
88
186
 
89
- var SidenavMenuTitle = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n margin-bottom: 16px;\n"])), function (props) {
187
+ var SidenavTitle = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n line-height: 27px;\n display: flex;\n align-items: center;\n color: ", ";\n text-transform: ", ";\n letter-spacing: ", ";\n padding: 0.5rem 1.2rem;\n\n svg {\n margin-right: 0.5rem;\n }\n"])), function (props) {
90
188
  return props.theme.titleFontFamily;
91
- }, function (props) {
92
- return props.theme.titleFontSize;
93
189
  }, function (props) {
94
190
  return props.theme.titleFontStyle;
95
191
  }, function (props) {
96
192
  return props.theme.titleFontWeight;
97
193
  }, function (props) {
98
- return props.theme.titleFontColor;
194
+ return props.theme.titleFontSize;
99
195
  }, function (props) {
100
- return props.theme.titleFontLetterSpacing;
196
+ return props.theme.titleFontColor;
101
197
  }, function (props) {
102
198
  return props.theme.titleFontTextTransform;
199
+ }, function (props) {
200
+ return props.theme.titleFontLetterSpacing;
103
201
  });
104
202
 
105
- var SidenavMenuSubTitle = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n margin-bottom: 4px;\n"])), function (props) {
106
- return props.theme.subtitleFontFamily;
203
+ var Divider = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n height: 1px;\n background-color: #999999;\n"])));
204
+
205
+ var SidenavGroup = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n a {\n padding: 0.5rem 1.2rem 0.5rem 2.25rem;\n }\n"])));
206
+
207
+ var SidenavGroupTitle = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n svg {\n width: 16px;\n margin-right: 0.5rem;\n }\n box-sizing: border-box;\n width: 100%;\n\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n line-height: 18px;\n\n display: flex;\n align-items: center;\n margin: 0px;\n padding: 0.5rem 1.2rem;\n"])), function (props) {
208
+ return props.theme.groupTitleFontFamily;
107
209
  }, function (props) {
108
- return props.theme.subtitleFontSize;
210
+ return props.theme.groupTitleFontStyle;
109
211
  }, function (props) {
110
- return props.theme.subtitleFontStyle;
212
+ return props.theme.groupTitleFontWeight;
111
213
  }, function (props) {
112
- return props.theme.subtitleFontWeight;
214
+ return props.theme.groupTitleFontSize;
215
+ });
216
+
217
+ var SidenavGroupTitleButton = _styledComponents["default"].button(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n all: unset;\n cursor: pointer;\n justify-content: space-between;\n box-sizing: border-box;\n width: 100%;\n\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n line-height: 19px;\n\n display: flex;\n align-items: center;\n margin: 0px;\n padding: 0.5rem 1.2rem;\n &:focus-visible {\n outline: 2px solid ", ";\n outline-offset: -2px;\n }\n &:hover {\n ", "\n }\n &:active {\n background-color: ", ";\n color: ", ";\n }\n ", "\n svg {\n width: 18px;\n height: auto;\n }\n"])), function (props) {
218
+ return props.theme.groupTitleFontFamily;
113
219
  }, function (props) {
114
- return props.theme.subtitleFontColor;
220
+ return props.theme.groupTitleFontStyle;
115
221
  }, function (props) {
116
- return props.theme.subtitleFontLetterSpacing;
222
+ return props.theme.groupTitleFontWeight;
117
223
  }, function (props) {
118
- return props.theme.subtitleFontTextTransform;
119
- });
120
-
121
- var SidenavMenuLink = _styledComponents["default"].a(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n text-decoration: ", ";\n margin: ", ";\n cursor: pointer;\n\n :focus-visible {\n outline: 2px solid ", ";\n outline-offset: 1px;\n }\n"])), function (props) {
122
- return props.theme.linkFontFamily;
224
+ return props.theme.groupTitleFontSize;
123
225
  }, function (props) {
124
- return props.theme.linkFontSize;
226
+ return props.theme.linkFocusColor;
125
227
  }, function (props) {
126
- return props.theme.linkFontStyle;
228
+ return props.selectedGroup ? "color: ".concat(props.theme.groupTitleSelectedHoverFontColor, "; background: ").concat(props.theme.groupTitleSelectedHoverBackgroundColor, ";") : "color: ".concat(props.theme.groupTitleFontColor, "; background: ").concat(props.theme.groupTitleHoverBackgroundColor, ";");
127
229
  }, function (props) {
128
- return props.theme.linkFontWeight;
230
+ return props.theme.groupTitleActiveBackgroundColor;
129
231
  }, function (props) {
130
- return props.theme.linkFontColor;
232
+ return props.theme.groupTitleFontColor;
131
233
  }, function (props) {
234
+ return props.selectedGroup ? "color: ".concat(props.theme.groupTitleSelectedFontColor, "; background: ").concat(props.theme.groupTitleSelectedBackgroundColor, ";") : "color: ".concat(props.theme.groupTitleFontColor, "; background: transparent;");
235
+ });
236
+
237
+ var SidenavLink = _styledComponents["default"].a(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n letter-spacing: ", ";\n\n text-transform: ", ";\n text-decoration: ", ";\n\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n line-height: 19px;\n\n ", "\n\n display: flex;\n align-items: center;\n justify-content: space-between;\n\n box-shadow: 0 0 0 2px transparent;\n\n padding: 0.5rem 1.2rem;\n\n cursor: pointer;\n svg {\n width: 16px;\n margin-right: 0.5rem;\n }\n\n &:hover {\n ", "\n }\n\n &:focus {\n outline: 2px solid ", ";\n outline-offset: -2px;\n }\n\n &:active {\n color: #ffffff;\n background: #4d4d4d;\n outline: 2px solid #0095ff;\n outline-offset: -2px;\n }\n"])), function (props) {
132
238
  return props.theme.linkFontLetterSpacing;
133
239
  }, function (props) {
134
240
  return props.theme.linkFontTextTransform;
135
241
  }, function (props) {
136
242
  return props.theme.linkTextDecoration;
137
243
  }, function (props) {
138
- return "".concat(props.theme.linkMarginTop, " ").concat(props.theme.linkMarginRight, " ").concat(props.theme.linkMarginBottom, " ").concat(props.theme.linkMarginLeft);
244
+ return props.theme.linkFontFamily;
245
+ }, function (props) {
246
+ return props.theme.linkFontStyle;
247
+ }, function (props) {
248
+ return props.theme.linkFontWeight;
249
+ }, function (props) {
250
+ return props.theme.linkFontSize;
251
+ }, function (props) {
252
+ return props.selected ? "color: ".concat(props.theme.linkSelectedFontColor, "; background: ").concat(props.theme.linkSelectedBackgroundColor, ";") : "color: ".concat(props.theme.linkFontColor, "; background: transparent;");
253
+ }, function (props) {
254
+ return props.selected ? "color: ".concat(props.theme.linkSelectedHoverFontColor, "; background: ").concat(props.theme.linkSelectedHoverBackgroundColor, ";") : "color: ".concat(props.theme.linkFontColor, "; background: ").concat(props.theme.linkHoverBackgroundColor, ";");
139
255
  }, function (props) {
140
256
  return props.theme.linkFocusColor;
141
257
  });
142
258
 
143
- DxcSidenav.Title = Title;
144
- DxcSidenav.Subtitle = Subtitle;
259
+ var SidenavContent = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n\n svg {\n width: 16px;\n margin-right: 0.5rem;\n }\n"])));
260
+
261
+ var SidenavIcon = _styledComponents["default"].img(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n width: 16px;\n margin-right: 0.5rem;\n"])));
262
+
263
+ DxcSidenav.Section = Section;
264
+ DxcSidenav.Group = Group;
145
265
  DxcSidenav.Link = Link;
266
+ DxcSidenav.Title = Title;
146
267
  var _default = DxcSidenav;
147
268
  exports["default"] = _default;