@cloudscape-design/components 3.0.13 → 3.0.16
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/alert/styles.css.js +19 -19
- package/alert/styles.scoped.css +33 -35
- package/alert/styles.selectors.js +19 -19
- package/annotation-context/annotation/styles.css.js +24 -24
- package/annotation-context/annotation/styles.scoped.css +30 -31
- package/annotation-context/annotation/styles.selectors.js +24 -24
- package/app-layout/toggles/styles.css.js +3 -3
- package/app-layout/toggles/styles.scoped.css +12 -12
- package/app-layout/toggles/styles.selectors.js +3 -3
- package/app-layout/visual-refresh/styles.css.js +59 -59
- package/app-layout/visual-refresh/styles.scoped.css +152 -152
- package/app-layout/visual-refresh/styles.selectors.js +59 -59
- package/area-chart/styles.scoped.css +0 -1
- package/attribute-editor/styles.scoped.css +0 -1
- package/autosuggest/internal.d.ts.map +1 -1
- package/autosuggest/internal.js +19 -33
- package/autosuggest/internal.js.map +1 -1
- package/autosuggest/options-list.d.ts +19 -0
- package/autosuggest/options-list.d.ts.map +1 -0
- package/autosuggest/options-list.js +37 -0
- package/autosuggest/options-list.js.map +1 -0
- package/autosuggest/plain-list.d.ts +3 -5
- package/autosuggest/plain-list.d.ts.map +1 -1
- package/autosuggest/plain-list.js +7 -7
- package/autosuggest/plain-list.js.map +1 -1
- package/autosuggest/virtual-list.d.ts +2 -6
- package/autosuggest/virtual-list.d.ts.map +1 -1
- package/autosuggest/virtual-list.js +7 -7
- package/autosuggest/virtual-list.js.map +1 -1
- package/badge/styles.css.js +5 -5
- package/badge/styles.scoped.css +6 -7
- package/badge/styles.selectors.js +5 -5
- package/breadcrumb-group/item/styles.css.js +7 -7
- package/breadcrumb-group/item/styles.scoped.css +16 -16
- package/breadcrumb-group/item/styles.selectors.js +7 -7
- package/breadcrumb-group/styles.scoped.css +0 -2
- package/button/styles.css.js +18 -18
- package/button/styles.scoped.css +164 -165
- package/button/styles.selectors.js +18 -18
- package/button-dropdown/category-elements/styles.css.js +12 -12
- package/button-dropdown/category-elements/styles.scoped.css +23 -23
- package/button-dropdown/category-elements/styles.selectors.js +12 -12
- package/button-dropdown/item-element/styles.css.js +13 -13
- package/button-dropdown/item-element/styles.scoped.css +18 -18
- package/button-dropdown/item-element/styles.selectors.js +13 -13
- package/button-dropdown/mobile-expandable-group/styles.scoped.css +0 -2
- package/cards/styles.css.js +37 -37
- package/cards/styles.scoped.css +46 -47
- package/cards/styles.selectors.js +37 -37
- package/checkbox/styles.css.js +3 -3
- package/checkbox/styles.scoped.css +7 -8
- package/checkbox/styles.selectors.js +3 -3
- package/code-editor/styles.css.js +33 -33
- package/code-editor/styles.scoped.css +134 -135
- package/code-editor/styles.selectors.js +33 -33
- package/column-layout/styles.scoped.css +0 -1
- package/container/styles.css.js +15 -15
- package/container/styles.scoped.css +26 -27
- package/container/styles.selectors.js +15 -15
- package/date-picker/calendar/index.d.ts +1 -1
- package/date-picker/calendar/index.d.ts.map +1 -1
- package/date-picker/calendar/index.js +3 -1
- package/date-picker/calendar/index.js.map +1 -1
- package/date-picker/embedded.d.ts +3 -0
- package/date-picker/embedded.d.ts.map +1 -0
- package/date-picker/embedded.js +15 -0
- package/date-picker/embedded.js.map +1 -0
- package/date-picker/index.d.ts.map +1 -1
- package/date-picker/index.js +14 -39
- package/date-picker/index.js.map +1 -1
- package/date-picker/interfaces.d.ts +12 -10
- package/date-picker/interfaces.d.ts.map +1 -1
- package/date-picker/interfaces.js.map +1 -1
- package/date-picker/styles.css.js +24 -24
- package/date-picker/styles.scoped.css +46 -48
- package/date-picker/styles.selectors.js +24 -24
- package/date-picker/use-date-picker.d.ts +17 -0
- package/date-picker/use-date-picker.d.ts.map +1 -0
- package/date-picker/use-date-picker.js +48 -0
- package/date-picker/use-date-picker.js.map +1 -0
- package/date-range-picker/calendar/grids/day/styles.css.js +21 -21
- package/date-range-picker/calendar/grids/day/styles.scoped.css +50 -50
- package/date-range-picker/calendar/grids/day/styles.selectors.js +21 -21
- package/date-range-picker/calendar/header/button/index.d.ts +1 -2
- package/date-range-picker/calendar/header/button/index.d.ts.map +1 -1
- package/date-range-picker/calendar/header/button/index.js +2 -3
- package/date-range-picker/calendar/header/button/index.js.map +1 -1
- package/date-range-picker/calendar/header/index.d.ts +1 -2
- package/date-range-picker/calendar/header/index.d.ts.map +1 -1
- package/date-range-picker/calendar/header/index.js +3 -3
- package/date-range-picker/calendar/header/index.js.map +1 -1
- package/date-range-picker/calendar/index.js +1 -1
- package/date-range-picker/calendar/index.js.map +1 -1
- package/date-range-picker/styles.css.js +42 -42
- package/date-range-picker/styles.scoped.css +53 -56
- package/date-range-picker/styles.selectors.js +42 -42
- package/expandable-section/styles.css.js +20 -20
- package/expandable-section/styles.scoped.css +42 -43
- package/expandable-section/styles.selectors.js +20 -20
- package/flashbar/styles.css.js +22 -22
- package/flashbar/styles.scoped.css +87 -88
- package/flashbar/styles.selectors.js +22 -22
- package/form/styles.scoped.css +0 -1
- package/form-field/styles.scoped.css +0 -1
- package/grid/styles.scoped.css +0 -1
- package/header/styles.scoped.css +0 -1
- package/help-panel/styles.css.js +4 -4
- package/help-panel/styles.scoped.css +59 -60
- package/help-panel/styles.selectors.js +4 -4
- package/input/styles.css.js +13 -13
- package/input/styles.scoped.css +36 -37
- package/input/styles.selectors.js +13 -13
- package/internal/base-component/styles.scoped.css +12 -13
- package/internal/components/abstract-switch/styles.scoped.css +0 -1
- package/internal/components/button-trigger/styles.css.js +9 -9
- package/internal/components/button-trigger/styles.scoped.css +26 -27
- package/internal/components/button-trigger/styles.selectors.js +9 -9
- package/internal/components/chart-filter/styles.scoped.css +0 -1
- package/internal/components/chart-legend/styles.css.js +7 -7
- package/internal/components/chart-legend/styles.scoped.css +16 -17
- package/internal/components/chart-legend/styles.selectors.js +7 -7
- package/internal/components/chart-popover/styles.scoped.css +0 -1
- package/internal/components/chart-series-details/styles.scoped.css +0 -2
- package/internal/components/chart-series-marker/styles.scoped.css +0 -1
- package/internal/components/dropdown/styles.css.js +20 -20
- package/internal/components/dropdown/styles.scoped.css +38 -40
- package/internal/components/dropdown/styles.selectors.js +20 -20
- package/internal/components/dropdown-footer/styles.scoped.css +0 -1
- package/internal/components/dropdown-status/styles.scoped.css +0 -1
- package/internal/components/filtering-token/styles.css.js +7 -7
- package/internal/components/filtering-token/styles.scoped.css +15 -15
- package/internal/components/filtering-token/styles.selectors.js +7 -7
- package/internal/components/menu-dropdown/styles.css.js +7 -7
- package/internal/components/menu-dropdown/styles.scoped.css +14 -15
- package/internal/components/menu-dropdown/styles.selectors.js +7 -7
- package/internal/components/option/styles.scoped.css +0 -1
- package/internal/components/options-list/styles.css.js +2 -2
- package/internal/components/options-list/styles.scoped.css +3 -4
- package/internal/components/options-list/styles.selectors.js +2 -2
- package/internal/components/selectable-item/styles.css.js +16 -16
- package/internal/components/selectable-item/styles.scoped.css +28 -28
- package/internal/components/selectable-item/styles.selectors.js +16 -16
- package/internal/environment.js +1 -1
- package/internal/generated/theming/index.cjs +36 -39
- package/internal/generated/theming/index.js +36 -39
- package/link/styles.css.js +18 -18
- package/link/styles.scoped.css +70 -71
- package/link/styles.selectors.js +18 -18
- package/mixed-line-bar-chart/styles.scoped.css +0 -1
- package/modal/styles.css.js +22 -22
- package/modal/styles.scoped.css +42 -44
- package/modal/styles.selectors.js +22 -22
- package/multiselect/styles.scoped.css +0 -1
- package/package.json +1 -1
- package/pagination/styles.css.js +9 -9
- package/pagination/styles.scoped.css +24 -25
- package/pagination/styles.selectors.js +9 -9
- package/pie-chart/styles.scoped.css +0 -1
- package/popover/styles.css.js +48 -48
- package/popover/styles.scoped.css +64 -66
- package/popover/styles.selectors.js +48 -48
- package/progress-bar/styles.scoped.css +0 -1
- package/property-filter/styles.scoped.css +0 -1
- package/radio-group/styles.css.js +9 -9
- package/radio-group/styles.scoped.css +17 -18
- package/radio-group/styles.selectors.js +9 -9
- package/segmented-control/styles.css.js +14 -14
- package/segmented-control/styles.scoped.css +36 -43
- package/segmented-control/styles.selectors.js +14 -14
- package/select/styles.scoped.css +0 -1
- package/side-navigation/styles.css.js +22 -22
- package/side-navigation/styles.scoped.css +33 -34
- package/side-navigation/styles.selectors.js +22 -22
- package/split-panel/styles.css.js +58 -58
- package/split-panel/styles.scoped.css +81 -83
- package/split-panel/styles.selectors.js +58 -58
- package/table/body-cell/styles.css.js +7 -7
- package/table/body-cell/styles.scoped.css +20 -20
- package/table/body-cell/styles.selectors.js +7 -7
- package/table/header-cell/styles.css.js +14 -14
- package/table/header-cell/styles.scoped.css +26 -26
- package/table/header-cell/styles.selectors.js +14 -14
- package/table/resizer/styles.scoped.css +0 -1
- package/table/styles.css.js +32 -32
- package/table/styles.scoped.css +40 -40
- package/table/styles.selectors.js +32 -32
- package/tabs/styles.css.js +21 -21
- package/tabs/styles.scoped.css +39 -40
- package/tabs/styles.selectors.js +21 -21
- package/tag-editor/styles.css.js +3 -3
- package/tag-editor/styles.scoped.css +11 -11
- package/tag-editor/styles.selectors.js +3 -3
- package/text-content/styles.css.js +1 -1
- package/text-content/styles.scoped.css +61 -62
- package/text-content/styles.selectors.js +1 -1
- package/text-filter/styles.scoped.css +0 -1
- package/textarea/styles.css.js +4 -4
- package/textarea/styles.scoped.css +14 -26
- package/textarea/styles.selectors.js +4 -4
- package/tiles/styles.css.js +28 -28
- package/tiles/styles.scoped.css +69 -71
- package/tiles/styles.selectors.js +28 -28
- package/toggle/styles.css.js +8 -8
- package/toggle/styles.scoped.css +15 -16
- package/toggle/styles.selectors.js +8 -8
- package/token-group/styles.css.js +7 -7
- package/token-group/styles.scoped.css +25 -27
- package/token-group/styles.selectors.js +7 -7
- package/top-navigation/1.0-beta/styles.css.js +25 -25
- package/top-navigation/1.0-beta/styles.scoped.css +43 -44
- package/top-navigation/1.0-beta/styles.selectors.js +25 -25
- package/top-navigation/styles.css.js +47 -47
- package/top-navigation/styles.scoped.css +68 -71
- package/top-navigation/styles.selectors.js +47 -47
- package/tutorial-panel/components/tutorial-detail-view/styles.scoped.css +0 -1
- package/tutorial-panel/components/tutorial-list/styles.css.js +18 -18
- package/tutorial-panel/components/tutorial-list/styles.scoped.css +30 -33
- package/tutorial-panel/components/tutorial-list/styles.selectors.js +18 -18
- package/tutorial-panel/styles.scoped.css +0 -1
- package/wizard/styles.css.js +31 -31
- package/wizard/styles.scoped.css +60 -61
- package/wizard/styles.selectors.js +31 -31
- package/autosuggest/hooks/a11y.d.ts +0 -5
- package/autosuggest/hooks/a11y.d.ts.map +0 -1
- package/autosuggest/hooks/a11y.js +0 -24
- package/autosuggest/hooks/a11y.js.map +0 -1
package/date-picker/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/date-picker/index.tsx"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport clsx from 'clsx';\nimport React, { Ref, useCallback, useRef, useState } from 'react';\nimport { getWeekStartByLocale } from 'weekstart';\nimport styles from './styles.css.js';\nimport { DatePickerProps } from './interfaces';\nimport Calendar, { DayIndex } from './calendar';\nimport { normalizeLocale } from './calendar/utils/locales';\nimport { getDateLabel } from './calendar/utils/intl';\nimport { CalendarTypes } from './calendar/definitions';\nimport { displayToIso, formatDate, isoToDisplay, memoizedDate } from './calendar/utils/date';\nimport { InputProps } from '../input/interfaces';\nimport { KeyCode } from '../internal/keycode';\nimport { fireNonCancelableEvent } from '../internal/events';\nimport Dropdown from '../internal/components/dropdown';\nimport DateInput from '../internal/components/date-input';\nimport { getBaseProps } from '../internal/base-component';\nimport { applyDisplayName } from '../internal/utils/apply-display-name.js';\nimport checkControlled from '../internal/hooks/check-controlled';\nimport { useFocusTracker } from '../internal/hooks/use-focus-tracker.js';\nimport useForwardFocus from '../internal/hooks/forward-focus';\nimport { usePrevious } from '../internal/hooks/use-previous';\nimport { ButtonProps } from '../button/interfaces';\nimport { InternalButton } from '../button/internal';\nimport useBaseComponent from '../internal/hooks/use-base-component';\nimport { useUniqueId } from '../internal/hooks/use-unique-id';\nimport { useMergeRefs } from '../internal/hooks/use-merge-refs';\nimport FocusLock from '../internal/components/focus-lock';\n\nexport { DatePickerProps };\n\nconst DatePicker = React.forwardRef(\n (\n {\n locale = '',\n startOfWeek,\n isDateEnabled,\n nextMonthAriaLabel,\n previousMonthAriaLabel,\n todayAriaLabel,\n placeholder = '',\n value = '',\n readOnly = false,\n disabled = false,\n onBlur,\n autoFocus = false,\n onChange,\n onFocus,\n name,\n ariaLabel,\n ariaRequired,\n ariaLabelledby,\n ariaDescribedby,\n controlId,\n invalid,\n openCalendarAriaLabel,\n expandToViewport,\n ...rest\n }: DatePickerProps,\n ref: Ref<DatePickerProps.Ref>\n ) => {\n const { __internalRootRef } = useBaseComponent('DatePicker');\n\n const baseProps = getBaseProps(rest);\n const [isDropDownOpen, setIsDropDownOpen] = useState<boolean>(false);\n const normalizedLocale = normalizeLocale('DatePicker', locale ?? '');\n const normalizedStartOfWeek = (\n typeof startOfWeek === 'number' ? startOfWeek : getWeekStartByLocale(normalizedLocale)\n ) as DayIndex;\n\n const defaultSelectedDate = value.length >= 10 ? value : null;\n const [selectedDate, setSelectedDate] = useState<string | null>(defaultSelectedDate);\n\n const defaultDisplayedDate = value.length >= 10 ? value : formatDate(new Date());\n const [displayedDate, setDisplayedDate] = useState<string>(defaultDisplayedDate);\n\n const internalInputRef = useRef<HTMLInputElement>(null);\n const buttonRef = useRef<ButtonProps.Ref>(null);\n useForwardFocus(ref, internalInputRef);\n\n const rootRef = useRef<HTMLDivElement>(null);\n const dropdownId = useUniqueId('calender');\n const mergedRef = useMergeRefs(rootRef, __internalRootRef);\n\n useFocusTracker({ rootRef, onBlur, onFocus, viewportId: expandToViewport ? dropdownId : '' });\n\n const onChangeMonthHandler = (newMonth: Date) => {\n setDisplayedDate(formatDate(newMonth));\n };\n\n const onSelectDateHandler = ({ date }: CalendarTypes.DateDetail) => {\n const formattedDate = formatDate(date);\n buttonRef.current?.focus();\n setIsDropDownOpen(false);\n setSelectedDate(formattedDate);\n setDisplayedDate(formattedDate);\n fireNonCancelableEvent(onChange, { value: formattedDate });\n };\n\n const onDropdownCloseHandler = useCallback(() => {\n setDisplayedDate(defaultDisplayedDate);\n setIsDropDownOpen(false);\n }, [defaultDisplayedDate]);\n\n const onButtonClickHandler = () => {\n if (!isDropDownOpen) {\n setIsDropDownOpen(true);\n }\n };\n\n const onWrapperKeyDownHandler = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.keyCode === KeyCode.escape && isDropDownOpen) {\n buttonRef.current?.focus();\n setIsDropDownOpen(false);\n }\n };\n\n const onInputChangeHandler: InputProps['onChange'] = event => {\n const isoDateString = displayToIso(event.detail.value);\n fireNonCancelableEvent(onChange, { value: isoDateString });\n };\n\n const onInputBlurHandler: InputProps['onBlur'] = () => {\n if (!isDropDownOpen) {\n setDisplayedDate(defaultDisplayedDate);\n setIsDropDownOpen(false);\n }\n };\n\n const prevValue = usePrevious(value);\n if (prevValue !== value) {\n if (value === '' && selectedDate !== value) {\n setSelectedDate(value);\n }\n // update the displayedDate when inputValue changes in order to\n // display the correct month when the date picker gets open again.\n if (value.length >= 4 && displayedDate !== value) {\n setDisplayedDate(value);\n }\n // set the selected date only when a full date (yyyy-mm-dd) is entered\n if (value.length >= 10 && selectedDate !== value) {\n setSelectedDate(value);\n }\n }\n\n const DateInputElement = (\n <div className={styles['date-picker-trigger']}>\n <div className={styles['date-picker-input']}>\n <DateInput\n name={name}\n invalid={invalid}\n controlId={controlId}\n ariaLabelledby={ariaLabelledby}\n ariaDescribedby={ariaDescribedby}\n ariaLabel={ariaLabel}\n ariaRequired={ariaRequired}\n value={isoToDisplay(value)}\n autoComplete={false}\n disableBrowserAutocorrect={true}\n disableAutocompleteOnBlur={isDropDownOpen}\n disabled={disabled}\n readOnly={readOnly}\n onChange={onInputChangeHandler}\n onBlur={onInputBlurHandler}\n placeholder={placeholder}\n ref={internalInputRef}\n autoFocus={autoFocus}\n />\n </div>\n <div>\n <InternalButton\n iconName=\"calendar\"\n className={styles['open-calendar-button']}\n onClick={onButtonClickHandler}\n ref={buttonRef}\n ariaLabel={\n openCalendarAriaLabel &&\n openCalendarAriaLabel(\n value.length === 10 ? getDateLabel(normalizedLocale, memoizedDate('value', value)) : null\n )\n }\n disabled={disabled || readOnly}\n formAction=\"none\"\n />\n </div>\n </div>\n );\n\n baseProps.className = clsx(baseProps.className, styles.root, styles['date-picker-container']);\n\n if (readOnly || disabled) {\n return <div {...baseProps}>{DateInputElement}</div>;\n }\n\n checkControlled('DatePicker', 'value', value, 'onChange', onChange);\n\n const handleMouseDown = (event: React.MouseEvent) => {\n // prevent currently focused element from losing it\n event.preventDefault();\n };\n\n return (\n <div {...baseProps} ref={mergedRef} onKeyDown={onWrapperKeyDownHandler}>\n <Dropdown\n stretchWidth={true}\n stretchHeight={true}\n open={isDropDownOpen}\n onDropdownClose={onDropdownCloseHandler}\n onMouseDown={handleMouseDown}\n trigger={DateInputElement}\n expandToViewport={expandToViewport}\n scrollable={false}\n dropdownId={dropdownId}\n >\n {isDropDownOpen && (\n <FocusLock autoFocus={true}>\n <Calendar\n selectedDate={memoizedDate('value', selectedDate)}\n displayedDate={memoizedDate('displayed', displayedDate)}\n locale={normalizedLocale}\n startOfWeek={normalizedStartOfWeek}\n isDateEnabled={isDateEnabled ? isDateEnabled : () => true}\n nextMonthLabel={nextMonthAriaLabel}\n previousMonthLabel={previousMonthAriaLabel}\n todayAriaLabel={todayAriaLabel}\n onChangeMonth={onChangeMonthHandler}\n onSelectDate={onSelectDateHandler}\n />\n </FocusLock>\n )}\n </Dropdown>\n </div>\n );\n }\n);\n\napplyDisplayName(DatePicker, 'DatePicker');\nexport default DatePicker;\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/date-picker/index.tsx"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport clsx from 'clsx';\nimport React, { Ref, useCallback, useRef, useState } from 'react';\nimport styles from './styles.css.js';\nimport { DatePickerProps } from './interfaces';\nimport Calendar from './calendar';\nimport { normalizeLocale } from './calendar/utils/locales';\nimport { getDateLabel } from './calendar/utils/intl';\nimport { displayToIso, isoToDisplay, memoizedDate } from './calendar/utils/date';\nimport { InputProps } from '../input/interfaces';\nimport { KeyCode } from '../internal/keycode';\nimport { fireNonCancelableEvent } from '../internal/events';\nimport Dropdown from '../internal/components/dropdown';\nimport DateInput from '../internal/components/date-input';\nimport { getBaseProps } from '../internal/base-component';\nimport { applyDisplayName } from '../internal/utils/apply-display-name.js';\nimport checkControlled from '../internal/hooks/check-controlled';\nimport { useFocusTracker } from '../internal/hooks/use-focus-tracker.js';\nimport useForwardFocus from '../internal/hooks/forward-focus';\nimport { ButtonProps } from '../button/interfaces';\nimport { InternalButton } from '../button/internal';\nimport useBaseComponent from '../internal/hooks/use-base-component';\nimport { useUniqueId } from '../internal/hooks/use-unique-id';\nimport { useMergeRefs } from '../internal/hooks/use-merge-refs';\nimport FocusLock from '../internal/components/focus-lock';\nimport { useDatePicker } from './use-date-picker.js';\n\nexport { DatePickerProps };\n\nconst DatePicker = React.forwardRef(\n (\n {\n locale = '',\n startOfWeek,\n isDateEnabled,\n nextMonthAriaLabel,\n previousMonthAriaLabel,\n todayAriaLabel,\n placeholder = '',\n value = '',\n readOnly = false,\n disabled = false,\n onBlur,\n autoFocus = false,\n onChange,\n onFocus,\n name,\n ariaLabel,\n ariaRequired,\n ariaLabelledby,\n ariaDescribedby,\n controlId,\n invalid,\n openCalendarAriaLabel,\n expandToViewport,\n ...rest\n }: DatePickerProps,\n ref: Ref<DatePickerProps.Ref>\n ) => {\n const { __internalRootRef } = useBaseComponent('DatePicker');\n\n const {\n defaultDisplayedDate,\n displayedDate,\n setDisplayedDate,\n selectedDate,\n onChangeMonthHandler,\n onSelectDateHandler,\n } = useDatePicker({\n value,\n onChange,\n });\n\n const baseProps = getBaseProps(rest);\n const [isDropDownOpen, setIsDropDownOpen] = useState<boolean>(false);\n const normalizedLocale = normalizeLocale('DatePicker', locale ?? '');\n\n const internalInputRef = useRef<HTMLInputElement>(null);\n const buttonRef = useRef<ButtonProps.Ref>(null);\n useForwardFocus(ref, internalInputRef);\n\n const rootRef = useRef<HTMLDivElement>(null);\n const dropdownId = useUniqueId('calender');\n const mergedRef = useMergeRefs(rootRef, __internalRootRef);\n\n useFocusTracker({ rootRef, onBlur, onFocus, viewportId: expandToViewport ? dropdownId : '' });\n\n const onDropdownCloseHandler = useCallback(() => {\n setDisplayedDate(defaultDisplayedDate);\n setIsDropDownOpen(false);\n }, [defaultDisplayedDate, setDisplayedDate, setIsDropDownOpen]);\n\n const onButtonClickHandler = () => {\n if (!isDropDownOpen) {\n setIsDropDownOpen(true);\n }\n };\n\n const onWrapperKeyDownHandler = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.keyCode === KeyCode.escape && isDropDownOpen) {\n buttonRef.current?.focus();\n setIsDropDownOpen(false);\n }\n };\n\n const onInputChangeHandler: InputProps['onChange'] = event => {\n const isoDateString = displayToIso(event.detail.value);\n fireNonCancelableEvent(onChange, { value: isoDateString });\n };\n\n const onInputBlurHandler: InputProps['onBlur'] = () => {\n if (!isDropDownOpen) {\n setDisplayedDate(defaultDisplayedDate);\n setIsDropDownOpen(false);\n }\n };\n\n const DateInputElement = (\n <div className={styles['date-picker-trigger']}>\n <div className={styles['date-picker-input']}>\n <DateInput\n name={name}\n invalid={invalid}\n controlId={controlId}\n ariaLabelledby={ariaLabelledby}\n ariaDescribedby={ariaDescribedby}\n ariaLabel={ariaLabel}\n ariaRequired={ariaRequired}\n value={isoToDisplay(value)}\n autoComplete={false}\n disableBrowserAutocorrect={true}\n disableAutocompleteOnBlur={isDropDownOpen}\n disabled={disabled}\n readOnly={readOnly}\n onChange={onInputChangeHandler}\n onBlur={onInputBlurHandler}\n placeholder={placeholder}\n ref={internalInputRef}\n autoFocus={autoFocus}\n />\n </div>\n <div>\n <InternalButton\n iconName=\"calendar\"\n className={styles['open-calendar-button']}\n onClick={onButtonClickHandler}\n ref={buttonRef}\n ariaLabel={\n openCalendarAriaLabel &&\n openCalendarAriaLabel(\n value.length === 10 ? getDateLabel(normalizedLocale, memoizedDate('value', value)) : null\n )\n }\n disabled={disabled || readOnly}\n formAction=\"none\"\n />\n </div>\n </div>\n );\n\n baseProps.className = clsx(baseProps.className, styles.root, styles['date-picker-container']);\n\n if (readOnly || disabled) {\n return <div {...baseProps}>{DateInputElement}</div>;\n }\n\n checkControlled('DatePicker', 'value', value, 'onChange', onChange);\n\n const handleMouseDown = (event: React.MouseEvent) => {\n // prevent currently focused element from losing it\n event.preventDefault();\n };\n\n return (\n <div {...baseProps} ref={mergedRef} onKeyDown={onWrapperKeyDownHandler}>\n <Dropdown\n stretchWidth={true}\n stretchHeight={true}\n open={isDropDownOpen}\n onDropdownClose={onDropdownCloseHandler}\n onMouseDown={handleMouseDown}\n trigger={DateInputElement}\n expandToViewport={expandToViewport}\n scrollable={false}\n dropdownId={dropdownId}\n >\n {isDropDownOpen && (\n <FocusLock autoFocus={true}>\n <Calendar\n selectedDate={memoizedDate('value', selectedDate)}\n displayedDate={memoizedDate('displayed', displayedDate)}\n locale={normalizedLocale}\n startOfWeek={startOfWeek}\n isDateEnabled={isDateEnabled ? isDateEnabled : () => true}\n nextMonthLabel={nextMonthAriaLabel}\n previousMonthLabel={previousMonthAriaLabel}\n todayAriaLabel={todayAriaLabel}\n onChangeMonth={onChangeMonthHandler}\n onSelectDate={e => {\n onSelectDateHandler(e);\n buttonRef?.current?.focus();\n setIsDropDownOpen(false);\n }}\n />\n </FocusLock>\n )}\n </Dropdown>\n </div>\n );\n }\n);\n\napplyDisplayName(DatePicker, 'DatePicker');\nexport default DatePicker;\n"]}
|
|
@@ -2,15 +2,11 @@ import { BaseComponentProps } from '../internal/base-component';
|
|
|
2
2
|
import { FormFieldValidationControlProps } from '../internal/context/form-field-context';
|
|
3
3
|
import { ExpandToViewport } from '../internal/components/dropdown/interfaces';
|
|
4
4
|
import { NonCancelableEventHandler } from '../internal/events';
|
|
5
|
-
export interface
|
|
5
|
+
export interface DatePickerBaseProps {
|
|
6
6
|
/**
|
|
7
7
|
* The current input value, in YYYY-MM-DD format.
|
|
8
8
|
*/
|
|
9
9
|
value: string;
|
|
10
|
-
/**
|
|
11
|
-
* Specifies the placeholder text rendered when the value is an empty string.
|
|
12
|
-
*/
|
|
13
|
-
placeholder?: string;
|
|
14
10
|
/**
|
|
15
11
|
* Defines whether a particular date is enabled in the calendar or not.
|
|
16
12
|
* If you disable a date in the calendar, users can still enter this date using a keyboard.
|
|
@@ -43,6 +39,17 @@ export interface DatePickerProps extends BaseComponentProps, FormFieldValidation
|
|
|
43
39
|
* Specifies an `aria-label` for the 'previous month' button.
|
|
44
40
|
*/
|
|
45
41
|
previousMonthAriaLabel: string;
|
|
42
|
+
/**
|
|
43
|
+
* Called whenever a user changes the input value (by typing, pasting, or selecting a value).
|
|
44
|
+
* The event `detail` contains the current value of the field.
|
|
45
|
+
*/
|
|
46
|
+
onChange?: NonCancelableEventHandler<DatePickerProps.ChangeDetail>;
|
|
47
|
+
}
|
|
48
|
+
export interface DatePickerProps extends BaseComponentProps, FormFieldValidationControlProps, ExpandToViewport, DatePickerBaseProps {
|
|
49
|
+
/**
|
|
50
|
+
* Specifies the placeholder text rendered when the value is an empty string.
|
|
51
|
+
*/
|
|
52
|
+
placeholder?: string;
|
|
46
53
|
/**
|
|
47
54
|
* Specifies a function that generates the `aria-label` for the 'open calendar' button. The `selectedDate` parameter is
|
|
48
55
|
* a human-readable localised string representing the current value of the input.
|
|
@@ -94,11 +101,6 @@ export interface DatePickerProps extends BaseComponentProps, FormFieldValidation
|
|
|
94
101
|
* Called when input focus is removed from the UI control.
|
|
95
102
|
*/
|
|
96
103
|
onBlur?: NonCancelableEventHandler<null>;
|
|
97
|
-
/**
|
|
98
|
-
* Called whenever a user changes the input value (by typing, pasting, or selecting a value).
|
|
99
|
-
* The event `detail` contains the current value of the field.
|
|
100
|
-
*/
|
|
101
|
-
onChange?: NonCancelableEventHandler<DatePickerProps.ChangeDetail>;
|
|
102
104
|
}
|
|
103
105
|
export declare namespace DatePickerProps {
|
|
104
106
|
interface ChangeDetail {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../src/date-picker/interfaces.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,+BAA+B,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAE,gBAAgB,EAAE,MAAM,4CAA4C,CAAC;AAC9E,OAAO,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAC;AAE/D,MAAM,WAAW,
|
|
1
|
+
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../src/date-picker/interfaces.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,+BAA+B,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAE,gBAAgB,EAAE,MAAM,4CAA4C,CAAC;AAC9E,OAAO,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAC;AAE/D,MAAM,WAAW,mBAAmB;IAClC;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC;IAEd;;;;;;OAMG;IACH,aAAa,CAAC,EAAE,eAAe,CAAC,qBAAqB,CAAC;IAEtD;;;;;OAKG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB;;OAEG;IACH,cAAc,EAAE,MAAM,CAAC;IAEvB;;OAEG;IACH,kBAAkB,EAAE,MAAM,CAAC;IAE3B;;OAEG;IACH,sBAAsB,EAAE,MAAM,CAAC;IAE/B;;;OAGG;IACH,QAAQ,CAAC,EAAE,yBAAyB,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;CACpE;AAED,MAAM,WAAW,eACf,SAAQ,kBAAkB,EACxB,+BAA+B,EAC/B,gBAAgB,EAChB,mBAAmB;IACrB;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB;;;;OAIG;IACH,qBAAqB,CAAC,EAAE,eAAe,CAAC,qBAAqB,CAAC;IAE9D;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;IAEd;;;;;OAKG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;;;;;OAMG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;;;;;OAMG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB;;;;OAIG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,YAAY,CAAC,EAAE,OAAO,CAAC;IAEvB;;OAEG;IACH,OAAO,CAAC,EAAE,yBAAyB,CAAC,IAAI,CAAC,CAAC;IAE1C;;OAEG;IACH,MAAM,CAAC,EAAE,yBAAyB,CAAC,IAAI,CAAC,CAAC;CAC1C;AAED,yBAAiB,eAAe,CAAC;IAC/B,UAAiB,YAAY;QAC3B;;WAEG;QACH,KAAK,EAAE,MAAM,CAAC;KACf;IAED,UAAiB,qBAAqB;QACpC,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC;KACvB;IAED,UAAiB,qBAAqB;QACpC,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,CAAC;KACvC;IAED,UAAiB,GAAG;QAClB;;WAEG;QACH,KAAK,IAAI,IAAI,CAAC;KACf;CACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/date-picker/interfaces.ts"],"names":[],"mappings":"","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { BaseComponentProps } from '../internal/base-component';\nimport { FormFieldValidationControlProps } from '../internal/context/form-field-context';\nimport { ExpandToViewport } from '../internal/components/dropdown/interfaces';\nimport { NonCancelableEventHandler } from '../internal/events';\n\nexport interface
|
|
1
|
+
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/date-picker/interfaces.ts"],"names":[],"mappings":"","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { BaseComponentProps } from '../internal/base-component';\nimport { FormFieldValidationControlProps } from '../internal/context/form-field-context';\nimport { ExpandToViewport } from '../internal/components/dropdown/interfaces';\nimport { NonCancelableEventHandler } from '../internal/events';\n\nexport interface DatePickerBaseProps {\n /**\n * The current input value, in YYYY-MM-DD format.\n */\n value: string;\n\n /**\n * Defines whether a particular date is enabled in the calendar or not.\n * If you disable a date in the calendar, users can still enter this date using a keyboard.\n * We recommend that you also validate these constraints on the client-side and server-side\n * as you would for other form elements.\n * @param date\n */\n isDateEnabled?: DatePickerProps.IsDateEnabledFunction;\n\n /**\n * Specifies the locale to use to render month names and determine the starting day of the week.\n * If you don't provide this, the locale is determined by the page and browser locales.\n * Supported values and formats are listed in the\n * [JavaScript Intl API specification](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl#Locale_identification_and_negotiation).\n */\n locale?: string;\n\n /**\n * Determines the starting day of the week. The values 0-6 map to Sunday-Saturday.\n * By default the starting day of the week is defined by the locale, but you can use this property to override it.\n */\n startOfWeek?: number;\n\n /**\n * Used as part of the `aria-label` for today's date in the calendar.\n */\n todayAriaLabel: string;\n\n /**\n * Specifies an `aria-label` for the 'next month' button.\n */\n nextMonthAriaLabel: string;\n\n /**\n * Specifies an `aria-label` for the 'previous month' button.\n */\n previousMonthAriaLabel: string;\n\n /**\n * Called whenever a user changes the input value (by typing, pasting, or selecting a value).\n * The event `detail` contains the current value of the field.\n */\n onChange?: NonCancelableEventHandler<DatePickerProps.ChangeDetail>;\n}\n\nexport interface DatePickerProps\n extends BaseComponentProps,\n FormFieldValidationControlProps,\n ExpandToViewport,\n DatePickerBaseProps {\n /**\n * Specifies the placeholder text rendered when the value is an empty string.\n */\n placeholder?: string;\n\n /**\n * Specifies a function that generates the `aria-label` for the 'open calendar' button. The `selectedDate` parameter is\n * a human-readable localised string representing the current value of the input.\n * (for example, ``selectedDate => 'Choose Date' + (selectedDate ? `, selected date is ${selectedDate}` : '')``)\n */\n openCalendarAriaLabel?: DatePickerProps.OpenCalendarAriaLabel;\n\n /**\n * Specifies the name of the control used in HTML forms.\n */\n name?: string;\n\n /**\n * Specifies if the control is disabled, which prevents the\n * user from modifying the value and prevents the value from\n * being included in a form submission. A disabled control can't\n * receive focus.\n */\n disabled?: boolean;\n\n /**\n * Specifies if the control is read only, which prevents the\n * user from modifying the value but includes it in a form\n * submission. A read-only control can receive focus.\n *\n * Do not use read-only inputs outside of a form.\n */\n readOnly?: boolean;\n\n /**\n * Indicates whether the control should be focused as\n * soon as the page loads, which enables the user to\n * start typing without having to manually focus the control. Don't\n * use this option on pages where the control may be\n * scrolled out of the viewport.\n */\n autoFocus?: boolean;\n\n /**\n * Adds an `aria-label` to the native control.\n *\n * Use this if you don't have a visible label for this control.\n */\n ariaLabel?: string;\n\n /**\n * Specifies whether to add `aria-required` to the native control.\n */\n ariaRequired?: boolean;\n\n /**\n * Called when input focus is moved to the UI control.\n */\n onFocus?: NonCancelableEventHandler<null>;\n\n /**\n * Called when input focus is removed from the UI control.\n */\n onBlur?: NonCancelableEventHandler<null>;\n}\n\nexport namespace DatePickerProps {\n export interface ChangeDetail {\n /**\n * The new value of this date-picker.\n */\n value: string;\n }\n\n export interface IsDateEnabledFunction {\n (date: Date): boolean;\n }\n\n export interface OpenCalendarAriaLabel {\n (selectedDate: string | null): string;\n }\n\n export interface Ref {\n /**\n * Sets the browser focus on the UI control\n */\n focus(): void;\n }\n}\n"]}
|
|
@@ -1,29 +1,29 @@
|
|
|
1
1
|
|
|
2
2
|
import './styles.scoped.css';
|
|
3
3
|
export default {
|
|
4
|
-
"calendar": "
|
|
5
|
-
"awsui-motion-fade-in-0": "awsui_awsui-motion-fade-in-
|
|
6
|
-
"root": "
|
|
7
|
-
"date-picker-container": "awsui_date-picker-
|
|
8
|
-
"date-picker-trigger": "awsui_date-picker-
|
|
9
|
-
"date-picker-input": "awsui_date-picker-
|
|
10
|
-
"open-calendar-button": "awsui_open-calendar-
|
|
11
|
-
"calendar-inner": "awsui_calendar-
|
|
12
|
-
"calendar-header": "awsui_calendar-
|
|
13
|
-
"calendar-header-month": "awsui_calendar-header-
|
|
14
|
-
"calendar-next-month-btn": "awsui_calendar-next-month-
|
|
15
|
-
"calendar-prev-month-btn": "awsui_calendar-prev-month-
|
|
16
|
-
"calendar-day-names": "awsui_calendar-day-
|
|
17
|
-
"calendar-day-name": "awsui_calendar-day-
|
|
18
|
-
"calendar-dates": "awsui_calendar-
|
|
19
|
-
"calendar-week": "awsui_calendar-
|
|
20
|
-
"calendar-day": "awsui_calendar-
|
|
21
|
-
"calendar-day-in-last-week": "awsui_calendar-day-in-last-
|
|
22
|
-
"calendar-day-focusable": "awsui_calendar-day-
|
|
23
|
-
"calendar-day-enabled": "awsui_calendar-day-
|
|
24
|
-
"calendar-day-current-month": "awsui_calendar-day-current-
|
|
25
|
-
"calendar-day-selected": "awsui_calendar-day-
|
|
26
|
-
"calendar-day-today": "awsui_calendar-day-
|
|
27
|
-
"day-inner": "awsui_day-
|
|
4
|
+
"calendar": "awsui_calendar_145pa_2hhg5_93",
|
|
5
|
+
"awsui-motion-fade-in-0": "awsui_awsui-motion-fade-in-0_145pa_2hhg5_1",
|
|
6
|
+
"root": "awsui_root_145pa_2hhg5_120",
|
|
7
|
+
"date-picker-container": "awsui_date-picker-container_145pa_2hhg5_131",
|
|
8
|
+
"date-picker-trigger": "awsui_date-picker-trigger_145pa_2hhg5_136",
|
|
9
|
+
"date-picker-input": "awsui_date-picker-input_145pa_2hhg5_140",
|
|
10
|
+
"open-calendar-button": "awsui_open-calendar-button_145pa_2hhg5_145",
|
|
11
|
+
"calendar-inner": "awsui_calendar-inner_145pa_2hhg5_165",
|
|
12
|
+
"calendar-header": "awsui_calendar-header_145pa_2hhg5_168",
|
|
13
|
+
"calendar-header-month": "awsui_calendar-header-month_145pa_2hhg5_173",
|
|
14
|
+
"calendar-next-month-btn": "awsui_calendar-next-month-btn_145pa_2hhg5_179",
|
|
15
|
+
"calendar-prev-month-btn": "awsui_calendar-prev-month-btn_145pa_2hhg5_182",
|
|
16
|
+
"calendar-day-names": "awsui_calendar-day-names_145pa_2hhg5_185",
|
|
17
|
+
"calendar-day-name": "awsui_calendar-day-name_145pa_2hhg5_185",
|
|
18
|
+
"calendar-dates": "awsui_calendar-dates_145pa_2hhg5_200",
|
|
19
|
+
"calendar-week": "awsui_calendar-week_145pa_2hhg5_203",
|
|
20
|
+
"calendar-day": "awsui_calendar-day_145pa_2hhg5_185",
|
|
21
|
+
"calendar-day-in-last-week": "awsui_calendar-day-in-last-week_145pa_2hhg5_222",
|
|
22
|
+
"calendar-day-focusable": "awsui_calendar-day-focusable_145pa_2hhg5_225",
|
|
23
|
+
"calendar-day-enabled": "awsui_calendar-day-enabled_145pa_2hhg5_228",
|
|
24
|
+
"calendar-day-current-month": "awsui_calendar-day-current-month_145pa_2hhg5_232",
|
|
25
|
+
"calendar-day-selected": "awsui_calendar-day-selected_145pa_2hhg5_239",
|
|
26
|
+
"calendar-day-today": "awsui_calendar-day-today_145pa_2hhg5_243",
|
|
27
|
+
"day-inner": "awsui_day-inner_145pa_2hhg5_255"
|
|
28
28
|
};
|
|
29
29
|
|
|
@@ -90,12 +90,12 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
90
90
|
Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
91
91
|
SPDX-License-Identifier: Apache-2.0
|
|
92
92
|
*/
|
|
93
|
-
.
|
|
94
|
-
animation: awsui_awsui-motion-fade-in-
|
|
95
|
-
animation: awsui_awsui-motion-fade-in-
|
|
93
|
+
.awsui_calendar_145pa_2hhg5_93:not(#\9) {
|
|
94
|
+
animation: awsui_awsui-motion-fade-in-0_145pa_2hhg5_1 135ms ease-out;
|
|
95
|
+
animation: awsui_awsui-motion-fade-in-0_145pa_2hhg5_1 var(--motion-duration-show-quick-tyaalm, 135ms) var(--motion-easing-show-quick-1fcgbv, ease-out);
|
|
96
96
|
animation-fill-mode: both;
|
|
97
97
|
}
|
|
98
|
-
@keyframes awsui_awsui-motion-fade-in-
|
|
98
|
+
@keyframes awsui_awsui-motion-fade-in-0_145pa_2hhg5_1 {
|
|
99
99
|
from {
|
|
100
100
|
opacity: 0;
|
|
101
101
|
}
|
|
@@ -104,12 +104,12 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
104
104
|
}
|
|
105
105
|
}
|
|
106
106
|
@media (prefers-reduced-motion: reduce) {
|
|
107
|
-
.
|
|
107
|
+
.awsui_calendar_145pa_2hhg5_93:not(#\9) {
|
|
108
108
|
animation: none;
|
|
109
109
|
transition: none;
|
|
110
110
|
}
|
|
111
111
|
}
|
|
112
|
-
.awsui-motion-disabled .
|
|
112
|
+
.awsui-motion-disabled .awsui_calendar_145pa_2hhg5_93:not(#\9), .awsui-mode-entering .awsui_calendar_145pa_2hhg5_93:not(#\9) {
|
|
113
113
|
animation: none;
|
|
114
114
|
transition: none;
|
|
115
115
|
}
|
|
@@ -118,7 +118,7 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
118
118
|
Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
119
119
|
SPDX-License-Identifier: Apache-2.0
|
|
120
120
|
*/
|
|
121
|
-
.
|
|
121
|
+
.awsui_root_145pa_2hhg5_120:not(#\9) {
|
|
122
122
|
/* stylelint-disable-next-line plugin/no-unsupported-browser-features */
|
|
123
123
|
border-collapse: separate;
|
|
124
124
|
border-spacing: 0;
|
|
@@ -134,7 +134,6 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
134
134
|
font-stretch: normal;
|
|
135
135
|
line-height: normal;
|
|
136
136
|
-webkit-hyphens: none;
|
|
137
|
-
-ms-hyphens: none;
|
|
138
137
|
hyphens: none;
|
|
139
138
|
letter-spacing: normal;
|
|
140
139
|
list-style: disc outside none;
|
|
@@ -160,26 +159,26 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
160
159
|
font-family: var(--font-family-base-qnistn, "Open Sans", "Helvetica Neue", Roboto, Arial, sans-serif);
|
|
161
160
|
}
|
|
162
161
|
|
|
163
|
-
.awsui_date-picker-
|
|
162
|
+
.awsui_date-picker-container_145pa_2hhg5_131:not(#\9) {
|
|
164
163
|
position: relative;
|
|
165
164
|
max-width: 234px;
|
|
166
165
|
}
|
|
167
166
|
|
|
168
|
-
.awsui_date-picker-
|
|
167
|
+
.awsui_date-picker-trigger_145pa_2hhg5_136:not(#\9) {
|
|
169
168
|
display: flex;
|
|
170
169
|
}
|
|
171
170
|
|
|
172
|
-
.awsui_date-picker-
|
|
171
|
+
.awsui_date-picker-input_145pa_2hhg5_140:not(#\9) {
|
|
173
172
|
padding-right: 8px;
|
|
174
173
|
padding-right: var(--space-xs-rsr2qu, 8px);
|
|
175
174
|
width: 100%;
|
|
176
175
|
}
|
|
177
176
|
|
|
178
|
-
.awsui_open-calendar-
|
|
177
|
+
.awsui_open-calendar-button_145pa_2hhg5_145:not(#\9) {
|
|
179
178
|
/* used in test-utils */
|
|
180
179
|
}
|
|
181
180
|
|
|
182
|
-
.
|
|
181
|
+
.awsui_calendar_145pa_2hhg5_93:not(#\9) {
|
|
183
182
|
display: block;
|
|
184
183
|
width: 234px;
|
|
185
184
|
overflow: auto;
|
|
@@ -198,7 +197,6 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
198
197
|
font-stretch: normal;
|
|
199
198
|
line-height: normal;
|
|
200
199
|
-webkit-hyphens: none;
|
|
201
|
-
-ms-hyphens: none;
|
|
202
200
|
hyphens: none;
|
|
203
201
|
letter-spacing: normal;
|
|
204
202
|
list-style: disc outside none;
|
|
@@ -223,19 +221,19 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
223
221
|
font-family: "Open Sans", "Helvetica Neue", Roboto, Arial, sans-serif;
|
|
224
222
|
font-family: var(--font-family-base-qnistn, "Open Sans", "Helvetica Neue", Roboto, Arial, sans-serif);
|
|
225
223
|
}
|
|
226
|
-
.
|
|
224
|
+
.awsui_calendar_145pa_2hhg5_93:not(#\9):focus {
|
|
227
225
|
outline: none;
|
|
228
226
|
}
|
|
229
|
-
.awsui_calendar-
|
|
227
|
+
.awsui_calendar-inner_145pa_2hhg5_165:not(#\9) {
|
|
230
228
|
margin: 8px;
|
|
231
229
|
margin: var(--space-xs-rsr2qu, 8px);
|
|
232
230
|
}
|
|
233
|
-
.awsui_calendar-
|
|
231
|
+
.awsui_calendar-header_145pa_2hhg5_168:not(#\9) {
|
|
234
232
|
display: flex;
|
|
235
233
|
justify-content: space-between;
|
|
236
234
|
align-items: center;
|
|
237
235
|
}
|
|
238
|
-
.awsui_calendar-header-
|
|
236
|
+
.awsui_calendar-header-month_145pa_2hhg5_173:not(#\9) {
|
|
239
237
|
font-size: 14px;
|
|
240
238
|
font-size: var(--font-body-m-size-sregvd, 14px);
|
|
241
239
|
line-height: 22px;
|
|
@@ -244,17 +242,17 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
244
242
|
color: #000716;
|
|
245
243
|
color: var(--color-text-dropdown-item-default-7tg9p2, #000716);
|
|
246
244
|
}
|
|
247
|
-
.awsui_calendar-next-month-
|
|
245
|
+
.awsui_calendar-next-month-btn_145pa_2hhg5_179:not(#\9) {
|
|
248
246
|
/* used for identifying element */
|
|
249
247
|
}
|
|
250
|
-
.awsui_calendar-prev-month-
|
|
248
|
+
.awsui_calendar-prev-month-btn_145pa_2hhg5_182:not(#\9) {
|
|
251
249
|
/* used for identifying element */
|
|
252
250
|
}
|
|
253
|
-
.awsui_calendar-day-
|
|
251
|
+
.awsui_calendar-day-names_145pa_2hhg5_185:not(#\9) {
|
|
254
252
|
display: flex;
|
|
255
253
|
justify-content: stretch;
|
|
256
254
|
}
|
|
257
|
-
.awsui_calendar-day-
|
|
255
|
+
.awsui_calendar-day-name_145pa_2hhg5_185:not(#\9) {
|
|
258
256
|
flex: 1 1 0%;
|
|
259
257
|
width: 0;
|
|
260
258
|
word-break: break-word;
|
|
@@ -270,15 +268,15 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
270
268
|
letter-spacing: 0.005em;
|
|
271
269
|
letter-spacing: var(--font-body-s-letter-spacing-cy0oxj, 0.005em);
|
|
272
270
|
}
|
|
273
|
-
.awsui_calendar-
|
|
271
|
+
.awsui_calendar-dates_145pa_2hhg5_200:not(#\9) {
|
|
274
272
|
border: 1px solid transparent;
|
|
275
273
|
border: 1px solid var(--color-border-calendar-grid-sshunw, transparent);
|
|
276
274
|
}
|
|
277
|
-
.awsui_calendar-
|
|
275
|
+
.awsui_calendar-week_145pa_2hhg5_203:not(#\9) {
|
|
278
276
|
display: flex;
|
|
279
277
|
justify-content: stretch;
|
|
280
278
|
}
|
|
281
|
-
.awsui_calendar-
|
|
279
|
+
.awsui_calendar-day_145pa_2hhg5_185:not(#\9) {
|
|
282
280
|
flex: 1 1 0%;
|
|
283
281
|
width: 0;
|
|
284
282
|
word-break: break-word;
|
|
@@ -288,48 +286,48 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
288
286
|
border-right: 1px solid transparent;
|
|
289
287
|
border-right: 1px solid var(--color-border-calendar-grid-sshunw, transparent);
|
|
290
288
|
border-radius: 8px;
|
|
291
|
-
border-radius: var(--border-
|
|
289
|
+
border-radius: var(--border-radius-item-u2ibpi, 8px);
|
|
292
290
|
padding: 4px 0;
|
|
293
291
|
padding: var(--space-xxs-ynfts5, 4px) 0;
|
|
294
292
|
color: #9ba7b6;
|
|
295
293
|
color: var(--color-text-dropdown-item-disabled-varol7, #9ba7b6);
|
|
296
294
|
position: relative;
|
|
297
295
|
}
|
|
298
|
-
.awsui_calendar-
|
|
296
|
+
.awsui_calendar-day_145pa_2hhg5_185:not(#\9):last-child {
|
|
299
297
|
border-right: none;
|
|
300
298
|
}
|
|
301
|
-
.awsui_calendar-day-in-last-
|
|
299
|
+
.awsui_calendar-day-in-last-week_145pa_2hhg5_222:not(#\9) {
|
|
302
300
|
border-bottom: none;
|
|
303
301
|
}
|
|
304
|
-
.awsui_calendar-day-
|
|
302
|
+
.awsui_calendar-day-focusable_145pa_2hhg5_225:not(#\9) {
|
|
305
303
|
/* used for identifying element */
|
|
306
304
|
}
|
|
307
|
-
.awsui_calendar-day-
|
|
305
|
+
.awsui_calendar-day-enabled_145pa_2hhg5_228:not(#\9) {
|
|
308
306
|
cursor: pointer;
|
|
309
307
|
color: #5f6b7a;
|
|
310
308
|
color: var(--color-text-dropdown-item-secondary-0me7js, #5f6b7a);
|
|
311
309
|
}
|
|
312
|
-
.awsui_calendar-day-
|
|
310
|
+
.awsui_calendar-day-enabled_145pa_2hhg5_228.awsui_calendar-day-current-month_145pa_2hhg5_232:not(#\9) {
|
|
313
311
|
color: #000716;
|
|
314
312
|
color: var(--color-text-dropdown-item-default-7tg9p2, #000716);
|
|
315
313
|
}
|
|
316
|
-
.awsui_calendar-day-
|
|
314
|
+
.awsui_calendar-day-enabled_145pa_2hhg5_228.awsui_calendar-day-current-month_145pa_2hhg5_232:not(#\9):hover {
|
|
317
315
|
color: #000716;
|
|
318
316
|
color: var(--color-text-calendar-day-hover-graajh, #000716);
|
|
319
317
|
background-color: #f4f4f4;
|
|
320
318
|
background-color: var(--color-background-dropdown-item-hover-mqsxkv, #f4f4f4);
|
|
321
319
|
}
|
|
322
|
-
.awsui_calendar-day-
|
|
320
|
+
.awsui_calendar-day-enabled_145pa_2hhg5_228.awsui_calendar-day-current-month_145pa_2hhg5_232:not(#\9):hover:not(.awsui_calendar-day-selected_145pa_2hhg5_239)::after {
|
|
323
321
|
border: 2px solid #7d8998;
|
|
324
322
|
border: var(--border-item-width-qbbbsa, 2px) solid var(--color-border-dropdown-item-hover-tyzq9m, #7d8998);
|
|
325
323
|
border-radius: 8px;
|
|
326
|
-
border-radius: var(--border-
|
|
324
|
+
border-radius: var(--border-radius-item-u2ibpi, 8px);
|
|
327
325
|
}
|
|
328
|
-
.awsui_calendar-day-
|
|
326
|
+
.awsui_calendar-day-today_145pa_2hhg5_243:not(#\9) {
|
|
329
327
|
background-color: #f4f4f4;
|
|
330
328
|
background-color: var(--color-background-calendar-today-762czq, #f4f4f4);
|
|
331
329
|
}
|
|
332
|
-
.awsui_calendar-
|
|
330
|
+
.awsui_calendar-day_145pa_2hhg5_185:not(#\9)::after {
|
|
333
331
|
content: "";
|
|
334
332
|
position: absolute;
|
|
335
333
|
top: -1px;
|
|
@@ -338,20 +336,20 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
338
336
|
right: -1px;
|
|
339
337
|
background-color: transparent;
|
|
340
338
|
}
|
|
341
|
-
.awsui_calendar-
|
|
339
|
+
.awsui_calendar-day_145pa_2hhg5_185 > .awsui_day-inner_145pa_2hhg5_255:not(#\9) {
|
|
342
340
|
position: relative;
|
|
343
341
|
z-index: 1;
|
|
344
342
|
}
|
|
345
|
-
.awsui_calendar-
|
|
343
|
+
.awsui_calendar-day_145pa_2hhg5_185:not(#\9):focus {
|
|
346
344
|
outline: none;
|
|
347
345
|
position: relative;
|
|
348
346
|
}
|
|
349
|
-
.awsui_calendar-
|
|
347
|
+
.awsui_calendar-day_145pa_2hhg5_185:not(#\9):focus {
|
|
350
348
|
outline: 2px dotted transparent;
|
|
351
349
|
outline-offset: calc(-5px - 1px);
|
|
352
350
|
outline-offset: calc(var(--space-calendar-grid-focus-outline-gutter-v3dwvl, -5px) - 1px);
|
|
353
351
|
}
|
|
354
|
-
.awsui_calendar-
|
|
352
|
+
.awsui_calendar-day_145pa_2hhg5_185:not(#\9):focus::before {
|
|
355
353
|
content: " ";
|
|
356
354
|
display: block;
|
|
357
355
|
position: absolute;
|
|
@@ -364,35 +362,35 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
|
|
|
364
362
|
height: calc(100% + 2 * -5px);
|
|
365
363
|
height: calc(100% + 2 * var(--space-calendar-grid-focus-outline-gutter-v3dwvl, -5px));
|
|
366
364
|
border-radius: 3px;
|
|
367
|
-
border-radius: var(--border-calendar-
|
|
365
|
+
border-radius: var(--border-radius-calendar-day-focused-4la5vv, 3px);
|
|
368
366
|
box-shadow: 0 0 0 2px #0972d3;
|
|
369
367
|
box-shadow: 0 0 0 2px var(--color-border-item-focused-ap3b6s, #0972d3);
|
|
370
368
|
}
|
|
371
|
-
.awsui_calendar-
|
|
369
|
+
.awsui_calendar-day_145pa_2hhg5_185:not(#\9):focus::before {
|
|
372
370
|
z-index: 2;
|
|
373
371
|
}
|
|
374
|
-
.awsui_calendar-day-
|
|
372
|
+
.awsui_calendar-day-selected_145pa_2hhg5_239:not(#\9) {
|
|
375
373
|
border-color: transparent;
|
|
376
374
|
position: relative;
|
|
377
375
|
}
|
|
378
|
-
.awsui_calendar-day-
|
|
376
|
+
.awsui_calendar-day-selected_145pa_2hhg5_239:not(#\9)::after {
|
|
379
377
|
background-color: #f2f8fd;
|
|
380
378
|
background-color: var(--color-background-dropdown-item-selected-8l4mpk, #f2f8fd);
|
|
381
379
|
border: 2px solid #0972d3;
|
|
382
380
|
border: var(--border-item-width-qbbbsa, 2px) solid var(--color-border-dropdown-item-selected-eahq2j, #0972d3);
|
|
383
381
|
border-radius: 8px;
|
|
384
|
-
border-radius: var(--border-
|
|
382
|
+
border-radius: var(--border-radius-item-u2ibpi, 8px);
|
|
385
383
|
}
|
|
386
|
-
.awsui_calendar-day-
|
|
384
|
+
.awsui_calendar-day-selected_145pa_2hhg5_239 > .awsui_day-inner_145pa_2hhg5_255:not(#\9) {
|
|
387
385
|
color: #0972d3;
|
|
388
386
|
color: var(--color-text-calendar-day-selected-64o9sq, #0972d3);
|
|
389
387
|
position: relative;
|
|
390
388
|
}
|
|
391
|
-
.
|
|
389
|
+
.awsui_calendar_145pa_2hhg5_93[data-awsui-focus-visible=true]:not(#\9):focus {
|
|
392
390
|
outline: 2px dotted transparent;
|
|
393
391
|
outline-offset: 2px;
|
|
394
392
|
border-radius: 16px;
|
|
395
|
-
border-radius: var(--border-container-
|
|
393
|
+
border-radius: var(--border-radius-container-gh9ysk, 16px);
|
|
396
394
|
box-shadow: 0 0 0 2px #0972d3;
|
|
397
395
|
box-shadow: 0 0 0 2px var(--color-border-item-focused-ap3b6s, #0972d3);
|
|
398
396
|
}
|
|
@@ -2,29 +2,29 @@
|
|
|
2
2
|
// es-module interop with Babel and Typescript
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
4
|
module.exports.default = {
|
|
5
|
-
"calendar": "
|
|
6
|
-
"awsui-motion-fade-in-0": "awsui_awsui-motion-fade-in-
|
|
7
|
-
"root": "
|
|
8
|
-
"date-picker-container": "awsui_date-picker-
|
|
9
|
-
"date-picker-trigger": "awsui_date-picker-
|
|
10
|
-
"date-picker-input": "awsui_date-picker-
|
|
11
|
-
"open-calendar-button": "awsui_open-calendar-
|
|
12
|
-
"calendar-inner": "awsui_calendar-
|
|
13
|
-
"calendar-header": "awsui_calendar-
|
|
14
|
-
"calendar-header-month": "awsui_calendar-header-
|
|
15
|
-
"calendar-next-month-btn": "awsui_calendar-next-month-
|
|
16
|
-
"calendar-prev-month-btn": "awsui_calendar-prev-month-
|
|
17
|
-
"calendar-day-names": "awsui_calendar-day-
|
|
18
|
-
"calendar-day-name": "awsui_calendar-day-
|
|
19
|
-
"calendar-dates": "awsui_calendar-
|
|
20
|
-
"calendar-week": "awsui_calendar-
|
|
21
|
-
"calendar-day": "awsui_calendar-
|
|
22
|
-
"calendar-day-in-last-week": "awsui_calendar-day-in-last-
|
|
23
|
-
"calendar-day-focusable": "awsui_calendar-day-
|
|
24
|
-
"calendar-day-enabled": "awsui_calendar-day-
|
|
25
|
-
"calendar-day-current-month": "awsui_calendar-day-current-
|
|
26
|
-
"calendar-day-selected": "awsui_calendar-day-
|
|
27
|
-
"calendar-day-today": "awsui_calendar-day-
|
|
28
|
-
"day-inner": "awsui_day-
|
|
5
|
+
"calendar": "awsui_calendar_145pa_2hhg5_93",
|
|
6
|
+
"awsui-motion-fade-in-0": "awsui_awsui-motion-fade-in-0_145pa_2hhg5_1",
|
|
7
|
+
"root": "awsui_root_145pa_2hhg5_120",
|
|
8
|
+
"date-picker-container": "awsui_date-picker-container_145pa_2hhg5_131",
|
|
9
|
+
"date-picker-trigger": "awsui_date-picker-trigger_145pa_2hhg5_136",
|
|
10
|
+
"date-picker-input": "awsui_date-picker-input_145pa_2hhg5_140",
|
|
11
|
+
"open-calendar-button": "awsui_open-calendar-button_145pa_2hhg5_145",
|
|
12
|
+
"calendar-inner": "awsui_calendar-inner_145pa_2hhg5_165",
|
|
13
|
+
"calendar-header": "awsui_calendar-header_145pa_2hhg5_168",
|
|
14
|
+
"calendar-header-month": "awsui_calendar-header-month_145pa_2hhg5_173",
|
|
15
|
+
"calendar-next-month-btn": "awsui_calendar-next-month-btn_145pa_2hhg5_179",
|
|
16
|
+
"calendar-prev-month-btn": "awsui_calendar-prev-month-btn_145pa_2hhg5_182",
|
|
17
|
+
"calendar-day-names": "awsui_calendar-day-names_145pa_2hhg5_185",
|
|
18
|
+
"calendar-day-name": "awsui_calendar-day-name_145pa_2hhg5_185",
|
|
19
|
+
"calendar-dates": "awsui_calendar-dates_145pa_2hhg5_200",
|
|
20
|
+
"calendar-week": "awsui_calendar-week_145pa_2hhg5_203",
|
|
21
|
+
"calendar-day": "awsui_calendar-day_145pa_2hhg5_185",
|
|
22
|
+
"calendar-day-in-last-week": "awsui_calendar-day-in-last-week_145pa_2hhg5_222",
|
|
23
|
+
"calendar-day-focusable": "awsui_calendar-day-focusable_145pa_2hhg5_225",
|
|
24
|
+
"calendar-day-enabled": "awsui_calendar-day-enabled_145pa_2hhg5_228",
|
|
25
|
+
"calendar-day-current-month": "awsui_calendar-day-current-month_145pa_2hhg5_232",
|
|
26
|
+
"calendar-day-selected": "awsui_calendar-day-selected_145pa_2hhg5_239",
|
|
27
|
+
"calendar-day-today": "awsui_calendar-day-today_145pa_2hhg5_243",
|
|
28
|
+
"day-inner": "awsui_day-inner_145pa_2hhg5_255"
|
|
29
29
|
};
|
|
30
30
|
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { CalendarTypes } from './calendar/definitions';
|
|
2
|
+
import { NonCancelableEventHandler } from '../internal/events';
|
|
3
|
+
import { DatePickerProps } from './interfaces';
|
|
4
|
+
export declare function useDatePicker({ value, onChange }: UseDatePickerProps): {
|
|
5
|
+
defaultDisplayedDate: string;
|
|
6
|
+
displayedDate: string;
|
|
7
|
+
setDisplayedDate: import("react").Dispatch<import("react").SetStateAction<string>>;
|
|
8
|
+
selectedDate: string | null;
|
|
9
|
+
setSelectedDate: import("react").Dispatch<import("react").SetStateAction<string | null>>;
|
|
10
|
+
onChangeMonthHandler: (newMonth: Date) => void;
|
|
11
|
+
onSelectDateHandler: ({ date }: CalendarTypes.DateDetail) => void;
|
|
12
|
+
};
|
|
13
|
+
export interface UseDatePickerProps {
|
|
14
|
+
value: string;
|
|
15
|
+
onChange: NonCancelableEventHandler<DatePickerProps.ChangeDetail> | undefined;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=use-date-picker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-date-picker.d.ts","sourceRoot":"","sources":["../../../src/date-picker/use-date-picker.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAGvD,OAAO,EAA0B,yBAAyB,EAAE,MAAM,oBAAoB,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,wBAAgB,aAAa,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,kBAAkB;;;;;;qCAO3B,IAAI;oCAIL,cAAc,UAAU;EAgChE;AAED,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,yBAAyB,CAAC,eAAe,CAAC,YAAY,CAAC,GAAG,SAAS,CAAC;CAC/E"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
import { useState } from 'react';
|
|
4
|
+
import { formatDate } from './calendar/utils/date';
|
|
5
|
+
import { usePrevious } from '../internal/hooks/use-previous';
|
|
6
|
+
import { fireNonCancelableEvent } from '../internal/events';
|
|
7
|
+
export function useDatePicker(_a) {
|
|
8
|
+
var value = _a.value, onChange = _a.onChange;
|
|
9
|
+
var defaultSelectedDate = value.length >= 10 ? value : null;
|
|
10
|
+
var _b = useState(defaultSelectedDate), selectedDate = _b[0], setSelectedDate = _b[1];
|
|
11
|
+
var defaultDisplayedDate = value.length >= 10 ? value : formatDate(new Date());
|
|
12
|
+
var _c = useState(defaultDisplayedDate), displayedDate = _c[0], setDisplayedDate = _c[1];
|
|
13
|
+
var onChangeMonthHandler = function (newMonth) {
|
|
14
|
+
setDisplayedDate(formatDate(newMonth));
|
|
15
|
+
};
|
|
16
|
+
var onSelectDateHandler = function (_a) {
|
|
17
|
+
var date = _a.date;
|
|
18
|
+
var formattedDate = formatDate(date);
|
|
19
|
+
setSelectedDate(formattedDate);
|
|
20
|
+
setDisplayedDate(formattedDate);
|
|
21
|
+
fireNonCancelableEvent(onChange, { value: formattedDate });
|
|
22
|
+
};
|
|
23
|
+
var prevValue = usePrevious(value);
|
|
24
|
+
if (prevValue !== value) {
|
|
25
|
+
if (value === '' && selectedDate !== value) {
|
|
26
|
+
setSelectedDate(value);
|
|
27
|
+
}
|
|
28
|
+
// update the displayedDate when inputValue changes in order to
|
|
29
|
+
// display the correct month when the date picker gets open again.
|
|
30
|
+
if (value.length >= 4 && displayedDate !== value) {
|
|
31
|
+
setDisplayedDate(value);
|
|
32
|
+
}
|
|
33
|
+
// set the selected date only when a full date (yyyy-mm-dd) is entered
|
|
34
|
+
if (value.length >= 10 && selectedDate !== value) {
|
|
35
|
+
setSelectedDate(value);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return {
|
|
39
|
+
defaultDisplayedDate: defaultDisplayedDate,
|
|
40
|
+
displayedDate: displayedDate,
|
|
41
|
+
setDisplayedDate: setDisplayedDate,
|
|
42
|
+
selectedDate: selectedDate,
|
|
43
|
+
setSelectedDate: setSelectedDate,
|
|
44
|
+
onChangeMonthHandler: onChangeMonthHandler,
|
|
45
|
+
onSelectDateHandler: onSelectDateHandler
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=use-date-picker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-date-picker.js","sourceRoot":"","sources":["../../../src/date-picker/use-date-picker.tsx"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,sCAAsC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEjC,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,OAAO,EAAE,sBAAsB,EAA6B,MAAM,oBAAoB,CAAC;AAGvF,MAAM,UAAU,aAAa,CAAC,EAAuC;QAArC,KAAK,WAAA,EAAE,QAAQ,cAAA;IAC7C,IAAM,mBAAmB,GAAG,KAAK,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IACxD,IAAA,KAAkC,QAAQ,CAAgB,mBAAmB,CAAC,EAA7E,YAAY,QAAA,EAAE,eAAe,QAAgD,CAAC;IAErF,IAAM,oBAAoB,GAAG,KAAK,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;IAC3E,IAAA,KAAoC,QAAQ,CAAS,oBAAoB,CAAC,EAAzE,aAAa,QAAA,EAAE,gBAAgB,QAA0C,CAAC;IAEjF,IAAM,oBAAoB,GAAG,UAAC,QAAc;QAC1C,gBAAgB,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC;IAEF,IAAM,mBAAmB,GAAG,UAAC,EAAkC;YAAhC,IAAI,UAAA;QACjC,IAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;QACvC,eAAe,CAAC,aAAa,CAAC,CAAC;QAC/B,gBAAgB,CAAC,aAAa,CAAC,CAAC;QAChC,sBAAsB,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC;IAC7D,CAAC,CAAC;IAEF,IAAM,SAAS,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;IACrC,IAAI,SAAS,KAAK,KAAK,EAAE;QACvB,IAAI,KAAK,KAAK,EAAE,IAAI,YAAY,KAAK,KAAK,EAAE;YAC1C,eAAe,CAAC,KAAK,CAAC,CAAC;SACxB;QACD,+DAA+D;QAC/D,kEAAkE;QAClE,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,IAAI,aAAa,KAAK,KAAK,EAAE;YAChD,gBAAgB,CAAC,KAAK,CAAC,CAAC;SACzB;QACD,sEAAsE;QACtE,IAAI,KAAK,CAAC,MAAM,IAAI,EAAE,IAAI,YAAY,KAAK,KAAK,EAAE;YAChD,eAAe,CAAC,KAAK,CAAC,CAAC;SACxB;KACF;IAED,OAAO;QACL,oBAAoB,sBAAA;QACpB,aAAa,eAAA;QACb,gBAAgB,kBAAA;QAChB,YAAY,cAAA;QACZ,eAAe,iBAAA;QACf,oBAAoB,sBAAA;QACpB,mBAAmB,qBAAA;KACpB,CAAC;AACJ,CAAC","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { useState } from 'react';\nimport { CalendarTypes } from './calendar/definitions';\nimport { formatDate } from './calendar/utils/date';\nimport { usePrevious } from '../internal/hooks/use-previous';\nimport { fireNonCancelableEvent, NonCancelableEventHandler } from '../internal/events';\nimport { DatePickerProps } from './interfaces';\n\nexport function useDatePicker({ value, onChange }: UseDatePickerProps) {\n const defaultSelectedDate = value.length >= 10 ? value : null;\n const [selectedDate, setSelectedDate] = useState<string | null>(defaultSelectedDate);\n\n const defaultDisplayedDate = value.length >= 10 ? value : formatDate(new Date());\n const [displayedDate, setDisplayedDate] = useState<string>(defaultDisplayedDate);\n\n const onChangeMonthHandler = (newMonth: Date) => {\n setDisplayedDate(formatDate(newMonth));\n };\n\n const onSelectDateHandler = ({ date }: CalendarTypes.DateDetail) => {\n const formattedDate = formatDate(date);\n setSelectedDate(formattedDate);\n setDisplayedDate(formattedDate);\n fireNonCancelableEvent(onChange, { value: formattedDate });\n };\n\n const prevValue = usePrevious(value);\n if (prevValue !== value) {\n if (value === '' && selectedDate !== value) {\n setSelectedDate(value);\n }\n // update the displayedDate when inputValue changes in order to\n // display the correct month when the date picker gets open again.\n if (value.length >= 4 && displayedDate !== value) {\n setDisplayedDate(value);\n }\n // set the selected date only when a full date (yyyy-mm-dd) is entered\n if (value.length >= 10 && selectedDate !== value) {\n setSelectedDate(value);\n }\n }\n\n return {\n defaultDisplayedDate,\n displayedDate,\n setDisplayedDate,\n selectedDate,\n setSelectedDate,\n onChangeMonthHandler,\n onSelectDateHandler,\n };\n}\n\nexport interface UseDatePickerProps {\n value: string;\n onChange: NonCancelableEventHandler<DatePickerProps.ChangeDetail> | undefined;\n}\n"]}
|