@fe6/water-pro
Version:
An enterprise-class UI design language and Vue-based implementation
157 lines (131 loc) • 5.77 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _vue = require("vue");
var _skeleton = _interopRequireDefault(require("../skeleton"));
var _transition = require("../transition");
var _containerLazy = _interopRequireDefault(require("../container-lazy/container-lazy"));
var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
var _propsUtil = require("../_util/props-util");
var _dom = require("../_util/dom");
var _useTimeout = require("../_util/hooks/use-timeout");
var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
var _type = require("../_util/type");
var _collapseHeader = _interopRequireDefault(require("./collapse-header"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
var _default2 = (0, _vue.defineComponent)({
name: 'AContainerCollapse',
props: {
title: _vueTypes.default.string.def(''),
// Can it be expanded
expanable: _vueTypes.default.bool.def(true),
// Warm reminder on the right side of the title
helpMessage: {
type: [Array, String],
default: ''
},
value: _vueTypes.default.bool,
triggerWindowResize: _vueTypes.default.bool,
loading: _vueTypes.default.bool,
lazy: _vueTypes.default.bool,
lazyTime: _vueTypes.default.number.def(0),
titleLevel: _vueTypes.default.number.def(5),
prefixCls: _vueTypes.default.string,
mode: _vueTypes.default.oneOf((0, _type.tuple)('simple', 'default')).def('default'),
headerClassName: _vueTypes.default.string,
wrapClassName: _vueTypes.default.string
},
emits: ['expand'],
setup: function setup(props) {
var _useConfigInject = (0, _useConfigInject2.default)('container-collapse', props),
prefixClsNew = _useConfigInject.prefixCls;
return {
prefixClsNew: prefixClsNew
};
},
data: function data() {
return {
show: this.value
};
},
watch: {
value: function value(newValue) {
this.show = newValue;
}
},
methods: {
handleExpand: function handleExpand() {
if (!this.lazy) {
this.show = !this.show;
}
if (this.triggerWindowResize) {
// 200 milliseconds here is because the expansion has animation,
(0, _useTimeout.useTimeoutFn)(_dom.triggerWindowResize, 200);
}
this.$emit('expand', this.lazy ? !this.show : this.show);
}
},
render: function render() {
var _this = this;
var defChildren = (0, _propsUtil.getSlot)(this);
var titleChildren = (0, _propsUtil.getSlot)(this, 'title');
var skeletonChildren = (0, _propsUtil.getSlot)(this, 'skeleton');
var props = (0, _propsUtil.getOptionProps)(this);
var collapseHeaderNode = (0, _vue.createVNode)(_collapseHeader.default, _objectSpread(_objectSpread(_objectSpread({}, this.$attrs), props), {}, {
"prefix-cls": this.prefixClsNew,
"show": this.show,
"loading": this.loading,
"onExpand": this.handleExpand,
"level": this.titleLevel,
"mode": this.mode,
"headerClassName": this.headerClassName
}), {
default: function _default() {
return [titleChildren];
},
action: function action(status) {
return (0, _propsUtil.getSlot)(_this, 'action', status);
},
icon: function icon(status) {
return (0, _propsUtil.getSlot)(_this, 'icon', status);
}
});
var lazyNode = null;
if (this.lazy) {
lazyNode = (0, _vue.createVNode)(_containerLazy.default, {
"timeout": this.lazyTime
}, {
default: function _default() {
return [defChildren, skeletonChildren];
}
});
} else {
lazyNode = defChildren;
}
var childrenNode = null;
if (this.loading) {
childrenNode = (0, _vue.createVNode)(_skeleton.default, null, null);
} else {
childrenNode = (0, _vue.createVNode)("div", {
"style": "display: ".concat(this.show ? 'block' : 'none'),
"class": "".concat(this.prefixClsNew, "-body ").concat(this.prefixClsNew, "-body-").concat(this.mode).concat(this.wrapClassName ? " ".concat(this.wrapClassName) : '')
}, [lazyNode]);
}
var collapseTransitionNode = (0, _vue.createVNode)(_transition.CollapseTransition, {
"enable": this.expanable
}, {
default: function _default() {
return [childrenNode];
}
});
return (0, _vue.createVNode)("div", {
"class": [this.prefixClsNew, "".concat(this.prefixClsNew, "-").concat(this.mode)]
}, [collapseHeaderNode, collapseTransitionNode]);
}
});
exports.default = _default2;