@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.
- package/lib/cjs/components/Calendar/Calendar.js +202 -0
- package/lib/cjs/components/Calendar/Calendar.stories.js +192 -0
- package/lib/cjs/components/Calendar/Calendar.styles.js +74 -0
- package/lib/cjs/components/Calendar/Calendar.test.js +324 -0
- package/lib/cjs/components/Calendar/CalendarCell.js +125 -0
- package/lib/cjs/components/Calendar/CalendarGrid.js +77 -0
- package/lib/cjs/components/Calendar/index.js +14 -0
- package/lib/cjs/components/DatePicker/DateField.js +316 -0
- package/lib/cjs/components/DatePicker/DatePicker.js +195 -0
- package/lib/cjs/components/DatePicker/DatePicker.stories.js +205 -0
- package/lib/cjs/components/DatePicker/DatePicker.styles.js +60 -0
- package/lib/cjs/components/DatePicker/DatePicker.test.js +570 -0
- package/lib/cjs/components/DatePicker/DateSegment.js +71 -0
- package/lib/cjs/components/DatePicker/index.js +14 -0
- package/lib/cjs/components/IconButton/IconButton.styles.js +4 -0
- package/lib/cjs/components/TextField/TextField.js +6 -2
- package/lib/cjs/components/TextField/TextField.stories.js +13 -1
- package/lib/cjs/components/TooltipTrigger/Tooltip.js +4 -6
- package/lib/cjs/components/TooltipTrigger/Tooltip.styles.js +14 -18
- package/lib/cjs/hooks/useOverlayPanelState/useOverlayPanelState.test.js +2 -2
- package/lib/cjs/index.js +132 -59
- package/lib/cjs/styles/forms/index.js +2 -0
- package/lib/cjs/styles/variants/variants.js +4 -2
- package/lib/components/Calendar/Calendar.js +190 -0
- package/lib/components/Calendar/Calendar.stories.js +171 -0
- package/lib/components/Calendar/Calendar.styles.js +66 -0
- package/lib/components/Calendar/Calendar.test.js +321 -0
- package/lib/components/Calendar/CalendarCell.js +111 -0
- package/lib/components/Calendar/CalendarGrid.js +68 -0
- package/lib/components/Calendar/index.js +1 -0
- package/lib/components/DatePicker/DateField.js +303 -0
- package/lib/components/DatePicker/DatePicker.js +183 -0
- package/lib/components/DatePicker/DatePicker.stories.js +180 -0
- package/lib/components/DatePicker/DatePicker.styles.js +51 -0
- package/lib/components/DatePicker/DatePicker.test.js +563 -0
- package/lib/components/DatePicker/DateSegment.js +58 -0
- package/lib/components/DatePicker/index.js +1 -0
- package/lib/components/IconButton/IconButton.styles.js +4 -0
- package/lib/components/TextField/TextField.js +6 -2
- package/lib/components/TextField/TextField.stories.js +11 -0
- package/lib/components/TooltipTrigger/Tooltip.js +4 -6
- package/lib/components/TooltipTrigger/Tooltip.styles.js +14 -18
- package/lib/hooks/useOverlayPanelState/useOverlayPanelState.test.js +2 -2
- package/lib/index.js +8 -0
- package/lib/styles/forms/index.js +2 -0
- package/lib/styles/variants/variants.js +3 -1
- package/package.json +7 -1
- package/NOTICE.html +0 -12399
- /package/lib/cjs/{styles/variants/callout.js → components/Callout/Callout.styles.js} +0 -0
- /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;
|