123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- "use strict";
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = Panel;
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
- var _classnames = _interopRequireDefault(require("classnames"));
- var _rcUtil = require("rc-util");
- var React = _interopRequireWildcard(require("react"));
- var _context = _interopRequireDefault(require("./context"));
- var _useMissingValues = _interopRequireDefault(require("./hooks/useMissingValues"));
- var _useOptions3 = _interopRequireDefault(require("./hooks/useOptions"));
- var _useSelect = _interopRequireDefault(require("./hooks/useSelect"));
- var _useValues3 = _interopRequireDefault(require("./hooks/useValues"));
- var _List = _interopRequireDefault(require("./OptionList/List"));
- var _commonUtil = require("./utils/commonUtil");
- var _treeUtil = require("./utils/treeUtil");
- function noop() {}
- function Panel(props) {
- var _classNames;
- var _ref = props,
- _ref$prefixCls = _ref.prefixCls,
- prefixCls = _ref$prefixCls === void 0 ? 'rc-cascader' : _ref$prefixCls,
- style = _ref.style,
- className = _ref.className,
- options = _ref.options,
- checkable = _ref.checkable,
- defaultValue = _ref.defaultValue,
- value = _ref.value,
- fieldNames = _ref.fieldNames,
- changeOnSelect = _ref.changeOnSelect,
- onChange = _ref.onChange,
- showCheckedStrategy = _ref.showCheckedStrategy,
- loadData = _ref.loadData,
- expandTrigger = _ref.expandTrigger,
- _ref$expandIcon = _ref.expandIcon,
- expandIcon = _ref$expandIcon === void 0 ? '>' : _ref$expandIcon,
- loadingIcon = _ref.loadingIcon,
- direction = _ref.direction,
- _ref$notFoundContent = _ref.notFoundContent,
- notFoundContent = _ref$notFoundContent === void 0 ? 'Not Found' : _ref$notFoundContent,
- disabled = _ref.disabled;
- // ======================== Multiple ========================
- var multiple = !!checkable;
- // ========================= Values =========================
- var _useMergedState = (0, _rcUtil.useMergedState)(defaultValue, {
- value: value,
- postState: _commonUtil.toRawValues
- }),
- _useMergedState2 = (0, _slicedToArray2.default)(_useMergedState, 2),
- rawValues = _useMergedState2[0],
- setRawValues = _useMergedState2[1];
- // ========================= FieldNames =========================
- var mergedFieldNames = React.useMemo(function () {
- return (0, _commonUtil.fillFieldNames)(fieldNames);
- }, /* eslint-disable react-hooks/exhaustive-deps */
- [JSON.stringify(fieldNames)]
- /* eslint-enable react-hooks/exhaustive-deps */);
- // =========================== Option ===========================
- var _useOptions = (0, _useOptions3.default)(mergedFieldNames, options),
- _useOptions2 = (0, _slicedToArray2.default)(_useOptions, 3),
- mergedOptions = _useOptions2[0],
- getPathKeyEntities = _useOptions2[1],
- getValueByKeyPath = _useOptions2[2];
- // ========================= Values =========================
- var getMissingValues = (0, _useMissingValues.default)(mergedOptions, mergedFieldNames);
- // Fill `rawValues` with checked conduction values
- var _useValues = (0, _useValues3.default)(multiple, rawValues, getPathKeyEntities, getValueByKeyPath, getMissingValues),
- _useValues2 = (0, _slicedToArray2.default)(_useValues, 3),
- checkedValues = _useValues2[0],
- halfCheckedValues = _useValues2[1],
- missingCheckedValues = _useValues2[2];
- // =========================== Change ===========================
- var triggerChange = (0, _rcUtil.useEvent)(function (nextValues) {
- setRawValues(nextValues);
- // Save perf if no need trigger event
- if (onChange) {
- var nextRawValues = (0, _commonUtil.toRawValues)(nextValues);
- var valueOptions = nextRawValues.map(function (valueCells) {
- return (0, _treeUtil.toPathOptions)(valueCells, mergedOptions, mergedFieldNames).map(function (valueOpt) {
- return valueOpt.option;
- });
- });
- var triggerValues = multiple ? nextRawValues : nextRawValues[0];
- var triggerOptions = multiple ? valueOptions : valueOptions[0];
- onChange(triggerValues, triggerOptions);
- }
- });
- // =========================== Select ===========================
- var handleSelection = (0, _useSelect.default)(multiple, triggerChange, checkedValues, halfCheckedValues, missingCheckedValues, getPathKeyEntities, getValueByKeyPath, showCheckedStrategy);
- var onInternalSelect = (0, _rcUtil.useEvent)(function (valuePath) {
- handleSelection(valuePath);
- });
- // ======================== Context =========================
- var cascaderContext = React.useMemo(function () {
- return {
- options: mergedOptions,
- fieldNames: mergedFieldNames,
- values: checkedValues,
- halfValues: halfCheckedValues,
- changeOnSelect: changeOnSelect,
- onSelect: onInternalSelect,
- checkable: checkable,
- searchOptions: [],
- dropdownPrefixCls: undefined,
- loadData: loadData,
- expandTrigger: expandTrigger,
- expandIcon: expandIcon,
- loadingIcon: loadingIcon,
- dropdownMenuColumnStyle: undefined
- };
- }, [mergedOptions, mergedFieldNames, checkedValues, halfCheckedValues, changeOnSelect, onInternalSelect, checkable, loadData, expandTrigger, expandIcon, loadingIcon]);
- // ========================= Render =========================
- var panelPrefixCls = "".concat(prefixCls, "-panel");
- var isEmpty = !mergedOptions.length;
- return /*#__PURE__*/React.createElement(_context.default.Provider, {
- value: cascaderContext
- }, /*#__PURE__*/React.createElement("div", {
- className: (0, _classnames.default)(panelPrefixCls, (_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat(panelPrefixCls, "-rtl"), direction === 'rtl'), (0, _defineProperty2.default)(_classNames, "".concat(panelPrefixCls, "-empty"), isEmpty), _classNames), className),
- style: style
- }, isEmpty ? notFoundContent : /*#__PURE__*/React.createElement(_List.default, {
- prefixCls: prefixCls,
- searchValue: "",
- multiple: multiple,
- toggleOpen: noop,
- open: true,
- direction: direction,
- disabled: disabled
- })));
- }
|