UNPKG

7.68 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
5Object.defineProperty(exports, "__esModule", {
6 value: true
7});
8Object.defineProperty(exports, "collapseProps", {
9 enumerable: true,
10 get: function get() {
11 return _commonProps.collapseProps;
12 }
13});
14exports.default = void 0;
15
16var _vue = require("vue");
17
18var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
19
20var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
21
22var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
23
24var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
25
26var _propsUtil = require("../_util/props-util");
27
28var _vnode = require("../_util/vnode");
29
30var _commonProps = require("./commonProps");
31
32var _util = require("../_util/util");
33
34var _RightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/RightOutlined"));
35
36var _firstNotUndefined = _interopRequireDefault(require("../_util/firstNotUndefined"));
37
38var _classNames2 = _interopRequireDefault(require("../_util/classNames"));
39
40var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
41
42var _collapseMotion = _interopRequireDefault(require("../_util/collapseMotion"));
43
44function getActiveKeysArray(activeKey) {
45 var currentActiveKey = activeKey;
46
47 if (!Array.isArray(currentActiveKey)) {
48 var activeKeyType = (0, _typeof2.default)(currentActiveKey);
49 currentActiveKey = activeKeyType === 'number' || activeKeyType === 'string' ? [currentActiveKey] : [];
50 }
51
52 return currentActiveKey.map(function (key) {
53 return String(key);
54 });
55}
56
57var _default = (0, _vue.defineComponent)({
58 name: 'ACollapse',
59 inheritAttrs: false,
60 props: (0, _propsUtil.initDefaultProps)((0, _commonProps.collapseProps)(), {
61 accordion: false,
62 destroyInactivePanel: false,
63 bordered: true,
64 openAnimation: (0, _collapseMotion.default)('ant-motion-collapse', false),
65 expandIconPosition: 'left'
66 }),
67 slots: ['expandIcon'],
68 emits: ['change', 'update:activeKey'],
69 setup: function setup(props, _ref) {
70 var attrs = _ref.attrs,
71 slots = _ref.slots,
72 emit = _ref.emit;
73 var stateActiveKey = (0, _vue.ref)(getActiveKeysArray((0, _firstNotUndefined.default)([props.activeKey, props.defaultActiveKey])));
74 (0, _vue.watch)(function () {
75 return props.activeKey;
76 }, function () {
77 stateActiveKey.value = getActiveKeysArray(props.activeKey);
78 }, {
79 deep: true
80 });
81
82 var _useConfigInject = (0, _useConfigInject2.default)('collapse', props),
83 prefixCls = _useConfigInject.prefixCls,
84 direction = _useConfigInject.direction;
85
86 var iconPosition = (0, _vue.computed)(function () {
87 var expandIconPosition = props.expandIconPosition;
88
89 if (expandIconPosition !== undefined) {
90 return expandIconPosition;
91 }
92
93 return direction.value === 'rtl' ? 'right' : 'left';
94 });
95
96 var renderExpandIcon = function renderExpandIcon(panelProps) {
97 var _props$expandIcon = props.expandIcon,
98 expandIcon = _props$expandIcon === void 0 ? slots.expandIcon : _props$expandIcon;
99 var icon = expandIcon ? expandIcon(panelProps) : (0, _vue.createVNode)(_RightOutlined.default, {
100 "rotate": panelProps.isActive ? 90 : undefined
101 }, null);
102 return (0, _vue.createVNode)("div", null, [(0, _propsUtil.isValidElement)(Array.isArray(expandIcon) ? icon[0] : icon) ? (0, _vnode.cloneElement)(icon, {
103 class: "".concat(prefixCls.value, "-arrow")
104 }, false) : icon]);
105 };
106
107 var setActiveKey = function setActiveKey(activeKey) {
108 if (props.activeKey === undefined) {
109 stateActiveKey.value = activeKey;
110 }
111
112 var newKey = props.accordion ? activeKey[0] : activeKey;
113 emit('update:activeKey', newKey);
114 emit('change', newKey);
115 };
116
117 var onClickItem = function onClickItem(key) {
118 var activeKey = stateActiveKey.value;
119
120 if (props.accordion) {
121 activeKey = activeKey[0] === key ? [] : [key];
122 } else {
123 activeKey = (0, _toConsumableArray2.default)(activeKey);
124 var index = activeKey.indexOf(key);
125 var isActive = index > -1;
126
127 if (isActive) {
128 // remove active state
129 activeKey.splice(index, 1);
130 } else {
131 activeKey.push(key);
132 }
133 }
134
135 setActiveKey(activeKey);
136 };
137
138 var getNewChild = function getNewChild(child, index) {
139 var _a, _b, _c;
140
141 if ((0, _propsUtil.isEmptyElement)(child)) return;
142 var activeKey = stateActiveKey.value;
143 var accordion = props.accordion,
144 destroyInactivePanel = props.destroyInactivePanel,
145 collapsible = props.collapsible,
146 openAnimation = props.openAnimation; // If there is no key provide, use the panel order as default key
147
148 var key = String((_a = child.key) !== null && _a !== void 0 ? _a : index);
149
150 var _ref2 = child.props || {},
151 _ref2$header = _ref2.header,
152 header = _ref2$header === void 0 ? (_c = (_b = child.children) === null || _b === void 0 ? void 0 : _b.header) === null || _c === void 0 ? void 0 : _c.call(_b) : _ref2$header,
153 headerClass = _ref2.headerClass,
154 childCollapsible = _ref2.collapsible,
155 disabled = _ref2.disabled;
156
157 var isActive = false;
158
159 if (accordion) {
160 isActive = activeKey[0] === key;
161 } else {
162 isActive = activeKey.indexOf(key) > -1;
163 }
164
165 var mergeCollapsible = childCollapsible !== null && childCollapsible !== void 0 ? childCollapsible : collapsible; // legacy 2.x
166
167 if (disabled || disabled === '') {
168 mergeCollapsible = 'disabled';
169 }
170
171 var newProps = {
172 key: key,
173 panelKey: key,
174 header: header,
175 headerClass: headerClass,
176 isActive: isActive,
177 prefixCls: prefixCls.value,
178 destroyInactivePanel: destroyInactivePanel,
179 openAnimation: openAnimation,
180 accordion: accordion,
181 onItemClick: mergeCollapsible === 'disabled' ? null : onClickItem,
182 expandIcon: renderExpandIcon,
183 collapsible: mergeCollapsible
184 };
185 return (0, _vnode.cloneElement)(child, newProps);
186 };
187
188 var getItems = function getItems() {
189 var _a;
190
191 return (0, _propsUtil.flattenChildren)((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)).map(getNewChild);
192 };
193
194 return function () {
195 var _classNames;
196
197 var accordion = props.accordion,
198 bordered = props.bordered,
199 ghost = props.ghost;
200 var collapseClassName = (0, _classNames2.default)((_classNames = {}, (0, _defineProperty2.default)(_classNames, prefixCls.value, true), (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-borderless"), !bordered), (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-icon-position-").concat(iconPosition.value), true), (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-rtl"), direction.value === 'rtl'), (0, _defineProperty2.default)(_classNames, "".concat(prefixCls.value, "-ghost"), !!ghost), (0, _defineProperty2.default)(_classNames, attrs.class, !!attrs.class), _classNames));
201 return (0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({
202 "class": collapseClassName
203 }, (0, _util.getDataAndAriaProps)(attrs)), {}, {
204 "style": attrs.style,
205 "role": accordion ? 'tablist' : null
206 }), [getItems()]);
207 };
208 }
209});
210
211exports.default = _default;
\No newline at end of file