@pingux/astro 2.2.0 → 2.3.0-alpha.1

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 (50) hide show
  1. package/lib/cjs/components/Calendar/Calendar.js +202 -0
  2. package/lib/cjs/components/Calendar/Calendar.stories.js +192 -0
  3. package/lib/cjs/components/Calendar/Calendar.styles.js +74 -0
  4. package/lib/cjs/components/Calendar/Calendar.test.js +324 -0
  5. package/lib/cjs/components/Calendar/CalendarCell.js +125 -0
  6. package/lib/cjs/components/Calendar/CalendarGrid.js +77 -0
  7. package/lib/cjs/components/Calendar/index.js +14 -0
  8. package/lib/cjs/components/DatePicker/DateField.js +316 -0
  9. package/lib/cjs/components/DatePicker/DatePicker.js +195 -0
  10. package/lib/cjs/components/DatePicker/DatePicker.stories.js +205 -0
  11. package/lib/cjs/components/DatePicker/DatePicker.styles.js +60 -0
  12. package/lib/cjs/components/DatePicker/DatePicker.test.js +570 -0
  13. package/lib/cjs/components/DatePicker/DateSegment.js +71 -0
  14. package/lib/cjs/components/DatePicker/index.js +14 -0
  15. package/lib/cjs/components/IconButton/IconButton.styles.js +4 -0
  16. package/lib/cjs/components/TextField/TextField.js +6 -2
  17. package/lib/cjs/components/TextField/TextField.stories.js +13 -1
  18. package/lib/cjs/components/TooltipTrigger/Tooltip.js +4 -6
  19. package/lib/cjs/components/TooltipTrigger/Tooltip.styles.js +14 -18
  20. package/lib/cjs/hooks/useOverlayPanelState/useOverlayPanelState.test.js +2 -2
  21. package/lib/cjs/index.js +132 -59
  22. package/lib/cjs/styles/forms/index.js +2 -0
  23. package/lib/cjs/styles/variants/variants.js +4 -2
  24. package/lib/components/Calendar/Calendar.js +190 -0
  25. package/lib/components/Calendar/Calendar.stories.js +171 -0
  26. package/lib/components/Calendar/Calendar.styles.js +66 -0
  27. package/lib/components/Calendar/Calendar.test.js +321 -0
  28. package/lib/components/Calendar/CalendarCell.js +111 -0
  29. package/lib/components/Calendar/CalendarGrid.js +68 -0
  30. package/lib/components/Calendar/index.js +1 -0
  31. package/lib/components/DatePicker/DateField.js +303 -0
  32. package/lib/components/DatePicker/DatePicker.js +183 -0
  33. package/lib/components/DatePicker/DatePicker.stories.js +180 -0
  34. package/lib/components/DatePicker/DatePicker.styles.js +51 -0
  35. package/lib/components/DatePicker/DatePicker.test.js +563 -0
  36. package/lib/components/DatePicker/DateSegment.js +58 -0
  37. package/lib/components/DatePicker/index.js +1 -0
  38. package/lib/components/IconButton/IconButton.styles.js +4 -0
  39. package/lib/components/TextField/TextField.js +6 -2
  40. package/lib/components/TextField/TextField.stories.js +11 -0
  41. package/lib/components/TooltipTrigger/Tooltip.js +4 -6
  42. package/lib/components/TooltipTrigger/Tooltip.styles.js +14 -18
  43. package/lib/hooks/useOverlayPanelState/useOverlayPanelState.test.js +2 -2
  44. package/lib/index.js +8 -0
  45. package/lib/styles/forms/index.js +2 -0
  46. package/lib/styles/variants/variants.js +3 -1
  47. package/package.json +7 -1
  48. package/NOTICE.html +0 -12399
  49. /package/lib/cjs/{styles/variants/callout.js → components/Callout/Callout.styles.js} +0 -0
  50. /package/lib/{styles/variants/callout.js → components/Callout/Callout.styles.js} +0 -0
