@dxc-technology/halstack-react 0.0.0-b9523dd → 0.0.0-b98c25c

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 (315) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +124 -137
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +12 -11
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -37
  12. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +17 -10
  15. package/alert/Alert.js +7 -4
  16. package/alert/Alert.stories.tsx +170 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/alert/types.d.ts +1 -1
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -4
  21. package/badge/types.d.ts +5 -0
  22. package/{radio → badge}/types.js +0 -0
  23. package/bleed/Bleed.d.ts +3 -0
  24. package/bleed/Bleed.js +51 -0
  25. package/bleed/Bleed.stories.tsx +341 -0
  26. package/bleed/types.d.ts +37 -0
  27. package/bleed/types.js +5 -0
  28. package/box/Box.d.ts +4 -0
  29. package/box/Box.js +29 -65
  30. package/box/{Box.stories.jsx → Box.stories.tsx} +0 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +44 -0
  33. package/box/types.js +5 -0
  34. package/bulleted-list/BulletedList.d.ts +7 -0
  35. package/bulleted-list/BulletedList.js +123 -0
  36. package/bulleted-list/BulletedList.stories.tsx +200 -0
  37. package/bulleted-list/types.d.ts +11 -0
  38. package/bulleted-list/types.js +5 -0
  39. package/button/Button.d.ts +1 -1
  40. package/button/Button.js +62 -83
  41. package/button/Button.stories.tsx +231 -241
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +10 -14
  44. package/card/Card.js +26 -30
  45. package/card/Card.stories.tsx +201 -0
  46. package/card/Card.test.js +50 -0
  47. package/card/ice-cream.jpg +0 -0
  48. package/card/types.d.ts +5 -6
  49. package/checkbox/Checkbox.d.ts +1 -1
  50. package/checkbox/Checkbox.js +104 -108
  51. package/checkbox/Checkbox.stories.tsx +124 -128
  52. package/checkbox/Checkbox.test.js +155 -0
  53. package/checkbox/types.d.ts +11 -7
  54. package/chip/Chip.d.ts +4 -0
  55. package/chip/Chip.js +16 -76
  56. package/chip/Chip.stories.tsx +119 -0
  57. package/chip/Chip.test.js +56 -0
  58. package/chip/types.d.ts +45 -0
  59. package/chip/types.js +5 -0
  60. package/common/variables.js +319 -380
  61. package/date-input/DateInput.js +66 -55
  62. package/date-input/DateInput.stories.tsx +138 -0
  63. package/date-input/DateInput.test.js +479 -0
  64. package/date-input/types.d.ts +16 -9
  65. package/dialog/Dialog.js +50 -53
  66. package/dialog/Dialog.stories.tsx +267 -0
  67. package/dialog/Dialog.test.js +70 -0
  68. package/dialog/types.d.ts +3 -2
  69. package/dropdown/Dropdown.d.ts +1 -1
  70. package/dropdown/Dropdown.js +243 -273
  71. package/dropdown/Dropdown.stories.tsx +312 -0
  72. package/dropdown/Dropdown.test.js +591 -0
  73. package/dropdown/DropdownMenu.d.ts +4 -0
  74. package/dropdown/DropdownMenu.js +80 -0
  75. package/dropdown/DropdownMenuItem.d.ts +4 -0
  76. package/dropdown/DropdownMenuItem.js +92 -0
  77. package/dropdown/types.d.ts +30 -19
  78. package/file-input/FileInput.d.ts +4 -0
  79. package/file-input/FileInput.js +172 -111
  80. package/file-input/FileInput.stories.tsx +507 -0
  81. package/file-input/FileInput.test.js +457 -0
  82. package/file-input/FileItem.d.ts +14 -0
  83. package/file-input/FileItem.js +16 -23
  84. package/file-input/types.d.ts +112 -0
  85. package/file-input/types.js +5 -0
  86. package/flex/Flex.d.ts +4 -0
  87. package/flex/Flex.js +57 -0
  88. package/flex/Flex.stories.tsx +103 -0
  89. package/flex/types.d.ts +21 -0
  90. package/flex/types.js +5 -0
  91. package/footer/Footer.d.ts +1 -1
  92. package/footer/Footer.js +32 -113
  93. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +5 -19
  94. package/footer/Footer.test.js +109 -0
  95. package/footer/Icons.d.ts +2 -0
  96. package/footer/Icons.js +4 -4
  97. package/footer/types.d.ts +23 -18
  98. package/header/Header.js +97 -116
  99. package/header/Header.stories.tsx +172 -0
  100. package/header/Header.test.js +79 -0
  101. package/header/Icons.d.ts +2 -0
  102. package/header/Icons.js +2 -2
  103. package/header/types.d.ts +7 -4
  104. package/heading/Heading.d.ts +4 -0
  105. package/heading/Heading.js +7 -24
  106. package/heading/Heading.stories.tsx +54 -0
  107. package/heading/Heading.test.js +186 -0
  108. package/heading/types.d.ts +33 -0
  109. package/heading/types.js +5 -0
  110. package/inset/Inset.d.ts +3 -0
  111. package/inset/Inset.js +51 -0
  112. package/inset/Inset.stories.tsx +229 -0
  113. package/inset/types.d.ts +37 -0
  114. package/inset/types.js +5 -0
  115. package/layout/ApplicationLayout.d.ts +20 -0
  116. package/layout/ApplicationLayout.js +71 -135
  117. package/layout/ApplicationLayout.stories.tsx +162 -0
  118. package/layout/Icons.d.ts +5 -0
  119. package/layout/Icons.js +13 -2
  120. package/layout/SidenavContext.d.ts +5 -0
  121. package/layout/SidenavContext.js +19 -0
  122. package/layout/types.d.ts +42 -0
  123. package/layout/types.js +5 -0
  124. package/link/Link.d.ts +4 -0
  125. package/link/Link.js +60 -107
  126. package/link/Link.stories.tsx +193 -0
  127. package/link/Link.test.js +83 -0
  128. package/link/types.d.ts +54 -0
  129. package/link/types.js +5 -0
  130. package/main.d.ts +12 -12
  131. package/main.js +64 -58
  132. package/number-input/NumberInput.d.ts +4 -0
  133. package/number-input/NumberInput.js +16 -68
  134. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +5 -5
  135. package/number-input/NumberInput.test.js +506 -0
  136. package/number-input/NumberInputContext.d.ts +4 -0
  137. package/number-input/NumberInputContext.js +5 -2
  138. package/number-input/numberInputContextTypes.d.ts +19 -0
  139. package/number-input/numberInputContextTypes.js +5 -0
  140. package/number-input/types.d.ts +124 -0
  141. package/number-input/types.js +5 -0
  142. package/package.json +16 -12
  143. package/paginator/Paginator.js +19 -46
  144. package/paginator/Paginator.test.js +308 -0
  145. package/paragraph/Paragraph.d.ts +6 -0
  146. package/paragraph/Paragraph.js +38 -0
  147. package/paragraph/Paragraph.stories.tsx +44 -0
  148. package/password-input/PasswordInput.d.ts +4 -0
  149. package/password-input/PasswordInput.js +22 -55
  150. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +3 -3
  151. package/password-input/PasswordInput.test.js +180 -0
  152. package/password-input/types.d.ts +110 -0
  153. package/password-input/types.js +5 -0
  154. package/progress-bar/ProgressBar.d.ts +2 -2
  155. package/progress-bar/ProgressBar.js +59 -53
  156. package/progress-bar/ProgressBar.stories.jsx +60 -0
  157. package/progress-bar/ProgressBar.test.js +110 -0
  158. package/progress-bar/types.d.ts +3 -4
  159. package/quick-nav/QuickNav.d.ts +4 -0
  160. package/quick-nav/QuickNav.js +115 -0
  161. package/quick-nav/QuickNav.stories.tsx +300 -0
  162. package/quick-nav/types.d.ts +21 -0
  163. package/quick-nav/types.js +5 -0
  164. package/radio-group/Radio.d.ts +4 -0
  165. package/radio-group/Radio.js +156 -0
  166. package/radio-group/RadioGroup.d.ts +4 -0
  167. package/radio-group/RadioGroup.js +279 -0
  168. package/radio-group/RadioGroup.stories.tsx +101 -0
  169. package/radio-group/RadioGroup.test.js +665 -0
  170. package/radio-group/types.d.ts +114 -0
  171. package/radio-group/types.js +5 -0
  172. package/resultsetTable/ResultsetTable.d.ts +4 -0
  173. package/resultsetTable/ResultsetTable.js +9 -29
  174. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  175. package/resultsetTable/ResultsetTable.test.js +348 -0
  176. package/resultsetTable/types.d.ts +67 -0
  177. package/resultsetTable/types.js +5 -0
  178. package/select/Icons.d.ts +10 -0
  179. package/select/Icons.js +93 -0
  180. package/select/Listbox.d.ts +4 -0
  181. package/select/Listbox.js +198 -0
  182. package/select/Option.d.ts +4 -0
  183. package/select/Option.js +110 -0
  184. package/select/Select.d.ts +4 -0
  185. package/select/Select.js +158 -380
  186. package/select/Select.stories.tsx +627 -0
  187. package/select/Select.test.js +2175 -0
  188. package/select/types.d.ts +210 -0
  189. package/select/types.js +5 -0
  190. package/sidenav/Sidenav.d.ts +10 -0
  191. package/sidenav/Sidenav.js +186 -63
  192. package/sidenav/Sidenav.stories.tsx +180 -0
  193. package/sidenav/Sidenav.test.js +44 -0
  194. package/sidenav/types.d.ts +73 -0
  195. package/sidenav/types.js +5 -0
  196. package/slider/Slider.d.ts +1 -1
  197. package/slider/Slider.js +145 -109
  198. package/slider/Slider.stories.tsx +183 -0
  199. package/slider/Slider.test.js +250 -0
  200. package/slider/types.d.ts +8 -9
  201. package/spinner/Spinner.js +3 -3
  202. package/spinner/Spinner.stories.jsx +1 -0
  203. package/spinner/Spinner.test.js +64 -0
  204. package/switch/Switch.d.ts +2 -2
  205. package/switch/Switch.js +149 -67
  206. package/switch/Switch.stories.tsx +138 -0
  207. package/switch/Switch.test.js +225 -0
  208. package/switch/types.d.ts +9 -6
  209. package/table/Table.js +3 -3
  210. package/table/Table.stories.jsx +2 -1
  211. package/table/Table.test.js +26 -0
  212. package/tabs/Tab.d.ts +4 -0
  213. package/tabs/Tab.js +135 -0
  214. package/tabs/Tabs.d.ts +1 -1
  215. package/tabs/Tabs.js +364 -108
  216. package/tabs/Tabs.stories.tsx +186 -0
  217. package/tabs/Tabs.test.js +351 -0
  218. package/tabs/types.d.ts +41 -20
  219. package/tabs-nav/NavTabs.d.ts +8 -0
  220. package/tabs-nav/NavTabs.js +125 -0
  221. package/tabs-nav/NavTabs.stories.tsx +170 -0
  222. package/tabs-nav/NavTabs.test.js +82 -0
  223. package/tabs-nav/Tab.d.ts +4 -0
  224. package/tabs-nav/Tab.js +130 -0
  225. package/tabs-nav/types.d.ts +53 -0
  226. package/tabs-nav/types.js +5 -0
  227. package/tag/Tag.d.ts +4 -0
  228. package/tag/Tag.js +21 -52
  229. package/tag/{Tag.stories.jsx → Tag.stories.tsx} +26 -29
  230. package/tag/Tag.test.js +60 -0
  231. package/tag/types.d.ts +69 -0
  232. package/tag/types.js +5 -0
  233. package/text-input/Icons.d.ts +8 -0
  234. package/text-input/Icons.js +60 -0
  235. package/text-input/Suggestion.d.ts +4 -0
  236. package/text-input/Suggestion.js +57 -0
  237. package/text-input/Suggestions.d.ts +4 -0
  238. package/text-input/Suggestions.js +134 -0
  239. package/text-input/TextInput.d.ts +4 -0
  240. package/text-input/TextInput.js +166 -328
  241. package/text-input/TextInput.stories.tsx +481 -0
  242. package/text-input/TextInput.test.js +1713 -0
  243. package/text-input/types.d.ts +192 -0
  244. package/text-input/types.js +5 -0
  245. package/textarea/Textarea.d.ts +4 -0
  246. package/textarea/Textarea.js +39 -79
  247. package/textarea/Textarea.stories.jsx +37 -15
  248. package/textarea/Textarea.test.js +437 -0
  249. package/textarea/types.d.ts +137 -0
  250. package/textarea/types.js +5 -0
  251. package/toggle-group/ToggleGroup.d.ts +4 -0
  252. package/toggle-group/ToggleGroup.js +18 -46
  253. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  254. package/toggle-group/ToggleGroup.test.js +156 -0
  255. package/toggle-group/types.d.ts +105 -0
  256. package/toggle-group/types.js +5 -0
  257. package/typography/Typography.d.ts +4 -0
  258. package/typography/Typography.js +131 -0
  259. package/typography/Typography.stories.tsx +198 -0
  260. package/typography/types.d.ts +18 -0
  261. package/typography/types.js +5 -0
  262. package/useTheme.d.ts +2 -0
  263. package/useTheme.js +2 -2
  264. package/useTranslatedLabels.d.ts +2 -0
  265. package/useTranslatedLabels.js +20 -0
  266. package/wizard/Wizard.d.ts +4 -0
  267. package/wizard/Wizard.js +118 -104
  268. package/wizard/Wizard.stories.tsx +233 -0
  269. package/wizard/Wizard.test.js +141 -0
  270. package/wizard/types.d.ts +65 -0
  271. package/wizard/types.js +5 -0
  272. package/ThemeContext.js +0 -246
  273. package/V3Select/V3Select.js +0 -455
  274. package/V3Select/index.d.ts +0 -27
  275. package/V3Textarea/V3Textarea.js +0 -260
  276. package/V3Textarea/index.d.ts +0 -27
  277. package/box/index.d.ts +0 -25
  278. package/chip/index.d.ts +0 -22
  279. package/date/Date.js +0 -373
  280. package/date/index.d.ts +0 -27
  281. package/file-input/index.d.ts +0 -81
  282. package/heading/index.d.ts +0 -17
  283. package/input-text/Icons.js +0 -22
  284. package/input-text/InputText.js +0 -611
  285. package/input-text/index.d.ts +0 -36
  286. package/link/index.d.ts +0 -23
  287. package/number-input/index.d.ts +0 -113
  288. package/password-input/index.d.ts +0 -94
  289. package/radio/Radio.d.ts +0 -4
  290. package/radio/Radio.js +0 -174
  291. package/radio/Radio.stories.tsx +0 -192
  292. package/radio/types.d.ts +0 -54
  293. package/resultsetTable/index.d.ts +0 -19
  294. package/select/index.d.ts +0 -131
  295. package/sidenav/index.d.ts +0 -13
  296. package/tag/index.d.ts +0 -24
  297. package/text-input/index.d.ts +0 -135
  298. package/textarea/index.d.ts +0 -117
  299. package/toggle/Toggle.js +0 -186
  300. package/toggle/index.d.ts +0 -21
  301. package/toggle-group/index.d.ts +0 -21
  302. package/upload/Upload.js +0 -201
  303. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  304. package/upload/buttons-upload/Icons.js +0 -40
  305. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  306. package/upload/dragAndDropArea/Icons.js +0 -39
  307. package/upload/file-upload/FileToUpload.js +0 -115
  308. package/upload/file-upload/Icons.js +0 -66
  309. package/upload/files-upload/FilesToUpload.js +0 -109
  310. package/upload/index.d.ts +0 -15
  311. package/upload/transaction/Icons.js +0 -160
  312. package/upload/transaction/Transaction.js +0 -104
  313. package/upload/transactions/Transactions.js +0 -94
  314. package/wizard/Icons.js +0 -65
  315. package/wizard/index.d.ts +0 -18
