@dnb/eufemia 10.65.0 → 10.65.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/CHANGELOG.md +8 -0
- package/cjs/components/date-picker/DatePicker.d.ts +3 -1
- package/cjs/components/date-picker/DatePicker.js +3 -1
- package/cjs/components/date-picker/DatePicker.js.map +1 -1
- package/cjs/components/date-picker/DatePickerAddon.js +8 -1
- package/cjs/components/date-picker/DatePickerAddon.js.map +1 -1
- package/cjs/extensions/forms/DataContext/Context.d.ts +1 -1
- package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
- package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +1 -1
- package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
- package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +2 -2
- package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
- package/cjs/extensions/forms/DataContext/Provider/Provider.js +2 -2
- package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -2
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/cjs/extensions/forms/hooks/useFieldProps.js +8 -8
- package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/cjs/shared/Eufemia.d.ts +1 -1
- package/cjs/shared/Eufemia.js +2 -2
- package/cjs/shared/Eufemia.js.map +1 -1
- package/cjs/style/core/scopes.scss +1 -1
- package/cjs/style/dnb-ui-basis.css +1 -1
- package/cjs/style/dnb-ui-basis.min.css +1 -1
- package/cjs/style/dnb-ui-body.css +1 -1
- package/cjs/style/dnb-ui-body.min.css +1 -1
- package/cjs/style/dnb-ui-core.css +1 -1
- package/cjs/style/dnb-ui-core.min.css +1 -1
- package/components/date-picker/DatePicker.d.ts +3 -1
- package/components/date-picker/DatePicker.js +3 -1
- package/components/date-picker/DatePicker.js.map +1 -1
- package/components/date-picker/DatePickerAddon.js +6 -1
- package/components/date-picker/DatePickerAddon.js.map +1 -1
- package/es/components/date-picker/DatePicker.d.ts +3 -1
- package/es/components/date-picker/DatePicker.js +3 -1
- package/es/components/date-picker/DatePicker.js.map +1 -1
- package/es/components/date-picker/DatePickerAddon.js +6 -1
- package/es/components/date-picker/DatePickerAddon.js.map +1 -1
- package/es/extensions/forms/DataContext/Context.d.ts +1 -1
- package/es/extensions/forms/DataContext/Context.js.map +1 -1
- package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +1 -1
- package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
- package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +2 -2
- package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
- package/es/extensions/forms/DataContext/Provider/Provider.js +2 -2
- package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -2
- package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/es/extensions/forms/hooks/useFieldProps.js +8 -8
- package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/es/shared/Eufemia.d.ts +1 -1
- package/es/shared/Eufemia.js +2 -2
- package/es/shared/Eufemia.js.map +1 -1
- package/es/style/core/scopes.scss +1 -1
- package/es/style/dnb-ui-basis.css +1 -1
- package/es/style/dnb-ui-basis.min.css +1 -1
- package/es/style/dnb-ui-body.css +1 -1
- package/es/style/dnb-ui-body.min.css +1 -1
- package/es/style/dnb-ui-core.css +1 -1
- package/es/style/dnb-ui-core.min.css +1 -1
- package/esm/dnb-ui-basis.min.mjs +1 -1
- package/esm/dnb-ui-components.min.mjs +1 -1
- package/esm/dnb-ui-elements.min.mjs +1 -1
- package/esm/dnb-ui-extensions.min.mjs +3 -3
- package/esm/dnb-ui-lib.min.mjs +1 -1
- package/extensions/forms/DataContext/Context.d.ts +1 -1
- package/extensions/forms/DataContext/Context.js.map +1 -1
- package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +1 -1
- package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
- package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +2 -2
- package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
- package/extensions/forms/DataContext/Provider/Provider.js +2 -2
- package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -2
- package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/extensions/forms/hooks/useFieldProps.js +8 -8
- package/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/package.json +1 -1
- package/shared/Eufemia.d.ts +1 -1
- package/shared/Eufemia.js +2 -2
- package/shared/Eufemia.js.map +1 -1
- package/style/core/scopes.scss +1 -1
- package/style/dnb-ui-basis.css +1 -1
- package/style/dnb-ui-basis.min.css +1 -1
- package/style/dnb-ui-body.css +1 -1
- package/style/dnb-ui-body.min.css +1 -1
- package/style/dnb-ui-core.css +1 -1
- package/style/dnb-ui-core.min.css +1 -1
- package/umd/dnb-ui-basis.min.js +1 -1
- package/umd/dnb-ui-components.min.js +1 -1
- package/umd/dnb-ui-elements.min.js +1 -1
- package/umd/dnb-ui-extensions.min.js +2 -2
- package/umd/dnb-ui-lib.min.js +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,14 @@
|
|
|
3
3
|
All notable changes to @dnb/eufemia will be documented in this file. See
|
|
4
4
|
[Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [10.65.1](https://github.com/dnbexperience/eufemia/compare/v10.65.0...v10.65.1) (2025-02-25)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
### :bug: Bug Fixes
|
|
10
|
+
|
|
11
|
+
* **DatePicker:** correct focus behaviour when picker has closed ([#4622](https://github.com/dnbexperience/eufemia/issues/4622)) ([b20ed69](https://github.com/dnbexperience/eufemia/commit/b20ed69acb621a2d42ce0097f483c1e958f0c8b3))
|
|
12
|
+
* **Forms:** add support for using Visibility inside PushContainer ([#4623](https://github.com/dnbexperience/eufemia/issues/4623)) ([d333f38](https://github.com/dnbexperience/eufemia/commit/d333f38e0e7ab93a6299d4bf99334673a07d78ac))
|
|
13
|
+
|
|
6
14
|
## [10.65.0](https://github.com/dnbexperience/eufemia/compare/v10.64.1...v10.65.0) (2025-02-25)
|
|
7
15
|
|
|
8
16
|
|
|
@@ -21,8 +21,10 @@ export type DatePickerEventAttributes = {
|
|
|
21
21
|
end?: string;
|
|
22
22
|
} & Record<string, unknown>;
|
|
23
23
|
export type DatePickerEvent<T> = ReturnObject<T>;
|
|
24
|
-
|
|
24
|
+
type FocusOnHide = {
|
|
25
25
|
focusOnHide?: boolean | string;
|
|
26
|
+
};
|
|
27
|
+
export type DisplayPickerEvent = (React.MouseEvent<HTMLButtonElement | HTMLAnchorElement | HTMLElement> | MouseEvent | KeyboardEvent | FocusOnHide) & DatePickerDates & FocusOnHide & {
|
|
26
28
|
event?: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>;
|
|
27
29
|
};
|
|
28
30
|
export type DatePickerProps = {
|
|
@@ -184,7 +184,9 @@ function DatePicker(externalProps) {
|
|
|
184
184
|
} = _ref2,
|
|
185
185
|
args = _objectWithoutProperties(_ref2, _excluded);
|
|
186
186
|
if (shouldHidePicker && !showSubmitButton && !showCancelButton) {
|
|
187
|
-
hidePicker(
|
|
187
|
+
hidePicker({
|
|
188
|
+
focusOnHide: true
|
|
189
|
+
});
|
|
188
190
|
}
|
|
189
191
|
setDates({
|
|
190
192
|
startDate: args.startDate,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DatePicker.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_componentHelper","_AlignmentHelper2","_SpacingHelper","_SkeletonHelper","_format","_Context","_Suffix","_FormLabel","_FormStatus","_DatePickerProvider","_DatePickerRange","_DatePickerInput","_DatePickerAddon","_DatePickerFooter","_filterValidProps","_shared","_withSnakeCaseProps","_DatePickerPortal","_AlignmentHelper","_excluded","_excluded2","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","ownKeys","object","enumerableOnly","symbols","filter","sym","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","defaultProps","maskOrder","maskPlaceholder","dateFormat","returnFormat","hideNavigation","hideNavigationButtons","hideDays","onlyMonth","hideLastWeek","disableAutofocus","enableKeyboardNav","showInput","submitButtonText","cancelButtonText","resetButtonText","resetDate","firstDay","range","link","sync","statusState","opened","noAnimation","direction","skipPortal","DatePicker","externalProps","props","preventClose","onHide","onShow","onSubmit","onCancel","onReset","alignPicker","showSubmitButton","showCancelButton","openedProp","endDate","endDateProp","convertSnakeCaseProps","setOpened","useState","hidden","setHidden","dates","setDates","context","useContext","Context","blurDelay","id","makeUniqueId","innerRef","useRef","triangleRef","submitButtonRef","getReturnObject","hideTimeout","outsideClick","calendarContainerRef","translation","useTranslation","warn","removeOutsideClickHandler","useCallback","current","remove","hidePicker","args","event","persist","setTimeout","focus","preventScroll","e","setOutsideClickHandler","detectOutsideClick","_ref","focusOnHide","setTrianglePosition","triangleWidth","shellWidth","querySelector","getBoundingClientRect","width","buttonWidth","distance","style","marginRight","marginLeft","showPicker","clearTimeout","useLayoutEffect","useEffect","onPickerChange","_ref2","shouldHidePicker","startDate","onSubmitHandler","onCancelHandler","onResetHandler","togglePicker","formatSelectedDateTitle","selectedDate","start","end","currentDate","format","replace","extendedProps","extendPropsWithContext","skeleton","getTranslation","pickFormElementProps","FormRow","formElement","label","title","labelDirection","labelSrOnly","inputElement","addonElement","shortcuts","disabled","stretch","size","status","statusProps","statusNoAnimation","globalStatus","suffix","showResetButton","className","tooltip","restProps","attributes","useMemo","filterOutNonAttributes","shouldHideDays","shouldHideNavigation","showStatus","getStatusState","pickerParams","combineDescribedBy","submitParams","ref","tabIndex","selectedDateTitle","mainParams","classnames","createSpacingClasses","lang","locale","containerClassNames","remainingDOMProps","validateDOMAttributes","remainingSubmitProps","remainingPickerProps","skeletonDOMAttributes","createElement","setReturnObject","fn","forId","text","srOnly","show","text_id","width_selector","state","no_animation","isRange","submitAttributes","alignment","targetElementRef","firstDayOfWeek","isLink","isSync","hideNav","views","nextBtn","prevBtn","hideNextMonthWeek","noAutoFocus","onChange","renderElement","NonAttributes","reduce","includes","_default","exports","_supportsSpacingProps"],"sources":["../../../../src/components/date-picker/DatePicker.tsx"],"sourcesContent":["/**\n * Web DatePicker Component\n *\n */\n\nimport React, {\n HTMLProps,\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'react'\n\nimport classnames from 'classnames'\nimport {\n warn,\n makeUniqueId,\n extendPropsWithContext,\n detectOutsideClick,\n getStatusState,\n combineDescribedBy,\n validateDOMAttributes,\n DetectOutsideClickClass,\n} from '../../shared/component-helper'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport { skeletonDOMAttributes } from '../skeleton/SkeletonHelper'\n\n// date-fns\nimport format from 'date-fns/format'\n\nimport Context, { Locale } from '../../shared/Context'\nimport Suffix from '../../shared/helpers/Suffix'\nimport FormLabel from '../form-label/FormLabel'\nimport FormStatus, {\n FormStatusProps,\n FormStatusState,\n FormStatusText,\n} from '../form-status/FormStatus'\nimport DatePickerProvider, {\n DatePickerChangeEvent,\n type ReturnObject,\n} from './DatePickerProvider'\nimport DatePickerRange from './DatePickerRange'\nimport DatePickerInput from './DatePickerInput'\nimport DatePickerAddon, { DatePickerAddonProps } from './DatePickerAddon'\nimport DatePickerFooter from './DatePickerFooter'\nimport { SpacingProps } from '../space/types'\nimport { InputInputElement, InputSize } from '../Input'\nimport { SkeletonShow } from '../Skeleton'\nimport { GlobalStatusConfigObject } from '../GlobalStatus'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\nimport { CalendarDay, DatePickerCalendarProps } from './DatePickerCalendar'\nimport { DatePickerContextValues, DateType } from './DatePickerContext'\nimport { DatePickerDates } from './hooks/useDates'\nimport { useTranslation } from '../../shared'\nimport { convertSnakeCaseProps } from '../../shared/helpers/withSnakeCaseProps'\nimport DatePickerPortal from './DatePickerPortal'\n\nexport type DatePickerEventAttributes = {\n day?: string\n year?: string\n start?: string\n end?: string\n} & Record<string, unknown>\n\n// Takes the return object from DatePickerProvider and extends it with the event\nexport type DatePickerEvent<T> = ReturnObject<T>\n\nexport type DisplayPickerEvent = (\n | React.MouseEvent<HTMLButtonElement | HTMLAnchorElement | HTMLElement>\n | MouseEvent\n | KeyboardEvent\n) &\n DatePickerDates & {\n focusOnHide?: boolean | string\n event?: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n }\n\nexport type DatePickerProps = {\n /**\n * Defines the pre-filled date by either a JavaScript DateInstance or (ISO 8601) like `date=\"2019-05-05\"`.\n */\n date?: DateType\n /**\n * To set the pre-filled starting date. Is used if `range={true}` is set to `true`. Defaults to `null`, showing the `maskPlaceholder`.\n */\n startDate?: DateType\n /**\n * To set the pre-filled ending date. Is used if `range={true}` is set to `true`. Defaults to `null`, showing the `maskPlaceholder`.\n */\n endDate?: DateType\n /**\n * To display what month should be shown in the first calendar by default. Defaults to the `date` respective `startDate`.\n */\n month?: DateType\n /**\n * To display what month should be shown in the first calendar by default. Defaults to the `date` respective `startDate`.\n */\n startMonth?: DateType\n /**\n * To display what month should be shown in the second calendar by default. Defaults to the `date` respective `startDate`.\n */\n endMonth?: DateType\n /**\n * To limit a date range to a minimum `startDate`. Defaults to `null`.\n */\n minDate?: DateType\n /**\n * To limit a date range to a maximum `endDate`. Defaults to `null`.\n */\n maxDate?: DateType\n /**\n * Corrects the input date value to be the same as either `minDate` or `maxDate`, when the user types in a date that is either before or after one of these. Defaults to `false`.\n */\n correctInvalidDate?: boolean\n /**\n * To define the order of the masked placeholder input fields. Defaults to `dd/mm/yyyy`\n */\n maskOrder?: string\n /**\n * To display the placeholder on input. Defaults to `dd/mm/åååå`.\n */\n maskPlaceholder?: string\n /**\n * Defines how the prop dates (`date`, `startDate` and `endDate`) should be parsed, e.g. `yyyy/MM/dd`. Defaults to `yyyy-MM-dd`.\n */\n dateFormat?: string\n /**\n * Defines how the returned date, as a string, should be formatted as. Defaults to `yyyy-MM-dd`.\n */\n returnFormat?: string\n /**\n * If set to `true`, the navigation will be hidden. Defaults to `false`.\n */\n hideNavigation?: boolean\n hideNavigationButtons?: boolean\n /**\n * If set to `true`, the week days will be hidden. Defaults to `false`.\n */\n hideDays?: boolean\n /**\n * Use `true` to only show the defined month. Disables the month navigation possibility. Defaults to `false`.\n */\n onlyMonth?: boolean\n /**\n * Use `true` to only show the last week in the current month if it needs to be shown. The result is that there will mainly be shows five (5) weeks (rows) instead of six (6). Defaults to `false`.\n */\n hideLastWeek?: boolean\n /**\n * Once the date picker gets opened, there is a focus handling to ensure good accessibility. can be disabled with property. Defaults to `false`.\n */\n disableAutofocus?: boolean\n enableKeyboardNav?: boolean\n /**\n * If the input fields with the mask should be visible. Defaults to `false`.\n */\n showInput?: boolean\n /**\n * If set to `true`, a submit button will be shown. You can change the default text by using `submitButtonText=\"Ok\"`. Defaults to `false`. If the `range` prop is `true`, then the submit button is shown.\n */\n showSubmitButton?: boolean\n /**\n * If set to `true`, a cancel button will be shown. You can change the default text by using `cancelButtonText=\"Avbryt\"` Defaults to `false`. If the `range` prop is `true`, then the cancel button is shown.\n */\n showCancelButton?: boolean\n /**\n * If set to `true`, a reset button will be shown. You can change the default text by using `resetButtonText=\"Tilbakestill\"` Defaults to `false`.\n */\n showResetButton?: boolean\n submitButtonText?: string\n cancelButtonText?: string\n resetButtonText?: string\n resetDate?: boolean\n /**\n * To define the first day of the week. Defaults to `monday`.\n */\n firstDay?:\n | 'monday'\n | 'tuesday'\n | 'wednesday'\n | 'thursday'\n | 'friday'\n | 'saturday'\n | 'sunday'\n /**\n * If the date picker should support a range of two dates (starting and ending date). Defaults to `false`.\n */\n range?: boolean\n /**\n * Link both calendars, once to the user is navigating between months. Only meant to use if the range is set to `true`. Defaults to `false`.\n */\n link?: boolean\n /**\n * Sync input values with the calendars views. Once the input values get changed, the calendar changes its views in sync. Defaults to `true`.\n */\n sync?: boolean\n /**\n * A prepending label in sync with the date input field.\n */\n label?: React.ReactNode\n /**\n * Use `labelDirection=\"vertical\"` to change the label layout direction. Defaults to `horizontal`.\n */\n labelDirection?: 'vertical' | 'horizontal'\n /**\n * Use `true` to make the label only readable by screen readers.\n */\n labelSrOnly?: boolean\n /**\n * Gives you the possibility to use a plain/vanilla `<input />` HTML element by defining it as a string `inputElement=\"input\"`, a React element, or a render function `inputElement={(internalProps) => (<Return />)}`. Can also be used in circumstances where the `react-text-mask` not should be used, e.g. in testing environments. Defaults to custom masked input.\n */\n inputElement?: InputInputElement\n /**\n * Gives you the possibility to inject a React element showing up over the footer. Use it to customize `shortcuts`.\n */\n addonElement?: React.ReactNode\n /**\n * Gives you the possibility to set predefined dates and date ranges so the user can select these by one click. Define either a JSON or an object with the defined shortcuts. More info is below.\n */\n shortcuts?: DatePickerAddonProps['shortcuts']\n disabled?: boolean\n /**\n * If set to `true`, then the date-picker input field will be 100% in `width`.\n */\n stretch?: boolean\n /**\n * If set to `true`, an overlaying skeleton with animation will be shown.\n */\n skeleton?: SkeletonShow\n /**\n * The sizes you can choose is `small` (1.5rem), `default` (2rem), `medium` (2.5rem) and `large` (3rem) are supported component sizes. Defaults to `default` / `null`.\n */\n size?: InputSize\n /**\n * Text with a status message. The style defaults to an error message. You can use `true` to only get the status color, without a message.\n */\n status?: FormStatusText\n /**\n * Defines the state of the status. Currently, there are two statuses `[error, info]`. Defaults to `error`.\n */\n statusState?: FormStatusState\n /**\n * Use an object to define additional FormStatus properties.\n */\n statusProps?: FormStatusProps\n statusNoAnimation?: boolean\n /**\n * The <a href=\"/uilib/components/global-status/properties/#configuration-object\">configuration</a> used for the target <a href=\"/uilib/components/global-status\">GlobalStatus</a>.\n */\n globalStatus?: GlobalStatusConfigObject\n /**\n * Text describing the content of the DatePicker more than the label. You can also send in a React component, so it gets wrapped inside the DatePicker component.\n */\n suffix?: React.ReactNode\n /**\n * To open the date-picker by default. Defaults to `false`.\n */\n opened?: boolean\n /**\n * Provide a short Tooltip content that shows up on the picker button.\n */\n tooltip?: React.ReactNode\n tabIndex?: number\n preventClose?: boolean\n noAnimation?: boolean\n direction?: 'auto' | 'top' | 'bottom'\n /**\n * Use `right` to change the calendar alignment direction. Defaults to `left`.\n */\n alignPicker?: 'auto' | 'left' | 'right'\n /**\n * If set to `true`, the calendar will not be rendered inside a react portal. Defaults to `false`.\n */\n skipPortal?: boolean\n className?: string\n /**\n * Will be called right before every new calendar view gets rendered. See the example above.\n */\n onDaysRender?: (\n days: Array<CalendarDay>,\n nr?: DatePickerCalendarProps['nr']\n ) => void\n /**\n * Will be called on a date change event. Returns an `object`. See Returned Object below.\n */\n onChange?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called on every input and date picker interaction. Returns an `object`. See Returned Object below.\n */\n onType?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called once date-picker is visible.\n */\n onShow?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * Will be called once date-picker is hidden.\n */\n onHide?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * Will be called once a user presses the submit button.\n */\n onSubmit?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * Will be called once a user presses the cancel button.\n */\n onCancel?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * Will be called once a user presses the reset button.\n */\n onReset?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * Will be called once the input gets focus.\n */\n onFocus?: (event: DatePickerEvent<React.FocusEvent<HTMLElement>>) => void\n /**\n * Will be called once the input lose focus.\n */\n onBlur?: (event: DatePickerEvent<React.FocusEvent<HTMLElement>>) => void\n}\n// Can be removed in v11\ntype DatePickerDeprecatedProps = {\n /**\n * @deprecated use `startDate` instead.\n */\n start_date?: DateType\n /**\n * @deprecated use `endDate` instead.\n */\n end_date?: DateType\n /**\n * @deprecated use `startMonth` instead.\n */\n start_month?: DateType\n /**\n * @deprecated use `endMonth` instead.\n */\n end_month?: DateType\n /**\n * @deprecated use `minDate` instead.\n */\n min_date?: DateType\n /**\n * @deprecated use `maxDate` instead.\n */\n max_date?: DateType\n /**\n * @deprecated use `correctInvalidDate` instead.\n */\n correct_invalid_date?: boolean\n /**\n * @deprecated use `maskOrder` instead.\n */\n mask_order?: string\n /**\n * @deprecated use `maskPlaceholder` instead.\n */\n mask_placeholder?: string\n /**\n * @deprecated use `dateFormat` instead.\n */\n date_format?: string\n /**\n * @deprecated use `returnFormat` instead.\n */\n return_format?: string\n /**\n * @deprecated use `hideNavigation` instead.\n */\n hide_navigation?: boolean\n /**\n * @deprecated use `hideNavigationButtons` instead.\n */\n hide_navigation_buttons?: boolean\n /**\n * @deprecated use `hideDays` instead.\n */\n hide_days?: boolean\n /**\n * @deprecated use `onlyMonth` instead.\n */\n only_month?: boolean\n /**\n * @deprecated use `hideLastWeek` instead.\n */\n hide_last_week?: boolean\n /**\n * @deprecated use `disableAutofocus` instead.\n */\n disable_autofocus?: boolean\n /**\n * @deprecated use `enableKeyboardNav` instead.\n */\n enable_keyboard_nav?: boolean\n /**\n * @deprecated use `showInput` instead.\n */\n show_input?: boolean\n /**\n * @deprecated use `showSubmitButton` instead.\n */\n show_submit_button?: boolean\n /**\n * @deprecated use `showCancelButton` instead.\n */\n show_cancel_button?: boolean\n /**\n * @deprecated\n */\n show_reset_button?: boolean\n /**\n * @deprecated use `submitButtonText` instead.\n */\n submit_button_text?: string\n /**\n * @deprecated use `cancelButtonText` instead.\n */\n cancel_button_text?: string\n /**\n * @deprecated use `resetButtonText` instead.\n */\n reset_button_text?: string\n /**\n * @deprecated use `resetDate` instead.\n */\n reset_date?: boolean\n /**\n * @deprecated use `firstDay` instead.\n */\n first_day?: string\n /**\n * @deprecated set locale with `Provider` instead.\n */\n locale?: Locale\n /**\n * @deprecated use `labelDirection` instead.\n */\n label_direction?: 'vertical' | 'horizontal'\n /**\n * @deprecated use `labelSrOnly` instead.\n */\n label_sr_only?: boolean\n /**\n * @deprecated use `inputElement` instead.\n */\n input_element?: InputInputElement\n /**\n * @deprecated use `addonElement` instead.\n */\n addon_element?: React.ReactNode\n /**\n * @deprecated use `statusState` instead.\n */\n status_state?: FormStatusState\n /**\n * @deprecated use `statusProps` instead.\n */\n status_props?: FormStatusProps\n /**\n * @deprecated use `statusNoAnimation` instead.\n */\n status_no_animation?: boolean\n /**\n * @deprecated use `preventClose` instead.\n */\n prevent_close?: boolean\n /**\n * @deprecated use `no_animation` instead.\n */\n no_animation?: boolean\n /**\n * @deprecated use `alignPicker` instead.\n */\n align_picker?: 'auto' | 'left' | 'right'\n /**\n * @deprecated use `onDaysRender` instead.\n */\n on_days_render?: (\n days: Array<CalendarDay>,\n nr?: DatePickerCalendarProps['nr']\n ) => void\n /**\n * @deprecated use `onChange` instead.\n */\n on_change?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * @deprecated use `onType` instead.\n */\n on_type?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * @deprecated use `onShow` instead.\n */\n on_show?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * @deprecated use `onHide` instead.\n */\n on_hide?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * @deprecated use `onSubmit` instead.\n */\n on_submit?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * @deprecated use `onCancel` instead.\n */\n on_cancel?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * @deprecated use `onReset` instead.\n */\n on_reset?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n}\n\nexport type DatePickerAllProps = DatePickerProps &\n DatePickerDeprecatedProps &\n SpacingProps &\n Omit<\n React.HTMLProps<HTMLElement>,\n | 'ref'\n | 'children'\n | 'label'\n | 'size'\n | 'onChange'\n | 'onBlur'\n | 'onFocus'\n | 'onSubmit'\n | 'onReset'\n | 'start'\n >\n\nconst defaultProps: DatePickerProps = {\n maskOrder: 'dd/mm/yyyy',\n maskPlaceholder: 'dd/mm/åååå', // have to be same setup as \"mask\" - but can be like\n dateFormat: 'yyyy-MM-dd', // in v1 of date-fns we were more flexible in terms of the format\n returnFormat: 'yyyy-MM-dd', // used in date-fns v1\n hideNavigation: false,\n hideNavigationButtons: false,\n hideDays: false,\n onlyMonth: false,\n hideLastWeek: false,\n disableAutofocus: false,\n enableKeyboardNav: false,\n showInput: false,\n submitButtonText: 'Ok',\n cancelButtonText: 'Avbryt',\n resetButtonText: 'Tilbakestill',\n resetDate: true,\n firstDay: 'monday',\n range: false,\n link: false,\n sync: true,\n statusState: 'error',\n opened: false,\n noAnimation: false,\n direction: 'auto',\n skipPortal: false,\n}\n\nfunction DatePicker(externalProps: DatePickerAllProps) {\n const props = { ...defaultProps, ...externalProps }\n\n const {\n preventClose,\n onHide,\n onShow,\n onSubmit,\n onCancel,\n onReset,\n noAnimation,\n showInput,\n alignPicker,\n showSubmitButton,\n showCancelButton,\n range,\n hideDays,\n hideNavigation,\n opened: openedProp,\n endDate: endDateProp,\n } = convertSnakeCaseProps(props) // convertSnakeCaseProps - can be removed in v11\n\n const [opened, setOpened] = useState<boolean>(openedProp)\n const [hidden, setHidden] = useState(!opened)\n const [dates, setDates] = useState<\n Pick<DatePickerDates, 'startDate' | 'endDate'>\n >({})\n\n const context = useContext(Context)\n const blurDelay = 201 // some ms more than \"dropdownSlideDown 200ms\"\n const id = props.id || makeUniqueId()\n\n const innerRef = useRef<HTMLSpanElement>()\n const triangleRef = useRef<HTMLSpanElement>()\n const submitButtonRef = useRef<HTMLButtonElement>()\n const getReturnObject =\n useRef<DatePickerContextValues['getReturnObject']>()\n const hideTimeout = useRef<NodeJS.Timeout>()\n const outsideClick = useRef<DetectOutsideClickClass>()\n const calendarContainerRef = useRef<HTMLDivElement>()\n\n const translation = useTranslation().DatePicker\n\n if (endDateProp && !range) {\n warn(\n `The DatePicker got a \"endDate\". You have to set range={true} as well!.`\n )\n }\n\n const removeOutsideClickHandler = useCallback(() => {\n if (outsideClick.current) {\n outsideClick.current.remove()\n }\n }, [])\n\n const hidePicker = useCallback(\n (args?: DisplayPickerEvent) => {\n if (preventClose) {\n return // stop here\n }\n\n if (args && args.event && args.event.persist) {\n args.event.persist()\n }\n\n setOpened(false)\n\n hideTimeout.current = setTimeout(\n () => {\n setHidden(true)\n onHide?.({\n ...getReturnObject.current(args),\n })\n if (args?.['focusOnHide']) {\n try {\n submitButtonRef.current.focus({\n preventScroll: true,\n })\n } catch (e) {\n warn(e)\n }\n }\n },\n noAnimation ? 1 : blurDelay\n ) // wait until animation is over\n\n removeOutsideClickHandler()\n },\n [noAnimation, preventClose, onHide, removeOutsideClickHandler]\n )\n\n const setOutsideClickHandler = useCallback(() => {\n outsideClick.current = detectOutsideClick(\n // Sending in portalRef, instead of portalRef.current,\n // as that would lead to the ignoreElement being null/undefined,\n // since the portal has not been rendered yet,\n // causing the calendar to close when clicking on the calendar itself\n [innerRef.current, calendarContainerRef],\n ({ event }: { event: MouseEvent | KeyboardEvent }) => {\n hidePicker({ ...event, focusOnHide: event?.['code'] })\n }\n )\n }, [hidePicker])\n\n const setTrianglePosition = useCallback(() => {\n const triangleWidth = 16\n if (showInput && triangleRef.current && innerRef.current) {\n try {\n const shellWidth = innerRef.current\n .querySelector('.dnb-input__shell')\n .getBoundingClientRect().width\n\n const buttonWidth = innerRef.current\n .querySelector('.dnb-input__submit-button__button')\n .getBoundingClientRect().width\n\n if (alignPicker === 'right') {\n const distance = buttonWidth / 2 - triangleWidth / 2\n triangleRef.current.style.marginRight = `${distance / 16}rem`\n } else {\n const distance = shellWidth - buttonWidth / 2 - triangleWidth / 2\n triangleRef.current.style.marginLeft = `${distance / 16}rem`\n }\n } catch (e) {\n warn(e)\n }\n }\n }, [showInput, alignPicker])\n\n const showPicker = useCallback(\n (event?: DisplayPickerEvent) => {\n if (hideTimeout.current) {\n clearTimeout(hideTimeout.current)\n }\n\n setOpened(true)\n setHidden(false)\n\n onShow?.({ ...getReturnObject.current(event) })\n\n setOutsideClickHandler()\n },\n [setOutsideClickHandler, onShow]\n )\n\n // Make sure the triangle is positioned correctly after calendar is mounted\n useLayoutEffect(() => {\n if (!hidden) {\n setTrianglePosition()\n }\n }, [hidden, setTrianglePosition])\n\n // React to opened prop changes\n useEffect(() => {\n if (openedProp) {\n showPicker()\n }\n }, [openedProp, showPicker])\n\n const onPickerChange = useCallback(\n ({\n hidePicker: shouldHidePicker = true,\n ...args\n }: DatePickerChangeEvent<\n | React.MouseEvent<HTMLSpanElement>\n | React.KeyboardEvent<HTMLTableElement>\n >) => {\n if (shouldHidePicker && !showSubmitButton && !showCancelButton) {\n hidePicker()\n }\n\n setDates({ startDate: args.startDate, endDate: args.endDate })\n },\n [hidePicker, showSubmitButton, showCancelButton]\n )\n\n const onSubmitHandler = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n hidePicker(event)\n onSubmit?.({\n ...getReturnObject.current({ event }),\n })\n },\n [hidePicker, onSubmit]\n )\n\n const onCancelHandler = useCallback(\n (\n event: DatePickerChangeEvent<React.MouseEvent<HTMLButtonElement>>\n ) => {\n hidePicker()\n onCancel?.({ ...getReturnObject.current(event) })\n },\n [hidePicker, onCancel]\n )\n\n const onResetHandler = useCallback(\n (\n event: DatePickerChangeEvent<React.MouseEvent<HTMLButtonElement>>\n ) => {\n hidePicker()\n onReset?.({ ...getReturnObject.current(event) })\n },\n [hidePicker, onReset]\n )\n\n const togglePicker = useCallback(\n (args: React.MouseEvent<HTMLButtonElement>) => {\n !opened ? showPicker(args) : hidePicker(args)\n },\n [opened, showPicker, hidePicker]\n )\n\n const formatSelectedDateTitle = useCallback(() => {\n const { selectedDate, start, end } = translation\n const { startDate, endDate } = dates\n\n let currentDate = startDate ? format(startDate, 'PPPP') : null\n\n if (range && startDate && endDate) {\n currentDate = `${start} ${currentDate} - ${end} ${format(\n endDate,\n 'PPPP'\n )}`\n }\n\n return currentDate ? selectedDate.replace(/%s/, currentDate) : ''\n }, [range, translation, dates])\n\n // use only the props from context, who are available here anyway\n const extendedProps = extendPropsWithContext(\n props,\n defaultProps,\n { skeleton: context?.skeleton },\n convertSnakeCaseProps(context.getTranslation(props).DatePicker), // convertSnakeCaseProps - can be removed in v11\n pickFormElementProps(context?.FormRow), // Deprecated – can be removed in v11\n convertSnakeCaseProps(pickFormElementProps(context?.formElement)), // Deprecated – can be removed in v11\n context.DatePicker\n )\n\n const {\n label,\n title,\n labelDirection,\n labelSrOnly,\n onlyMonth,\n hideLastWeek,\n disableAutofocus,\n hideNavigationButtons,\n firstDay,\n resetDate,\n link,\n sync,\n inputElement,\n addonElement,\n shortcuts,\n disabled,\n stretch,\n skeleton,\n size,\n status,\n statusState,\n statusProps,\n statusNoAnimation,\n globalStatus,\n suffix,\n maskOrder,\n maskPlaceholder,\n submitButtonText,\n cancelButtonText,\n resetButtonText,\n showResetButton,\n className,\n tooltip,\n skipPortal,\n ...restProps\n } = extendedProps\n\n const attributes = useMemo(\n () => filterOutNonAttributes(restProps),\n [restProps]\n )\n\n const shouldHideDays = onlyMonth ? true : hideDays\n const shouldHideNavigation = onlyMonth\n ? hideNavigationButtons\n ? false\n : true\n : hideNavigation\n\n const showStatus = getStatusState(status)\n\n const pickerParams = {} as HTMLProps<HTMLSpanElement>\n\n if (showStatus || suffix) {\n pickerParams['aria-describedby'] = combineDescribedBy(\n pickerParams,\n showStatus ? id + '-status' : null,\n suffix ? id + '-suffix' : null\n )\n }\n\n const submitParams = {\n ['aria-expanded']: opened,\n ref: submitButtonRef,\n tabIndex: extendedProps.tabIndex,\n tooltip,\n }\n\n const selectedDateTitle = formatSelectedDateTitle()\n\n const mainParams = {\n className: classnames(\n 'dnb-date-picker',\n status && `dnb-date-picker__status--${statusState}`,\n labelDirection && `dnb-date-picker--${labelDirection}`,\n opened && 'dnb-date-picker--opened',\n hidden && 'dnb-date-picker--hidden',\n showInput && 'dnb-date-picker--show-input',\n (range || showSubmitButton || showCancelButton || showResetButton) &&\n 'dnb-date-picker--show-footer',\n alignPicker && `dnb-date-picker--${alignPicker}`,\n stretch && `dnb-date-picker--stretch`,\n 'dnb-form-component',\n size && `dnb-date-picker--${size}`,\n createSpacingClasses(props),\n className\n ),\n lang: context.locale,\n } as HTMLProps<HTMLSpanElement>\n\n const containerClassNames = classnames(\n 'dnb-date-picker__container',\n opened && 'dnb-date-picker__container--opened',\n !opened && 'dnb-date-picker__container--closed',\n hidden && 'dnb-date-picker__container--hidden',\n showInput && 'dnb-date-picker__container--show-input',\n alignPicker && `dnb-date-picker__container--${alignPicker}`,\n size && `dnb-date-picker--${size}`\n )\n\n const remainingDOMProps = validateDOMAttributes(props, attributes)\n const remainingSubmitProps = validateDOMAttributes(null, submitParams)\n const remainingPickerProps = validateDOMAttributes(\n null,\n skeletonDOMAttributes(pickerParams, skeleton, context)\n )\n\n return (\n <DatePickerProvider\n {...props}\n attributes={remainingDOMProps}\n setReturnObject={(fn) => (getReturnObject.current = fn)}\n hidePicker={hidePicker}\n >\n <span {...mainParams}>\n {label && (\n <FormLabel\n id={id + '-label'}\n forId={id}\n text={label}\n labelDirection={labelDirection}\n srOnly={labelSrOnly}\n disabled={disabled}\n skeleton={skeleton}\n />\n )}\n\n <span\n className=\"dnb-date-picker__inner\"\n ref={innerRef}\n {...remainingPickerProps}\n >\n <AlignmentHelper />\n\n <FormStatus\n show={showStatus}\n id={id + '-form-status'}\n globalStatus={globalStatus}\n label={String(label)}\n text_id={id + '-status'} // used for \"aria-describedby\"\n width_selector={id + '-shell'}\n text={status}\n state={statusState}\n no_animation={statusNoAnimation}\n skeleton={skeleton}\n {...statusProps}\n />\n\n <span className=\"dnb-date-picker__row\">\n <span className=\"dnb-date-picker__shell\" id={`${id}-shell`}>\n <DatePickerInput\n id={id}\n title={title}\n disabled={disabled}\n stretch={stretch}\n skeleton={skeleton}\n maskOrder={maskOrder}\n maskPlaceholder={maskPlaceholder}\n isRange={range}\n showInput={showInput}\n selectedDateTitle={selectedDateTitle}\n inputElement={inputElement}\n opened={opened}\n hidden={hidden}\n size={size}\n status={status ? 'error' : null}\n statusState={statusState}\n lang={context.locale}\n {...attributes}\n submitAttributes={remainingSubmitProps}\n onSubmit={togglePicker}\n {...statusProps}\n />\n\n {!hidden && (\n <DatePickerPortal\n alignment={alignPicker}\n skipPortal={skipPortal}\n targetElementRef={innerRef}\n >\n <span\n className={containerClassNames}\n ref={calendarContainerRef}\n >\n <span\n className=\"dnb-date-picker__triangle\"\n ref={triangleRef}\n />\n <DatePickerRange\n id={id}\n firstDayOfWeek={firstDay}\n resetDate={resetDate}\n isRange={range}\n isLink={link}\n isSync={sync}\n hideDays={shouldHideDays}\n hideNav={shouldHideNavigation}\n views={\n hideNavigationButtons\n ? [{ nextBtn: false, prevBtn: false }]\n : null\n }\n onlyMonth={onlyMonth}\n hideNextMonthWeek={hideLastWeek}\n noAutoFocus={disableAutofocus}\n onChange={onPickerChange}\n locale={context.locale}\n />\n {(addonElement || shortcuts) && (\n <DatePickerAddon\n renderElement={addonElement}\n shortcuts={shortcuts}\n />\n )}\n <DatePickerFooter\n isRange={range}\n onSubmit={onSubmitHandler}\n onCancel={onCancelHandler}\n onReset={onResetHandler}\n submitButtonText={submitButtonText}\n cancelButtonText={cancelButtonText}\n resetButtonText={resetButtonText}\n />\n </span>\n </DatePickerPortal>\n )}\n </span>\n {suffix && (\n <Suffix\n className=\"dnb-date-picker__suffix\"\n id={id + '-suffix'} // used for \"aria-describedby\"\n context={props}\n >\n {suffix}\n </Suffix>\n )}\n </span>\n </span>\n\n <p className=\"dnb-sr-only\" aria-live=\"assertive\">\n {selectedDateTitle}\n </p>\n </span>\n </DatePickerProvider>\n )\n}\n\nconst NonAttributes = [\n 'locale',\n 'id',\n 'month',\n 'date',\n 'startDate',\n 'endDate',\n 'minDate',\n 'maxDate',\n 'enableKeyboardNav',\n 'hideNavigation',\n 'returnFormat',\n 'dateFormat',\n 'hideDays',\n 'correctInvalidDate',\n 'opened',\n 'direction',\n 'range',\n 'showInput',\n 'noAnimation',\n 'onDaysRender',\n 'onShow',\n 'onType',\n 'onHide',\n 'showSubmitButton',\n 'showCancelButton',\n 'selectedDate',\n 'selectedMonth',\n 'selectedYear',\n 'nextMonth',\n 'nextYear',\n 'openPickerText',\n 'placeholderCharacters',\n 'prevMonth',\n 'prevYear',\n 'endMonth',\n 'startMonth',\n 'alignPicker',\n 'preventClose',\n]\n\nfunction filterOutNonAttributes(props: DatePickerProps) {\n return Object.keys(props).reduce((attributes, key) => {\n if (!NonAttributes.includes(key)) {\n attributes[key] = props[key]\n }\n return attributes\n }, {})\n}\n\nexport default DatePicker\n\nDatePicker._supportsSpacingProps = true\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"DatePicker.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_componentHelper","_AlignmentHelper2","_SpacingHelper","_SkeletonHelper","_format","_Context","_Suffix","_FormLabel","_FormStatus","_DatePickerProvider","_DatePickerRange","_DatePickerInput","_DatePickerAddon","_DatePickerFooter","_filterValidProps","_shared","_withSnakeCaseProps","_DatePickerPortal","_AlignmentHelper","_excluded","_excluded2","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","ownKeys","object","enumerableOnly","symbols","filter","sym","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","defaultProps","maskOrder","maskPlaceholder","dateFormat","returnFormat","hideNavigation","hideNavigationButtons","hideDays","onlyMonth","hideLastWeek","disableAutofocus","enableKeyboardNav","showInput","submitButtonText","cancelButtonText","resetButtonText","resetDate","firstDay","range","link","sync","statusState","opened","noAnimation","direction","skipPortal","DatePicker","externalProps","props","preventClose","onHide","onShow","onSubmit","onCancel","onReset","alignPicker","showSubmitButton","showCancelButton","openedProp","endDate","endDateProp","convertSnakeCaseProps","setOpened","useState","hidden","setHidden","dates","setDates","context","useContext","Context","blurDelay","id","makeUniqueId","innerRef","useRef","triangleRef","submitButtonRef","getReturnObject","hideTimeout","outsideClick","calendarContainerRef","translation","useTranslation","warn","removeOutsideClickHandler","useCallback","current","remove","hidePicker","args","event","persist","setTimeout","focus","preventScroll","e","setOutsideClickHandler","detectOutsideClick","_ref","focusOnHide","setTrianglePosition","triangleWidth","shellWidth","querySelector","getBoundingClientRect","width","buttonWidth","distance","style","marginRight","marginLeft","showPicker","clearTimeout","useLayoutEffect","useEffect","onPickerChange","_ref2","shouldHidePicker","startDate","onSubmitHandler","onCancelHandler","onResetHandler","togglePicker","formatSelectedDateTitle","selectedDate","start","end","currentDate","format","replace","extendedProps","extendPropsWithContext","skeleton","getTranslation","pickFormElementProps","FormRow","formElement","label","title","labelDirection","labelSrOnly","inputElement","addonElement","shortcuts","disabled","stretch","size","status","statusProps","statusNoAnimation","globalStatus","suffix","showResetButton","className","tooltip","restProps","attributes","useMemo","filterOutNonAttributes","shouldHideDays","shouldHideNavigation","showStatus","getStatusState","pickerParams","combineDescribedBy","submitParams","ref","tabIndex","selectedDateTitle","mainParams","classnames","createSpacingClasses","lang","locale","containerClassNames","remainingDOMProps","validateDOMAttributes","remainingSubmitProps","remainingPickerProps","skeletonDOMAttributes","createElement","setReturnObject","fn","forId","text","srOnly","show","text_id","width_selector","state","no_animation","isRange","submitAttributes","alignment","targetElementRef","firstDayOfWeek","isLink","isSync","hideNav","views","nextBtn","prevBtn","hideNextMonthWeek","noAutoFocus","onChange","renderElement","NonAttributes","reduce","includes","_default","exports","_supportsSpacingProps"],"sources":["../../../../src/components/date-picker/DatePicker.tsx"],"sourcesContent":["/**\n * Web DatePicker Component\n *\n */\n\nimport React, {\n HTMLProps,\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'react'\n\nimport classnames from 'classnames'\nimport {\n warn,\n makeUniqueId,\n extendPropsWithContext,\n detectOutsideClick,\n getStatusState,\n combineDescribedBy,\n validateDOMAttributes,\n DetectOutsideClickClass,\n} from '../../shared/component-helper'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport { skeletonDOMAttributes } from '../skeleton/SkeletonHelper'\n\n// date-fns\nimport format from 'date-fns/format'\n\nimport Context, { Locale } from '../../shared/Context'\nimport Suffix from '../../shared/helpers/Suffix'\nimport FormLabel from '../form-label/FormLabel'\nimport FormStatus, {\n FormStatusProps,\n FormStatusState,\n FormStatusText,\n} from '../form-status/FormStatus'\nimport DatePickerProvider, {\n DatePickerChangeEvent,\n type ReturnObject,\n} from './DatePickerProvider'\nimport DatePickerRange from './DatePickerRange'\nimport DatePickerInput from './DatePickerInput'\nimport DatePickerAddon, { DatePickerAddonProps } from './DatePickerAddon'\nimport DatePickerFooter from './DatePickerFooter'\nimport { SpacingProps } from '../space/types'\nimport { InputInputElement, InputSize } from '../Input'\nimport { SkeletonShow } from '../Skeleton'\nimport { GlobalStatusConfigObject } from '../GlobalStatus'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\nimport { CalendarDay, DatePickerCalendarProps } from './DatePickerCalendar'\nimport { DatePickerContextValues, DateType } from './DatePickerContext'\nimport { DatePickerDates } from './hooks/useDates'\nimport { useTranslation } from '../../shared'\nimport { convertSnakeCaseProps } from '../../shared/helpers/withSnakeCaseProps'\nimport DatePickerPortal from './DatePickerPortal'\n\nexport type DatePickerEventAttributes = {\n day?: string\n year?: string\n start?: string\n end?: string\n} & Record<string, unknown>\n\n// Takes the return object from DatePickerProvider and extends it with the event\nexport type DatePickerEvent<T> = ReturnObject<T>\n\ntype FocusOnHide = { focusOnHide?: boolean | string }\n\nexport type DisplayPickerEvent = (\n | React.MouseEvent<HTMLButtonElement | HTMLAnchorElement | HTMLElement>\n | MouseEvent\n | KeyboardEvent\n | FocusOnHide\n) &\n DatePickerDates &\n FocusOnHide & {\n event?: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n }\n\nexport type DatePickerProps = {\n /**\n * Defines the pre-filled date by either a JavaScript DateInstance or (ISO 8601) like `date=\"2019-05-05\"`.\n */\n date?: DateType\n /**\n * To set the pre-filled starting date. Is used if `range={true}` is set to `true`. Defaults to `null`, showing the `maskPlaceholder`.\n */\n startDate?: DateType\n /**\n * To set the pre-filled ending date. Is used if `range={true}` is set to `true`. Defaults to `null`, showing the `maskPlaceholder`.\n */\n endDate?: DateType\n /**\n * To display what month should be shown in the first calendar by default. Defaults to the `date` respective `startDate`.\n */\n month?: DateType\n /**\n * To display what month should be shown in the first calendar by default. Defaults to the `date` respective `startDate`.\n */\n startMonth?: DateType\n /**\n * To display what month should be shown in the second calendar by default. Defaults to the `date` respective `startDate`.\n */\n endMonth?: DateType\n /**\n * To limit a date range to a minimum `startDate`. Defaults to `null`.\n */\n minDate?: DateType\n /**\n * To limit a date range to a maximum `endDate`. Defaults to `null`.\n */\n maxDate?: DateType\n /**\n * Corrects the input date value to be the same as either `minDate` or `maxDate`, when the user types in a date that is either before or after one of these. Defaults to `false`.\n */\n correctInvalidDate?: boolean\n /**\n * To define the order of the masked placeholder input fields. Defaults to `dd/mm/yyyy`\n */\n maskOrder?: string\n /**\n * To display the placeholder on input. Defaults to `dd/mm/åååå`.\n */\n maskPlaceholder?: string\n /**\n * Defines how the prop dates (`date`, `startDate` and `endDate`) should be parsed, e.g. `yyyy/MM/dd`. Defaults to `yyyy-MM-dd`.\n */\n dateFormat?: string\n /**\n * Defines how the returned date, as a string, should be formatted as. Defaults to `yyyy-MM-dd`.\n */\n returnFormat?: string\n /**\n * If set to `true`, the navigation will be hidden. Defaults to `false`.\n */\n hideNavigation?: boolean\n hideNavigationButtons?: boolean\n /**\n * If set to `true`, the week days will be hidden. Defaults to `false`.\n */\n hideDays?: boolean\n /**\n * Use `true` to only show the defined month. Disables the month navigation possibility. Defaults to `false`.\n */\n onlyMonth?: boolean\n /**\n * Use `true` to only show the last week in the current month if it needs to be shown. The result is that there will mainly be shows five (5) weeks (rows) instead of six (6). Defaults to `false`.\n */\n hideLastWeek?: boolean\n /**\n * Once the date picker gets opened, there is a focus handling to ensure good accessibility. can be disabled with property. Defaults to `false`.\n */\n disableAutofocus?: boolean\n enableKeyboardNav?: boolean\n /**\n * If the input fields with the mask should be visible. Defaults to `false`.\n */\n showInput?: boolean\n /**\n * If set to `true`, a submit button will be shown. You can change the default text by using `submitButtonText=\"Ok\"`. Defaults to `false`. If the `range` prop is `true`, then the submit button is shown.\n */\n showSubmitButton?: boolean\n /**\n * If set to `true`, a cancel button will be shown. You can change the default text by using `cancelButtonText=\"Avbryt\"` Defaults to `false`. If the `range` prop is `true`, then the cancel button is shown.\n */\n showCancelButton?: boolean\n /**\n * If set to `true`, a reset button will be shown. You can change the default text by using `resetButtonText=\"Tilbakestill\"` Defaults to `false`.\n */\n showResetButton?: boolean\n submitButtonText?: string\n cancelButtonText?: string\n resetButtonText?: string\n resetDate?: boolean\n /**\n * To define the first day of the week. Defaults to `monday`.\n */\n firstDay?:\n | 'monday'\n | 'tuesday'\n | 'wednesday'\n | 'thursday'\n | 'friday'\n | 'saturday'\n | 'sunday'\n /**\n * If the date picker should support a range of two dates (starting and ending date). Defaults to `false`.\n */\n range?: boolean\n /**\n * Link both calendars, once to the user is navigating between months. Only meant to use if the range is set to `true`. Defaults to `false`.\n */\n link?: boolean\n /**\n * Sync input values with the calendars views. Once the input values get changed, the calendar changes its views in sync. Defaults to `true`.\n */\n sync?: boolean\n /**\n * A prepending label in sync with the date input field.\n */\n label?: React.ReactNode\n /**\n * Use `labelDirection=\"vertical\"` to change the label layout direction. Defaults to `horizontal`.\n */\n labelDirection?: 'vertical' | 'horizontal'\n /**\n * Use `true` to make the label only readable by screen readers.\n */\n labelSrOnly?: boolean\n /**\n * Gives you the possibility to use a plain/vanilla `<input />` HTML element by defining it as a string `inputElement=\"input\"`, a React element, or a render function `inputElement={(internalProps) => (<Return />)}`. Can also be used in circumstances where the `react-text-mask` not should be used, e.g. in testing environments. Defaults to custom masked input.\n */\n inputElement?: InputInputElement\n /**\n * Gives you the possibility to inject a React element showing up over the footer. Use it to customize `shortcuts`.\n */\n addonElement?: React.ReactNode\n /**\n * Gives you the possibility to set predefined dates and date ranges so the user can select these by one click. Define either a JSON or an object with the defined shortcuts. More info is below.\n */\n shortcuts?: DatePickerAddonProps['shortcuts']\n disabled?: boolean\n /**\n * If set to `true`, then the date-picker input field will be 100% in `width`.\n */\n stretch?: boolean\n /**\n * If set to `true`, an overlaying skeleton with animation will be shown.\n */\n skeleton?: SkeletonShow\n /**\n * The sizes you can choose is `small` (1.5rem), `default` (2rem), `medium` (2.5rem) and `large` (3rem) are supported component sizes. Defaults to `default` / `null`.\n */\n size?: InputSize\n /**\n * Text with a status message. The style defaults to an error message. You can use `true` to only get the status color, without a message.\n */\n status?: FormStatusText\n /**\n * Defines the state of the status. Currently, there are two statuses `[error, info]`. Defaults to `error`.\n */\n statusState?: FormStatusState\n /**\n * Use an object to define additional FormStatus properties.\n */\n statusProps?: FormStatusProps\n statusNoAnimation?: boolean\n /**\n * The <a href=\"/uilib/components/global-status/properties/#configuration-object\">configuration</a> used for the target <a href=\"/uilib/components/global-status\">GlobalStatus</a>.\n */\n globalStatus?: GlobalStatusConfigObject\n /**\n * Text describing the content of the DatePicker more than the label. You can also send in a React component, so it gets wrapped inside the DatePicker component.\n */\n suffix?: React.ReactNode\n /**\n * To open the date-picker by default. Defaults to `false`.\n */\n opened?: boolean\n /**\n * Provide a short Tooltip content that shows up on the picker button.\n */\n tooltip?: React.ReactNode\n tabIndex?: number\n preventClose?: boolean\n noAnimation?: boolean\n direction?: 'auto' | 'top' | 'bottom'\n /**\n * Use `right` to change the calendar alignment direction. Defaults to `left`.\n */\n alignPicker?: 'auto' | 'left' | 'right'\n /**\n * If set to `true`, the calendar will not be rendered inside a react portal. Defaults to `false`.\n */\n skipPortal?: boolean\n className?: string\n /**\n * Will be called right before every new calendar view gets rendered. See the example above.\n */\n onDaysRender?: (\n days: Array<CalendarDay>,\n nr?: DatePickerCalendarProps['nr']\n ) => void\n /**\n * Will be called on a date change event. Returns an `object`. See Returned Object below.\n */\n onChange?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called on every input and date picker interaction. Returns an `object`. See Returned Object below.\n */\n onType?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called once date-picker is visible.\n */\n onShow?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * Will be called once date-picker is hidden.\n */\n onHide?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * Will be called once a user presses the submit button.\n */\n onSubmit?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * Will be called once a user presses the cancel button.\n */\n onCancel?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * Will be called once a user presses the reset button.\n */\n onReset?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * Will be called once the input gets focus.\n */\n onFocus?: (event: DatePickerEvent<React.FocusEvent<HTMLElement>>) => void\n /**\n * Will be called once the input lose focus.\n */\n onBlur?: (event: DatePickerEvent<React.FocusEvent<HTMLElement>>) => void\n}\n// Can be removed in v11\ntype DatePickerDeprecatedProps = {\n /**\n * @deprecated use `startDate` instead.\n */\n start_date?: DateType\n /**\n * @deprecated use `endDate` instead.\n */\n end_date?: DateType\n /**\n * @deprecated use `startMonth` instead.\n */\n start_month?: DateType\n /**\n * @deprecated use `endMonth` instead.\n */\n end_month?: DateType\n /**\n * @deprecated use `minDate` instead.\n */\n min_date?: DateType\n /**\n * @deprecated use `maxDate` instead.\n */\n max_date?: DateType\n /**\n * @deprecated use `correctInvalidDate` instead.\n */\n correct_invalid_date?: boolean\n /**\n * @deprecated use `maskOrder` instead.\n */\n mask_order?: string\n /**\n * @deprecated use `maskPlaceholder` instead.\n */\n mask_placeholder?: string\n /**\n * @deprecated use `dateFormat` instead.\n */\n date_format?: string\n /**\n * @deprecated use `returnFormat` instead.\n */\n return_format?: string\n /**\n * @deprecated use `hideNavigation` instead.\n */\n hide_navigation?: boolean\n /**\n * @deprecated use `hideNavigationButtons` instead.\n */\n hide_navigation_buttons?: boolean\n /**\n * @deprecated use `hideDays` instead.\n */\n hide_days?: boolean\n /**\n * @deprecated use `onlyMonth` instead.\n */\n only_month?: boolean\n /**\n * @deprecated use `hideLastWeek` instead.\n */\n hide_last_week?: boolean\n /**\n * @deprecated use `disableAutofocus` instead.\n */\n disable_autofocus?: boolean\n /**\n * @deprecated use `enableKeyboardNav` instead.\n */\n enable_keyboard_nav?: boolean\n /**\n * @deprecated use `showInput` instead.\n */\n show_input?: boolean\n /**\n * @deprecated use `showSubmitButton` instead.\n */\n show_submit_button?: boolean\n /**\n * @deprecated use `showCancelButton` instead.\n */\n show_cancel_button?: boolean\n /**\n * @deprecated\n */\n show_reset_button?: boolean\n /**\n * @deprecated use `submitButtonText` instead.\n */\n submit_button_text?: string\n /**\n * @deprecated use `cancelButtonText` instead.\n */\n cancel_button_text?: string\n /**\n * @deprecated use `resetButtonText` instead.\n */\n reset_button_text?: string\n /**\n * @deprecated use `resetDate` instead.\n */\n reset_date?: boolean\n /**\n * @deprecated use `firstDay` instead.\n */\n first_day?: string\n /**\n * @deprecated set locale with `Provider` instead.\n */\n locale?: Locale\n /**\n * @deprecated use `labelDirection` instead.\n */\n label_direction?: 'vertical' | 'horizontal'\n /**\n * @deprecated use `labelSrOnly` instead.\n */\n label_sr_only?: boolean\n /**\n * @deprecated use `inputElement` instead.\n */\n input_element?: InputInputElement\n /**\n * @deprecated use `addonElement` instead.\n */\n addon_element?: React.ReactNode\n /**\n * @deprecated use `statusState` instead.\n */\n status_state?: FormStatusState\n /**\n * @deprecated use `statusProps` instead.\n */\n status_props?: FormStatusProps\n /**\n * @deprecated use `statusNoAnimation` instead.\n */\n status_no_animation?: boolean\n /**\n * @deprecated use `preventClose` instead.\n */\n prevent_close?: boolean\n /**\n * @deprecated use `no_animation` instead.\n */\n no_animation?: boolean\n /**\n * @deprecated use `alignPicker` instead.\n */\n align_picker?: 'auto' | 'left' | 'right'\n /**\n * @deprecated use `onDaysRender` instead.\n */\n on_days_render?: (\n days: Array<CalendarDay>,\n nr?: DatePickerCalendarProps['nr']\n ) => void\n /**\n * @deprecated use `onChange` instead.\n */\n on_change?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * @deprecated use `onType` instead.\n */\n on_type?: (\n event: DatePickerEvent<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * @deprecated use `onShow` instead.\n */\n on_show?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * @deprecated use `onHide` instead.\n */\n on_hide?: (event: DatePickerEvent<DisplayPickerEvent>) => void\n /**\n * @deprecated use `onSubmit` instead.\n */\n on_submit?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * @deprecated use `onCancel` instead.\n */\n on_cancel?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n /**\n * @deprecated use `onReset` instead.\n */\n on_reset?: (\n event: DatePickerEvent<React.MouseEvent<HTMLButtonElement>>\n ) => void\n}\n\nexport type DatePickerAllProps = DatePickerProps &\n DatePickerDeprecatedProps &\n SpacingProps &\n Omit<\n React.HTMLProps<HTMLElement>,\n | 'ref'\n | 'children'\n | 'label'\n | 'size'\n | 'onChange'\n | 'onBlur'\n | 'onFocus'\n | 'onSubmit'\n | 'onReset'\n | 'start'\n >\n\nconst defaultProps: DatePickerProps = {\n maskOrder: 'dd/mm/yyyy',\n maskPlaceholder: 'dd/mm/åååå', // have to be same setup as \"mask\" - but can be like\n dateFormat: 'yyyy-MM-dd', // in v1 of date-fns we were more flexible in terms of the format\n returnFormat: 'yyyy-MM-dd', // used in date-fns v1\n hideNavigation: false,\n hideNavigationButtons: false,\n hideDays: false,\n onlyMonth: false,\n hideLastWeek: false,\n disableAutofocus: false,\n enableKeyboardNav: false,\n showInput: false,\n submitButtonText: 'Ok',\n cancelButtonText: 'Avbryt',\n resetButtonText: 'Tilbakestill',\n resetDate: true,\n firstDay: 'monday',\n range: false,\n link: false,\n sync: true,\n statusState: 'error',\n opened: false,\n noAnimation: false,\n direction: 'auto',\n skipPortal: false,\n}\n\nfunction DatePicker(externalProps: DatePickerAllProps) {\n const props = { ...defaultProps, ...externalProps }\n\n const {\n preventClose,\n onHide,\n onShow,\n onSubmit,\n onCancel,\n onReset,\n noAnimation,\n showInput,\n alignPicker,\n showSubmitButton,\n showCancelButton,\n range,\n hideDays,\n hideNavigation,\n opened: openedProp,\n endDate: endDateProp,\n } = convertSnakeCaseProps(props) // convertSnakeCaseProps - can be removed in v11\n\n const [opened, setOpened] = useState<boolean>(openedProp)\n const [hidden, setHidden] = useState(!opened)\n const [dates, setDates] = useState<\n Pick<DatePickerDates, 'startDate' | 'endDate'>\n >({})\n\n const context = useContext(Context)\n const blurDelay = 201 // some ms more than \"dropdownSlideDown 200ms\"\n const id = props.id || makeUniqueId()\n\n const innerRef = useRef<HTMLSpanElement>()\n const triangleRef = useRef<HTMLSpanElement>()\n const submitButtonRef = useRef<HTMLButtonElement>()\n const getReturnObject =\n useRef<DatePickerContextValues['getReturnObject']>()\n const hideTimeout = useRef<NodeJS.Timeout>()\n const outsideClick = useRef<DetectOutsideClickClass>()\n const calendarContainerRef = useRef<HTMLDivElement>()\n\n const translation = useTranslation().DatePicker\n\n if (endDateProp && !range) {\n warn(\n `The DatePicker got a \"endDate\". You have to set range={true} as well!.`\n )\n }\n\n const removeOutsideClickHandler = useCallback(() => {\n if (outsideClick.current) {\n outsideClick.current.remove()\n }\n }, [])\n\n const hidePicker = useCallback(\n (args?: DisplayPickerEvent) => {\n if (preventClose) {\n return // stop here\n }\n\n if (args && args.event && args.event.persist) {\n args.event.persist()\n }\n\n setOpened(false)\n\n hideTimeout.current = setTimeout(\n () => {\n setHidden(true)\n onHide?.({\n ...getReturnObject.current(args),\n })\n if (args?.['focusOnHide']) {\n try {\n submitButtonRef.current.focus({\n preventScroll: true,\n })\n } catch (e) {\n warn(e)\n }\n }\n },\n noAnimation ? 1 : blurDelay\n ) // wait until animation is over\n\n removeOutsideClickHandler()\n },\n [noAnimation, preventClose, onHide, removeOutsideClickHandler]\n )\n\n const setOutsideClickHandler = useCallback(() => {\n outsideClick.current = detectOutsideClick(\n // Sending in portalRef, instead of portalRef.current,\n // as that would lead to the ignoreElement being null/undefined,\n // since the portal has not been rendered yet,\n // causing the calendar to close when clicking on the calendar itself\n [innerRef.current, calendarContainerRef],\n ({ event }: { event: MouseEvent | KeyboardEvent }) => {\n hidePicker({ ...event, focusOnHide: event?.['code'] })\n }\n )\n }, [hidePicker])\n\n const setTrianglePosition = useCallback(() => {\n const triangleWidth = 16\n if (showInput && triangleRef.current && innerRef.current) {\n try {\n const shellWidth = innerRef.current\n .querySelector('.dnb-input__shell')\n .getBoundingClientRect().width\n\n const buttonWidth = innerRef.current\n .querySelector('.dnb-input__submit-button__button')\n .getBoundingClientRect().width\n\n if (alignPicker === 'right') {\n const distance = buttonWidth / 2 - triangleWidth / 2\n triangleRef.current.style.marginRight = `${distance / 16}rem`\n } else {\n const distance = shellWidth - buttonWidth / 2 - triangleWidth / 2\n triangleRef.current.style.marginLeft = `${distance / 16}rem`\n }\n } catch (e) {\n warn(e)\n }\n }\n }, [showInput, alignPicker])\n\n const showPicker = useCallback(\n (event?: DisplayPickerEvent) => {\n if (hideTimeout.current) {\n clearTimeout(hideTimeout.current)\n }\n\n setOpened(true)\n setHidden(false)\n\n onShow?.({ ...getReturnObject.current(event) })\n\n setOutsideClickHandler()\n },\n [setOutsideClickHandler, onShow]\n )\n\n // Make sure the triangle is positioned correctly after calendar is mounted\n useLayoutEffect(() => {\n if (!hidden) {\n setTrianglePosition()\n }\n }, [hidden, setTrianglePosition])\n\n // React to opened prop changes\n useEffect(() => {\n if (openedProp) {\n showPicker()\n }\n }, [openedProp, showPicker])\n\n const onPickerChange = useCallback(\n ({\n hidePicker: shouldHidePicker = true,\n ...args\n }: DatePickerChangeEvent<\n | React.MouseEvent<HTMLSpanElement>\n | React.KeyboardEvent<HTMLTableElement>\n >) => {\n if (shouldHidePicker && !showSubmitButton && !showCancelButton) {\n hidePicker({ focusOnHide: true })\n }\n\n setDates({ startDate: args.startDate, endDate: args.endDate })\n },\n [hidePicker, showSubmitButton, showCancelButton]\n )\n\n const onSubmitHandler = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n hidePicker(event)\n onSubmit?.({\n ...getReturnObject.current({ event }),\n })\n },\n [hidePicker, onSubmit]\n )\n\n const onCancelHandler = useCallback(\n (\n event: DatePickerChangeEvent<React.MouseEvent<HTMLButtonElement>>\n ) => {\n hidePicker()\n onCancel?.({ ...getReturnObject.current(event) })\n },\n [hidePicker, onCancel]\n )\n\n const onResetHandler = useCallback(\n (\n event: DatePickerChangeEvent<React.MouseEvent<HTMLButtonElement>>\n ) => {\n hidePicker()\n onReset?.({ ...getReturnObject.current(event) })\n },\n [hidePicker, onReset]\n )\n\n const togglePicker = useCallback(\n (args: React.MouseEvent<HTMLButtonElement>) => {\n !opened ? showPicker(args) : hidePicker(args)\n },\n [opened, showPicker, hidePicker]\n )\n\n const formatSelectedDateTitle = useCallback(() => {\n const { selectedDate, start, end } = translation\n const { startDate, endDate } = dates\n\n let currentDate = startDate ? format(startDate, 'PPPP') : null\n\n if (range && startDate && endDate) {\n currentDate = `${start} ${currentDate} - ${end} ${format(\n endDate,\n 'PPPP'\n )}`\n }\n\n return currentDate ? selectedDate.replace(/%s/, currentDate) : ''\n }, [range, translation, dates])\n\n // use only the props from context, who are available here anyway\n const extendedProps = extendPropsWithContext(\n props,\n defaultProps,\n { skeleton: context?.skeleton },\n convertSnakeCaseProps(context.getTranslation(props).DatePicker), // convertSnakeCaseProps - can be removed in v11\n pickFormElementProps(context?.FormRow), // Deprecated – can be removed in v11\n convertSnakeCaseProps(pickFormElementProps(context?.formElement)), // Deprecated – can be removed in v11\n context.DatePicker\n )\n\n const {\n label,\n title,\n labelDirection,\n labelSrOnly,\n onlyMonth,\n hideLastWeek,\n disableAutofocus,\n hideNavigationButtons,\n firstDay,\n resetDate,\n link,\n sync,\n inputElement,\n addonElement,\n shortcuts,\n disabled,\n stretch,\n skeleton,\n size,\n status,\n statusState,\n statusProps,\n statusNoAnimation,\n globalStatus,\n suffix,\n maskOrder,\n maskPlaceholder,\n submitButtonText,\n cancelButtonText,\n resetButtonText,\n showResetButton,\n className,\n tooltip,\n skipPortal,\n ...restProps\n } = extendedProps\n\n const attributes = useMemo(\n () => filterOutNonAttributes(restProps),\n [restProps]\n )\n\n const shouldHideDays = onlyMonth ? true : hideDays\n const shouldHideNavigation = onlyMonth\n ? hideNavigationButtons\n ? false\n : true\n : hideNavigation\n\n const showStatus = getStatusState(status)\n\n const pickerParams = {} as HTMLProps<HTMLSpanElement>\n\n if (showStatus || suffix) {\n pickerParams['aria-describedby'] = combineDescribedBy(\n pickerParams,\n showStatus ? id + '-status' : null,\n suffix ? id + '-suffix' : null\n )\n }\n\n const submitParams = {\n ['aria-expanded']: opened,\n ref: submitButtonRef,\n tabIndex: extendedProps.tabIndex,\n tooltip,\n }\n\n const selectedDateTitle = formatSelectedDateTitle()\n\n const mainParams = {\n className: classnames(\n 'dnb-date-picker',\n status && `dnb-date-picker__status--${statusState}`,\n labelDirection && `dnb-date-picker--${labelDirection}`,\n opened && 'dnb-date-picker--opened',\n hidden && 'dnb-date-picker--hidden',\n showInput && 'dnb-date-picker--show-input',\n (range || showSubmitButton || showCancelButton || showResetButton) &&\n 'dnb-date-picker--show-footer',\n alignPicker && `dnb-date-picker--${alignPicker}`,\n stretch && `dnb-date-picker--stretch`,\n 'dnb-form-component',\n size && `dnb-date-picker--${size}`,\n createSpacingClasses(props),\n className\n ),\n lang: context.locale,\n } as HTMLProps<HTMLSpanElement>\n\n const containerClassNames = classnames(\n 'dnb-date-picker__container',\n opened && 'dnb-date-picker__container--opened',\n !opened && 'dnb-date-picker__container--closed',\n hidden && 'dnb-date-picker__container--hidden',\n showInput && 'dnb-date-picker__container--show-input',\n alignPicker && `dnb-date-picker__container--${alignPicker}`,\n size && `dnb-date-picker--${size}`\n )\n\n const remainingDOMProps = validateDOMAttributes(props, attributes)\n const remainingSubmitProps = validateDOMAttributes(null, submitParams)\n const remainingPickerProps = validateDOMAttributes(\n null,\n skeletonDOMAttributes(pickerParams, skeleton, context)\n )\n\n return (\n <DatePickerProvider\n {...props}\n attributes={remainingDOMProps}\n setReturnObject={(fn) => (getReturnObject.current = fn)}\n hidePicker={hidePicker}\n >\n <span {...mainParams}>\n {label && (\n <FormLabel\n id={id + '-label'}\n forId={id}\n text={label}\n labelDirection={labelDirection}\n srOnly={labelSrOnly}\n disabled={disabled}\n skeleton={skeleton}\n />\n )}\n\n <span\n className=\"dnb-date-picker__inner\"\n ref={innerRef}\n {...remainingPickerProps}\n >\n <AlignmentHelper />\n\n <FormStatus\n show={showStatus}\n id={id + '-form-status'}\n globalStatus={globalStatus}\n label={String(label)}\n text_id={id + '-status'} // used for \"aria-describedby\"\n width_selector={id + '-shell'}\n text={status}\n state={statusState}\n no_animation={statusNoAnimation}\n skeleton={skeleton}\n {...statusProps}\n />\n\n <span className=\"dnb-date-picker__row\">\n <span className=\"dnb-date-picker__shell\" id={`${id}-shell`}>\n <DatePickerInput\n id={id}\n title={title}\n disabled={disabled}\n stretch={stretch}\n skeleton={skeleton}\n maskOrder={maskOrder}\n maskPlaceholder={maskPlaceholder}\n isRange={range}\n showInput={showInput}\n selectedDateTitle={selectedDateTitle}\n inputElement={inputElement}\n opened={opened}\n hidden={hidden}\n size={size}\n status={status ? 'error' : null}\n statusState={statusState}\n lang={context.locale}\n {...attributes}\n submitAttributes={remainingSubmitProps}\n onSubmit={togglePicker}\n {...statusProps}\n />\n\n {!hidden && (\n <DatePickerPortal\n alignment={alignPicker}\n skipPortal={skipPortal}\n targetElementRef={innerRef}\n >\n <span\n className={containerClassNames}\n ref={calendarContainerRef}\n >\n <span\n className=\"dnb-date-picker__triangle\"\n ref={triangleRef}\n />\n <DatePickerRange\n id={id}\n firstDayOfWeek={firstDay}\n resetDate={resetDate}\n isRange={range}\n isLink={link}\n isSync={sync}\n hideDays={shouldHideDays}\n hideNav={shouldHideNavigation}\n views={\n hideNavigationButtons\n ? [{ nextBtn: false, prevBtn: false }]\n : null\n }\n onlyMonth={onlyMonth}\n hideNextMonthWeek={hideLastWeek}\n noAutoFocus={disableAutofocus}\n onChange={onPickerChange}\n locale={context.locale}\n />\n {(addonElement || shortcuts) && (\n <DatePickerAddon\n renderElement={addonElement}\n shortcuts={shortcuts}\n />\n )}\n <DatePickerFooter\n isRange={range}\n onSubmit={onSubmitHandler}\n onCancel={onCancelHandler}\n onReset={onResetHandler}\n submitButtonText={submitButtonText}\n cancelButtonText={cancelButtonText}\n resetButtonText={resetButtonText}\n />\n </span>\n </DatePickerPortal>\n )}\n </span>\n {suffix && (\n <Suffix\n className=\"dnb-date-picker__suffix\"\n id={id + '-suffix'} // used for \"aria-describedby\"\n context={props}\n >\n {suffix}\n </Suffix>\n )}\n </span>\n </span>\n\n <p className=\"dnb-sr-only\" aria-live=\"assertive\">\n {selectedDateTitle}\n </p>\n </span>\n </DatePickerProvider>\n )\n}\n\nconst NonAttributes = [\n 'locale',\n 'id',\n 'month',\n 'date',\n 'startDate',\n 'endDate',\n 'minDate',\n 'maxDate',\n 'enableKeyboardNav',\n 'hideNavigation',\n 'returnFormat',\n 'dateFormat',\n 'hideDays',\n 'correctInvalidDate',\n 'opened',\n 'direction',\n 'range',\n 'showInput',\n 'noAnimation',\n 'onDaysRender',\n 'onShow',\n 'onType',\n 'onHide',\n 'showSubmitButton',\n 'showCancelButton',\n 'selectedDate',\n 'selectedMonth',\n 'selectedYear',\n 'nextMonth',\n 'nextYear',\n 'openPickerText',\n 'placeholderCharacters',\n 'prevMonth',\n 'prevYear',\n 'endMonth',\n 'startMonth',\n 'alignPicker',\n 'preventClose',\n]\n\nfunction filterOutNonAttributes(props: DatePickerProps) {\n return Object.keys(props).reduce((attributes, key) => {\n if (!NonAttributes.includes(key)) {\n attributes[key] = props[key]\n }\n return attributes\n }, {})\n}\n\nexport default DatePicker\n\nDatePicker._supportsSpacingProps = true\n"],"mappings":"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"}
|
|
@@ -15,6 +15,11 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
|
|
|
15
15
|
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; }
|
|
16
16
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
17
17
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
18
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
19
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
20
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
21
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
22
|
+
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
18
23
|
function DatePickerAddon(props) {
|
|
19
24
|
const {
|
|
20
25
|
updateDates,
|
|
@@ -65,7 +70,9 @@ function DatePickerAddon(props) {
|
|
|
65
70
|
event
|
|
66
71
|
});
|
|
67
72
|
if (shortcut.close_on_select) {
|
|
68
|
-
hidePicker(event)
|
|
73
|
+
hidePicker(_objectSpread(_objectSpread({}, event), {}, {
|
|
74
|
+
focusOnHide: true
|
|
75
|
+
}));
|
|
69
76
|
}
|
|
70
77
|
}, [callOnChange, currentDates, hidePicker]);
|
|
71
78
|
const shortcutsArray = (0, _react.useMemo)(() => shortcuts ? typeof shortcuts === 'string' ? JSON.parse(shortcuts) : shortcuts : [], [shortcuts]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DatePickerAddon.js","names":["_react","_interopRequireWildcard","require","_DatePickerCalc","_Button","_interopRequireDefault","_DatePickerContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_objectWithoutProperties","source","excluded","target","_objectWithoutPropertiesLoose","i","getOwnPropertySymbols","sourceSymbolKeys","length","indexOf","propertyIsEnumerable","sourceKeys","keys","DatePickerAddon","props","updateDates","forceViewMonthChange","callOnChangeHandler","hidePicker","startDate","endDate","useContext","DatePickerContext","shortcuts","renderElement","currentDates","useMemo","date","start_date","end_date","callOnChange","useCallback","event","arguments","undefined","setDate","_ref","shortcut","convertStringToDate","close_on_select","shortcutsArray","JSON","parse","hasShortcuts","shortcutElements","createElement","Fragment","map","_ref2","title","text","variant","onClick","className","_default","exports"],"sources":["../../../../src/components/date-picker/DatePickerAddon.tsx"],"sourcesContent":["/**\n * Web DatePicker Component\n *\n */\n\nimport React, { useCallback, useContext, useMemo } from 'react'\nimport { convertStringToDate } from './DatePickerCalc'\nimport Button from '../button/Button'\nimport DatePickerContext from './DatePickerContext'\n\n// TODO: convert shortcut properties to camelCase, constitutes a breaking change - could be included in v11\nexport type DatePickerShortcut = {\n title?: string\n date?: string | Date | ((...args: unknown[]) => Date)\n start_date?: string | Date | ((...args: unknown[]) => Date)\n end_date?: string | Date | ((...args: unknown[]) => Date)\n close_on_select?: boolean\n}\n\nexport type DatePickerAddonProps = React.HTMLProps<HTMLElement> & {\n /**\n * Gives you the possibility to set predefined dates and date ranges so the user can select these by one click. Define either a JSON or an object with the defined shortcuts. More info is below.\n */\n shortcuts?: Array<DatePickerShortcut> | string\n renderElement?: React.ReactNode\n}\n\nfunction DatePickerAddon(props: DatePickerAddonProps) {\n const {\n updateDates,\n forceViewMonthChange,\n callOnChangeHandler,\n hidePicker,\n startDate,\n endDate,\n } = useContext(DatePickerContext)\n\n const { shortcuts, renderElement } = props\n\n const currentDates = useMemo(\n () => ({\n date: startDate,\n start_date: startDate,\n end_date: endDate,\n }),\n [startDate, endDate]\n )\n\n const callOnChange = useCallback(\n ({\n startDate,\n endDate,\n event = null,\n }: {\n startDate?: Date\n endDate?: Date\n event?: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n } = {}) => {\n updateDates({ startDate, endDate })\n forceViewMonthChange()\n callOnChangeHandler({\n startDate,\n endDate: endDate || startDate,\n event,\n })\n },\n [updateDates, callOnChangeHandler, forceViewMonthChange]\n )\n\n const setDate = useCallback(\n ({\n shortcut,\n event,\n }: {\n shortcut: DatePickerShortcut\n event: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n }) => {\n const start_date = shortcut.date || shortcut.start_date\n const end_date = shortcut.end_date\n\n const startDate =\n typeof start_date === 'function'\n ? start_date(currentDates)\n : start_date\n ? convertStringToDate(start_date)\n : null\n\n const endDate =\n typeof end_date === 'function'\n ? end_date(currentDates)\n : end_date\n ? convertStringToDate(end_date)\n : null\n\n callOnChange({\n startDate,\n endDate: endDate || startDate,\n event,\n })\n\n if (shortcut.close_on_select) {\n hidePicker(event)\n }\n },\n [callOnChange, currentDates, hidePicker]\n )\n\n const shortcutsArray: Array<DatePickerShortcut> = useMemo(\n () =>\n shortcuts\n ? typeof shortcuts === 'string'\n ? JSON.parse(shortcuts)\n : shortcuts\n : [],\n [shortcuts]\n )\n\n const hasShortcuts = shortcutsArray && shortcutsArray.length > 0\n\n const shortcutElements = useMemo(\n () =>\n hasShortcuts && (\n <>\n {shortcutsArray.map(({ title, ...shortcut }, i: number) => {\n return (\n <Button\n key={i}\n text={title}\n variant=\"secondary\"\n onClick={(event) => setDate({ shortcut, event })}\n />\n )\n })}\n </>\n ),\n [hasShortcuts, shortcutsArray, setDate]\n )\n\n if (!hasShortcuts && !renderElement) {\n return <></>\n }\n\n return (\n <div className=\"dnb-date-picker__addon\">\n {renderElement}\n {shortcutElements}\n </div>\n )\n}\n\nexport default DatePickerAddon\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"DatePickerAddon.js","names":["_react","_interopRequireWildcard","require","_DatePickerCalc","_Button","_interopRequireDefault","_DatePickerContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_objectWithoutProperties","source","excluded","target","_objectWithoutPropertiesLoose","i","getOwnPropertySymbols","sourceSymbolKeys","length","indexOf","propertyIsEnumerable","sourceKeys","keys","ownKeys","object","enumerableOnly","symbols","filter","sym","enumerable","push","apply","_objectSpread","arguments","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","DatePickerAddon","props","updateDates","forceViewMonthChange","callOnChangeHandler","hidePicker","startDate","endDate","useContext","DatePickerContext","shortcuts","renderElement","currentDates","useMemo","date","start_date","end_date","callOnChange","useCallback","event","setDate","_ref","shortcut","convertStringToDate","close_on_select","focusOnHide","shortcutsArray","JSON","parse","hasShortcuts","shortcutElements","createElement","Fragment","map","_ref2","title","text","variant","onClick","className","_default","exports"],"sources":["../../../../src/components/date-picker/DatePickerAddon.tsx"],"sourcesContent":["/**\n * Web DatePicker Component\n *\n */\n\nimport React, { useCallback, useContext, useMemo } from 'react'\nimport { convertStringToDate } from './DatePickerCalc'\nimport Button from '../button/Button'\nimport DatePickerContext from './DatePickerContext'\n\n// TODO: convert shortcut properties to camelCase, constitutes a breaking change - could be included in v11\nexport type DatePickerShortcut = {\n title?: string\n date?: string | Date | ((...args: unknown[]) => Date)\n start_date?: string | Date | ((...args: unknown[]) => Date)\n end_date?: string | Date | ((...args: unknown[]) => Date)\n close_on_select?: boolean\n}\n\nexport type DatePickerAddonProps = React.HTMLProps<HTMLElement> & {\n /**\n * Gives you the possibility to set predefined dates and date ranges so the user can select these by one click. Define either a JSON or an object with the defined shortcuts. More info is below.\n */\n shortcuts?: Array<DatePickerShortcut> | string\n renderElement?: React.ReactNode\n}\n\nfunction DatePickerAddon(props: DatePickerAddonProps) {\n const {\n updateDates,\n forceViewMonthChange,\n callOnChangeHandler,\n hidePicker,\n startDate,\n endDate,\n } = useContext(DatePickerContext)\n\n const { shortcuts, renderElement } = props\n\n const currentDates = useMemo(\n () => ({\n date: startDate,\n start_date: startDate,\n end_date: endDate,\n }),\n [startDate, endDate]\n )\n\n const callOnChange = useCallback(\n ({\n startDate,\n endDate,\n event = null,\n }: {\n startDate?: Date\n endDate?: Date\n event?: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n } = {}) => {\n updateDates({ startDate, endDate })\n forceViewMonthChange()\n callOnChangeHandler({\n startDate,\n endDate: endDate || startDate,\n event,\n })\n },\n [updateDates, callOnChangeHandler, forceViewMonthChange]\n )\n\n const setDate = useCallback(\n ({\n shortcut,\n event,\n }: {\n shortcut: DatePickerShortcut\n event: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n }) => {\n const start_date = shortcut.date || shortcut.start_date\n const end_date = shortcut.end_date\n\n const startDate =\n typeof start_date === 'function'\n ? start_date(currentDates)\n : start_date\n ? convertStringToDate(start_date)\n : null\n\n const endDate =\n typeof end_date === 'function'\n ? end_date(currentDates)\n : end_date\n ? convertStringToDate(end_date)\n : null\n\n callOnChange({\n startDate,\n endDate: endDate || startDate,\n event,\n })\n\n if (shortcut.close_on_select) {\n hidePicker({ ...event, focusOnHide: true })\n }\n },\n [callOnChange, currentDates, hidePicker]\n )\n\n const shortcutsArray: Array<DatePickerShortcut> = useMemo(\n () =>\n shortcuts\n ? typeof shortcuts === 'string'\n ? JSON.parse(shortcuts)\n : shortcuts\n : [],\n [shortcuts]\n )\n\n const hasShortcuts = shortcutsArray && shortcutsArray.length > 0\n\n const shortcutElements = useMemo(\n () =>\n hasShortcuts && (\n <>\n {shortcutsArray.map(({ title, ...shortcut }, i: number) => {\n return (\n <Button\n key={i}\n text={title}\n variant=\"secondary\"\n onClick={(event) => setDate({ shortcut, event })}\n />\n )\n })}\n </>\n ),\n [hasShortcuts, shortcutsArray, setDate]\n )\n\n if (!hasShortcuts && !renderElement) {\n return <></>\n }\n\n return (\n <div className=\"dnb-date-picker__addon\">\n {renderElement}\n {shortcutElements}\n </div>\n )\n}\n\nexport default DatePickerAddon\n"],"mappings":";;;;;;;AAKA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,eAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,kBAAA,GAAAD,sBAAA,CAAAH,OAAA;AAAmD,MAAAK,SAAA;AAAA,SAAAF,uBAAAG,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAX,wBAAAO,GAAA,EAAAI,WAAA,SAAAA,WAAA,IAAAJ,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAQ,KAAA,GAAAL,wBAAA,CAAAC,WAAA,OAAAI,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAT,GAAA,YAAAQ,KAAA,CAAAE,GAAA,CAAAV,GAAA,SAAAW,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAhB,GAAA,QAAAgB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAnB,GAAA,EAAAgB,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAf,GAAA,EAAAgB,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAhB,GAAA,CAAAgB,GAAA,SAAAL,MAAA,CAAAT,OAAA,GAAAF,GAAA,MAAAQ,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAArB,GAAA,EAAAW,MAAA,YAAAA,MAAA;AAAA,SAAAW,yBAAAC,MAAA,EAAAC,QAAA,QAAAD,MAAA,yBAAAE,MAAA,GAAAC,6BAAA,CAAAH,MAAA,EAAAC,QAAA,OAAAR,GAAA,EAAAW,CAAA,MAAAd,MAAA,CAAAe,qBAAA,QAAAC,gBAAA,GAAAhB,MAAA,CAAAe,qBAAA,CAAAL,MAAA,QAAAI,CAAA,MAAAA,CAAA,GAAAE,gBAAA,CAAAC,MAAA,EAAAH,CAAA,MAAAX,GAAA,GAAAa,gBAAA,CAAAF,CAAA,OAAAH,QAAA,CAAAO,OAAA,CAAAf,GAAA,uBAAAH,MAAA,CAAAI,SAAA,CAAAe,oBAAA,CAAAb,IAAA,CAAAI,MAAA,EAAAP,GAAA,aAAAS,MAAA,CAAAT,GAAA,IAAAO,MAAA,CAAAP,GAAA,cAAAS,MAAA;AAAA,SAAAC,8BAAAH,MAAA,EAAAC,QAAA,QAAAD,MAAA,yBAAAE,MAAA,WAAAQ,UAAA,GAAApB,MAAA,CAAAqB,IAAA,CAAAX,MAAA,OAAAP,GAAA,EAAAW,CAAA,OAAAA,CAAA,MAAAA,CAAA,GAAAM,UAAA,CAAAH,MAAA,EAAAH,CAAA,MAAAX,GAAA,GAAAiB,UAAA,CAAAN,CAAA,OAAAH,QAAA,CAAAO,OAAA,CAAAf,GAAA,kBAAAS,MAAA,CAAAT,GAAA,IAAAO,MAAA,CAAAP,GAAA,YAAAS,MAAA;AAAA,SAAAU,QAAAC,MAAA,EAAAC,cAAA,QAAAH,IAAA,GAAArB,MAAA,CAAAqB,IAAA,CAAAE,MAAA,OAAAvB,MAAA,CAAAe,qBAAA,QAAAU,OAAA,GAAAzB,MAAA,CAAAe,qBAAA,CAAAQ,MAAA,GAAAC,cAAA,KAAAC,OAAA,GAAAA,OAAA,CAAAC,MAAA,WAAAC,GAAA,WAAA3B,MAAA,CAAAE,wBAAA,CAAAqB,MAAA,EAAAI,GAAA,EAAAC,UAAA,OAAAP,IAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,IAAA,EAAAI,OAAA,YAAAJ,IAAA;AAAA,SAAAU,cAAAnB,MAAA,aAAAE,CAAA,MAAAA,CAAA,GAAAkB,SAAA,CAAAf,MAAA,EAAAH,CAAA,UAAAJ,MAAA,WAAAsB,SAAA,CAAAlB,CAAA,IAAAkB,SAAA,CAAAlB,CAAA,QAAAA,CAAA,OAAAQ,OAAA,CAAAtB,MAAA,CAAAU,MAAA,OAAAuB,OAAA,WAAA9B,GAAA,IAAA+B,eAAA,CAAAtB,MAAA,EAAAT,GAAA,EAAAO,MAAA,CAAAP,GAAA,SAAAH,MAAA,CAAAmC,yBAAA,GAAAnC,MAAA,CAAAoC,gBAAA,CAAAxB,MAAA,EAAAZ,MAAA,CAAAmC,yBAAA,CAAAzB,MAAA,KAAAY,OAAA,CAAAtB,MAAA,CAAAU,MAAA,GAAAuB,OAAA,WAAA9B,GAAA,IAAAH,MAAA,CAAAC,cAAA,CAAAW,MAAA,EAAAT,GAAA,EAAAH,MAAA,CAAAE,wBAAA,CAAAQ,MAAA,EAAAP,GAAA,iBAAAS,MAAA;AAAA,SAAAsB,gBAAA/C,GAAA,EAAAgB,GAAA,EAAAkC,KAAA,IAAAlC,GAAA,GAAAmC,cAAA,CAAAnC,GAAA,OAAAA,GAAA,IAAAhB,GAAA,IAAAa,MAAA,CAAAC,cAAA,CAAAd,GAAA,EAAAgB,GAAA,IAAAkC,KAAA,EAAAA,KAAA,EAAAT,UAAA,QAAAW,YAAA,QAAAC,QAAA,oBAAArD,GAAA,CAAAgB,GAAA,IAAAkC,KAAA,WAAAlD,GAAA;AAAA,SAAAmD,eAAAG,GAAA,QAAAtC,GAAA,GAAAuC,YAAA,CAAAD,GAAA,2BAAAtC,GAAA,gBAAAA,GAAA,GAAAwC,MAAA,CAAAxC,GAAA;AAAA,SAAAuC,aAAAE,KAAA,EAAAC,IAAA,eAAAD,KAAA,iBAAAA,KAAA,kBAAAA,KAAA,MAAAE,IAAA,GAAAF,KAAA,CAAAG,MAAA,CAAAC,WAAA,OAAAF,IAAA,KAAAG,SAAA,QAAAC,GAAA,GAAAJ,IAAA,CAAAxC,IAAA,CAAAsC,KAAA,EAAAC,IAAA,2BAAAK,GAAA,sBAAAA,GAAA,YAAAC,SAAA,4DAAAN,IAAA,gBAAAF,MAAA,GAAAS,MAAA,EAAAR,KAAA;AAmBnD,SAASS,eAAeA,CAACC,KAA2B,EAAE;EACpD,MAAM;IACJC,WAAW;IACXC,oBAAoB;IACpBC,mBAAmB;IACnBC,UAAU;IACVC,SAAS;IACTC;EACF,CAAC,GAAG,IAAAC,iBAAU,EAACC,0BAAiB,CAAC;EAEjC,MAAM;IAAEC,SAAS;IAAEC;EAAc,CAAC,GAAGV,KAAK;EAE1C,MAAMW,YAAY,GAAG,IAAAC,cAAO,EAC1B,OAAO;IACLC,IAAI,EAAER,SAAS;IACfS,UAAU,EAAET,SAAS;IACrBU,QAAQ,EAAET;EACZ,CAAC,CAAC,EACF,CAACD,SAAS,EAAEC,OAAO,CACrB,CAAC;EAED,MAAMU,YAAY,GAAG,IAAAC,kBAAW,EAC9B,YAQW;IAAA,IARV;MACCZ,SAAS;MACTC,OAAO;MACPY,KAAK,GAAG;IAKV,CAAC,GAAAxC,SAAA,CAAAf,MAAA,QAAAe,SAAA,QAAAiB,SAAA,GAAAjB,SAAA,MAAG,CAAC,CAAC;IACJuB,WAAW,CAAC;MAAEI,SAAS;MAAEC;IAAQ,CAAC,CAAC;IACnCJ,oBAAoB,CAAC,CAAC;IACtBC,mBAAmB,CAAC;MAClBE,SAAS;MACTC,OAAO,EAAEA,OAAO,IAAID,SAAS;MAC7Ba;IACF,CAAC,CAAC;EACJ,CAAC,EACD,CAACjB,WAAW,EAAEE,mBAAmB,EAAED,oBAAoB,CACzD,CAAC;EAED,MAAMiB,OAAO,GAAG,IAAAF,kBAAW,EACzBG,IAAA,IAMM;IAAA,IANL;MACCC,QAAQ;MACRH;IAIF,CAAC,GAAAE,IAAA;IACC,MAAMN,UAAU,GAAGO,QAAQ,CAACR,IAAI,IAAIQ,QAAQ,CAACP,UAAU;IACvD,MAAMC,QAAQ,GAAGM,QAAQ,CAACN,QAAQ;IAElC,MAAMV,SAAS,GACb,OAAOS,UAAU,KAAK,UAAU,GAC5BA,UAAU,CAACH,YAAY,CAAC,GACxBG,UAAU,GACV,IAAAQ,mCAAmB,EAACR,UAAU,CAAC,GAC/B,IAAI;IAEV,MAAMR,OAAO,GACX,OAAOS,QAAQ,KAAK,UAAU,GAC1BA,QAAQ,CAACJ,YAAY,CAAC,GACtBI,QAAQ,GACR,IAAAO,mCAAmB,EAACP,QAAQ,CAAC,GAC7B,IAAI;IAEVC,YAAY,CAAC;MACXX,SAAS;MACTC,OAAO,EAAEA,OAAO,IAAID,SAAS;MAC7Ba;IACF,CAAC,CAAC;IAEF,IAAIG,QAAQ,CAACE,eAAe,EAAE;MAC5BnB,UAAU,CAAA3B,aAAA,CAAAA,aAAA,KAAMyC,KAAK;QAAEM,WAAW,EAAE;MAAI,EAAE,CAAC;IAC7C;EACF,CAAC,EACD,CAACR,YAAY,EAAEL,YAAY,EAAEP,UAAU,CACzC,CAAC;EAED,MAAMqB,cAAyC,GAAG,IAAAb,cAAO,EACvD,MACEH,SAAS,GACL,OAAOA,SAAS,KAAK,QAAQ,GAC3BiB,IAAI,CAACC,KAAK,CAAClB,SAAS,CAAC,GACrBA,SAAS,GACX,EAAE,EACR,CAACA,SAAS,CACZ,CAAC;EAED,MAAMmB,YAAY,GAAGH,cAAc,IAAIA,cAAc,CAAC9D,MAAM,GAAG,CAAC;EAEhE,MAAMkE,gBAAgB,GAAG,IAAAjB,cAAO,EAC9B,MACEgB,YAAY,IACVvG,MAAA,CAAAU,OAAA,CAAA+F,aAAA,CAAAzG,MAAA,CAAAU,OAAA,CAAAgG,QAAA,QACGN,cAAc,CAACO,GAAG,CAAC,CAAAC,KAAA,EAAyBzE,CAAS,KAAK;IAAA,IAAtC;QAAE0E;MAAmB,CAAC,GAAAD,KAAA;MAAVZ,QAAQ,GAAAlE,wBAAA,CAAA8E,KAAA,EAAArG,SAAA;IACvC,OACEP,MAAA,CAAAU,OAAA,CAAA+F,aAAA,CAACrG,OAAA,CAAAM,OAAM;MACLc,GAAG,EAAEW,CAAE;MACP2E,IAAI,EAAED,KAAM;MACZE,OAAO,EAAC,WAAW;MACnBC,OAAO,EAAGnB,KAAK,IAAKC,OAAO,CAAC;QAAEE,QAAQ;QAAEH;MAAM,CAAC;IAAE,CAClD,CAAC;EAEN,CAAC,CACD,CACH,EACH,CAACU,YAAY,EAAEH,cAAc,EAAEN,OAAO,CACxC,CAAC;EAED,IAAI,CAACS,YAAY,IAAI,CAAClB,aAAa,EAAE;IACnC,OAAOrF,MAAA,CAAAU,OAAA,CAAA+F,aAAA,CAAAzG,MAAA,CAAAU,OAAA,CAAAgG,QAAA,MAAI,CAAC;EACd;EAEA,OACE1G,MAAA,CAAAU,OAAA,CAAA+F,aAAA;IAAKQ,SAAS,EAAC;EAAwB,GACpC5B,aAAa,EACbmB,gBACE,CAAC;AAEV;AAAC,IAAAU,QAAA,GAEcxC,eAAe;AAAAyC,OAAA,CAAAzG,OAAA,GAAAwG,QAAA"}
|
|
@@ -104,7 +104,7 @@ export interface ContextState {
|
|
|
104
104
|
getSubmitData?: () => unknown;
|
|
105
105
|
getSubmitParams?: () => OnSubmitParams;
|
|
106
106
|
setFieldEventListener?: (path: EventListenerCall['path'], type: EventListenerCall['type'], callback: EventListenerCall['callback']) => void;
|
|
107
|
-
|
|
107
|
+
revealError?: (path: Path, hasError: boolean) => void;
|
|
108
108
|
setFieldInternals?: (path: Path, props: unknown, id?: string) => void;
|
|
109
109
|
setValueInternals?: (path: Path, props: unknown) => void;
|
|
110
110
|
setHandleSubmit?: (callback: HandleSubmitCallback, params?: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Context.js","names":["_react","_interopRequireDefault","require","_utils","obj","__esModule","default","defaultContextState","hasContext","data","undefined","schema","submitState","handlePathChange","handlePathChangeUnvalidated","updateDataValue","setData","validateData","handleSubmit","scrollToTop","showAllErrors","hasVisibleError","formState","setFormState","setSubmitState","handleSubmitCall","setShowAllErrors","setMountedFieldState","hasErrors","hasFieldState","hasFieldError","ajvInstance","makeAjvInstance","contextErrorMessages","props","exports","Context","React","createContext","_default"],"sources":["../../../../../src/extensions/forms/DataContext/Context.ts"],"sourcesContent":["import React from 'react'\nimport { Ajv, FormError, JsonObject, makeAjvInstance } from '../utils'\nimport {\n AllJSONSchemaVersions,\n GlobalErrorMessagesWithPaths,\n SubmitState,\n Path,\n EventStateObject,\n EventReturnWithStateObject,\n FieldProps,\n ValueProps,\n OnChange,\n OnSubmitParams,\n} from '../types'\nimport { Props as ProviderProps } from './Provider'\nimport { SnapshotName } from '../Form/Snapshot'\nimport { SharedStateId } from '../../../shared/helpers/useSharedState'\n\nexport type MountState = {\n isPreMounted?: boolean\n isMounted?: boolean\n isVisible?: boolean\n isFocused?: boolean\n wasStepChange?: boolean\n}\n\nexport type EventListenerCall = {\n path?: Path\n type?: 'onSubmit' | 'onPathChange' | 'onMount'\n callback: (params?: { value: unknown }) => void | Promise<void | Error>\n}\n\nexport type VisibleDataHandler<Data> = (\n data?: Data,\n options?: VisibleDataOptions\n) => Partial<Data>\nexport type VisibleDataOptions = {\n keepPaths?: Array<Path>\n removePaths?: Array<Path>\n}\nexport type MutateDataHandler<Data> = (\n data: Data,\n mutate: TransformData\n) => Partial<Data>\nexport type FilterDataHandler<Data> = (\n data: Data,\n filter: FilterData\n) => Partial<Data>\nexport type FilterDataHandlerCallback<R> = (\n parameters: FilterDataHandlerParameters\n) => R\nexport type FilterDataHandlerParameters =\n FilterDataPathConditionParameters & {\n path: Path\n }\nexport type FilterDataPathCondition<Data = unknown> = (\n parameters: FilterDataPathConditionParameters<Data>\n) => boolean | undefined\nexport type FilterDataPathConditionParameters<Data = unknown> = {\n value: unknown\n displayValue: undefined | React.ReactNode | Array<React.ReactNode>\n label: React.ReactNode\n props: FieldProps\n data: Data\n internal: {\n error: Error | undefined\n }\n}\nexport type FilterDataPathObject<Data> = Record<\n Path,\n FilterDataPathCondition<Data> | boolean | undefined\n>\nexport type FilterData<Data = unknown> =\n | FilterDataPathObject<Data>\n | FilterDataHandlerCallback<boolean | undefined>\nexport type VisibleData<Data = unknown> = Partial<Data>\nexport type TransformData = FilterDataHandlerCallback<unknown>\nexport type HandleSubmitCallback = ({\n preventSubmit,\n}: {\n preventSubmit: () => void\n}) => void\nexport type FieldConnections = {\n setEventResult?: (status: EventStateObject) => void\n}\nexport type FieldInternalsRefProps =\n | (FieldProps & { children: unknown })\n | undefined\nexport type FieldInternalsRef = Record<\n Path,\n {\n props: FieldInternalsRefProps\n id: string | undefined\n }\n>\nexport type ValueInternalsRef = Record<\n Path,\n { props: ValueProps | undefined }\n>\n\nexport interface ContextState {\n id?: SharedStateId\n hasContext: boolean\n /** The dataset for the form / form wizard */\n data: any\n internalDataRef?: React.MutableRefObject<any>\n /** Should the form validate data before submitting? */\n errors?: Record<Path, Error>\n /** Will set autoComplete=\"on\" on each nested Field.String and Field.Number */\n autoComplete?: boolean\n handlePathChange: (\n path: Path,\n value?: any\n ) =>\n | EventReturnWithStateObject\n | unknown\n | Promise<EventReturnWithStateObject | unknown>\n handlePathChangeUnvalidated: (path: Path, value: any) => void\n updateDataValue: (\n path: Path,\n value: any,\n options?: { preventUpdate?: boolean }\n ) => void\n setData: (data: any) => void\n clearData?: () => void\n mutateDataHandler?: MutateDataHandler<unknown>\n filterDataHandler?: FilterDataHandler<unknown>\n visibleDataHandler?: VisibleDataHandler<unknown>\n validateData: () => void\n handleSubmit: () => Promise<EventStateObject | undefined>\n scrollToTop: () => void\n setShowAllErrors: (showAllErrors: boolean) => void\n hasErrors: () => boolean\n hasFieldState: (state: SubmitState) => boolean\n hasFieldError: (path: Path) => boolean\n setFieldState?: (path: Path, fieldState: SubmitState) => void\n setFieldError?: (path: Path, error: Error | FormError) => void\n setMountedFieldState: (path: Path, options: MountState) => void\n setFormState?: (\n state: SubmitState,\n options?: { keepPending?: boolean }\n ) => void\n setSubmitState?: (state: EventStateObject) => void\n addOnChangeHandler?: (callback: OnChange) => void\n handleSubmitCall: ({\n onSubmit,\n enableAsyncBehavior,\n skipFieldValidation,\n skipErrorCheck,\n }: {\n onSubmit: () =>\n | EventReturnWithStateObject\n | void\n | Promise<EventReturnWithStateObject | void>\n enableAsyncBehavior: boolean\n skipFieldValidation?: boolean\n skipErrorCheck?: boolean\n }) => Promise<EventStateObject | undefined>\n getSubmitData?: () => unknown\n getSubmitParams?: () => OnSubmitParams\n setFieldEventListener?: (\n path: EventListenerCall['path'],\n type: EventListenerCall['type'],\n callback: EventListenerCall['callback']\n ) => void\n
|
|
1
|
+
{"version":3,"file":"Context.js","names":["_react","_interopRequireDefault","require","_utils","obj","__esModule","default","defaultContextState","hasContext","data","undefined","schema","submitState","handlePathChange","handlePathChangeUnvalidated","updateDataValue","setData","validateData","handleSubmit","scrollToTop","showAllErrors","hasVisibleError","formState","setFormState","setSubmitState","handleSubmitCall","setShowAllErrors","setMountedFieldState","hasErrors","hasFieldState","hasFieldError","ajvInstance","makeAjvInstance","contextErrorMessages","props","exports","Context","React","createContext","_default"],"sources":["../../../../../src/extensions/forms/DataContext/Context.ts"],"sourcesContent":["import React from 'react'\nimport { Ajv, FormError, JsonObject, makeAjvInstance } from '../utils'\nimport {\n AllJSONSchemaVersions,\n GlobalErrorMessagesWithPaths,\n SubmitState,\n Path,\n EventStateObject,\n EventReturnWithStateObject,\n FieldProps,\n ValueProps,\n OnChange,\n OnSubmitParams,\n} from '../types'\nimport { Props as ProviderProps } from './Provider'\nimport { SnapshotName } from '../Form/Snapshot'\nimport { SharedStateId } from '../../../shared/helpers/useSharedState'\n\nexport type MountState = {\n isPreMounted?: boolean\n isMounted?: boolean\n isVisible?: boolean\n isFocused?: boolean\n wasStepChange?: boolean\n}\n\nexport type EventListenerCall = {\n path?: Path\n type?: 'onSubmit' | 'onPathChange' | 'onMount'\n callback: (params?: { value: unknown }) => void | Promise<void | Error>\n}\n\nexport type VisibleDataHandler<Data> = (\n data?: Data,\n options?: VisibleDataOptions\n) => Partial<Data>\nexport type VisibleDataOptions = {\n keepPaths?: Array<Path>\n removePaths?: Array<Path>\n}\nexport type MutateDataHandler<Data> = (\n data: Data,\n mutate: TransformData\n) => Partial<Data>\nexport type FilterDataHandler<Data> = (\n data: Data,\n filter: FilterData\n) => Partial<Data>\nexport type FilterDataHandlerCallback<R> = (\n parameters: FilterDataHandlerParameters\n) => R\nexport type FilterDataHandlerParameters =\n FilterDataPathConditionParameters & {\n path: Path\n }\nexport type FilterDataPathCondition<Data = unknown> = (\n parameters: FilterDataPathConditionParameters<Data>\n) => boolean | undefined\nexport type FilterDataPathConditionParameters<Data = unknown> = {\n value: unknown\n displayValue: undefined | React.ReactNode | Array<React.ReactNode>\n label: React.ReactNode\n props: FieldProps\n data: Data\n internal: {\n error: Error | undefined\n }\n}\nexport type FilterDataPathObject<Data> = Record<\n Path,\n FilterDataPathCondition<Data> | boolean | undefined\n>\nexport type FilterData<Data = unknown> =\n | FilterDataPathObject<Data>\n | FilterDataHandlerCallback<boolean | undefined>\nexport type VisibleData<Data = unknown> = Partial<Data>\nexport type TransformData = FilterDataHandlerCallback<unknown>\nexport type HandleSubmitCallback = ({\n preventSubmit,\n}: {\n preventSubmit: () => void\n}) => void\nexport type FieldConnections = {\n setEventResult?: (status: EventStateObject) => void\n}\nexport type FieldInternalsRefProps =\n | (FieldProps & { children: unknown })\n | undefined\nexport type FieldInternalsRef = Record<\n Path,\n {\n props: FieldInternalsRefProps\n id: string | undefined\n }\n>\nexport type ValueInternalsRef = Record<\n Path,\n { props: ValueProps | undefined }\n>\n\nexport interface ContextState {\n id?: SharedStateId\n hasContext: boolean\n /** The dataset for the form / form wizard */\n data: any\n internalDataRef?: React.MutableRefObject<any>\n /** Should the form validate data before submitting? */\n errors?: Record<Path, Error>\n /** Will set autoComplete=\"on\" on each nested Field.String and Field.Number */\n autoComplete?: boolean\n handlePathChange: (\n path: Path,\n value?: any\n ) =>\n | EventReturnWithStateObject\n | unknown\n | Promise<EventReturnWithStateObject | unknown>\n handlePathChangeUnvalidated: (path: Path, value: any) => void\n updateDataValue: (\n path: Path,\n value: any,\n options?: { preventUpdate?: boolean }\n ) => void\n setData: (data: any) => void\n clearData?: () => void\n mutateDataHandler?: MutateDataHandler<unknown>\n filterDataHandler?: FilterDataHandler<unknown>\n visibleDataHandler?: VisibleDataHandler<unknown>\n validateData: () => void\n handleSubmit: () => Promise<EventStateObject | undefined>\n scrollToTop: () => void\n setShowAllErrors: (showAllErrors: boolean) => void\n hasErrors: () => boolean\n hasFieldState: (state: SubmitState) => boolean\n hasFieldError: (path: Path) => boolean\n setFieldState?: (path: Path, fieldState: SubmitState) => void\n setFieldError?: (path: Path, error: Error | FormError) => void\n setMountedFieldState: (path: Path, options: MountState) => void\n setFormState?: (\n state: SubmitState,\n options?: { keepPending?: boolean }\n ) => void\n setSubmitState?: (state: EventStateObject) => void\n addOnChangeHandler?: (callback: OnChange) => void\n handleSubmitCall: ({\n onSubmit,\n enableAsyncBehavior,\n skipFieldValidation,\n skipErrorCheck,\n }: {\n onSubmit: () =>\n | EventReturnWithStateObject\n | void\n | Promise<EventReturnWithStateObject | void>\n enableAsyncBehavior: boolean\n skipFieldValidation?: boolean\n skipErrorCheck?: boolean\n }) => Promise<EventStateObject | undefined>\n getSubmitData?: () => unknown\n getSubmitParams?: () => OnSubmitParams\n setFieldEventListener?: (\n path: EventListenerCall['path'],\n type: EventListenerCall['type'],\n callback: EventListenerCall['callback']\n ) => void\n revealError?: (path: Path, hasError: boolean) => void\n setFieldInternals?: (path: Path, props: unknown, id?: string) => void\n setValueInternals?: (path: Path, props: unknown) => void\n setHandleSubmit?: (\n callback: HandleSubmitCallback,\n params?: { remove?: boolean }\n ) => void\n setFieldConnection?: (path: Path, connections: FieldConnections) => void\n isEmptyDataRef?: React.MutableRefObject<boolean>\n addSetShowAllErrorsRef?: React.MutableRefObject<\n Array<(showAllErrors: boolean) => void>\n >\n fieldDisplayValueRef?: React.MutableRefObject<\n Record<Path, { type: 'field'; value?: React.ReactNode }>\n >\n fieldInternalsRef?: React.MutableRefObject<FieldInternalsRef>\n valueInternalsRef?: React.MutableRefObject<ValueInternalsRef>\n fieldConnectionsRef?: React.RefObject<Record<Path, FieldConnections>>\n mountedFieldsRef?: React.MutableRefObject<Record<Path, MountState>>\n snapshotsRef?: React.MutableRefObject<\n Map<SnapshotName, Map<Path, unknown>>\n >\n existingFieldsRef?: React.MutableRefObject<Map<Path, boolean>>\n formElementRef?: React.MutableRefObject<HTMLFormElement>\n fieldErrorRef?: React.MutableRefObject<Record<Path, Error>>\n showAllErrors: boolean | number\n hasVisibleError: boolean\n formState: SubmitState\n ajvInstance: Ajv\n contextErrorMessages: GlobalErrorMessagesWithPaths\n schema: AllJSONSchemaVersions\n path?: Path\n disabled?: boolean\n required?: boolean\n submitState: Partial<EventStateObject>\n prerenderFieldProps?: boolean\n decoupleForm?: boolean\n hasElementRef?: React.MutableRefObject<boolean>\n restHandlerProps?: Record<string, unknown>\n props: ProviderProps<JsonObject>\n}\n\nexport const defaultContextState: ContextState = {\n hasContext: false,\n data: undefined,\n schema: undefined,\n submitState: undefined,\n handlePathChange: () => null,\n handlePathChangeUnvalidated: () => null,\n updateDataValue: () => null,\n setData: () => null,\n validateData: () => null,\n handleSubmit: () => null,\n scrollToTop: () => null,\n showAllErrors: false,\n hasVisibleError: false,\n formState: undefined,\n setFormState: () => null,\n setSubmitState: () => null,\n handleSubmitCall: () => null,\n setShowAllErrors: () => null,\n setMountedFieldState: () => null,\n hasErrors: () => false,\n hasFieldState: () => false,\n hasFieldError: () => false,\n ajvInstance: makeAjvInstance(),\n contextErrorMessages: undefined,\n props: null,\n}\n\nconst Context = React.createContext<ContextState>(defaultContextState)\n\nexport default Context\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AAAsE,SAAAD,uBAAAG,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AA8M/D,MAAMG,mBAAiC,GAAG;EAC/CC,UAAU,EAAE,KAAK;EACjBC,IAAI,EAAEC,SAAS;EACfC,MAAM,EAAED,SAAS;EACjBE,WAAW,EAAEF,SAAS;EACtBG,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,2BAA2B,EAAEA,CAAA,KAAM,IAAI;EACvCC,eAAe,EAAEA,CAAA,KAAM,IAAI;EAC3BC,OAAO,EAAEA,CAAA,KAAM,IAAI;EACnBC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,WAAW,EAAEA,CAAA,KAAM,IAAI;EACvBC,aAAa,EAAE,KAAK;EACpBC,eAAe,EAAE,KAAK;EACtBC,SAAS,EAAEZ,SAAS;EACpBa,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,cAAc,EAAEA,CAAA,KAAM,IAAI;EAC1BC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,oBAAoB,EAAEA,CAAA,KAAM,IAAI;EAChCC,SAAS,EAAEA,CAAA,KAAM,KAAK;EACtBC,aAAa,EAAEA,CAAA,KAAM,KAAK;EAC1BC,aAAa,EAAEA,CAAA,KAAM,KAAK;EAC1BC,WAAW,EAAE,IAAAC,sBAAe,EAAC,CAAC;EAC9BC,oBAAoB,EAAEvB,SAAS;EAC/BwB,KAAK,EAAE;AACT,CAAC;AAAAC,OAAA,CAAA5B,mBAAA,GAAAA,mBAAA;AAED,MAAM6B,OAAO,GAAGC,cAAK,CAACC,aAAa,CAAe/B,mBAAmB,CAAC;AAAA,IAAAgC,QAAA,GAEvDH,OAAO;AAAAD,OAAA,CAAA7B,OAAA,GAAAiC,QAAA"}
|
|
@@ -33,7 +33,7 @@ export interface FieldBoundaryContextState {
|
|
|
33
33
|
/**
|
|
34
34
|
* To set the local visible error state.
|
|
35
35
|
*/
|
|
36
|
-
|
|
36
|
+
revealError?: (path: Path, hasError: boolean) => void;
|
|
37
37
|
}
|
|
38
38
|
declare const FieldBoundaryContext: React.Context<FieldBoundaryContextState>;
|
|
39
39
|
export default FieldBoundaryContext;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FieldBoundaryContext.js","names":["_react","_interopRequireDefault","require","obj","__esModule","default","FieldBoundaryContext","React","createContext","undefined","_default","exports"],"sources":["../../../../../../src/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../../types'\n\nexport interface FieldBoundaryContextState {\n /**\n * Will be set to true when one or more nested fields are in error state.\n */\n hasError?: boolean\n\n /**\n * Will be set to true when the inherited data context has submit errors and the `hasError` has errors as well.\n */\n hasSubmitError?: boolean\n\n /**\n * Will be set to true when a nested field contains a visible error.\n */\n hasVisibleError?: boolean\n\n /**\n * Contains the nested field errors.\n */\n errorsRef?: React.RefObject<unknown>\n\n /**\n * Will be set to true when the boundary context error state should be shown.\n * Support a number to ensure we can renew hooks each time we get a new value.\n */\n showBoundaryErrors?: boolean | number\n\n /**\n * To set the boundary context error state.\n */\n setShowBoundaryErrors?: (\n showBoundaryErrors: FieldBoundaryContextState['showBoundaryErrors']\n ) => void\n\n /**\n * To set the local error state.\n */\n setFieldError?: (path: Path, error: Error) => void\n\n /**\n * To set the local visible error state.\n */\n
|
|
1
|
+
{"version":3,"file":"FieldBoundaryContext.js","names":["_react","_interopRequireDefault","require","obj","__esModule","default","FieldBoundaryContext","React","createContext","undefined","_default","exports"],"sources":["../../../../../../src/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../../types'\n\nexport interface FieldBoundaryContextState {\n /**\n * Will be set to true when one or more nested fields are in error state.\n */\n hasError?: boolean\n\n /**\n * Will be set to true when the inherited data context has submit errors and the `hasError` has errors as well.\n */\n hasSubmitError?: boolean\n\n /**\n * Will be set to true when a nested field contains a visible error.\n */\n hasVisibleError?: boolean\n\n /**\n * Contains the nested field errors.\n */\n errorsRef?: React.RefObject<unknown>\n\n /**\n * Will be set to true when the boundary context error state should be shown.\n * Support a number to ensure we can renew hooks each time we get a new value.\n */\n showBoundaryErrors?: boolean | number\n\n /**\n * To set the boundary context error state.\n */\n setShowBoundaryErrors?: (\n showBoundaryErrors: FieldBoundaryContextState['showBoundaryErrors']\n ) => void\n\n /**\n * To set the local error state.\n */\n setFieldError?: (path: Path, error: Error) => void\n\n /**\n * To set the local visible error state.\n */\n revealError?: (path: Path, hasError: boolean) => void\n}\n\nconst FieldBoundaryContext = React.createContext<\n FieldBoundaryContextState | undefined\n>(undefined)\n\nexport default FieldBoundaryContext\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAyB,SAAAD,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAgDzB,MAAMG,oBAAoB,GAAGC,cAAK,CAACC,aAAa,CAE9CC,SAAS,CAAC;AAAA,IAAAC,QAAA,GAEGJ,oBAAoB;AAAAK,OAAA,CAAAN,OAAA,GAAAK,QAAA"}
|
|
@@ -39,7 +39,7 @@ function FieldBoundaryProvider(props) {
|
|
|
39
39
|
(_onPathErrorRef$curre = onPathErrorRef.current) === null || _onPathErrorRef$curre === void 0 ? void 0 : _onPathErrorRef$curre.call(onPathErrorRef, path, error);
|
|
40
40
|
}, []);
|
|
41
41
|
const hasVisibleErrorRef = (0, _react.useRef)({});
|
|
42
|
-
const
|
|
42
|
+
const revealError = (0, _react.useCallback)((path, hasError) => {
|
|
43
43
|
if (hasError) {
|
|
44
44
|
hasVisibleErrorRef.current[path] = hasError;
|
|
45
45
|
} else {
|
|
@@ -59,7 +59,7 @@ function FieldBoundaryProvider(props) {
|
|
|
59
59
|
showBoundaryErrors: showBoundaryErrorsRef.current,
|
|
60
60
|
setShowBoundaryErrors,
|
|
61
61
|
setFieldError,
|
|
62
|
-
|
|
62
|
+
revealError
|
|
63
63
|
};
|
|
64
64
|
return _react.default.createElement(_FieldBoundaryContext.default.Provider, {
|
|
65
65
|
value: context
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FieldBoundaryProvider.js","names":["_react","_interopRequireWildcard","require","_FieldBoundaryContext","_interopRequireDefault","_Context","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","FieldBoundaryProvider","props","showErrors","undefined","onPathError","children","forceUpdate","useReducer","showAllErrors","useContext","DataContext","onPathErrorRef","useRef","current","errorsRef","showBoundaryErrorsRef","hasError","keys","length","hasSubmitError","setFieldError","useCallback","path","error","_onPathErrorRef$curre","_errorsRef$current","hasVisibleErrorRef","
|
|
1
|
+
{"version":3,"file":"FieldBoundaryProvider.js","names":["_react","_interopRequireWildcard","require","_FieldBoundaryContext","_interopRequireDefault","_Context","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","FieldBoundaryProvider","props","showErrors","undefined","onPathError","children","forceUpdate","useReducer","showAllErrors","useContext","DataContext","onPathErrorRef","useRef","current","errorsRef","showBoundaryErrorsRef","hasError","keys","length","hasSubmitError","setFieldError","useCallback","path","error","_onPathErrorRef$curre","_errorsRef$current","hasVisibleErrorRef","revealError","setShowBoundaryErrors","showBoundaryErrors","Date","now","context","hasVisibleError","createElement","Provider","value"],"sources":["../../../../../../src/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.tsx"],"sourcesContent":["import React, { useCallback, useContext, useReducer, useRef } from 'react'\nimport FieldBoundaryContext, {\n FieldBoundaryContextState,\n} from './FieldBoundaryContext'\nimport DataContext from '../Context'\nimport { Path } from '../../types'\n\nexport type Props = {\n showErrors?: boolean\n onPathError?: (path: Path, error: Error) => void\n children: React.ReactNode\n}\n\nexport default function FieldBoundaryProvider(props: Props) {\n const { showErrors = undefined, onPathError = null, children } = props\n const [, forceUpdate] = useReducer(() => ({}), {})\n const { showAllErrors } = useContext(DataContext)\n\n const onPathErrorRef = useRef(onPathError)\n onPathErrorRef.current = onPathError\n const errorsRef = useRef<Record<Path, boolean>>({})\n const showBoundaryErrorsRef =\n useRef<FieldBoundaryContextState['showBoundaryErrors']>(showErrors)\n const hasError = Object.keys(errorsRef.current).length > 0\n const hasSubmitError = showAllErrors && hasError\n\n const setFieldError = useCallback((path: Path, error: Error) => {\n if (error) {\n errorsRef.current[path] = !!error\n } else {\n delete errorsRef.current?.[path]\n }\n forceUpdate()\n onPathErrorRef.current?.(path, error)\n }, [])\n\n const hasVisibleErrorRef = useRef<Record<Path, boolean>>({})\n const revealError = useCallback((path: Path, hasError: boolean) => {\n if (hasError) {\n hasVisibleErrorRef.current[path] = hasError\n } else {\n delete hasVisibleErrorRef.current[path]\n }\n forceUpdate()\n }, [])\n\n const setShowBoundaryErrors: FieldBoundaryContextState['setShowBoundaryErrors'] =\n useCallback((showBoundaryErrors) => {\n showBoundaryErrorsRef.current = showBoundaryErrors\n ? Date.now() // in order to renew the internal dependency \"showBoundaryErrors\"\n : false\n forceUpdate()\n }, [])\n\n const context: FieldBoundaryContextState = {\n hasError,\n hasSubmitError,\n hasVisibleError: Object.keys(hasVisibleErrorRef.current).length > 0,\n errorsRef,\n showBoundaryErrors: showBoundaryErrorsRef.current,\n setShowBoundaryErrors,\n setFieldError,\n revealError,\n }\n\n return (\n <FieldBoundaryContext.Provider value={context}>\n {children}\n </FieldBoundaryContext.Provider>\n )\n}\n"],"mappings":"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"}
|
|
@@ -91,7 +91,7 @@ function Provider(props) {
|
|
|
91
91
|
forceUpdate();
|
|
92
92
|
addSetShowAllErrorsRef.current.forEach(fn => fn === null || fn === void 0 ? void 0 : fn(showAllErrors));
|
|
93
93
|
}, []);
|
|
94
|
-
const
|
|
94
|
+
const revealError = (0, _react.useCallback)((path, hasError) => {
|
|
95
95
|
if (hasError) {
|
|
96
96
|
hasVisibleErrorRef.current[path] = hasError;
|
|
97
97
|
} else {
|
|
@@ -827,7 +827,7 @@ function Provider(props) {
|
|
|
827
827
|
setFormState,
|
|
828
828
|
setSubmitState,
|
|
829
829
|
setShowAllErrors,
|
|
830
|
-
|
|
830
|
+
revealError,
|
|
831
831
|
setFieldEventListener,
|
|
832
832
|
setFieldState,
|
|
833
833
|
setFieldError,
|