UNPKG

@aplus-frontend/antdv

Version:

Vue basic component library maintained based on ant-design-vue

230 lines (229 loc) 7.86 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.descriptionsProps = exports.descriptionsContext = exports.default = exports.DescriptionsItemProps = exports.DescriptionsItem = void 0; var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _vue = require("vue"); var _warning = _interopRequireDefault(require("../_util/warning")); var _responsiveObserve = _interopRequireWildcard(require("../_util/responsiveObserve")); var _Row = _interopRequireDefault(require("./Row")); var _vueTypes = _interopRequireDefault(require("../_util/vue-types")); var _vnode = require("../_util/vnode"); var _propsUtil = require("../_util/props-util"); var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject")); var _style = _interopRequireDefault(require("./style")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } const DescriptionsItemProps = exports.DescriptionsItemProps = { prefixCls: String, label: _vueTypes.default.any, span: Number }; const descriptionsItemProp = () => ({ prefixCls: String, label: _vueTypes.default.any, labelStyle: { type: Object, default: undefined }, contentStyle: { type: Object, default: undefined }, span: { type: Number, default: 1 } }); const DescriptionsItem = exports.DescriptionsItem = (0, _vue.defineComponent)({ compatConfig: { MODE: 3 }, name: 'ADescriptionsItem', props: descriptionsItemProp(), setup(_, _ref) { let { slots } = _ref; return () => { var _a; return (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots); }; } }); const DEFAULT_COLUMN_MAP = { xxxl: 3, xxl: 3, xl: 3, lg: 3, md: 3, sm: 2, xs: 1 }; function getColumn(column, screens) { if (typeof column === 'number') { return column; } if (typeof column === 'object') { for (let i = 0; i < _responsiveObserve.responsiveArray.length; i++) { const breakpoint = _responsiveObserve.responsiveArray[i]; if (screens[breakpoint] && column[breakpoint] !== undefined) { return column[breakpoint] || DEFAULT_COLUMN_MAP[breakpoint]; } } } return 3; } function getFilledItem(node, rowRestCol, span) { let clone = node; if (span === undefined || span > rowRestCol) { clone = (0, _vnode.cloneElement)(node, { span: rowRestCol }); (0, _warning.default)(span === undefined, 'Descriptions', 'Sum of column `span` in a line not match `column` of Descriptions.'); } return clone; } function getRows(children, column) { const childNodes = (0, _propsUtil.flattenChildren)(children); const rows = []; let tmpRow = []; let rowRestCol = column; childNodes.forEach((node, index) => { var _a; const span = (_a = node.props) === null || _a === void 0 ? void 0 : _a.span; const mergedSpan = span || 1; // Additional handle last one if (index === childNodes.length - 1) { tmpRow.push(getFilledItem(node, rowRestCol, span)); rows.push(tmpRow); return; } if (mergedSpan < rowRestCol) { rowRestCol -= mergedSpan; tmpRow.push(node); } else { tmpRow.push(getFilledItem(node, rowRestCol, mergedSpan)); rows.push(tmpRow); rowRestCol = column; tmpRow = []; } }); return rows; } const descriptionsProps = () => ({ prefixCls: String, bordered: { type: Boolean, default: undefined }, size: { type: String, default: 'default' }, title: _vueTypes.default.any, extra: _vueTypes.default.any, column: { type: [Number, Object], default: () => DEFAULT_COLUMN_MAP }, layout: String, colon: { type: Boolean, default: undefined }, labelStyle: { type: Object, default: undefined }, contentStyle: { type: Object, default: undefined } }); exports.descriptionsProps = descriptionsProps; const descriptionsContext = exports.descriptionsContext = Symbol('descriptionsContext'); const Descriptions = (0, _vue.defineComponent)({ compatConfig: { MODE: 3 }, name: 'ADescriptions', inheritAttrs: false, props: descriptionsProps(), slots: Object, Item: DescriptionsItem, setup(props, _ref2) { let { slots, attrs } = _ref2; const { prefixCls, direction } = (0, _useConfigInject.default)('descriptions', props); let token; const screens = (0, _vue.ref)({}); const [wrapSSR, hashId] = (0, _style.default)(prefixCls); const responsiveObserve = (0, _responsiveObserve.default)(); (0, _vue.onBeforeMount)(() => { token = responsiveObserve.value.subscribe(screen => { if (typeof props.column !== 'object') { return; } screens.value = screen; }); }); (0, _vue.onBeforeUnmount)(() => { responsiveObserve.value.unsubscribe(token); }); (0, _vue.provide)(descriptionsContext, { labelStyle: (0, _vue.toRef)(props, 'labelStyle'), contentStyle: (0, _vue.toRef)(props, 'contentStyle') }); const mergeColumn = (0, _vue.computed)(() => getColumn(props.column, screens.value)); return () => { var _a, _b, _c; const { size, bordered = false, layout = 'horizontal', colon = true, title = (_a = slots.title) === null || _a === void 0 ? void 0 : _a.call(slots), extra = (_b = slots.extra) === null || _b === void 0 ? void 0 : _b.call(slots) } = props; const children = (_c = slots.default) === null || _c === void 0 ? void 0 : _c.call(slots); const rows = getRows(children, mergeColumn.value); return wrapSSR((0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, { "class": [prefixCls.value, { [`${prefixCls.value}-${size}`]: size !== 'default', [`${prefixCls.value}-bordered`]: !!bordered, [`${prefixCls.value}-rtl`]: direction.value === 'rtl' }, attrs.class, hashId.value] }), [(title || extra) && (0, _vue.createVNode)("div", { "class": `${prefixCls.value}-header` }, [title && (0, _vue.createVNode)("div", { "class": `${prefixCls.value}-title` }, [title]), extra && (0, _vue.createVNode)("div", { "class": `${prefixCls.value}-extra` }, [extra])]), (0, _vue.createVNode)("div", { "class": `${prefixCls.value}-view` }, [(0, _vue.createVNode)("table", null, [(0, _vue.createVNode)("tbody", null, [rows.map((row, index) => (0, _vue.createVNode)(_Row.default, { "key": index, "index": index, "colon": colon, "prefixCls": prefixCls.value, "vertical": layout === 'vertical', "bordered": bordered, "row": row }, null))])])])])); }; } }); Descriptions.install = function (app) { app.component(Descriptions.name, Descriptions); app.component(Descriptions.Item.name, Descriptions.Item); return app; }; var _default = exports.default = Descriptions;