package/dialog/Dialog.js CHANGED
@@ -13,21 +13,17 @@ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
13
 
14
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
15
 
16
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
16
  var _react = _interopRequireWildcard(require("react"));
19
17
 
20
18
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
19
 
22
- var _Dialog = _interopRequireDefault(require("@material-ui/core/Dialog"));
23
-
24
20
  var _variables = require("../common/variables.js");
25
21
 
26
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
22
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
27
23
 
28
- var _BackgroundColorContext = require("../BackgroundColorContext.js");
24
+ var _BackgroundColorContext = require("../BackgroundColorContext");
29
25
 
30
- var _templateObject, _templateObject2, _templateObject3, _templateObject4;
26
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
31
27
 
32
28
  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); }
33
29
 
@@ -41,15 +37,10 @@ var DxcDialog = function DxcDialog(_ref) {
41
37
  _ref$overlay = _ref.overlay,
42
38
  overlay = _ref$overlay === void 0 ? true : _ref$overlay,
43
39
  onBackgroundClick = _ref.onBackgroundClick,
44
- padding = _ref.padding,
40
+ _ref$padding = _ref.padding,
41
+ padding = _ref$padding === void 0 ? "small" : _ref$padding,
45
42
  _ref$tabIndex = _ref.tabIndex,
46
43
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
47
-
48
- var _useState = (0, _react.useState)(false),
49
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
50
- isResponsive = _useState2[0],
51
- setIsResponsive = _useState2[1];
52
-
53
44
  var colorsTheme = (0, _useTheme["default"])();
54
45
 
55
46
  var handleClose = function handleClose() {
@@ -60,31 +51,37 @@ var DxcDialog = function DxcDialog(_ref) {
60
51
  onBackgroundClick === null || onBackgroundClick === void 0 ? void 0 : onBackgroundClick();
61
52
  };
62
53
 
63
- var handleResize = function handleResize(width) {
64
- setIsResponsive(width && width <= _variables.responsiveSizes.tablet);
65
- };
66
-
67
- var handleEventListener = function handleEventListener() {
68
- handleResize(window.innerWidth);
54
+ var handleOnKeyDown = function handleOnKeyDown(event) {
55
+ if (event.key === "Escape") {
56
+ event.preventDefault();
57
+ handleClose();
58
+ }
69
59
  };
70
60
 
71
61
  (0, _react.useEffect)(function () {
72
- window.addEventListener("resize", handleEventListener);
73
- handleResize(window.innerWidth);
62
+ if (isCloseVisible) {
63
+ window.addEventListener("keydown", handleOnKeyDown);
64
+ }
65
+
74
66
  return function () {
75
- window.removeEventListener("resize", handleEventListener);
67
+ window.removeEventListener("keydown", handleOnKeyDown);
76
68
  };
77
- }, []);
69
+ }, [isCloseVisible]);
78
70
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
79
71
  theme: colorsTheme.dialog
80
- }, /*#__PURE__*/_react["default"].createElement(DialogContainer, {
81
- open: true,
82
- isCloseVisible: isCloseVisible,
83
- onClose: handleOverlayClick,
84
- overlay: overlay,
85
- padding: padding,
86
- isResponsive: isResponsive
87
- }, isCloseVisible && /*#__PURE__*/_react["default"].createElement(CloseIconContainer, {
72
+ }, /*#__PURE__*/_react["default"].createElement(BodyStyle, null), /*#__PURE__*/_react["default"].createElement(DialogContainer, {
73
+ role: "presentation"
74
+ }, overlay && /*#__PURE__*/_react["default"].createElement(Overlay, {
75
+ onClick: handleOverlayClick
76
+ }), /*#__PURE__*/_react["default"].createElement(Dialog, {
77
+ role: "dialog",
78
+ "aria-modal": overlay,
79
+ isCloseVisible: isCloseVisible
80
+ }, /*#__PURE__*/_react["default"].createElement(Children, {
81
+ padding: padding
82
+ }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
83
+ color: colorsTheme.dialog.backgroundColor
84
+ }, children)), isCloseVisible && /*#__PURE__*/_react["default"].createElement(CloseIconContainer, {
88
85
  onClick: handleClose,
89
86
  tabIndex: tabIndex
90
87
  }, /*#__PURE__*/_react["default"].createElement(CloseIcon, {
@@ -98,28 +95,34 @@ var DxcDialog = function DxcDialog(_ref) {
98
95
  fill: "none"
99
96
  }), /*#__PURE__*/_react["default"].createElement("path", {
100
97
  d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
101
- }))), /*#__PURE__*/_react["default"].createElement(Children, null, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
102
- color: colorsTheme.dialog.backgroundColor
103
- }, children))));
98
+ }))))));
104
99
  };
