UNPKG

@fe6/water-pro

Version:

An enterprise-class UI design language and Vue-based implementation

157 lines (131 loc) 5.77 kB
"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;