UNPKG

tdesign-mobile-vue

Version:
95 lines (87 loc) 3.9 kB
/** * tdesign v1.7.0 * (c) 2024 TDesign Group * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var vue = require('vue'); var isFunction = require('lodash/isFunction'); var camelCase = require('lodash/camelCase'); var kebabCase = require('lodash/kebabCase'); var hooks_renderTnode = require('./render-tnode.js'); require('lodash/isEmpty'); require('lodash/isString'); require('lodash/isObject'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var isFunction__default = /*#__PURE__*/_interopDefaultLegacy(isFunction); var camelCase__default = /*#__PURE__*/_interopDefaultLegacy(camelCase); var kebabCase__default = /*#__PURE__*/_interopDefaultLegacy(kebabCase); 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__default["default"](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__default["default"](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 = vue.getCurrentInstance(); return function (name, options) { var params = hooks_renderTnode.getParams(options); var defaultNode = hooks_renderTnode.getDefaultNode(options); var slotFirst = hooks_renderTnode.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__default["default"](propsNode)) return propsNode(vue.h, params); var isPropsEmpty = [void 0, params, ""].includes(propsNode); if ((isPropsEmpty || slotFirst) && (instance.slots[camelCase__default["default"](name)] || instance.slots[kebabCase__default["default"](name)])) { return handleSlots(instance, name, params); } return propsNode; }; }; var useTNodeDefault = function useTNodeDefault() { var renderTNodeJSX = useTNodeJSX(); return function (name, options) { var defaultNode = hooks_renderTnode.getDefaultNode(options); return renderTNodeJSX(name, options) || defaultNode; }; }; var useContent = function useContent() { var renderTNodeJSX = useTNodeJSX(); return function (name1, name2, options) { var params = hooks_renderTnode.getParams(options); var defaultNode = hooks_renderTnode.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; }; }; exports.useContent = useContent; exports.useTNodeDefault = useTNodeDefault; exports.useTNodeJSX = useTNodeJSX; //# sourceMappingURL=tnode.js.map