first commit
This commit is contained in:
145
frontend/node_modules/rc-picker/es/PickerInput/hooks/useFilledProps.js
generated
vendored
Normal file
145
frontend/node_modules/rc-picker/es/PickerInput/hooks/useFilledProps.js
generated
vendored
Normal file
@@ -0,0 +1,145 @@
|
||||
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
||||
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
||||
import { warning } from 'rc-util';
|
||||
import * as React from 'react';
|
||||
import useLocale from "../../hooks/useLocale";
|
||||
import { fillShowTimeConfig, getTimeProps } from "../../hooks/useTimeConfig";
|
||||
import { toArray } from "../../utils/miscUtil";
|
||||
import { fillClearIcon } from "../Selector/hooks/useClearIcon";
|
||||
import useDisabledBoundary from "./useDisabledBoundary";
|
||||
import { useFieldFormat } from "./useFieldFormat";
|
||||
import useInputReadOnly from "./useInputReadOnly";
|
||||
import useInvalidate from "./useInvalidate";
|
||||
function useList(value) {
|
||||
var fillMode = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
||||
var values = React.useMemo(function () {
|
||||
var list = value ? toArray(value) : value;
|
||||
if (fillMode && list) {
|
||||
list[1] = list[1] || list[0];
|
||||
}
|
||||
return list;
|
||||
}, [value, fillMode]);
|
||||
return values;
|
||||
}
|
||||
|
||||
/**
|
||||
* Align the outer props with unique typed and fill undefined props.
|
||||
* This is shared with both RangePicker and Picker. This will do:
|
||||
* - Convert `value` & `defaultValue` to array
|
||||
* - handle the legacy props fill like `clearIcon` + `allowClear` = `clearIcon`
|
||||
*/
|
||||
export default function useFilledProps(props, updater) {
|
||||
var generateConfig = props.generateConfig,
|
||||
locale = props.locale,
|
||||
_props$picker = props.picker,
|
||||
picker = _props$picker === void 0 ? 'date' : _props$picker,
|
||||
_props$prefixCls = props.prefixCls,
|
||||
prefixCls = _props$prefixCls === void 0 ? 'rc-picker' : _props$prefixCls,
|
||||
_props$styles = props.styles,
|
||||
styles = _props$styles === void 0 ? {} : _props$styles,
|
||||
_props$classNames = props.classNames,
|
||||
classNames = _props$classNames === void 0 ? {} : _props$classNames,
|
||||
_props$order = props.order,
|
||||
order = _props$order === void 0 ? true : _props$order,
|
||||
_props$components = props.components,
|
||||
components = _props$components === void 0 ? {} : _props$components,
|
||||
inputRender = props.inputRender,
|
||||
allowClear = props.allowClear,
|
||||
clearIcon = props.clearIcon,
|
||||
needConfirm = props.needConfirm,
|
||||
multiple = props.multiple,
|
||||
format = props.format,
|
||||
inputReadOnly = props.inputReadOnly,
|
||||
disabledDate = props.disabledDate,
|
||||
minDate = props.minDate,
|
||||
maxDate = props.maxDate,
|
||||
showTime = props.showTime,
|
||||
value = props.value,
|
||||
defaultValue = props.defaultValue,
|
||||
pickerValue = props.pickerValue,
|
||||
defaultPickerValue = props.defaultPickerValue;
|
||||
var values = useList(value);
|
||||
var defaultValues = useList(defaultValue);
|
||||
var pickerValues = useList(pickerValue);
|
||||
var defaultPickerValues = useList(defaultPickerValue);
|
||||
|
||||
// ======================== Picker ========================
|
||||
/** Almost same as `picker`, but add `datetime` for `date` with `showTime` */
|
||||
var internalPicker = picker === 'date' && showTime ? 'datetime' : picker;
|
||||
|
||||
/** The picker is `datetime` or `time` */
|
||||
var multipleInteractivePicker = internalPicker === 'time' || internalPicker === 'datetime';
|
||||
var complexPicker = multipleInteractivePicker || multiple;
|
||||
var mergedNeedConfirm = needConfirm !== null && needConfirm !== void 0 ? needConfirm : multipleInteractivePicker;
|
||||
|
||||
// ========================== Time ==========================
|
||||
// Auto `format` need to check `showTime.showXXX` first.
|
||||
// And then merge the `locale` into `mergedShowTime`.
|
||||
var _getTimeProps = getTimeProps(props),
|
||||
_getTimeProps2 = _slicedToArray(_getTimeProps, 4),
|
||||
timeProps = _getTimeProps2[0],
|
||||
localeTimeProps = _getTimeProps2[1],
|
||||
showTimeFormat = _getTimeProps2[2],
|
||||
propFormat = _getTimeProps2[3];
|
||||
|
||||
// ======================= Locales ========================
|
||||
var mergedLocale = useLocale(locale, localeTimeProps);
|
||||
var mergedShowTime = React.useMemo(function () {
|
||||
return fillShowTimeConfig(internalPicker, showTimeFormat, propFormat, timeProps, mergedLocale);
|
||||
}, [internalPicker, showTimeFormat, propFormat, timeProps, mergedLocale]);
|
||||
|
||||
// ======================= Warning ========================
|
||||
if (process.env.NODE_ENV !== 'production' && picker === 'time') {
|
||||
if (['disabledHours', 'disabledMinutes', 'disabledSeconds'].some(function (key) {
|
||||
return props[key];
|
||||
})) {
|
||||
warning(false, "'disabledHours', 'disabledMinutes', 'disabledSeconds' will be removed in the next major version, please use 'disabledTime' instead.");
|
||||
}
|
||||
}
|
||||
|
||||
// ======================== Props =========================
|
||||
var filledProps = React.useMemo(function () {
|
||||
return _objectSpread(_objectSpread({}, props), {}, {
|
||||
prefixCls: prefixCls,
|
||||
locale: mergedLocale,
|
||||
picker: picker,
|
||||
styles: styles,
|
||||
classNames: classNames,
|
||||
order: order,
|
||||
components: _objectSpread({
|
||||
input: inputRender
|
||||
}, components),
|
||||
clearIcon: fillClearIcon(prefixCls, allowClear, clearIcon),
|
||||
showTime: mergedShowTime,
|
||||
value: values,
|
||||
defaultValue: defaultValues,
|
||||
pickerValue: pickerValues,
|
||||
defaultPickerValue: defaultPickerValues
|
||||
}, updater === null || updater === void 0 ? void 0 : updater());
|
||||
}, [props]);
|
||||
|
||||
// ======================== Format ========================
|
||||
var _useFieldFormat = useFieldFormat(internalPicker, mergedLocale, format),
|
||||
_useFieldFormat2 = _slicedToArray(_useFieldFormat, 2),
|
||||
formatList = _useFieldFormat2[0],
|
||||
maskFormat = _useFieldFormat2[1];
|
||||
|
||||
// ======================= ReadOnly =======================
|
||||
var mergedInputReadOnly = useInputReadOnly(formatList, inputReadOnly, multiple);
|
||||
|
||||
// ======================= Boundary =======================
|
||||
var disabledBoundaryDate = useDisabledBoundary(generateConfig, locale, disabledDate, minDate, maxDate);
|
||||
|
||||
// ====================== Invalidate ======================
|
||||
var isInvalidateDate = useInvalidate(generateConfig, picker, disabledBoundaryDate, mergedShowTime);
|
||||
|
||||
// ======================== Merged ========================
|
||||
var mergedProps = React.useMemo(function () {
|
||||
return _objectSpread(_objectSpread({}, filledProps), {}, {
|
||||
needConfirm: mergedNeedConfirm,
|
||||
inputReadOnly: mergedInputReadOnly,
|
||||
disabledDate: disabledBoundaryDate
|
||||
});
|
||||
}, [filledProps, mergedNeedConfirm, mergedInputReadOnly, disabledBoundaryDate]);
|
||||
return [mergedProps, internalPicker, complexPicker, formatList, maskFormat, isInvalidateDate];
|
||||
}
|
||||
Reference in New Issue
Block a user