tdesign-vue
Version:
124 lines (116 loc) • 4.91 kB
JavaScript
/**
* tdesign v1.12.1
* (c) 2025 tdesign
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var _defineProperty = require('@babel/runtime/helpers/defineProperty');
var _slicedToArray = require('@babel/runtime/helpers/slicedToArray');
var VueCompositionAPI = require('@vue/composition-api');
var collapse_props = require('./props.js');
var hooks_useVModel = require('../hooks/useVModel.js');
var hooks_tnode = require('../hooks/tnode.js');
var hooks_useConfig = require('../hooks/useConfig.js');
require('../_chunks/dep-727a349e.js');
require('../_chunks/dep-4b30bfe2.js');
require('../_chunks/dep-e1cc6f64.js');
require('../_chunks/dep-5ea2b00f.js');
require('@babel/runtime/helpers/typeof');
require('../_chunks/dep-9b72cbc5.js');
require('../_chunks/dep-7b78e8c3.js');
require('../_chunks/dep-d7270eaf.js');
require('../hooks/render-tnode.js');
require('../_chunks/dep-51fe98f1.js');
require('../_chunks/dep-6b60413b.js');
require('../_chunks/dep-bf70543d.js');
require('../_chunks/dep-f895c884.js');
require('../_chunks/dep-68f48b50.js');
require('../_chunks/dep-051ce30d.js');
require('../_chunks/dep-411a10dd.js');
require('../_chunks/dep-f6069bb1.js');
require('../_chunks/dep-ed8c3176.js');
require('../_chunks/dep-4aa08166.js');
require('../_chunks/dep-ddc1429e.js');
require('../_chunks/dep-65896ff9.js');
require('../_chunks/dep-887c649b.js');
require('../_chunks/dep-28836b00.js');
require('../_chunks/dep-dea23841.js');
require('../config-provider/useConfig.js');
require('../_chunks/dep-6247fdbf.js');
require('../_common/js/global-config/default-config.js');
require('../_common/js/global-config/locale/zh_CN.js');
require('../_chunks/dep-3ed0c42e.js');
require('../_chunks/dep-53935099.js');
require('dayjs');
require('../_chunks/dep-403352a7.js');
require('../_chunks/dep-cca66fee.js');
require('../_chunks/dep-4361b357.js');
require('../_chunks/dep-3d682642.js');
require('../_chunks/dep-b65b2f55.js');
require('../_chunks/dep-6e7b8cda.js');
require('../_chunks/dep-98f48ff2.js');
require('../_chunks/dep-80e3757f.js');
require('../_chunks/dep-08d7842c.js');
require('../_chunks/dep-1ca3138c.js');
require('../_chunks/dep-e6ed4b1f.js');
require('../_chunks/dep-c44b2462.js');
require('../_common/js/global-config/t.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty);
var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray);
var _Collapse = VueCompositionAPI.defineComponent({
name: "TCollapse",
props: collapse_props["default"],
setup: function setup(props2) {
var componentName = hooks_useConfig.usePrefixClass("collapse");
var borderlessClass = hooks_useConfig.usePrefixClass("-border-less");
var _toRefs = VueCompositionAPI.toRefs(props2),
value = _toRefs.value,
expandMutex = _toRefs.expandMutex,
borderless = _toRefs.borderless;
var _useVModel = hooks_useVModel.useVModel(value, props2.defaultValue, props2.onChange, "change"),
_useVModel2 = _slicedToArray__default["default"](_useVModel, 2),
collapseValue = _useVModel2[0],
setCollapseValue = _useVModel2[1];
var updateCollapseValue = function updateCollapseValue(value2) {
var newValue = [].concat(collapseValue.value || []);
var index = newValue.indexOf(value2);
if (index >= 0) {
newValue.splice(index, 1);
} else if (expandMutex.value) {
newValue = [value2];
} else {
newValue.push(value2);
}
setCollapseValue(newValue);
};
var classes = VueCompositionAPI.computed(function () {
return [componentName.value, _defineProperty__default["default"]({}, borderlessClass.value, !!borderless.value)];
});
var getUniqId = function () {
var index = 0;
return function () {
return index += 1;
};
}();
VueCompositionAPI.provide("collapseValue", collapseValue);
VueCompositionAPI.provide("updateCollapseValue", updateCollapseValue);
VueCompositionAPI.provide("collapseProps", VueCompositionAPI.toRefs(props2));
VueCompositionAPI.provide("getUniqId", getUniqId);
VueCompositionAPI.provide("renderParentTNode", hooks_tnode.useTNodeJSX());
return {
classes: classes
};
},
render: function render() {
var _this$$scopedSlots, _this$$scopedSlots$de;
var h = arguments[0];
var nodes = ((_this$$scopedSlots = this.$scopedSlots) === null || _this$$scopedSlots === void 0 || (_this$$scopedSlots$de = _this$$scopedSlots["default"]) === null || _this$$scopedSlots$de === void 0 ? void 0 : _this$$scopedSlots$de.call(_this$$scopedSlots, {})) || null;
return h("div", {
"class": this.classes
}, [nodes]);
}
});
exports["default"] = _Collapse;
//# sourceMappingURL=collapse.js.map