UNPKG

tdesign-mobile-vue

Version:
100 lines (96 loc) 4 kB
/** * tdesign v1.7.0 * (c) 2024 TDesign Group * @license MIT */ import { getCurrentInstance, h } from 'vue'; import { i as isFunction_1 } from '../_chunks/dep-91d696ea.mjs'; import { c as camelCase_1 } from '../_chunks/dep-60cadef8.mjs'; import { k as kebabCase_1 } from '../_chunks/dep-6917b9bc.mjs'; import { getParams, getDefaultNode, getSlotFirst } from './render-tnode.mjs'; import '../_chunks/dep-8bf3054e.mjs'; import '../_chunks/dep-3d249f65.mjs'; import '../_chunks/dep-620d73f7.mjs'; import '../_chunks/dep-e6c129ab.mjs'; import '../_chunks/dep-8140c29b.mjs'; import '../_chunks/dep-0d52e58f.mjs'; import '../_chunks/dep-019e292f.mjs'; import '../_chunks/dep-32364550.mjs'; import '../_chunks/dep-a836a38c.mjs'; import '../_chunks/dep-9b2de386.mjs'; import '../_chunks/dep-0ea7bbde.mjs'; import '../_chunks/dep-b437ef0b.mjs'; import '../_chunks/dep-40507aac.mjs'; import '../_chunks/dep-2bce42ea.mjs'; import '../_chunks/dep-e57d46f3.mjs'; import '../_chunks/dep-4f44985d.mjs'; import '../_chunks/dep-6bc862af.mjs'; import '../_chunks/dep-b84be35c.mjs'; import '../_chunks/dep-08bc7a4c.mjs'; import '../_chunks/dep-6303c50c.mjs'; function handleSlots(instance, name, params) { var _instance$slots$camel, _instance$slots, _instance$slots$kebab, _instance$slots2; var node = (_instance$slots$camel = (_instance$slots = instance.slots)[camelCase_1(name)]) === null || _instance$slots$camel === void 0 ? void 0 : _instance$slots$camel.call(_instance$slots, params); if (node && node.filter(function (t) { return t.type.toString() !== "Symbol(v-cmt)"; }).length) return node; node = (_instance$slots$kebab = (_instance$slots2 = instance.slots)[kebabCase_1(name)]) === null || _instance$slots$kebab === void 0 ? void 0 : _instance$slots$kebab.call(_instance$slots2, params); if (node && node.filter(function (t) { return t.type.toString() !== "Symbol(v-cmt)"; }).length) return node; return null; } function isEmptyNode(node) { if ([void 0, null, ""].includes(node)) return true; var innerNodes = node instanceof Array ? node : [node]; var r = innerNodes.filter(function (node2) { var _node2$type; return (node2 === null || node2 === void 0 || (_node2$type = node2.type) === null || _node2$type === void 0 ? void 0 : _node2$type.toString()) !== "Symbol(Comment)"; }); return !r.length; } var useTNodeJSX = function useTNodeJSX() { var instance = getCurrentInstance(); return function (name, options) { var params = getParams(options); var defaultNode = getDefaultNode(options); var slotFirst = getSlotFirst(options); var propsNode; if (Object.keys(instance.props).includes(name)) { propsNode = instance.props[name]; } if (propsNode === false || propsNode === null) return; if (propsNode === true) { return handleSlots(instance, name, params) || defaultNode; } if (isFunction_1(propsNode)) return propsNode(h, params); var isPropsEmpty = [void 0, params, ""].includes(propsNode); if ((isPropsEmpty || slotFirst) && (instance.slots[camelCase_1(name)] || instance.slots[kebabCase_1(name)])) { return handleSlots(instance, name, params); } return propsNode; }; }; var useTNodeDefault = function useTNodeDefault() { var renderTNodeJSX = useTNodeJSX(); return function (name, options) { var defaultNode = getDefaultNode(options); return renderTNodeJSX(name, options) || defaultNode; }; }; var useContent = function useContent() { var renderTNodeJSX = useTNodeJSX(); return function (name1, name2, options) { var params = getParams(options); var defaultNode = getDefaultNode(options); var toParams = params ? { params: params } : void 0; var node1 = renderTNodeJSX(name1, toParams); var node2 = renderTNodeJSX(name2, toParams); var res = isEmptyNode(node1) ? node2 : node1; return isEmptyNode(res) ? defaultNode : res; }; }; export { useContent, useTNodeDefault, useTNodeJSX }; //# sourceMappingURL=tnode.mjs.map