@@ -0,0 +1,316 @@
1
+ "use strict";
2
+
3
+ var _typeof = require("@babel/runtime-corejs3/helpers/typeof");
4
+ var _Object$keys = require("@babel/runtime-corejs3/core-js-stable/object/keys");
5
+ var _Object$getOwnPropertySymbols = require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols");
6
+ var _filterInstanceProperty = require("@babel/runtime-corejs3/core-js-stable/instance/filter");
7
+ var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor");
8
+ var _forEachInstanceProperty2 = require("@babel/runtime-corejs3/core-js-stable/instance/for-each");
9
+ var _Object$getOwnPropertyDescriptors = require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors");
10
+ var _Object$defineProperties = require("@babel/runtime-corejs3/core-js-stable/object/define-properties");
11
+ var _Object$defineProperty = require("@babel/runtime-corejs3/core-js-stable/object/define-property");
12
+ var _WeakMap = require("@babel/runtime-corejs3/core-js-stable/weak-map");
13
+ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
14
+ _Object$defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ exports["default"] = void 0;
18
+ var _setTimeout2 = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/set-timeout"));
19
+ var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
20
+ var _forEach = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/for-each"));
21
+ var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
22
+ var _values = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/values"));
23
+ var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
24
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
25
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
26
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/objectWithoutProperties"));
27
+ var _react = _interopRequireWildcard(require("react"));
28
+ var _reactAria = require("react-aria");
29
+ var _reactStately = require("react-stately");
30
+ var _date = require("@internationalized/date");
31
+ var _datepicker = require("@react-aria/datepicker");
32
+ var _i18n = require("@react-aria/i18n");
33
+ var _visuallyHidden = require("@react-aria/visually-hidden");
34
+ var _datepicker2 = require("@react-stately/datepicker");
35
+ var _CalendarIcon = _interopRequireDefault(require("mdi-react/CalendarIcon"));
36
+ var _propTypes = _interopRequireDefault(require("prop-types"));
37
+ var _hooks = require("../../hooks");
38
+ var _index = require("../../index");
39
+ var _statuses = _interopRequireDefault(require("../../utils/devUtils/constants/statuses"));
40
+ var _DateSegment = _interopRequireDefault(require("./DateSegment"));
41
+ var _react2 = require("@emotion/react");
42
+ var _excluded = ["buttonProps", "fieldProps", "groupProps", "groupRef", "hasFormatHelpText", "helperText", "isDisabled", "isOpen", "isReadOnly", "isRequired", "status", "datePickerState", "minValue", "maxValue", "unavailableRanges"],
43
+ _excluded2 = ["defaultValue"];
44
+ 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); }
45
+ 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; }
46
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
47
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context4, _context5; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty2(_context4 = ownKeys(Object(source), !0)).call(_context4, function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty2(_context5 = ownKeys(Object(source))).call(_context5, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
48
+ /**
49
+ * DateFields allow users to enter and edit date using a keyboard.
50
+ * Parts of the date is displayed in editable segments
51
+ */
52
+
53
+ var ARIA_LABELS_CALENDAR_BUTTON_EXPANSION = {
54
+ OPEN: 'Open the Calendar Popover',
55
+ CLOSE: 'Close the Calendar Popover'
56
+ };
57
+ var DateField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
58
+ var _labelRef$current, _context3;
59
+ var buttonProps = props.buttonProps,
60
+ fieldProps = props.fieldProps,
61
+ groupProps = props.groupProps,
62
+ groupRef = props.groupRef,
63
+ hasFormatHelpText = props.hasFormatHelpText,
64
+ helperText = props.helperText,
65
+ isDisabled = props.isDisabled,
66
+ isOpen = props.isOpen,
67
+ isReadOnly = props.isReadOnly,
68
+ isRequired = props.isRequired,
69
+ status = props.status,
70
+ datePickerState = props.datePickerState,
71
+ minValue = props.minValue,
72
+ maxValue = props.maxValue,
73
+ unavailableRanges = props.unavailableRanges,
74
+ other = (0, _objectWithoutProperties2["default"])(props, _excluded);
75
+ var _useState = (0, _react.useState)(''),
76
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
77
+ errorMessage = _useState2[0],
78
+ setErrorMessage = _useState2[1];
79
+ var fieldRef = (0, _react.useRef)();
80
+ var inputRef = (0, _react.useRef)();
81
+ var labelRef = (0, _react.useRef)();
82
+
83
+ // istanbul ignore next
84
+ (0, _react.useImperativeHandle)(ref, function () {
85
+ return inputRef.current;
86
+ });
87
+ var _useLocale = (0, _i18n.useLocale)(),
88
+ locale = _useLocale.locale;
89
+ var state = (0, _datepicker2.useDateFieldState)(_objectSpread(_objectSpread({}, fieldProps), {}, {
90
+ locale: locale,
91
+ createCalendar: _date.createCalendar
92
+ }));
93
+ var segments = state.segments;
94
+ var setValue = datePickerState.setValue;
95
+ var _useDateField = (0, _datepicker.useDateField)(_objectSpread({}, fieldProps), state, fieldRef),
96
+ dateFieldProps = _useDateField.fieldProps;
97
+
98
+ // removing a duplicate id, otherwise the groups element and field element each apply it
99
+ delete dateFieldProps.id;
100
+
101
+ // useDateFieldState does not return defaultValue so we separate it out to prevent control clashes
102
+ var defaultValue = props.defaultValue,
103
+ others = (0, _objectWithoutProperties2["default"])(props, _excluded2);
104
+ var _useField = (0, _hooks.useField)(_objectSpread(_objectSpread({}, others), {}, {
105
+ value: state.value || ''
106
+ })),
107
+ fieldContainerProps = _useField.fieldContainerProps,
108
+ fieldControlInputProps = _useField.fieldControlInputProps,
109
+ fieldControlWrapperProps = _useField.fieldControlWrapperProps,
110
+ fieldLabelProps = _useField.fieldLabelProps;
111
+ var toggleCalendarButtonAriaLabel = isOpen ? ARIA_LABELS_CALENDAR_BUTTON_EXPANSION.OPEN : ARIA_LABELS_CALENDAR_BUTTON_EXPANSION.CLOSE;
112
+ (0, _react.useEffect)(function () {
113
+ if (errorMessage) {
114
+ var timer = (0, _setTimeout2["default"])(function () {
115
+ setErrorMessage('');
116
+ }, 5000);
117
+ return function () {
118
+ clearTimeout(timer);
119
+ };
120
+ }
121
+ return undefined;
122
+ }, [errorMessage]);
123
+ var getKey = function getKey(segment, index) {
124
+ var _context;
125
+ return (0, _concat["default"])(_context = "".concat(segment, "-")).call(_context, index);
126
+ };
127
+
128
+ /**
129
+ * Reordering segments object for YYYY-MM-DD format
130
+ */
131
+ var enUSSegments = [];
132
+ if (locale === 'en-US') {
133
+ do {
134
+ (0, _forEach["default"])(segments).call(segments, function (item) {
135
+ if (item.type === 'year' && enUSSegments.length === 0) {
136
+ enUSSegments.push(item);
137
+ }
138
+ if (item.type === 'literal' && enUSSegments.length === 1) {
139
+ enUSSegments.push(item);
140
+ }
141
+ if (item.type === 'month' && enUSSegments.length === 2) {
142
+ enUSSegments.push(item);
143
+ }
144
+ if (item.type === 'literal' && enUSSegments.length === 3) {
145
+ enUSSegments.push(item);
146
+ }
147
+ if (item.type === 'day' && enUSSegments.length === 4) {
148
+ enUSSegments.push(item);
149
+ }
150
+ });
151
+ } while (enUSSegments.length < 5);
152
+ }
153
+
154
+ /**
155
+ * Creates an expected date format helper text and automatically changes based on locale.
156
+ */
157
+
158
+ var formatHelpText = (0, _react.useMemo)(function () {
159
+ var _context2;
160
+ return (0, _map["default"])(_context2 = locale === 'en-US' ? enUSSegments : segments).call(_context2, function (s) {
161
+ return s.text;
162
+ }).join(' ');
163
+ }, [hasFormatHelpText]);
164
+ var handlePaste = (0, _react.useCallback)(function (e) {
165
+ var copiedValue = e.clipboardData.getData('text');
166
+ var isNextAvailableDate;
167
+ var handleSetDateValue = function handleSetDateValue(isDate) {
168
+ setValue(isDate);
169
+ };
170
+ if (locale === 'en-US' && !isDisabled && !isReadOnly) {
171
+ try {
172
+ if (copiedValue.match(/^\d{4}-\d{2}-\d{2}$/) !== null) {
173
+ var DateProps = {
174
+ isMinValue: minValue && (0, _date.parseDate)(minValue),
175
+ isMaxValue: maxValue && (0, _date.parseDate)(maxValue),
176
+ isValidDate: (0, _date.parseDate)(copiedValue)
177
+ };
178
+
179
+ // pastes the min/max/isNextAvailable date if the pasted value is
180
+ // min date, beyond max date or is an unavailable date.
181
+
182
+ if (DateProps.isValidDate <= DateProps.isMinValue) {
183
+ return handleSetDateValue(DateProps.isMinValue);
184
+ }
185
+ if (DateProps.isValidDate >= DateProps.isMaxValue) {
186
+ return handleSetDateValue(DateProps.isMaxValue);
187
+ }
188
+ if (unavailableRanges) {
189
+ (0, _map["default"])(unavailableRanges).call(unavailableRanges, function (interval) {
190
+ if (DateProps.isValidDate >= (0, _date.parseDate)(interval[0]) && DateProps.isValidDate <= (0, _date.parseDate)(interval[1])) {
191
+ isNextAvailableDate = (0, _date.parseDate)(interval[1]).add({
192
+ days: 1
193
+ });
194
+ return isNextAvailableDate && setErrorMessage("Pasted value ".concat(copiedValue, " is an unavailable date"));
195
+ }
196
+ return null;
197
+ });
198
+ return handleSetDateValue(isNextAvailableDate || DateProps.isValidDate);
199
+ }
200
+ return handleSetDateValue(DateProps.isValidDate);
201
+ }
202
+ throw new Error();
203
+ } catch (err) {
204
+ setErrorMessage("Invalid Date. Paste in YYYY-MM-DD format. Pasted value ".concat(copiedValue));
205
+ }
206
+ }
207
+ return null;
208
+ }, [minValue, maxValue, unavailableRanges]);
209
+ return (0, _react2.jsx)(_index.Box, (0, _extends2["default"])({
210
+ variant: "forms.input.fieldContainer"
211
+ }, fieldContainerProps), (0, _react2.jsx)(_index.Label, (0, _extends2["default"])({}, fieldLabelProps, {
212
+ ref: labelRef
213
+ })), (0, _react2.jsx)(_index.Box, (0, _extends2["default"])({
214
+ isRow: true,
215
+ variant: "forms.datePicker.inSlotContainer"
216
+ }, groupProps, {
217
+ ref: groupRef
218
+ }), (0, _react2.jsx)(_index.Box, fieldControlWrapperProps, (0, _react2.jsx)(_visuallyHidden.VisuallyHidden, null, (0, _react2.jsx)(_index.Input, (0, _extends2["default"])({
219
+ ref: inputRef,
220
+ tabIndex: -1,
221
+ type: "date/text",
222
+ "data-testid": "date-field"
223
+ }, fieldControlInputProps, {
224
+ "aria-labelledby": labelRef === null || labelRef === void 0 ? void 0 : (_labelRef$current = labelRef.current) === null || _labelRef$current === void 0 ? void 0 : _labelRef$current.id
225
+ })))), (0, _react2.jsx)(_index.Box, (0, _extends2["default"])({
226
+ isRow: true,
227
+ variant: "forms.datePicker.inputField"
228
+ }, dateFieldProps, {
229
+ ref: fieldRef
230
+ }), (0, _react2.jsx)(_reactAria.FocusScope, null, (0, _map["default"])(_context3 = locale === 'en-US' ? enUSSegments : segments).call(_context3, function (segment, index) {
231
+ return (0, _react2.jsx)(_DateSegment["default"], (0, _extends2["default"])({
232
+ key: getKey(segment, index),
233
+ segment: segment,
234
+ state: state,
235
+ isDisabled: isDisabled,
236
+ isReadOnly: isReadOnly,
237
+ isRequired: isRequired,
238
+ handlePaste: handlePaste
239
+ }, other));
240
+ })), (0, _react2.jsx)(_index.IconButton, (0, _extends2["default"])({
241
+ variant: "datePicker.containedIcon",
242
+ isDisabled: isDisabled || isReadOnly
243
+ }, buttonProps, {
244
+ "aria-label": toggleCalendarButtonAriaLabel
245
+ }), (0, _react2.jsx)(_index.Icon, {
246
+ icon: _CalendarIcon["default"],
247
+ size: 20
248
+ })))), hasFormatHelpText && (0, _react2.jsx)(_index.FieldHelperText, null, formatHelpText), errorMessage && (0, _react2.jsx)(_index.Messages, {
249
+ onClose: function onClose() {
250
+ return setErrorMessage('');
251
+ }
252
+ }, (0, _react2.jsx)(_reactStately.Item, {
253
+ key: "message1",
254
+ status: "error"
255
+ }, errorMessage)));
256
+ });
257
+ DateField.propTypes = {
258
+ /** Prop to provide a custom default date (uncontrolled) */
259
+ defaultValue: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
260
+ /** Prop to provide a default date (controlled) */
261
+ value: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
262
+ /** Props object that is spread directly into the calendar button element. */
263
+ buttonProps: _propTypes["default"].shape({}),
264
+ /** Props object that is spread directly into the root (top-level) element. */
265
+ containerProps: _propTypes["default"].shape({}),
266
+ /** state management for a date picker component */
267
+ datePickerState: _propTypes["default"].shape({
268
+ setValue: _propTypes["default"].func
269
+ }),
270
+ /** @ignore Props object that is spread directly into the segmented date field. */
271
+ fieldProps: _propTypes["default"].shape({}),
272
+ /** @ignore Props passed to the box surrounding the input, button, and helper text. */
273
+ groupProps: _propTypes["default"].shape({}),
274
+ /** @ignore Ref which is passed to the role="group" element. */
275
+ groupRef: _propTypes["default"].shape({}),
276
+ /** Whether the input element is automatically focused when loaded onto the page. See [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#htmlattrdefautofocus). */
277
+ hasAutoFocus: _propTypes["default"].bool,
278
+ /** Text rendered below the input displaying the expected date format for the user's locale. */
279
+ hasFormatHelpText: _propTypes["default"].bool,
280
+ /** Text rendered below the input. */
281
+ helperText: _propTypes["default"].node,
282
+ /** Whether the field is disabled. */
283
+ isDisabled: _propTypes["default"].bool,
284
+ /** Whether the overlay is currently open. */
285
+ isOpen: _propTypes["default"].bool,
286
+ /** Whether the input can be selected, but not changed by the user. */
287
+ isReadOnly: _propTypes["default"].bool,
288
+ /** Whether the field is required. */
289
+ isRequired: _propTypes["default"].bool,
290
+ /** Whether the field is quiet. */
291
+ isQuiet: _propTypes["default"].bool,
292
+ /** Props object that is spread directly into the label element. */
293
+ labelProps: _propTypes["default"].shape({}),
294
+ /** The maximum allowed date that a user may select. */
295
+ maxValue: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
296
+ /** The minimum allowed date that a user may select. */
297
+ minValue: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
298
+ /** Handler that is called when the element's selection state changes. */
299
+ onChange: _propTypes["default"].func,
300
+ /** Determines the input status indicator and helper text styling. */
301
+ status: _propTypes["default"].oneOf((0, _values["default"])(_statuses["default"])),
302
+ /** The ranges of unavailable dates passed */
303
+ unavailableRanges: _propTypes["default"].arrayOf(_propTypes["default"].arrayOf(_propTypes["default"].string)),
304
+ /** Props object that is spread directly into the input wrapper element. */
305
+ wrapperProps: _propTypes["default"].shape({})
306
+ };
307
+ DateField.defaultProps = {
308
+ hasAutoFocus: false,
309
+ isDisabled: false,
310
+ isQuiet: false,
311
+ isReadOnly: false,
312
+ isRequired: false,
313
+ status: _statuses["default"].DEFAULT
314
+ };
315
+ var _default = DateField;
316
+ exports["default"] = _default;
@@ -0,0 +1,195 @@
1
+ "use strict";
2
+
3
+ var _typeof = require("@babel/runtime-corejs3/helpers/typeof");
4
+ var _Object$keys = require("@babel/runtime-corejs3/core-js-stable/object/keys");
5
+ var _Object$getOwnPropertySymbols = require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols");
6
+ var _filterInstanceProperty = require("@babel/runtime-corejs3/core-js-stable/instance/filter");
7
+ var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor");
8
+ var _forEachInstanceProperty = require("@babel/runtime-corejs3/core-js-stable/instance/for-each");
9
+ var _Object$getOwnPropertyDescriptors = require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors");
10
+ var _Object$defineProperties = require("@babel/runtime-corejs3/core-js-stable/object/define-properties");
11
+ var _Object$defineProperty = require("@babel/runtime-corejs3/core-js-stable/object/define-property");
12
+ var _WeakMap = require("@babel/runtime-corejs3/core-js-stable/weak-map");
13
+ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
14
+ _Object$defineProperty(exports, "__esModule", {
15
+ value: true
16
+ });
17
+ exports["default"] = void 0;
18
+ var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
19
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
20
+ var _some = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/some"));
21
+ var _values = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/values"));
22
+ var _react = _interopRequireWildcard(require("react"));
23
+ var _date = require("@internationalized/date");
24
+ var _datepicker = require("@react-aria/datepicker");
25
+ var _focus = require("@react-aria/focus");
26
+ var _overlays = require("@react-aria/overlays");
27
+ var _utils = require("@react-aria/utils");
28
+ var _datepicker2 = require("@react-stately/datepicker");
29
+ var _propTypes = _interopRequireDefault(require("prop-types"));
30
+ var _index = require("../../index");
31
+ var _statuses = _interopRequireDefault(require("../../utils/devUtils/constants/statuses"));
32
+ var _DateField = _interopRequireDefault(require("./DateField"));
33
+ var _react2 = require("@emotion/react");
34
+ 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); }
35
+ 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; }
36
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
37
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
38
+ /**
39
+ * Console Warning: The state update warning is a known issue coming from the react-aria library.
40
+ * The `is-selected` class is added to the button after the component unmounts.
41
+ */
42
+
43
+ /**
44
+ * Combines an DateField with a calendar to enter or select a date.
45
+ *
46
+ * Utilizes [useDatePicker](https://react-spectrum.adobe.com/react-aria/useDatePicker.html) from React
47
+ * Aria and [useDatePickerState](https://react-spectrum.adobe.com/react-stately/useDatePickerState.html)
48
+ * from React Stately.
49
+ *
50
+ * Props not specified are passed along to the underlying `DateField` component.
51
+ */
52
+
53
+ var DatePicker = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
54
+ var defaultValue = props.defaultValue,
55
+ hasAutoFocus = props.hasAutoFocus,
56
+ helperText = props.helperText,
57
+ isDefaultOpen = props.isDefaultOpen,
58
+ isReadOnly = props.isReadOnly,
59
+ maxValue = props.maxValue,
60
+ minValue = props.minValue,
61
+ status = props.status,
62
+ value = props.value,
63
+ unavailableRanges = props.unavailableRanges;
64
+ var groupRef = (0, _react.useRef)();
65
+ var popoverRef = (0, _react.useRef)();
66
+
67
+ /**
68
+ * This function is run against each date in the calendar
69
+ */
70
+ var isDateUnavailable = function isDateUnavailable(date) {
71
+ return (0, _some["default"])(unavailableRanges).call(unavailableRanges, function (interval) {
72
+ return date.compare((0, _date.parseDate)(interval[0])) >= 0 && date.compare((0, _date.parseDate)(interval[1])) <= 0;
73
+ });
74
+ };
75
+
76
+ /**
77
+ * To accept date value as an object or as a string in format YYYY-MM-DD
78
+ */
79
+ var parsedDates = {
80
+ value: value || value && (0, _date.parseDate)(value),
81
+ defaultValue: defaultValue && (0, _date.parseDate)(defaultValue),
82
+ maxValue: maxValue && (0, _date.parseDate)(maxValue),
83
+ minValue: minValue && (0, _date.parseDate)(minValue),
84
+ isDateUnavailable: unavailableRanges && isDateUnavailable
85
+ };
86
+ var state = (0, _datepicker2.useDatePickerState)(_objectSpread({
87
+ autoFocus: hasAutoFocus,
88
+ defaultOpen: isDefaultOpen
89
+ }, (0, _utils.mergeProps)(props, parsedDates)));
90
+ var _useDatePicker = (0, _datepicker.useDatePicker)(_objectSpread({
91
+ autoFocus: hasAutoFocus
92
+ }, (0, _utils.mergeProps)(props, parsedDates)), state, groupRef),
93
+ buttonProps = _useDatePicker.buttonProps,
94
+ calendarProps = _useDatePicker.calendarProps,
95
+ dialogProps = _useDatePicker.dialogProps,
96
+ fieldProps = _useDatePicker.fieldProps,
97
+ groupProps = _useDatePicker.groupProps,
98
+ labelProps = _useDatePicker.labelProps;
99
+ var _useOverlayPosition = (0, _overlays.useOverlayPosition)({
100
+ targetRef: groupRef,
101
+ overlayRef: popoverRef,
102
+ offset: 15,
103
+ crossOffset: 40,
104
+ isOpen: state.isOpen,
105
+ onClose: state.setOpen,
106
+ shouldUpdatePosition: true
107
+ }),
108
+ positionProps = _useOverlayPosition.overlayProps;
109
+ var calendar = !isReadOnly && (0, _react2.jsx)(_index.PopoverContainer, (0, _extends2["default"])({
110
+ hasNoArrow: true,
111
+ isDismissable: true,
112
+ isNonModal: true,
113
+ ref: popoverRef,
114
+ isOpen: state.isOpen,
115
+ onClose: state.setOpen
116
+ }, (0, _utils.mergeProps)(dialogProps, positionProps)), (0, _react2.jsx)(_focus.FocusScope, {
117
+ autoFocus: true,
118
+ contain: true,
119
+ restoreFocus: true
120
+ }, (0, _react2.jsx)(_index.Calendar, calendarProps)));
121
+ return (0, _react2.jsx)(_react["default"].Fragment, null, (0, _react2.jsx)(_DateField["default"], (0, _extends2["default"])({}, props, {
122
+ ref: ref,
123
+ buttonProps: buttonProps,
124
+ fieldProps: fieldProps,
125
+ groupProps: groupProps,
126
+ groupRef: groupRef,
127
+ helperText: helperText,
128
+ labelProps: labelProps,
129
+ isOpen: state.isOpen,
130
+ status: status,
131
+ datePickerState: state
132
+ })), calendar, helperText && (0, _react2.jsx)(_index.FieldHelperText, {
133
+ status: status
134
+ }, helperText));
135
+ });
136
+ DatePicker.propTypes = {
137
+ /** Prop to provide a custom default date (uncontrolled) */
138
+ defaultValue: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
139
+ /** Prop to provide a default date (controlled) */
140
+ value: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
141
+ /** Whether the element should receive focus on render. */
142
+ hasAutoFocus: _propTypes["default"].bool,
143
+ /** Text rendered below the input displaying the expected date format for the user's locale. */
144
+ hasFormatHelpText: _propTypes["default"].bool,
145
+ /** Text rendered below the input. */
146
+ helperText: _propTypes["default"].string,
147
+ /** The element's unique identifier. */
148
+ id: _propTypes["default"].string,
149
+ /**
150
+ * Callback that is called for each date of the calendar.
151
+ * If it returns true, then the date is unavailable.
152
+ *
153
+ * (date: DateValue) => boolean
154
+ */
155
+ isDateUnavailable: _propTypes["default"].func,
156
+ /** Sets the default open state of the overlay (uncontrolled). */
157
+ isDefaultOpen: _propTypes["default"].bool,
158
+ /** Whether the calendar is disabled. */
159
+ isDisabled: _propTypes["default"].bool,
160
+ /** Whether the overlay is currently open (controlled). */
161
+ isOpen: _propTypes["default"].bool,
162
+ /** Whether the calendar dates are only focusable. */
163
+ isReadOnly: _propTypes["default"].bool,
164
+ /** Whether user input is required on the input before form submission. */
165
+ isRequired: _propTypes["default"].bool,
166
+ /** The rendered label for the field. */
167
+ label: _propTypes["default"].node,
168
+ /** The maximum allowed date that a user may select. */
169
+ maxValue: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
170
+ /** The minimum allowed date that a user may select. */
171
+ minValue: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].object]),
172
+ /** Handler that is called when the element loses focus. */
173
+ onBlur: _propTypes["default"].func,
174
+ /** Handler that is called when the element's selection state changes. */
175
+ onChange: _propTypes["default"].func,
176
+ /** Handler that is called when the element receives focus. */
177
+ onFocus: _propTypes["default"].func,
178
+ /** Handler that is called when the element's focus status changes. */
179
+ onFocusChange: _propTypes["default"].func,
180
+ /** Handler that is called when a key is pressed. */
181
+ onKeyDown: _propTypes["default"].func,
182
+ /** Handler that is called when a key is released. */
183
+ onKeyUp: _propTypes["default"].func,
184
+ /** Determines the textarea status indicator and helper text styling. */
185
+ status: _propTypes["default"].oneOf((0, _values["default"])(_statuses["default"])),
186
+ /** The ranges of unavailable dates passed */
187
+ unavailableRanges: _propTypes["default"].arrayOf(_propTypes["default"].arrayOf(_propTypes["default"].string))
188
+ };
189
+ _DateField["default"].defaultProps = {
190
+ isDisabled: false,
191
+ isReadOnly: false,
192
+ isRequired: false
193
+ };
194
+ var _default = DatePicker;
195
+ exports["default"] = _default;