tdesign-mobile-vue
Version:
tdesign-mobile-vue
95 lines (87 loc) • 3.9 kB
JavaScript
/**
* tdesign v1.7.0
* (c) 2024 TDesign Group
* @license MIT
*/
;
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