UNPKG

xdesign-vue-next

Version:

XDesign Component for vue-next

95 lines (91 loc) 3.42 kB
/** * xdesign v1.0.6 * (c) 2023 xdesign * @license MIT */ import _defineProperty from '@babel/runtime/helpers/defineProperty'; import { defineComponent, provide, createVNode, isVNode } from 'vue'; import props from './avatar-group-props.js'; import _Avatar from './avatar.js'; import { useTNodeJSX } from '../hooks/tnode.js'; import { usePrefixClass } from '../hooks/useConfig.js'; import './props.js'; import '../image/index.js'; import '../image/image.js'; import '../_chunks/dep-e816f437.js'; import '../_chunks/dep-bd86e885.js'; import '@babel/runtime/helpers/slicedToArray'; import 'lodash/omit'; import 'lodash/isFunction'; import '../_common/js/utils/observe.js'; import '../config-provider/useConfig.js'; import 'lodash/cloneDeep'; import 'lodash/isString'; import '../config-provider/context.js'; import 'lodash/mergeWith'; import 'lodash/merge'; import '../_common/js/global-config/default-config.js'; import '../_common/js/global-config/locale/en_US.js'; import '../_chunks/dep-3a1cce9f.js'; import 'lodash/isArray'; import '../image/props.js'; import '../space/index.js'; import '../space/space.js'; import '../space/props.js'; import '../hooks/slot.js'; import '@babel/runtime/helpers/typeof'; import 'lodash/isNumber'; import 'lodash/camelCase'; import 'lodash/kebabCase'; import '../utils/render-tnode.js'; import 'lodash/isEmpty'; import 'lodash/isObject'; import '../utils/withInstall.js'; import '../hooks/useImagePreviewUrl.js'; import '../_common/js/upload/utils.js'; import '../_common/js/log/log.js'; function _isSlot(s) { return typeof s === 'function' || Object.prototype.toString.call(s) === '[object Object]' && !isVNode(s); } var _AvatarGroup = defineComponent({ name: "XAvatarGroup", props: props, setup: function setup(props2) { provide("avatarGroup", props2); var renderTNodeJSX = useTNodeJSX(); var AVATAR_NAME = usePrefixClass("avatar"); var COMPONENT_NAME = usePrefixClass("avatar-group"); var renderEllipsisAvatar = function renderEllipsisAvatar(children) { if ((children === null || children === void 0 ? void 0 : children.length) > props2.max) { var content = getEllipsisContent(children); var outAvatar = children.slice(0, props2.max); outAvatar.push(createVNode(_Avatar, { "class": "".concat(AVATAR_NAME.value, "__collapse"), "size": props2.size }, _isSlot(content) ? content : { "default": function _default() { return [content]; } })); return [outAvatar]; } return [children]; }; var getEllipsisContent = function getEllipsisContent(children) { return renderTNodeJSX("collapseAvatar") || "+".concat(children.length - props2.max); }; return function () { var _ref; var children = renderTNodeJSX("default"); var cascading = props2.cascading, max = props2.max; var groupClass = ["".concat(COMPONENT_NAME.value), (_ref = {}, _defineProperty(_ref, "".concat(AVATAR_NAME.value, "--offset-right"), cascading === "right-up"), _defineProperty(_ref, "".concat(AVATAR_NAME.value, "--offset-left"), cascading === "left-up"), _ref)]; var content = max && max >= 0 ? [renderEllipsisAvatar(children)] : [children]; return createVNode("div", { "class": groupClass }, [content]); }; } }); export { _AvatarGroup as default }; //# sourceMappingURL=group.js.map