@pingux/astro 2.70.0-alpha.2 → 2.71.0-alpha.0
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/AccordionItem/AccordionItem.d.ts +1 -1
- package/lib/cjs/components/AccordionItem/AccordionItem.js +1 -1
- package/lib/cjs/components/Calendar/Calendar.js +4 -0
- package/lib/cjs/components/Calendar/Calendar.mdx +1 -1
- package/lib/cjs/components/Calendar/Calendar.test.js +1 -4
- package/lib/cjs/components/Calendar/CalendarCell.js +1 -1
- package/lib/cjs/components/DatePicker/DatePicker.test.js +62 -6
- package/lib/cjs/components/RangeCalendar/RangeCalendar.d.ts +7 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.js +100 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.mdx +39 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.stories.d.ts +103 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.stories.js +131 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.styles.d.ts +104 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.styles.js +118 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.test.d.ts +1 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendar.test.js +217 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendarCell.d.ts +4 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendarCell.js +96 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendarGrid.d.ts +4 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendarGrid.js +70 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendarHeader.d.ts +4 -0
- package/lib/cjs/components/RangeCalendar/RangeCalendarHeader.js +85 -0
- package/lib/cjs/components/RangeCalendar/index.d.ts +2 -0
- package/lib/cjs/components/RangeCalendar/index.js +33 -0
- package/lib/cjs/components/TimeField/TimeField.d.ts +7 -0
- package/lib/cjs/components/TimeField/TimeField.js +105 -0
- package/lib/cjs/components/TimeField/TimeField.mdx +35 -0
- package/lib/cjs/components/TimeField/TimeField.stories.d.ts +27 -0
- package/lib/cjs/components/TimeField/TimeField.stories.js +96 -0
- package/lib/cjs/components/TimeField/TimeField.styles.d.ts +865 -0
- package/lib/cjs/components/TimeField/TimeField.styles.js +47 -0
- package/lib/cjs/components/TimeField/TimeField.test.d.ts +1 -0
- package/lib/cjs/components/TimeField/TimeField.test.js +194 -0
- package/lib/cjs/components/TimeField/TimeSegment.d.ts +4 -0
- package/lib/cjs/components/TimeField/TimeSegment.js +64 -0
- package/lib/cjs/components/TimeField/index.d.ts +2 -0
- package/lib/cjs/components/TimeField/index.js +33 -0
- package/lib/cjs/index.d.ts +4 -0
- package/lib/cjs/index.js +64 -26
- package/lib/cjs/styles/forms/index.js +2 -0
- package/lib/cjs/styles/variants/variants.js +4 -0
- package/lib/cjs/types/calendar.d.ts +51 -16
- package/lib/cjs/types/index.d.ts +1 -0
- package/lib/cjs/types/index.js +13 -2
- package/lib/cjs/types/timefield.d.ts +69 -0
- package/lib/cjs/types/timefield.js +6 -0
- package/lib/components/AccordionItem/AccordionItem.js +0 -3
- package/lib/components/Calendar/Calendar.js +4 -0
- package/lib/components/Calendar/Calendar.mdx +1 -1
- package/lib/components/Calendar/Calendar.test.js +1 -4
- package/lib/components/Calendar/CalendarCell.js +1 -1
- package/lib/components/DatePicker/DatePicker.test.js +62 -6
- package/lib/components/RangeCalendar/RangeCalendar.js +86 -0
- package/lib/components/RangeCalendar/RangeCalendar.mdx +39 -0
- package/lib/components/RangeCalendar/RangeCalendar.stories.js +112 -0
- package/lib/components/RangeCalendar/RangeCalendar.styles.js +110 -0
- package/lib/components/RangeCalendar/RangeCalendar.test.js +208 -0
- package/lib/components/RangeCalendar/RangeCalendarCell.js +82 -0
- package/lib/components/RangeCalendar/RangeCalendarGrid.js +61 -0
- package/lib/components/RangeCalendar/RangeCalendarHeader.js +76 -0
- package/lib/components/RangeCalendar/index.js +2 -0
- package/lib/components/TimeField/TimeField.js +92 -0
- package/lib/components/TimeField/TimeField.mdx +35 -0
- package/lib/components/TimeField/TimeField.stories.js +75 -0
- package/lib/components/TimeField/TimeField.styles.js +39 -0
- package/lib/components/TimeField/TimeField.test.js +191 -0
- package/lib/components/TimeField/TimeSegment.js +50 -0
- package/lib/components/TimeField/index.js +2 -0
- package/lib/index.js +4 -0
- package/lib/styles/forms/index.js +2 -0
- package/lib/styles/variants/variants.js +4 -0
- package/lib/types/index.js +1 -0
- package/lib/types/timefield.js +1 -0
- package/package.json +4 -4
@@ -0,0 +1,50 @@
|
|
1
|
+
import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
|
2
|
+
import React, { useCallback, useRef } from 'react';
|
3
|
+
import { useFocusManager } from 'react-aria';
|
4
|
+
import { useDateSegment } from '@react-aria/datepicker';
|
5
|
+
import { Box } from '../../index';
|
6
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
7
|
+
var TimeSegment = function TimeSegment(props) {
|
8
|
+
var state = props.state,
|
9
|
+
segment = props.segment,
|
10
|
+
segments = props.segments,
|
11
|
+
segmentIndex = props.segmentIndex;
|
12
|
+
var text = segment.text,
|
13
|
+
isPlaceholder = segment.isPlaceholder;
|
14
|
+
var ref = useRef(null);
|
15
|
+
var _useDateSegment = useDateSegment(segment, state, ref),
|
16
|
+
segmentProps = _useDateSegment.segmentProps;
|
17
|
+
delete segmentProps.role;
|
18
|
+
var focusManager = useFocusManager();
|
19
|
+
var handleKeyEvents = useCallback(function (e) {
|
20
|
+
var getSegmentValue = function getSegmentValue(seg) {
|
21
|
+
if (!seg) return false;
|
22
|
+
var isNumber = /^\d+$/.test(seg.text);
|
23
|
+
return isNumber;
|
24
|
+
};
|
25
|
+
if (e.key === 'Backspace' && isPlaceholder) {
|
26
|
+
var nextSegmentIndex = segmentIndex + 1;
|
27
|
+
while (segments[nextSegmentIndex] && segments[nextSegmentIndex].type === 'literal') {
|
28
|
+
nextSegmentIndex += 1;
|
29
|
+
}
|
30
|
+
var nextSegment = segments[nextSegmentIndex];
|
31
|
+
var previousSegmentIndex = segmentIndex - 1;
|
32
|
+
while (segments[previousSegmentIndex] && segments[previousSegmentIndex].type === 'literal') {
|
33
|
+
previousSegmentIndex -= 1;
|
34
|
+
}
|
35
|
+
var previousSegment = segments[previousSegmentIndex];
|
36
|
+
if (getSegmentValue(nextSegment)) return focusManager.focusNext();
|
37
|
+
if (!getSegmentValue(nextSegment) && getSegmentValue(previousSegment)) {
|
38
|
+
return focusManager.focusPrevious();
|
39
|
+
}
|
40
|
+
}
|
41
|
+
return null;
|
42
|
+
}, [focusManager, isPlaceholder, segments, segmentIndex]);
|
43
|
+
return ___EmotionJSX(Box, _extends({}, segmentProps, {
|
44
|
+
ref: ref,
|
45
|
+
variant: "forms.timeField.segment",
|
46
|
+
onKeyUp: handleKeyEvents,
|
47
|
+
role: "spinbutton"
|
48
|
+
}), text);
|
49
|
+
};
|
50
|
+
export default TimeSegment;
|
package/lib/index.js
CHANGED
@@ -134,6 +134,8 @@ export { default as RadioField } from './components/RadioField';
|
|
134
134
|
export * from './components/RadioField';
|
135
135
|
export { default as RadioGroupField } from './components/RadioGroupField';
|
136
136
|
export * from './components/RadioGroupField';
|
137
|
+
export { default as RangeCalendar } from './components/RangeCalendar';
|
138
|
+
export * from './components/RangeCalendar';
|
137
139
|
export { default as RequirementsList } from './components/RequirementsList';
|
138
140
|
export * from './components/RequirementsList';
|
139
141
|
export { default as RockerButton } from './components/RockerButton';
|
@@ -178,6 +180,8 @@ export { default as TextAreaField } from './components/TextAreaField';
|
|
178
180
|
export * from './components/TextAreaField';
|
179
181
|
export { default as TextField } from './components/TextField';
|
180
182
|
export * from './components/TextField';
|
183
|
+
export { default as TimeField } from './components/TimeField';
|
184
|
+
export * from './components/TimeField';
|
181
185
|
export { default as TimeZonePicker } from './components/TimeZonePicker';
|
182
186
|
export { default as TooltipTrigger } from './components/TooltipTrigger';
|
183
187
|
export * from './components/TooltipTrigger';
|
@@ -22,6 +22,7 @@ import search from '../../components/SearchField/Search.styles';
|
|
22
22
|
import * as select from '../../components/SelectField/Select.styles';
|
23
23
|
import * as switchable from '../../components/Switch/Switch.styles'; // 'switch' is a reserved keyword
|
24
24
|
import textarea from '../../components/TextArea/TextArea.styles';
|
25
|
+
import timeField from '../../components/TimeField/TimeField.styles';
|
25
26
|
|
26
27
|
// See ThemeUI docs on variants and themes for intended structure
|
27
28
|
// Variants should be defined in the approprate file.
|
@@ -35,6 +36,7 @@ export default _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSp
|
|
35
36
|
radio: radio
|
36
37
|
}, select), {}, {
|
37
38
|
textarea: textarea,
|
39
|
+
timeField: timeField,
|
38
40
|
"switch": _objectSpread({}, switchable),
|
39
41
|
search: search
|
40
42
|
});
|
@@ -39,12 +39,14 @@ import overlayPanel from '../../components/OverlayPanel/OverlayPanel.styles';
|
|
39
39
|
import panelHeader from '../../components/PanelHeader/PanelHeader.styles';
|
40
40
|
import popoverMenu from '../../components/PopoverMenu/PopoverMenu.styles';
|
41
41
|
import progressBar from '../../components/ProgressBar/ProgressBar.styles';
|
42
|
+
import rangeCalendar from '../../components/RangeCalendar/RangeCalendar.styles';
|
42
43
|
import rockerButton from '../../components/RockerButton/RockerButton.styles';
|
43
44
|
import scrollBox from '../../components/ScrollBox/ScrollBox.styles';
|
44
45
|
import separator from '../../components/Separator/Separator.styles';
|
45
46
|
import stepper from '../../components/Stepper/Stepper.styles';
|
46
47
|
import table from '../../components/Table/Table.styles';
|
47
48
|
import * as tab from '../../components/Tabs/Tabs.style';
|
49
|
+
import timefield from '../../components/TimeField/TimeField.styles';
|
48
50
|
import timeZone from '../../components/TimeZonePicker/TimeZone.styles';
|
49
51
|
import tooltip from '../../components/TooltipTrigger/Tooltip.styles';
|
50
52
|
import treeView from '../../components/TreeView/TreeView.styles';
|
@@ -56,6 +58,7 @@ export default _objectSpread({
|
|
56
58
|
breadcrumb: breadcrumb,
|
57
59
|
buttonBar: buttonBar,
|
58
60
|
calendar: calendar,
|
61
|
+
rangeCalendar: rangeCalendar,
|
59
62
|
callout: callout,
|
60
63
|
codeView: codeView,
|
61
64
|
collapsiblePanel: collapsiblePanel,
|
@@ -84,6 +87,7 @@ export default _objectSpread({
|
|
84
87
|
separator: separator,
|
85
88
|
stepper: stepper,
|
86
89
|
table: table,
|
90
|
+
timefield: timefield,
|
87
91
|
timeZone: timeZone,
|
88
92
|
tooltip: tooltip,
|
89
93
|
treeView: treeView
|
package/lib/types/index.js
CHANGED
@@ -0,0 +1 @@
|
|
1
|
+
export {};
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@pingux/astro",
|
3
|
-
"version": "2.
|
3
|
+
"version": "2.71.0-alpha.0",
|
4
4
|
"description": "React component library for Ping Identity's design system",
|
5
5
|
"repository": {
|
6
6
|
"type": "git",
|
@@ -51,7 +51,7 @@
|
|
51
51
|
"@react-aria/checkbox": "^3.2.0",
|
52
52
|
"@react-aria/color": "~3.0.0-beta.15",
|
53
53
|
"@react-aria/combobox": "^3.0.0",
|
54
|
-
"@react-aria/datepicker": "^3.10.
|
54
|
+
"@react-aria/datepicker": "^3.10.1",
|
55
55
|
"@react-aria/dialog": "^3.1.2",
|
56
56
|
"@react-aria/dnd": "^3.5.0",
|
57
57
|
"@react-aria/focus": "~3.8.0",
|
@@ -76,7 +76,7 @@
|
|
76
76
|
"@react-spectrum/utils": "~3.6.1",
|
77
77
|
"@react-stately/calendar": "^3.5.0",
|
78
78
|
"@react-stately/color": "~3.1.1",
|
79
|
-
"@react-stately/datepicker": "^3.9.
|
79
|
+
"@react-stately/datepicker": "^3.9.4",
|
80
80
|
"@react-stately/dnd": "^3.2.6",
|
81
81
|
"@react-stately/grid": "~3.3.1",
|
82
82
|
"@react-stately/layout": "^3.13.4",
|
@@ -93,7 +93,7 @@
|
|
93
93
|
"@react-types/button": "^3.9.3",
|
94
94
|
"@react-types/calendar": "^3.4.5",
|
95
95
|
"@react-types/checkbox": "^3.8.0",
|
96
|
-
"@react-types/datepicker": "^3.7.
|
96
|
+
"@react-types/datepicker": "^3.7.4",
|
97
97
|
"@react-types/grid": "^3.2.4",
|
98
98
|
"@react-types/select": "^3.9.1",
|
99
99
|
"@react-types/shared": "^3.23.1",
|