@dxc-technology/halstack-react 0.0.0-9282b45 → 0.0.0-92fa0e1

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 (288) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1229 -6
  4. package/HalstackContext.js +125 -110
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +36 -99
  8. package/accordion/Accordion.stories.tsx +101 -124
  9. package/accordion/Accordion.test.js +19 -34
  10. package/accordion/types.d.ts +5 -17
  11. package/accordion-group/AccordionGroup.d.ts +4 -3
  12. package/accordion-group/AccordionGroup.js +29 -77
  13. package/accordion-group/AccordionGroup.stories.tsx +78 -77
  14. package/accordion-group/AccordionGroup.test.js +44 -72
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +6 -18
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +43 -0
  20. package/action-icon/types.d.ts +26 -0
  21. package/alert/Alert.js +19 -58
  22. package/alert/Alert.stories.tsx +28 -0
  23. package/alert/Alert.test.js +29 -46
  24. package/alert/types.d.ts +5 -5
  25. package/badge/Badge.js +4 -17
  26. package/badge/types.d.ts +1 -1
  27. package/bleed/Bleed.js +13 -21
  28. package/bleed/Bleed.stories.tsx +1 -0
  29. package/bleed/types.d.ts +2 -2
  30. package/box/Box.d.ts +1 -1
  31. package/box/Box.js +18 -59
  32. package/box/Box.stories.tsx +38 -51
  33. package/box/Box.test.js +2 -7
  34. package/box/types.d.ts +3 -15
  35. package/bulleted-list/BulletedList.js +19 -53
  36. package/bulleted-list/BulletedList.stories.tsx +8 -93
  37. package/bulleted-list/types.d.ts +32 -5
  38. package/button/Button.d.ts +1 -1
  39. package/button/Button.js +69 -105
  40. package/button/Button.stories.tsx +152 -91
  41. package/button/Button.test.js +18 -17
  42. package/button/types.d.ts +8 -4
  43. package/card/Card.d.ts +1 -1
  44. package/card/Card.js +48 -89
  45. package/card/Card.stories.tsx +12 -42
  46. package/card/Card.test.js +11 -22
  47. package/card/types.d.ts +6 -12
  48. package/checkbox/Checkbox.d.ts +2 -2
  49. package/checkbox/Checkbox.js +92 -126
  50. package/checkbox/Checkbox.stories.tsx +128 -94
  51. package/checkbox/Checkbox.test.js +108 -64
  52. package/checkbox/types.d.ts +11 -3
  53. package/chip/Chip.js +39 -79
  54. package/chip/Chip.stories.tsx +121 -26
  55. package/chip/Chip.test.js +16 -31
  56. package/chip/types.d.ts +4 -4
  57. package/common/OpenSans.css +68 -80
  58. package/common/coreTokens.d.ts +237 -0
  59. package/common/coreTokens.js +184 -0
  60. package/common/utils.d.ts +1 -0
  61. package/common/utils.js +6 -12
  62. package/common/variables.d.ts +1381 -0
  63. package/common/variables.js +893 -1148
  64. package/container/Container.d.ts +4 -0
  65. package/container/Container.js +194 -0
  66. package/container/Container.stories.tsx +214 -0
  67. package/container/types.d.ts +74 -0
  68. package/date-input/Calendar.d.ts +4 -0
  69. package/date-input/Calendar.js +214 -0
  70. package/date-input/DateInput.js +150 -299
  71. package/date-input/DateInput.stories.tsx +203 -56
  72. package/date-input/DateInput.test.js +700 -371
  73. package/date-input/DatePicker.d.ts +4 -0
  74. package/date-input/DatePicker.js +115 -0
  75. package/date-input/Icons.d.ts +6 -0
  76. package/date-input/Icons.js +58 -0
  77. package/date-input/YearPicker.d.ts +4 -0
  78. package/date-input/YearPicker.js +100 -0
  79. package/date-input/types.d.ts +72 -15
  80. package/dialog/Dialog.d.ts +1 -1
  81. package/dialog/Dialog.js +61 -119
  82. package/dialog/Dialog.stories.tsx +310 -212
  83. package/dialog/Dialog.test.js +269 -32
  84. package/dialog/types.d.ts +18 -26
  85. package/dropdown/Dropdown.js +66 -120
  86. package/dropdown/Dropdown.stories.tsx +210 -84
  87. package/dropdown/Dropdown.test.js +409 -400
  88. package/dropdown/DropdownMenu.js +20 -37
  89. package/dropdown/DropdownMenuItem.js +9 -34
  90. package/dropdown/types.d.ts +17 -19
  91. package/file-input/FileInput.d.ts +2 -2
  92. package/file-input/FileInput.js +241 -355
  93. package/file-input/FileInput.stories.tsx +123 -12
  94. package/file-input/FileInput.test.js +369 -367
  95. package/file-input/FileItem.d.ts +4 -14
  96. package/file-input/FileItem.js +45 -96
  97. package/file-input/types.d.ts +25 -8
  98. package/flex/Flex.js +27 -39
  99. package/flex/Flex.stories.tsx +35 -26
  100. package/flex/types.d.ts +74 -9
  101. package/footer/Footer.d.ts +1 -1
  102. package/footer/Footer.js +70 -117
  103. package/footer/Footer.stories.tsx +55 -21
  104. package/footer/Footer.test.js +33 -57
  105. package/footer/Icons.d.ts +3 -2
  106. package/footer/Icons.js +66 -7
  107. package/footer/types.d.ts +25 -27
  108. package/grid/Grid.d.ts +7 -0
  109. package/grid/Grid.js +76 -0
  110. package/grid/Grid.stories.tsx +219 -0
  111. package/grid/types.d.ts +115 -0
  112. package/header/Header.d.ts +4 -3
  113. package/header/Header.js +48 -133
  114. package/header/Header.stories.tsx +115 -36
  115. package/header/Header.test.js +13 -26
  116. package/header/Icons.d.ts +2 -2
  117. package/header/Icons.js +2 -7
  118. package/header/types.d.ts +5 -20
  119. package/heading/Heading.js +10 -32
  120. package/heading/Heading.test.js +71 -88
  121. package/heading/types.d.ts +7 -7
  122. package/image/Image.d.ts +4 -0
  123. package/image/Image.js +70 -0
  124. package/image/Image.stories.tsx +127 -0
  125. package/image/types.d.ts +72 -0
  126. package/image/types.js +5 -0
  127. package/inset/Inset.js +13 -21
  128. package/inset/Inset.stories.tsx +2 -1
  129. package/inset/types.d.ts +2 -2
  130. package/layout/ApplicationLayout.d.ts +5 -5
  131. package/layout/ApplicationLayout.js +29 -66
  132. package/layout/ApplicationLayout.stories.tsx +1 -1
  133. package/layout/Icons.d.ts +8 -5
  134. package/layout/Icons.js +51 -59
  135. package/layout/SidenavContext.d.ts +1 -1
  136. package/layout/SidenavContext.js +3 -9
  137. package/layout/types.d.ts +5 -6
  138. package/link/Link.js +25 -46
  139. package/link/Link.stories.tsx +60 -0
  140. package/link/Link.test.js +24 -44
  141. package/link/types.d.ts +14 -14
  142. package/main.d.ts +7 -4
  143. package/main.js +32 -58
  144. package/{tabs-nav → nav-tabs}/NavTabs.d.ts +2 -2
  145. package/{tabs-nav → nav-tabs}/NavTabs.js +23 -55
  146. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +111 -7
  147. package/{tabs-nav → nav-tabs}/NavTabs.test.js +37 -44
  148. package/nav-tabs/Tab.js +117 -0
  149. package/{tabs-nav → nav-tabs}/types.d.ts +14 -15
  150. package/nav-tabs/types.js +5 -0
  151. package/number-input/NumberInput.d.ts +7 -0
  152. package/number-input/NumberInput.js +26 -35
  153. package/number-input/NumberInput.stories.tsx +42 -26
  154. package/number-input/NumberInput.test.js +701 -377
  155. package/number-input/types.d.ts +11 -5
  156. package/package.json +37 -40
  157. package/paginator/Icons.d.ts +5 -0
  158. package/paginator/Icons.js +21 -47
  159. package/paginator/Paginator.js +23 -59
  160. package/paginator/Paginator.stories.tsx +24 -0
  161. package/paginator/Paginator.test.js +253 -226
  162. package/paginator/types.d.ts +3 -3
  163. package/paragraph/Paragraph.d.ts +3 -4
  164. package/paragraph/Paragraph.js +6 -22
  165. package/paragraph/Paragraph.stories.tsx +0 -17
  166. package/password-input/Icons.d.ts +6 -0
  167. package/password-input/Icons.js +35 -0
  168. package/password-input/PasswordInput.js +57 -128
  169. package/password-input/PasswordInput.stories.tsx +1 -33
  170. package/password-input/PasswordInput.test.js +158 -141
  171. package/password-input/types.d.ts +8 -7
  172. package/progress-bar/ProgressBar.d.ts +2 -2
  173. package/progress-bar/ProgressBar.js +23 -55
  174. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
  175. package/progress-bar/ProgressBar.test.js +36 -53
  176. package/progress-bar/types.d.ts +4 -3
  177. package/quick-nav/QuickNav.js +4 -27
  178. package/quick-nav/QuickNav.stories.tsx +15 -1
  179. package/quick-nav/types.d.ts +10 -10
  180. package/radio-group/Radio.d.ts +1 -1
  181. package/radio-group/Radio.js +31 -63
  182. package/radio-group/RadioGroup.js +45 -93
  183. package/radio-group/RadioGroup.stories.tsx +131 -18
  184. package/radio-group/RadioGroup.test.js +505 -471
  185. package/radio-group/types.d.ts +8 -8
  186. package/resultset-table/Icons.d.ts +7 -0
  187. package/resultset-table/Icons.js +47 -0
  188. package/resultset-table/ResultsetTable.js +159 -0
  189. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +50 -25
  190. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +101 -144
  191. package/{resultsetTable → resultset-table}/types.d.ts +7 -7
  192. package/resultset-table/types.js +5 -0
  193. package/select/Icons.d.ts +7 -7
  194. package/select/Icons.js +1 -5
  195. package/select/Listbox.d.ts +1 -1
  196. package/select/Listbox.js +17 -72
  197. package/select/Option.js +27 -50
  198. package/select/Select.js +120 -175
  199. package/select/Select.stories.tsx +497 -153
  200. package/select/Select.test.js +1974 -1837
  201. package/select/types.d.ts +16 -17
  202. package/sidenav/Icons.d.ts +7 -0
  203. package/sidenav/Icons.js +47 -0
  204. package/sidenav/Sidenav.d.ts +2 -2
  205. package/sidenav/Sidenav.js +81 -153
  206. package/sidenav/Sidenav.stories.tsx +165 -63
  207. package/sidenav/Sidenav.test.js +3 -10
  208. package/sidenav/types.d.ts +31 -28
  209. package/slider/Slider.d.ts +2 -2
  210. package/slider/Slider.js +77 -134
  211. package/slider/Slider.test.js +108 -104
  212. package/slider/types.d.ts +7 -3
  213. package/spinner/Spinner.js +31 -75
  214. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  215. package/spinner/Spinner.test.js +26 -35
  216. package/spinner/types.d.ts +3 -3
  217. package/status-light/StatusLight.d.ts +4 -0
  218. package/status-light/StatusLight.js +51 -0
  219. package/status-light/StatusLight.stories.tsx +74 -0
  220. package/status-light/StatusLight.test.js +25 -0
  221. package/status-light/types.d.ts +17 -0
  222. package/status-light/types.js +5 -0
  223. package/switch/Switch.d.ts +3 -3
  224. package/switch/Switch.js +56 -103
  225. package/switch/Switch.stories.tsx +33 -34
  226. package/switch/Switch.test.js +52 -97
  227. package/switch/types.d.ts +8 -3
  228. package/table/Table.js +8 -30
  229. package/table/{Table.stories.jsx → Table.stories.tsx} +80 -1
  230. package/table/Table.test.js +3 -8
  231. package/table/types.d.ts +8 -8
  232. package/tabs/Tab.js +22 -44
  233. package/tabs/Tabs.js +62 -145
  234. package/tabs/Tabs.stories.tsx +45 -5
  235. package/tabs/Tabs.test.js +66 -123
  236. package/tabs/types.d.ts +19 -19
  237. package/tag/Tag.js +28 -60
  238. package/tag/Tag.stories.tsx +14 -1
  239. package/tag/Tag.test.js +20 -31
  240. package/tag/types.d.ts +7 -7
  241. package/text-input/Icons.d.ts +5 -5
  242. package/text-input/Icons.js +1 -5
  243. package/text-input/Suggestion.js +35 -25
  244. package/text-input/Suggestions.d.ts +1 -1
  245. package/text-input/Suggestions.js +15 -65
  246. package/text-input/TextInput.js +219 -320
  247. package/text-input/TextInput.stories.tsx +139 -155
  248. package/text-input/TextInput.test.js +1372 -1347
  249. package/text-input/types.d.ts +27 -19
  250. package/textarea/Textarea.js +70 -113
  251. package/textarea/Textarea.stories.tsx +174 -0
  252. package/textarea/Textarea.test.js +152 -183
  253. package/textarea/types.d.ts +9 -5
  254. package/toggle-group/ToggleGroup.d.ts +2 -2
  255. package/toggle-group/ToggleGroup.js +92 -106
  256. package/toggle-group/ToggleGroup.stories.tsx +49 -4
  257. package/toggle-group/ToggleGroup.test.js +69 -88
  258. package/toggle-group/types.d.ts +26 -17
  259. package/typography/Typography.d.ts +2 -2
  260. package/typography/Typography.js +15 -123
  261. package/typography/Typography.stories.tsx +1 -1
  262. package/typography/types.d.ts +1 -1
  263. package/useTheme.d.ts +1133 -1
  264. package/useTheme.js +2 -9
  265. package/useTranslatedLabels.d.ts +84 -1
  266. package/useTranslatedLabels.js +1 -7
  267. package/utils/BaseTypography.d.ts +21 -0
  268. package/utils/BaseTypography.js +94 -0
  269. package/utils/FocusLock.d.ts +13 -0
  270. package/utils/FocusLock.js +124 -0
  271. package/wizard/Wizard.js +16 -51
  272. package/wizard/Wizard.stories.tsx +20 -0
  273. package/wizard/Wizard.test.js +54 -81
  274. package/wizard/types.d.ts +8 -9
  275. package/card/ice-cream.jpg +0 -0
  276. package/common/RequiredComponent.js +0 -32
  277. package/number-input/NumberInputContext.d.ts +0 -4
  278. package/number-input/NumberInputContext.js +0 -19
  279. package/number-input/numberInputContextTypes.d.ts +0 -19
  280. package/resultsetTable/ResultsetTable.js +0 -254
  281. package/slider/Slider.stories.tsx +0 -183
  282. package/tabs-nav/Tab.js +0 -130
  283. package/textarea/Textarea.stories.jsx +0 -157
  284. /package/{resultsetTable → action-icon}/types.js +0 -0
  285. /package/{tabs-nav → container}/types.js +0 -0
  286. /package/{number-input/numberInputContextTypes.js → grid/types.js} +0 -0
  287. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
  288. /package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +0 -0
