UNPKG

tdesign-mobile-vue

Version:
136 lines (132 loc) 5.01 kB
/** * tdesign v1.9.3 * (c) 2025 TDesign Group * @license MIT */ import { _ as _defineProperty } from '../_chunks/dep-900db0e1.mjs'; import { defineComponent, computed, createVNode, withDirectives, resolveDirective } from 'vue'; import { ChevronRightIcon } from 'tdesign-icons-vue-next'; import '../shared/index.mjs'; import config from '../config.mjs'; import props from './props.mjs'; import { useFormDisabled } from '../form/hooks.mjs'; import { usePrefixClass } from '../hooks/useClass.mjs'; import { useTNodeJSX, useContent } from '../hooks/tnode.mjs'; import Hover from '../shared/hover.mjs'; import '../_chunks/dep-4915223e.mjs'; import '../shared/functions.mjs'; import '../shared/util.mjs'; import '../_chunks/dep-26b97ced.mjs'; import '../_chunks/dep-a953013f.mjs'; import 'lodash-es'; import '../shared/component.mjs'; import '../shared/render.mjs'; import '../shared/dom.mjs'; import '../shared/render-tnode.mjs'; import '../shared/useCountDown/index.mjs'; import '../_chunks/dep-99e43b7b.mjs'; import '../_chunks/dep-6b2b02fd.mjs'; import '@vueuse/core'; import '../shared/useCountDown/utils.mjs'; import '../shared/useTouch/index.mjs'; import '../shared/useScrollParent/index.mjs'; import '../shared/useTest/index.mjs'; import '../shared/useClickAway/index.mjs'; import '../_chunks/dep-fb4113ef.mjs'; import '../config-provider/useConfig.mjs'; import '../config-provider/context.mjs'; import '../_common/js/global-config/mobile/default-config.mjs'; import '../_common/js/global-config/mobile/locale/zh_CN.mjs'; import '../_chunks/dep-bca0f578.mjs'; import '../_chunks/dep-c6f44a15.mjs'; import '../_chunks/dep-c984d53e.mjs'; import '../config-provider/type.mjs'; import '../hooks/render-tnode.mjs'; import '../_common/js/utils/general.mjs'; var prefix = config.prefix; var _Cell = defineComponent({ name: "".concat(prefix, "-cell"), directives: { Hover: Hover }, props: props, setup: function setup(props2) { var renderTNodeJSX = useTNodeJSX(); var renderTNodeContent = useContent(); var disabled = useFormDisabled(); var cellClass = usePrefixClass("cell"); var cellClasses = computed(function () { return ["".concat(cellClass.value), _defineProperty({}, "".concat(cellClass.value, "--borderless"), !props2.bordered)]; }); var hoverDisabled = computed(function () { return !props2.hover || disabled.value; }); var handleClick = function handleClick(e) { if (!disabled.value) { var _props2$onClick; (_props2$onClick = props2.onClick) === null || _props2$onClick === void 0 || _props2$onClick.call(props2, { e: e }); } }; var renderImage = function renderImage() { if (typeof props2.image === "string") { return createVNode("img", { "src": props2.image, "class": "".concat(cellClass.value, "__left-image") }, null); } var image = renderTNodeJSX("image"); return image; }; var renderLeft = function renderLeft() { var leftIcon = renderTNodeJSX("leftIcon"); return createVNode("div", { "class": "".concat(cellClass.value, "__left") }, [leftIcon && createVNode("div", { "class": "".concat(cellClass.value, "__left-icon") }, [leftIcon]), renderImage()]); }; var renderTitle = function renderTitle() { var title = renderTNodeJSX("title"); if (!title) { return null; } var description = renderTNodeJSX("description"); return createVNode("div", { "class": "".concat(cellClass.value, "__title") }, [createVNode("div", { "class": "".concat(cellClass.value, "__title-text") }, [title, props2.required && createVNode("span", { "class": "".concat(cellClass.value, "--required") }, ["\xA0*"])]), description && createVNode("div", { "class": "".concat(cellClass.value, "__description") }, [description])]); }; var renderRight = function renderRight() { var rightIcon = props2.arrow ? createVNode(ChevronRightIcon, null, null) : renderTNodeJSX("rightIcon"); if (!rightIcon) { return null; } return createVNode("div", { "class": ["".concat(cellClass.value, "__right"), "".concat(cellClass.value, "__right--").concat(props2.align)] }, [createVNode("div", { "class": "".concat(cellClass.value, "__right-icon") }, [rightIcon])]); }; return function () { var note = renderTNodeContent("default", "note"); return withDirectives(createVNode("div", { "class": cellClasses.value, "onClick": handleClick }, [renderLeft(), renderTitle(), note && createVNode("div", { "class": "".concat(cellClass.value, "__note") }, [note]), renderRight()]), [[resolveDirective("hover"), { className: "".concat(cellClass.value, "--hover"), disabledHover: hoverDisabled.value }]]); }; } }); export { _Cell as default }; //# sourceMappingURL=cell.mjs.map