xdesign-vue-next
Version:
XDesign Component for vue-next
159 lines (151 loc) • 6.73 kB
JavaScript
/**
* xdesign v1.0.6
* (c) 2023 xdesign
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var _defineProperty = require('@babel/runtime/helpers/defineProperty');
var vue = require('vue');
var avatar_props = require('./props.js');
var hooks_useConfig = require('../hooks/useConfig.js');
var hooks_tnode = require('../hooks/tnode.js');
var image_index = require('../image/index.js');
require('../config-provider/useConfig.js');
require('lodash/isFunction');
require('lodash/cloneDeep');
require('lodash/isString');
require('../config-provider/context.js');
require('lodash/mergeWith');
require('lodash/merge');
require('../_common/js/global-config/default-config.js');
require('../_common/js/global-config/locale/en_US.js');
require('../_chunks/dep-8d10b59f.js');
require('lodash/isArray');
require('lodash/camelCase');
require('lodash/kebabCase');
require('../utils/render-tnode.js');
require('lodash/isEmpty');
require('lodash/isObject');
require('../image/image.js');
require('../_chunks/dep-6085e357.js');
require('../_chunks/dep-d2b45a10.js');
require('@babel/runtime/helpers/slicedToArray');
require('lodash/omit');
require('../_common/js/utils/observe.js');
require('../image/props.js');
require('../space/index.js');
require('../space/space.js');
require('../space/props.js');
require('../hooks/slot.js');
require('@babel/runtime/helpers/typeof');
require('lodash/isNumber');
require('../utils/withInstall.js');
require('../hooks/useImagePreviewUrl.js');
require('../_common/js/upload/utils.js');
require('../_common/js/log/log.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty);
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); 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 = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty__default["default"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
var _Avatar = vue.defineComponent({
name: "XAvatar",
props: avatar_props["default"],
setup: function setup(props2) {
var COMPONENT_NAME = hooks_useConfig.usePrefixClass("avatar");
var renderContent = hooks_tnode.useContent();
var renderTNodeJSX = hooks_tnode.useTNodeJSX();
var _useCommonClassName = hooks_useConfig.useCommonClassName(),
SIZE = _useCommonClassName.SIZE;
var avatarGroup = vue.inject("avatarGroup", void 0);
var avatar = vue.ref(null);
var avatarChild = vue.ref(null);
var isImgExist = vue.ref(true);
var gap = vue.ref(4);
var scale = vue.ref("");
var sizeValue = vue.computed(function () {
return props2.size || (avatarGroup === null || avatarGroup === void 0 ? void 0 : avatarGroup.size);
});
var isCustomSize = vue.computed(function () {
return sizeValue.value && !SIZE.value[sizeValue.value];
});
var customAvatarSize = vue.computed(function () {
return isCustomSize.value ? {
width: sizeValue.value,
height: sizeValue.value,
"font-size": "".concat(Number.parseInt(sizeValue.value, 10) / 2, "px")
} : {};
});
var customImageSize = vue.computed(function () {
return isCustomSize.value ? {
height: sizeValue.value,
width: sizeValue.value
} : {};
});
var customCharacterSize = vue.computed(function () {
return {
transform: scale.value
};
});
var handleImgLoadError = function handleImgLoadError(_ref) {
var _props2$onError;
var e = _ref.e;
var hideOnLoadFailed = props2.hideOnLoadFailed;
isImgExist.value = !hideOnLoadFailed;
(_props2$onError = props2.onError) === null || _props2$onError === void 0 ? void 0 : _props2$onError.call(props2, {
e: e
});
};
var setScaleParams = function setScaleParams() {
var $avatar = avatar.value;
var $avatarChild = avatarChild.value;
var avatarWidth = $avatar === null || $avatar === void 0 ? void 0 : $avatar.offsetWidth;
var avatarChildWidth = $avatarChild === null || $avatarChild === void 0 ? void 0 : $avatarChild.offsetWidth;
if (gap.value * 2 < avatarWidth) {
scale.value = avatarChildWidth > avatarWidth - gap.value * 2 ? "scale(".concat((avatarWidth - gap.value * 2) / avatarChildWidth, ")") : "scale(1)";
}
};
vue.onMounted(function () {
vue.nextTick(function () {
setScaleParams();
});
});
vue.onUpdated(function () {
vue.nextTick(function () {
setScaleParams();
});
});
return function () {
var _ref2;
var content = renderContent("default", "content");
var icon = renderTNodeJSX("icon");
var isIconOnly = icon && !content;
var shape = props2.shape,
image = props2.image,
alt = props2.alt;
var avatarClass = ["".concat(COMPONENT_NAME.value), SIZE.value[sizeValue.value], (_ref2 = {}, _defineProperty__default["default"](_ref2, "".concat(COMPONENT_NAME.value, "--circle"), shape === "circle"), _defineProperty__default["default"](_ref2, "".concat(COMPONENT_NAME.value, "--round"), shape === "round"), _defineProperty__default["default"](_ref2, "".concat(COMPONENT_NAME.value, "__icon"), !!isIconOnly), _ref2)];
content = vue.createVNode("span", {
"ref": avatarChild,
"style": _objectSpread({}, customCharacterSize.value)
}, [content]);
if (icon) {
content = [icon, !isIconOnly ? content : ""];
}
if (image && isImgExist.value) {
content = vue.createVNode(image_index.Image, vue.mergeProps({
"style": _objectSpread({}, customImageSize.value),
"src": image,
"alt": alt,
"onError": handleImgLoadError
}, props2.imageProps), null);
}
return vue.createVNode("div", {
"ref": avatar,
"class": avatarClass,
"style": _objectSpread({}, customAvatarSize.value)
}, [content]);
};
}
});
exports["default"] = _Avatar;
//# sourceMappingURL=avatar.js.map