@@ -0,0 +1,214 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
13
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
14
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
15
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4;
16
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
17
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
18
+ var getDays = function getDays(innerDate) {
19
+ var monthDayCells = [];
20
+ var lastMonthNumberOfDays = innerDate.set("month", innerDate.get("month") - 1).endOf("month");
21
+ var firstDayOfMonth = innerDate.startOf("month").day() === 0 ? 6 : innerDate.startOf("month").day() - 1;
22
+ var daysInMonth = firstDayOfMonth + innerDate.daysInMonth();
23
+ for (var i = 0; i < 42; i++) {
24
+ if (i < firstDayOfMonth) {
25
+ monthDayCells.push({
26
+ day: lastMonthNumberOfDays.get("date") - firstDayOfMonth + i + 1,
27
+ month: innerDate.get("month") ? innerDate.get("month") - 1 : 11,
28
+ year: innerDate.set("month", innerDate.get("month") - 1).get("year")
29
+ });
30
+ } else if (i < daysInMonth) {
31
+ monthDayCells.push({
32
+ day: i - firstDayOfMonth + 1,
33
+ month: innerDate.get("month"),
34
+ year: innerDate.get("year")
35
+ });
36
+ } else {
37
+ monthDayCells.push({
38
+ day: i - daysInMonth + 1,
39
+ month: innerDate.get("month") === 11 ? 0 : innerDate.get("month") + 1,
40
+ year: innerDate.set("month", innerDate.get("month") + 1).get("year")
41
+ });
42
+ }
43
+ }
44
+ return monthDayCells;
45
+ };
46
+ var getDateToFocus = function getDateToFocus(selectedDate, innerDate, today) {
47
+ return (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("month")) === innerDate.get("month") && (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === innerDate.get("year") ? selectedDate : today.get("month") === innerDate.get("month") && today.get("year") === innerDate.get("year") ? today : innerDate.set("date", 1);
48
+ };
49
+ var isDaySelected = function isDaySelected(date, selectedDate) {
50
+ return (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("month")) === date.month && (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === date.year && (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("date")) === date.day;
51
+ };
52
+ var Calendar = function Calendar(_ref) {
53
+ var selectedDate = _ref.selectedDate,
54
+ innerDate = _ref.innerDate,
55
+ onInnerDateChange = _ref.onInnerDateChange,
56
+ onDaySelect = _ref.onDaySelect,
57
+ today = _ref.today;
58
+ var _useState = (0, _react.useState)(getDateToFocus(selectedDate, innerDate, today)),
59
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
60
+ dateToFocus = _useState2[0],
61
+ setDateToFocus = _useState2[1];
62
+ var _useState3 = (0, _react.useState)(false),
63
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
64
+ isFocusable = _useState4[0],
65
+ setIsFocusable = _useState4[1];
66
+ var dayCells = (0, _react.useMemo)(function () {
67
+ return getDays(innerDate);
68
+ }, [innerDate]);
69
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
70
+ var weekDays = translatedLabels.calendar.daysShort;
71
+ var onDateClickHandler = function onDateClickHandler(date) {
72
+ var newDate = innerDate.set("month", date.month).set("date", date.day);
73
+ onDaySelect(newDate);
74
+ setDateToFocus(newDate);
75
+ };
76
+ var handleOnBlur = function handleOnBlur(event) {
77
+ if (!(event !== null && event !== void 0 && event.currentTarget.contains(event.relatedTarget))) {
78
+ setDateToFocus(getDateToFocus(selectedDate, innerDate, today));
79
+ }
80
+ };
81
+ var focusDate = function focusDate(date) {
82
+ if (innerDate.get("month") !== date.get("month") || innerDate.get("year") !== date.get("year")) {
83
+ onInnerDateChange(date);
84
+ }
85
+ setDateToFocus(date);
86
+ setIsFocusable(true);
87
+ };
88
+ (0, _react.useEffect)(function () {
89
+ if (isFocusable) {
90
+ var _document$getElementB;
91
+ (_document$getElementB = document.getElementById("day_".concat(dateToFocus.get("date"), "_month").concat(dateToFocus.get("month")))) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.focus();
92
+ setIsFocusable(false);
93
+ }
94
+ }, [dateToFocus, isFocusable]);
95
+ (0, _react.useEffect)(function () {
96
+ if (dateToFocus.get("month") !== innerDate.get("month") || dateToFocus.get("year") !== innerDate.get("year")) {
97
+ setDateToFocus(getDateToFocus(selectedDate, innerDate, today));
98
+ }
99
+ }, [innerDate, dateToFocus, selectedDate, today]);
100
+ var handleDayKeyboardEvent = function handleDayKeyboardEvent(event, date) {
101
+ var dateToFocusTemp = date.month === innerDate.get("month") ? innerDate.set("date", date.day) : innerDate.set("date", date.day).set("month", date.month);
102
+ switch (event.key) {
103
+ case "PageUp":
104
+ event.preventDefault();
105
+ event.shiftKey ? dateToFocusTemp = dateToFocusTemp.set("year", dateToFocusTemp.get("year") - 1) : dateToFocusTemp = dateToFocusTemp.set("month", dateToFocusTemp.get("month") - 1);
106
+ focusDate(dateToFocusTemp);
107
+ break;
108
+ case "PageDown":
109
+ event.preventDefault();
110
+ event.shiftKey ? dateToFocusTemp = dateToFocusTemp.set("year", dateToFocusTemp.get("year") + 1) : dateToFocusTemp = dateToFocusTemp.set("month", dateToFocusTemp.get("month") + 1);
111
+ focusDate(dateToFocusTemp);
112
+ break;
113
+ case "ArrowLeft":
114
+ event.preventDefault();
115
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") - 1);
116
+ focusDate(dateToFocusTemp);
117
+ break;
118
+ case "ArrowRight":
119
+ event.preventDefault();
120
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") + 1);
121
+ focusDate(dateToFocusTemp);
122
+ break;
123
+ case "ArrowUp":
124
+ event.preventDefault();
125
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") - 7);
126
+ focusDate(dateToFocusTemp);
127
+ break;
128
+ case "ArrowDown":
129
+ event.preventDefault();
130
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") + 7);
131
+ focusDate(dateToFocusTemp);
132
+ break;
133
+ case "Home":
134
+ event.preventDefault();
135
+ dateToFocus.get("day") !== 0 ? dateToFocusTemp = dateToFocusTemp.day(1) : dateToFocusTemp = innerDate.date(date.day - 1).day(1);
136
+ focusDate(dateToFocusTemp);
137
+ break;
138
+ case "End":
139
+ event.preventDefault();
140
+ dateToFocusTemp.get("day") !== 0 && (dateToFocusTemp = dateToFocusTemp.day(7));
141
+ focusDate(dateToFocusTemp);
142
+ break;
143
+ case " ":
144
+ event.preventDefault();
145
+ onDaySelect(dateToFocusTemp);
146
+ break;
147
+ }
148
+ };
149
+ return /*#__PURE__*/_react["default"].createElement(CalendarContainer, null, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
150
+ alignItems: "center",
151
+ justifyContent: "space-between"
152
+ }, weekDays.map(function (weekDay) {
153
+ return /*#__PURE__*/_react["default"].createElement(WeekHeaderCell, {
154
+ key: weekDay
155
+ }, weekDay);
156
+ })), /*#__PURE__*/_react["default"].createElement(DayCellsContainer, {
157
+ onBlur: handleOnBlur
158
+ }, dayCells.map(function (date, index) {
159
+ return /*#__PURE__*/_react["default"].createElement(DayCell, {
160
+ onKeyDown: function onKeyDown(event) {
161
+ return handleDayKeyboardEvent(event, date);
162
+ },
163
+ "aria-label": date.day,
164
+ id: "day_".concat(date.day, "_month").concat(date.month),
165
+ key: "day_".concat(index),
166
+ onClick: function onClick() {
167
+ return onDateClickHandler(date);
168
+ },
169
+ selected: isDaySelected(date, selectedDate),
170
+ actualMonth: date.month === innerDate.get("month"),
171
+ autoFocus: date.day === dateToFocus.get("date") && date.month === dateToFocus.get("month"),
172
+ "aria-selected": isDaySelected(date, selectedDate),
173
+ tabIndex: date.day === dateToFocus.get("date") && date.month === dateToFocus.get("month") ? 0 : -1,
174
+ isCurrentDay: today.get("date") === date.day && today.get("month") === innerDate.get("month") && today.get("month") === date.month && today.get("year") === innerDate.get("year")
175
+ }, date.day);
176
+ })));
177
+ };
178
+ var CalendarContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n justify-content: center;\n padding: 0px 8px 8px 8px;\n width: 292px;\n font-family: ", ";\n font-size: ", ";\n color: ", ";\n font-weight: ", ";\n"])), function (props) {
179
+ return props.theme.dateInput.pickerFontFamily;
180
+ }, function (props) {
181
+ return props.theme.dateInput.pickerFontSize;
182
+ }, function (props) {
183
+ return props.theme.dateInput.pickerFontColor;
184
+ }, function (props) {
185
+ return props.theme.dateInput.pickerFontWeight;
186
+ });
187
+ var WeekHeaderCell = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 36px;\n height: 36px;\n"])));
188
+ var DayCellsContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n gap: 4px;\n flex-wrap: wrap;\n justify-content: space-between;\n"])));
189
+ var DayCell = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n width: 36px;\n height: 36px;\n padding: 0;\n border: none;\n border-radius: 50%;\n cursor: pointer;\n font-family: ", ";\n font-size: ", ";\n color: ", ";\n font-weight: ", ";\n\n &:focus {\n outline: ", " solid 2px;\n }\n &:hover {\n background-color: ", ";\n color: ", ";\n }\n &:active {\n background-color: ", ";\n color: ", ";\n }\n\n ", "\n background-color: ", ";\n color: ", ";\n"])), function (props) {
190
+ return props.theme.dateInput.pickerFontFamily;
191
+ }, function (props) {
192
+ return props.theme.dateInput.pickerFontSize;
193
+ }, function (props) {
194
+ return props.theme.dateInput.pickerFontColor;
195
+ }, function (props) {
196
+ return props.theme.dateInput.pickerFontWeight;
197
+ }, function (props) {
198
+ return props.theme.dateInput.pickerFocusColor;
199
+ }, function (props) {
200
+ return props.selected ? props.theme.dateInput.pickerSelectedBackgroundColor : props.theme.dateInput.pickerHoverBackgroundColor;
201
+ }, function (props) {
202
+ return props.selected ? props.theme.dateInput.pickerSelectedFontColor : props.theme.dateInput.pickerHoverFontColor;
203
+ }, function (props) {
204
+ return props.theme.dateInput.pickerActiveBackgroundColor;
205
+ }, function (props) {
206
+ return props.theme.dateInput.pickerActiveFontColor;
207
+ }, function (props) {
208
+ return props.isCurrentDay && !props.selected && "border: ".concat(props.theme.dateInput.pickerCurrentDateBorderWidth, " solid ").concat(props.theme.dateInput.pickerCurrentDateBorderColor, ";");
209
+ }, function (props) {
210
+ return props.selected ? props.theme.dateInput.pickerSelectedBackgroundColor : "transparent";
211
+ }, function (props) {
212
+ return props.selected ? props.theme.dateInput.pickerSelectedFontColor : props.isCurrentDay ? props.theme.dateInput.pickerCurrentDateFontColor : !props.actualMonth ? props.theme.dateInput.pickerNonCurrentMonthFontColor : props.theme.dateInput.pickerFontColor;
213
+ });
214
+ var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(Calendar);