UNPKG

xdesign-vue-next

Version:

XDesign Component for vue-next

218 lines (214 loc) 8.18 kB
/** * xdesign v1.0.6 * (c) 2023 xdesign * @license MIT */ import { _ as __unplugin_components_3 } from '../../_chunks/dep-8b4428a1.mjs'; import { isVNode, defineComponent, ref, computed, createVNode, mergeProps } from 'vue'; import { getFullPathLabel } from '../core/helper.mjs'; import { getCascaderItemClass, getCascaderItemIconClass } from '../core/className.mjs'; import { Checkbox } from '../../checkbox/index.mjs'; import { Loading } from '../../loading/index.mjs'; import { usePrefixClass, useCommonClassName } from '../../hooks/useConfig.mjs'; import useRipple from '../../hooks/useRipple.mjs'; import '../../_chunks/dep-23f91684.mjs'; import '../../_chunks/dep-10a947a6.mjs'; import '../../_chunks/dep-b75d8d74.mjs'; import '../../_chunks/dep-82805301.mjs'; import '../../_chunks/dep-addc2a84.mjs'; import '../../_chunks/dep-6ad18815.mjs'; import '../../_chunks/dep-a95026f2.mjs'; import '../../_chunks/dep-9d7ebc32.mjs'; import '../../_chunks/dep-69963a8c.mjs'; import '../../_chunks/dep-6e7b37b8.mjs'; import '../../_chunks/dep-e1ab85c5.mjs'; import '../../_chunks/dep-5f0e0453.mjs'; import '../../_chunks/dep-db381ece.mjs'; import '../../_chunks/dep-1cc1c24f.mjs'; import '../../_chunks/dep-5755c21c.mjs'; import '../../_chunks/dep-8d1c9a23.mjs'; import '../../_chunks/dep-dafada74.mjs'; import '../../_chunks/dep-068e912d.mjs'; import '../../_chunks/dep-0e832fc7.mjs'; import '../../_chunks/dep-5bec687c.mjs'; import '../../_chunks/dep-89b966f4.mjs'; import '../../_chunks/dep-f9e836af.mjs'; import '../../checkbox/checkbox.mjs'; import '../../_chunks/dep-32d4c595.mjs'; import '../../checkbox/props.mjs'; import '../../hooks/useVModel.mjs'; import '../../_chunks/dep-ae4bffa5.mjs'; import '../../_chunks/dep-8db27830.mjs'; import '../../_chunks/dep-4903a8a8.mjs'; import '../../_chunks/dep-7dcfa37a.mjs'; import '../../hooks/tnode.mjs'; import '../../_chunks/dep-a628549d.mjs'; import '../../_chunks/dep-f4eba04c.mjs'; import '../../_chunks/dep-735bcd0d.mjs'; import '../../_chunks/dep-765678ef.mjs'; import '../../utils/render-tnode.mjs'; import '../../_chunks/dep-11fa9c2c.mjs'; import '../../checkbox/constants.mjs'; import '../../checkbox/hooks/useCheckboxLazyLoad.mjs'; import '../../_common/js/utils/observe.mjs'; import '../../checkbox/hooks/useKeyboard.mjs'; import '../../hooks/useDisabled.mjs'; import '../../_chunks/dep-b9fae426.mjs'; import '../../hooks/useKeepAnimation.mjs'; import '../../_chunks/dep-b09f48fa.mjs'; import '../../_chunks/dep-81c83986.mjs'; import '../../_chunks/dep-6aa0223b.mjs'; import '../../_chunks/dep-7f239c43.mjs'; import '../../_chunks/dep-6f04869e.mjs'; import '../../_chunks/dep-d32fbbb3.mjs'; import '../../_chunks/dep-71f84cf2.mjs'; import '../../_chunks/dep-26bf361a.mjs'; import '../../_chunks/dep-3ec3335a.mjs'; import '../../_chunks/dep-ed4e7c50.mjs'; import '../../_chunks/dep-a666b9ad.mjs'; import '../../_common/js/global-config/default-config.mjs'; import '../../_common/js/global-config/locale/en_US.mjs'; import '../../config-provider/useConfig.mjs'; import '../../_chunks/dep-91ac8f71.mjs'; import '../../_chunks/dep-c4737535.mjs'; import '../../_chunks/dep-03412fab.mjs'; import '../../_chunks/dep-205ff58d.mjs'; import '../../config-provider/type.mjs'; import '../../utils/set-style.mjs'; import '../../checkbox/group.mjs'; import '../../_chunks/dep-6269eaa3.mjs'; import '../../_chunks/dep-4265f69a.mjs'; import '../../_chunks/dep-1bae6a97.mjs'; import '../../checkbox/checkbox-group-props.mjs'; import '../../hooks/slot.mjs'; import '../../utils/withInstall.mjs'; import './style/css.mjs'; import '../../checkbox/type.mjs'; import '../../loading/directive.mjs'; import '../../loading/plugin.mjs'; import '../../loading/loading.mjs'; import '../../loading/icon/gradient.mjs'; import '../../_common/js/loading/circle-adapter.mjs'; import '../../_common/js/utils/set-style.mjs'; import '../../_common/js/utils/helper.mjs'; import '../../_chunks/dep-53e379cd.mjs'; import '../../_chunks/dep-5a2ce53e.mjs'; import '../../utils/dom.mjs'; import '../../utils/easing.mjs'; import '../../loading/props.mjs'; import '../../hooks/useTeleport.mjs'; import '../../loading/type.mjs'; 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: "XCascaderItem", props: props, setup: function setup(props2) { var liRef = ref(); useRipple(liRef); var COMPONENT_NAME = usePrefixClass("cascader__item"); var classPrefix = usePrefixClass(); 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; } function RenderLabelContent(node, cascaderContext) { var label = RenderLabelInner(node, cascaderContext); var labelCont = createVNode("span", { "title": cascaderContext.inputVal ? getFullPathLabel(node) : node.label, "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) : node.label, "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; return createVNode("li", { "ref": liRef, "class": itemClass.value, "onClick": function onClick(e) { e.stopPropagation(); props2.onClick(); }, "onMouseenter": function onMouseenter(e) { e.stopPropagation(); props2.onMouseenter(); } }, [optionChild || (cascaderContext.multiple ? RenderCheckBox(node, cascaderContext) : RenderLabelContent(node, cascaderContext)), node.children && (node.loading ? createVNode(Loading, { "class": iconClass.value, "size": "small" }, null) : createVNode(__unplugin_components_3, { "class": iconClass.value }, null))]); }; } }); export { Item as default }; //# sourceMappingURL=Item.mjs.map