105
100
 
106
- var DialogContainer = (0, _styledComponents["default"])(_Dialog["default"])(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n overflow: unset;\n font-family: ", ";\n\n .MuiBackdrop-root {\n background-color: ", ";\n opacity: ", " !important;\n }\n .MuiDialog-paperWidthSm {\n background-color: ", ";\n max-width: ", ";\n min-width: ", ";\n box-sizing: border-box;\n min-height: ", ";\n box-shadow: ", ";\n\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n }\n"])), function (props) {
107
- return props.theme.fontFamily;
108
- }, function (props) {
109
- return props.overlay === true ? props.theme.overlayColor : "transparent";
110
- }, function (props) {
111
- return props.overlay === true && props.theme.overlayOpacity;
101
+ var BodyStyle = (0, _styledComponents.createGlobalStyle)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n body {\n overflow: hidden;\n }\n"])));
102
+
103
+ var DialogContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n position: fixed;\n inset: 0px;\n height: 100%;\n z-index: 1300;\n"])));
104
+
105
+ var Overlay = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n inset: 0px;\n height: 100%;\n background-color: ", ";\n opacity: ", ";\n"])), function (props) {
106
+ return props.theme.overlayColor;
112
107
  }, function (props) {
108
+ return props.theme.overlayOpacity;
109
+ });
110
+
111
+ var Dialog = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n z-index: 1300;\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n ", "\n box-sizing: border-box;\n box-shadow: ", ";\n border-radius: 4px;\n position: relative;\n\n @media (min-width: ", "rem) {\n max-width: 80%;\n min-width: 800px;\n }\n\n @media (max-width: ", "rem) {\n //mobile phones\n max-width: 92%;\n min-width: 92%;\n }\n"])), function (props) {
113
112
  return props.theme.backgroundColor;
114
113
  }, function (props) {
115
- return props.isResponsive ? "92%" : "80%";
114
+ return props.theme.fontFamily;
116
115
  }, function (props) {
117
- return props.isResponsive ? "92%" : "800px";
116
+ return props.theme.fontSize;
118
117
  }, function (props) {
119
- return props.isCloseVisible ? "72px" : "";
118
+ return props.theme.fontWeight;
120
119
  }, function (props) {
121
- return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
120
+ return props.isCloseVisible && "min-height: 72px; padding-top: 24px;";
122
121
  }, function (props) {
122
+ return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
123
+ }, _variables.responsiveSizes.medium, _variables.responsiveSizes.medium);
124
+
125
+ var Children = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n width: 100%;\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (props) {
123
126
  return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : _variables.spaces["small"];
124
127
  }, function (props) {
125
128
  return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
@@ -131,13 +134,7 @@ var DialogContainer = (0, _styledComponents["default"])(_Dialog["default"])(_tem
131
134
  return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
132
135
  });
