203 lines
5.6 KiB
JavaScript
203 lines
5.6 KiB
JavaScript
![]() |
'use strict';
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports.SkeletonProps = undefined;
|
||
|
|
||
|
var _defineProperty2 = require('babel-runtime/helpers/defineProperty');
|
||
|
|
||
|
var _defineProperty3 = _interopRequireDefault(_defineProperty2);
|
||
|
|
||
|
var _extends2 = require('babel-runtime/helpers/extends');
|
||
|
|
||
|
var _extends3 = _interopRequireDefault(_extends2);
|
||
|
|
||
|
var _typeof2 = require('babel-runtime/helpers/typeof');
|
||
|
|
||
|
var _typeof3 = _interopRequireDefault(_typeof2);
|
||
|
|
||
|
var _classnames = require('classnames');
|
||
|
|
||
|
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
|
||
|
var _vueTypes = require('../_util/vue-types');
|
||
|
|
||
|
var _vueTypes2 = _interopRequireDefault(_vueTypes);
|
||
|
|
||
|
var _propsUtil = require('../_util/props-util');
|
||
|
|
||
|
var _configConsumerProps = require('../config-provider/configConsumerProps');
|
||
|
|
||
|
var _Avatar = require('./Avatar');
|
||
|
|
||
|
var _Avatar2 = _interopRequireDefault(_Avatar);
|
||
|
|
||
|
var _Title = require('./Title');
|
||
|
|
||
|
var _Title2 = _interopRequireDefault(_Title);
|
||
|
|
||
|
var _Paragraph = require('./Paragraph');
|
||
|
|
||
|
var _Paragraph2 = _interopRequireDefault(_Paragraph);
|
||
|
|
||
|
var _base = require('../base');
|
||
|
|
||
|
var _base2 = _interopRequireDefault(_base);
|
||
|
|
||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
||
|
|
||
|
var SkeletonProps = exports.SkeletonProps = {
|
||
|
active: _vueTypes2['default'].bool,
|
||
|
loading: _vueTypes2['default'].bool,
|
||
|
prefixCls: _vueTypes2['default'].string,
|
||
|
children: _vueTypes2['default'].any,
|
||
|
avatar: _vueTypes2['default'].oneOfType([_vueTypes2['default'].string, _Avatar.SkeletonAvatarProps, _vueTypes2['default'].bool]),
|
||
|
title: _vueTypes2['default'].oneOfType([_vueTypes2['default'].bool, _vueTypes2['default'].string, _Title.SkeletonTitleProps]),
|
||
|
paragraph: _vueTypes2['default'].oneOfType([_vueTypes2['default'].bool, _vueTypes2['default'].string, _Paragraph.SkeletonParagraphProps])
|
||
|
};
|
||
|
|
||
|
function getComponentProps(prop) {
|
||
|
if (prop && (typeof prop === 'undefined' ? 'undefined' : (0, _typeof3['default'])(prop)) === 'object') {
|
||
|
return prop;
|
||
|
}
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
function getAvatarBasicProps(hasTitle, hasParagraph) {
|
||
|
if (hasTitle && !hasParagraph) {
|
||
|
return { shape: 'square' };
|
||
|
}
|
||
|
|
||
|
return { shape: 'circle' };
|
||
|
}
|
||
|
|
||
|
function getTitleBasicProps(hasAvatar, hasParagraph) {
|
||
|
if (!hasAvatar && hasParagraph) {
|
||
|
return { width: '38%' };
|
||
|
}
|
||
|
|
||
|
if (hasAvatar && hasParagraph) {
|
||
|
return { width: '50%' };
|
||
|
}
|
||
|
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
function getParagraphBasicProps(hasAvatar, hasTitle) {
|
||
|
var basicProps = {};
|
||
|
|
||
|
// Width
|
||
|
if (!hasAvatar || !hasTitle) {
|
||
|
basicProps.width = '61%';
|
||
|
}
|
||
|
|
||
|
// Rows
|
||
|
if (!hasAvatar && hasTitle) {
|
||
|
basicProps.rows = 3;
|
||
|
} else {
|
||
|
basicProps.rows = 2;
|
||
|
}
|
||
|
|
||
|
return basicProps;
|
||
|
}
|
||
|
|
||
|
var Skeleton = {
|
||
|
name: 'ASkeleton',
|
||
|
props: (0, _propsUtil.initDefaultProps)(SkeletonProps, {
|
||
|
avatar: false,
|
||
|
title: true,
|
||
|
paragraph: true
|
||
|
}),
|
||
|
inject: {
|
||
|
configProvider: { 'default': function _default() {
|
||
|
return _configConsumerProps.ConfigConsumerProps;
|
||
|
} }
|
||
|
},
|
||
|
render: function render() {
|
||
|
var h = arguments[0];
|
||
|
var _$props = this.$props,
|
||
|
customizePrefixCls = _$props.prefixCls,
|
||
|
loading = _$props.loading,
|
||
|
avatar = _$props.avatar,
|
||
|
title = _$props.title,
|
||
|
paragraph = _$props.paragraph,
|
||
|
active = _$props.active;
|
||
|
|
||
|
var getPrefixCls = this.configProvider.getPrefixCls;
|
||
|
var prefixCls = getPrefixCls('skeleton', customizePrefixCls);
|
||
|
|
||
|
if (loading || !(0, _propsUtil.hasProp)(this, 'loading')) {
|
||
|
var _classNames;
|
||
|
|
||
|
var hasAvatar = !!avatar || avatar === '';
|
||
|
var hasTitle = !!title;
|
||
|
var hasParagraph = !!paragraph;
|
||
|
|
||
|
// Avatar
|
||
|
var avatarNode = void 0;
|
||
|
if (hasAvatar) {
|
||
|
var avatarProps = {
|
||
|
props: (0, _extends3['default'])({
|
||
|
prefixCls: prefixCls + '-avatar'
|
||
|
}, getAvatarBasicProps(hasTitle, hasParagraph), getComponentProps(avatar))
|
||
|
};
|
||
|
|
||
|
avatarNode = h(
|
||
|
'div',
|
||
|
{ 'class': prefixCls + '-header' },
|
||
|
[h(_Avatar2['default'], avatarProps)]
|
||
|
);
|
||
|
}
|
||
|
|
||
|
var contentNode = void 0;
|
||
|
if (hasTitle || hasParagraph) {
|
||
|
// Title
|
||
|
var $title = void 0;
|
||
|
if (hasTitle) {
|
||
|
var titleProps = {
|
||
|
props: (0, _extends3['default'])({
|
||
|
prefixCls: prefixCls + '-title'
|
||
|
}, getTitleBasicProps(hasAvatar, hasParagraph), getComponentProps(title))
|
||
|
};
|
||
|
|
||
|
$title = h(_Title2['default'], titleProps);
|
||
|
}
|
||
|
|
||
|
// Paragraph
|
||
|
var paragraphNode = void 0;
|
||
|
if (hasParagraph) {
|
||
|
var paragraphProps = {
|
||
|
props: (0, _extends3['default'])({
|
||
|
prefixCls: prefixCls + '-paragraph'
|
||
|
}, getParagraphBasicProps(hasAvatar, hasTitle), getComponentProps(paragraph))
|
||
|
};
|
||
|
|
||
|
paragraphNode = h(_Paragraph2['default'], paragraphProps);
|
||
|
}
|
||
|
|
||
|
contentNode = h(
|
||
|
'div',
|
||
|
{ 'class': prefixCls + '-content' },
|
||
|
[$title, paragraphNode]
|
||
|
);
|
||
|
}
|
||
|
|
||
|
var cls = (0, _classnames2['default'])(prefixCls, (_classNames = {}, (0, _defineProperty3['default'])(_classNames, prefixCls + '-with-avatar', hasAvatar), (0, _defineProperty3['default'])(_classNames, prefixCls + '-active', active), _classNames));
|
||
|
|
||
|
return h(
|
||
|
'div',
|
||
|
{ 'class': cls },
|
||
|
[avatarNode, contentNode]
|
||
|
);
|
||
|
}
|
||
|
var children = this.$slots['default'];
|
||
|
return children && children.length === 1 ? children[0] : h('span', [children]);
|
||
|
}
|
||
|
};
|
||
|
/* istanbul ignore next */
|
||
|
Skeleton.install = function (Vue) {
|
||
|
Vue.use(_base2['default']);
|
||
|
Vue.component(Skeleton.name, Skeleton);
|
||
|
};
|
||
|
exports['default'] = Skeleton;
|