UNPKG

tdesign-vue-next

Version:
177 lines (173 loc) 6.68 kB
/** * tdesign v1.15.2 * (c) 2025 tdesign * @license MIT */ import { defineComponent, ref, computed, createVNode, mergeProps, isVNode } from 'vue'; import { ChevronRightIcon } from 'tdesign-icons-vue-next'; import { getCascaderItemClass, getCascaderItemIconClass } from '../utils/className.js'; import '@babel/runtime/helpers/slicedToArray'; import 'lodash-es'; import { getFullPathLabel } from '../utils/helper.js'; import { Checkbox } from '../../checkbox/index.js'; import { Loading } from '../../loading/index.js'; import '@babel/runtime/helpers/toConsumableArray'; import '@babel/runtime/helpers/typeof'; import '../../_chunks/dep-e604a5ce.js'; import { u as useCommonClassName } from '../../_chunks/dep-b9ab7399.js'; import { u as usePrefixClass } from '../../_chunks/dep-79c44a11.js'; import { u as useGlobalIcon } from '../../_chunks/dep-2ac22271.js'; import '../../_chunks/dep-7324137b.js'; import { u as useRipple } from '../../_chunks/dep-7b209207.js'; import '@babel/runtime/helpers/defineProperty'; import '../../checkbox/checkbox.js'; import '../../checkbox/props.js'; import '../../_chunks/dep-1d44782f.js'; import '../../_chunks/dep-1f7ad104.js'; import '../../_chunks/dep-6c13cc0e.js'; import '../../_chunks/dep-5360ac56.js'; import '../../_chunks/dep-41ae8479.js'; import '../../_chunks/dep-34e44a4e.js'; import '../../checkbox/consts/index.js'; import '../../checkbox/hooks/useCheckboxLazyLoad.js'; import '../../_chunks/dep-6f34ddfa.js'; import '../../checkbox/hooks/useKeyboardEvent.js'; import '../../_chunks/dep-01e48141.js'; import '../../_chunks/dep-7fac49fa.js'; import '../../config-provider/hooks/useConfig.js'; import '../../config-provider/utils/context.js'; import '../../_chunks/dep-3b49fbbe.js'; import 'dayjs'; import '@babel/runtime/helpers/createClass'; import '@babel/runtime/helpers/classCallCheck'; import '../../_chunks/dep-3ba91e12.js'; import '../../checkbox/group.js'; import '../../checkbox/checkbox-group-props.js'; import '../../_chunks/dep-0f8c45fe.js'; import '../../_chunks/dep-37a2e7c8.js'; import '../../loading/directive.js'; import '../../loading/plugin.js'; import '../../_chunks/dep-199af351.js'; import '../../loading/icon/gradient.js'; import '../../_chunks/dep-a72765fe.js'; import '@babel/runtime/helpers/objectWithoutProperties'; import '../../loading/props.js'; function _isSlot(s) { return typeof s === 'function' || Object.prototype.toString.call(s) === '[object Object]' && !isVNode(s); } var props = { node: { type: Object, "default": function _default() { return {}; } }, optionChild: { type: [Object, Array] }, cascaderContext: { type: Object }, onChange: Function, onClick: Function, onMouseenter: Function }; var Item = defineComponent({ name: "TCascaderItem", props: props, setup: function setup(props2) { var liRef = ref(); useRipple(liRef); var COMPONENT_NAME = usePrefixClass("cascader__item"); var classPrefix = usePrefixClass(); var _useGlobalIcon = useGlobalIcon({ ChevronRightIcon: ChevronRightIcon }), ChevronRightIcon$1 = _useGlobalIcon.ChevronRightIcon; var _useCommonClassName = useCommonClassName(), STATUS = _useCommonClassName.STATUS, SIZE = _useCommonClassName.SIZE; var itemClass = computed(function () { return getCascaderItemClass(classPrefix.value, props2.node, SIZE.value, STATUS.value, props2.cascaderContext); }); var iconClass = computed(function () { return getCascaderItemIconClass(classPrefix.value, props2.node, STATUS.value, props2.cascaderContext); }); function RenderLabelInner(node, cascaderContext) { var inputVal = cascaderContext.inputVal; var labelText = inputVal ? getFullPathLabel(node) : node.label; if (inputVal) { var texts = labelText.split(inputVal); var doms = []; for (var index = 0; index < texts.length; index++) { doms.push(createVNode("span", { "key": index }, [texts[index]])); if (index === texts.length - 1) break; doms.push(createVNode("span", { "key": "".concat(index, "filter"), "class": "".concat(COMPONENT_NAME.value, "-label--filter") }, [inputVal])); } return doms; } return labelText; } var renderTitle = function renderTitle(node) { if (typeof node.label === "string") return node.label; return null; }; function RenderLabelContent(node, cascaderContext) { var label = RenderLabelInner(node, cascaderContext); var labelCont = createVNode("span", { "title": cascaderContext.inputVal ? getFullPathLabel(node) : renderTitle(node), "class": ["".concat(COMPONENT_NAME.value, "-label"), "".concat(COMPONENT_NAME.value, "-label--ellipsis")], "role": "label" }, [label]); return labelCont; } function RenderCheckBox(node, cascaderContext) { var checkProps = cascaderContext.checkProps, value = cascaderContext.value, max = cascaderContext.max, inputVal = cascaderContext.inputVal; var label = RenderLabelInner(node, cascaderContext); return createVNode(Checkbox, mergeProps({ "checked": node.checked, "indeterminate": node.indeterminate, "disabled": node.isDisabled() || value.length >= max && max !== 0, "name": String(node.value), "stopLabelTrigger": !!node.children, "title": inputVal ? getFullPathLabel(node) : renderTitle(node), "onChange": function onChange() { props2.onChange(); } }, checkProps), _isSlot(label) ? label : { "default": function _default() { return [label]; } }); } return function () { var cascaderContext = props2.cascaderContext, node = props2.node, optionChild = props2.optionChild; var isOptionChildAndMultiple = optionChild && cascaderContext.multiple; return createVNode("li", { "ref": liRef, "class": itemClass.value, "onClick": function onClick() { return isOptionChildAndMultiple ? props2.onChange() : props2.onClick(); }, "onMouseenter": props2.onMouseenter }, [optionChild || (cascaderContext.multiple ? RenderCheckBox(node, cascaderContext) : RenderLabelContent(node, cascaderContext)), node.children && (node.loading ? createVNode(Loading, { "class": iconClass.value, "size": "small" }, null) : createVNode(ChevronRightIcon$1, { "class": iconClass.value }, null))]); }; } }); export { Item as default }; //# sourceMappingURL=Item.js.map