133
136
 
134
- var Children = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])([""])));
135
-
136
- var CloseIconContainer = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: flex-end;\n position: absolute;\n top: ", ";\n right: ", ";\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n color: ", ";\n width: ", ";\n height: ", ";\n border: none;\n"])), function (props) {
137
- return props.theme.closeIconTopPosition;
138
- }, function (props) {
139
- return props.theme.closeIconRightPosition;
140
- }, function (props) {
137
+ var CloseIconContainer = _styledComponents["default"].button(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n border: none;\n position: absolute;\n top: 20px;\n right: 20px;\n color: ", ";\n width: ", ";\n height: ", ";\n"])), function (props) {
141
138
  return props.theme.closeIconColor;
142
139
  }, function (props) {
143
140
  return props.theme.closeIconWidth;
@@ -145,7 +142,7 @@ var CloseIconContainer = _styledComponents["default"].button(_templateObject3 ||
145
142
  return props.theme.closeIconHeight;
146
143
  });
147
144
 
148
- var CloseIcon = _styledComponents["default"].svg(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: ", ";\n height: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n"])), function (props) {
145
+ var CloseIcon = _styledComponents["default"].svg(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: ", ";\n height: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n"])), function (props) {
149
146
  return props.theme.closeIconBackgroundColor;
150
147
  }, function (props) {
151
148
  return props.theme.closeIconWidth;
@@ -0,0 +1,267 @@
1
+ import React from "react";
2
+ import DxcDialog from "./Dialog";
3
+ import DxcTextInput from "../text-input/TextInput";
4
+ import DxcButton from "../button/Button";
5
+ import DxcFlex from "../flex/Flex";
6
+ import DxcInset from "../inset/Inset";
7
+ import Title from "../../.storybook/components/Title";
8
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
9
+
10
+ export default {
11
+ title: "Dialog ",
12
+ component: DxcDialog,
13
+ };
14
+
15
+ export const DefaultDialog = () => (
16
+ <>
17
+ <ExampleContainer expanded={true}>
18
+ <Title title="Default dialog" theme="light" level={4} />
19
+ <DxcDialog>
20
+ {" "}
21
+ <p>
22
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
23
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
24
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
25
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
26
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
27
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
28
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
29
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
30
+ dignissim, pharetra neque molestie, molestie lectus.
31
+ </p>{" "}
32
+ </DxcDialog>
33
+ </ExampleContainer>
34
+ </>
35
+ );
36
+
37
+ export const DialogWithInputs = () => (
38
+ <>
39
+ <ExampleContainer expanded={true}>
40
+ <Title title="Dialog with inputs" theme="light" level={4} />
41
+ <DxcDialog>
42
+ <DxcInset bottom="1rem">
43
+ <DxcFlex gap="2rem" direction="column">
44
+ <DxcFlex gap="1rem" direction="column">
45
+ <DxcTextInput size="fillParent" label="Name"></DxcTextInput>
46
+ <DxcTextInput size="fillParent" label="Surname"></DxcTextInput>
47
+ </DxcFlex>
48
+ <DxcFlex justifyContent="flex-end" gap="1rem">
49
+ <DxcButton label="Save"></DxcButton>
50
+ <DxcButton label="Cancel" mode="secondary"></DxcButton>
51
+ </DxcFlex>
52
+ </DxcFlex>
53
+ </DxcInset>
54
+ </DxcDialog>
55
+ </ExampleContainer>
56
+ </>
57
+ );
58
+
59
+ const RespDialog = () => (
60
+ <>
61
+ <ExampleContainer expanded={true}>
62
+ <Title title="Responsive dialog" theme="light" level={4} />
63
+ <DxcDialog>
64
+ <DxcInset bottom="1rem">
65
+ <DxcFlex gap="2rem" direction="column">
66
+ <DxcFlex gap="1rem" direction="column">
67
+ <DxcTextInput size="fillParent" label="Name"></DxcTextInput>
68
+ <DxcTextInput size="fillParent" label="Surname"></DxcTextInput>
69
+ </DxcFlex>
70
+ <DxcFlex justifyContent="flex-end" gap="1rem">
71
+ <DxcButton label="Save"></DxcButton>
72
+ <DxcButton label="Cancel" mode="secondary"></DxcButton>
73
+ </DxcFlex>
74
+ </DxcFlex>
75
+ </DxcInset>
76
+ </DxcDialog>
77
+ </ExampleContainer>
78
+ </>
79
+ );
80
+
81
+ export const DialogWithoutOverlay = () => (
82
+ <ExampleContainer expanded={true}>
83
+ <Title title="Dialog Without Overlay" theme="light" level={4} />
84
+ <DxcDialog overlay={false}>
85
+ {" "}
86
+ <p>
87
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
88
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
89
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
90
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
91
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
92
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
93
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
94
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
95
+ dignissim, pharetra neque molestie, molestie lectus.
96
+ </p>{" "}
97
+ </DxcDialog>
98
+ </ExampleContainer>
99
+ );
100
+
101
+ export const DialogCloseVisibleFalse = () => (
102
+ <ExampleContainer expanded={true}>
103
+ <Title title="Dialog Close Visible" theme="dark" level={4} />
104
+ <DxcDialog isCloseVisible={false}>
105
+ {" "}
106
+ <p>
107
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
108
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
109
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
110
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
111
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
112
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
113
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
114
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
115
+ dignissim, pharetra neque molestie, molestie lectus.
116
+ </p>{" "}
117
+ </DxcDialog>
118
+ </ExampleContainer>
119
+ );
120
+
121
+ export const DialogWithXxsmallPadding = () => (
122
+ <ExampleContainer expanded={true}>
123
+ <Title title="Dialog With Xxsmall Padding" theme="light" level={4} />
124
+ <DxcDialog padding={"xxsmall"}>
125
+ {" "}
126
+ <p>
127
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
128
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
129
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
130
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
131
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
132
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
133
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
134
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
135
+ dignissim, pharetra neque molestie, molestie lectus.
136
+ </p>{" "}
137
+ </DxcDialog>
138
+ </ExampleContainer>
139
+ );
140
+
141
+ export const DialogWithXsmallPadding = () => (
142
+ <ExampleContainer expanded={true}>
143
+ <Title title="Dialog With Xsmall Padding" theme="light" level={4} />
144
+ <DxcDialog padding={"xsmall"}>
145
+ {" "}
146
+ <p>
147
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
148
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
149
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
150
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
151
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
152
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
153
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
154
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
155
+ dignissim, pharetra neque molestie, molestie lectus.
156
+ </p>{" "}
157
+ </DxcDialog>
158
+ </ExampleContainer>
159
+ );
160
+
161
+ export const DialogWithSmallPadding = () => (
162
+ <ExampleContainer expanded={true}>
163
+ <Title title="Dialog With Small Padding" theme="light" level={4} />
164
+ <DxcDialog padding={"small"}>
165
+ {" "}
166
+ <p>
167
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
168
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
169
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
170
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
171
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
172
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
173
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
174
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
175
+ dignissim, pharetra neque molestie, molestie lectus.
176
+ </p>{" "}
177
+ </DxcDialog>
178
+ </ExampleContainer>
179
+ );
180
+
181
+ export const DialogWithMediumPadding = () => (
182
+ <ExampleContainer expanded={true}>
183
+ <Title title="Dialog With Medium Padding" theme="light" level={4} />
184
+ <DxcDialog padding={"medium"}>
185
+ {" "}
186
+ <p>
187
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
188
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
189
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
190
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
191
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
192
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
193
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
194
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
195
+ dignissim, pharetra neque molestie, molestie lectus.
196
+ </p>{" "}
197
+ </DxcDialog>
198
+ </ExampleContainer>
199
+ );
200
+
201
+ export const DialogWithLargePadding = () => (
202
+ <ExampleContainer expanded={true}>
203
+ <Title title="Dialog With Large Padding" theme="light" level={4} />
204
+ <DxcDialog padding={"large"}>
205
+ {" "}
206
+ <p>
207
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
208
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
209
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
210
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
211
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
212
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
213
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
214
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
215
+ dignissim, pharetra neque molestie, molestie lectus.
216
+ </p>{" "}
217
+ </DxcDialog>
218
+ </ExampleContainer>
219
+ );
220
+
221
+ export const DialogWithXlargePadding = () => (
222
+ <ExampleContainer expanded={true}>
223
+ <Title title="Dialog With Xlarge Padding" theme="light" level={4} />
224
+ <DxcDialog padding={"xlarge"}>
225
+ {" "}
226
+ <p>
227
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
228
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
229
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
230
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
231
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
232
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
233
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
234
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
235
+ dignissim, pharetra neque molestie, molestie lectus.
236
+ </p>{" "}
237
+ </DxcDialog>
238
+ </ExampleContainer>
239
+ );
240
+
241
+ export const DialogWithXxlargePadding = () => (
242
+ <ExampleContainer expanded={true}>
243
+ <Title title="Dialog With Xxlarge Padding" theme="light" level={4} />
244
+ <DxcDialog padding={"xxlarge"}>
245
+ {" "}
246
+ <p>
247
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
248
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
249
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
250
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
251
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
252
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
253
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
254
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
255
+ dignissim, pharetra neque molestie, molestie lectus.
256
+ </p>{" "}
257
+ </DxcDialog>
258
+ </ExampleContainer>
259
+ );
260
+
261
+ export const ResponsiveDialog = RespDialog.bind({});
262
+ ResponsiveDialog.parameters = {
263
+ viewport: {
264
+ defaultViewport: "iphonex",
265
+ },
266
+ chromatic: { viewports: [375] },
267
+ };
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Dialog = _interopRequireDefault(require("./Dialog"));
10
+
11
+ describe("Dialog component tests", function () {
12
+ test("Dialog renders with correct text and accesibility attributes", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "dialog-text")),
14
+ getByText = _render.getByText,
15
+ getByRole = _render.getByRole;
16
+
17
+ expect(getByRole("dialog")).toBeTruthy();
18
+ expect(getByRole("dialog").getAttribute("aria-modal")).toBe("true");
19
+ expect(getByText("dialog-text")).toBeTruthy();
20
+ });
21
+ test("Dialog renders without close button", function () {
22
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
23
+ isCloseVisible: false
24
+ }, "dialog-text")),
25
+ queryByRole = _render2.queryByRole;
26
+
27
+ expect(queryByRole("button")).toBeFalsy();
28
+ });
29
+ test("Dialog renders with aria-modal false when overlay is not used", function () {
30
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
31
+ isCloseVisible: false,
32
+ overlay: false
33
+ }, "dialog-text")),
34
+ getByRole = _render3.getByRole;
35
+
36
+ expect(getByRole("dialog")).toBeTruthy();
37
+ expect(getByRole("dialog").getAttribute("aria-modal")).toBe("false");
38
+ });
39
+ test("Calls correct function onCloseClick", function () {
40
+ var onCloseClick = jest.fn();
41
+
42
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
43
+ onCloseClick: onCloseClick
44
+ }, "dialog-text")),
45
+ getByRole = _render4.getByRole;
46
+
47
+ var closeButton = getByRole("button");
48
+
49
+ _react2.fireEvent.click(closeButton);
50
+
51
+ expect(onCloseClick).toHaveBeenCalled();
52
+ });
53
+ test("Calls correct function onCloseClick when 'escape' key is pressed", function () {
54
+ var onCloseClick = jest.fn();
55
+
56
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
57
+ onCloseClick: onCloseClick
58
+ }, "dialog-text")),
59
+ getByRole = _render5.getByRole;
60
+
61
+ _react2.fireEvent.keyDown(getByRole("button"), {
62
+ key: "Escape",
63
+ code: "Escape",
64
+ keyCode: 27,
65
+ charCode: 27
66
+ });
67
+
68
+ expect(onCloseClick).toHaveBeenCalled();
69
+ });
70
+ });
package/dialog/types.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Padding = {
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Padding = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
@@ -26,6 +26,7 @@ declare type Props = {
26
26
  */
27
27
  onBackgroundClick?: () => void;
28
28
  /**
29
+ * @deprecated This prop will be removed shortly, consider using the Inset component for this purpose.
29
30
  * Size of the padding to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
30
31
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
31
32
  */
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import DropdownPropsType from "./types";
3
- declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconSrc, iconPosition, label, caretHidden, onSelectOption, expandOnHover, margin, size, tabIndex, disabled, }: DropdownPropsType) => JSX.Element;
3
+ declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconPosition, label, caretHidden, disabled, expandOnHover, onSelectOption, margin, size, tabIndex, }: DropdownPropsType) => JSX.Element;
4
4
  export default DxcDropdown;