123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.prepareComponentToken = exports.default = void 0;
- var _cssinjs = require("@ant-design/cssinjs");
- var _internal = require("../../theme/internal");
- const skeletonClsLoading = new _cssinjs.Keyframes(`ant-skeleton-loading`, {
- '0%': {
- backgroundPosition: '100% 50%'
- },
- '100%': {
- backgroundPosition: '0 50%'
- }
- });
- const genSkeletonElementCommonSize = size => ({
- height: size,
- lineHeight: (0, _cssinjs.unit)(size)
- });
- const genSkeletonElementAvatarSize = size => Object.assign({
- width: size
- }, genSkeletonElementCommonSize(size));
- const genSkeletonColor = token => ({
- background: token.skeletonLoadingBackground,
- backgroundSize: '400% 100%',
- animationName: skeletonClsLoading,
- animationDuration: token.skeletonLoadingMotionDuration,
- animationTimingFunction: 'ease',
- animationIterationCount: 'infinite'
- });
- const genSkeletonElementInputSize = (size, calc) => Object.assign({
- width: calc(size).mul(5).equal(),
- minWidth: calc(size).mul(5).equal()
- }, genSkeletonElementCommonSize(size));
- const genSkeletonElementAvatar = token => {
- const {
- skeletonAvatarCls,
- gradientFromColor,
- controlHeight,
- controlHeightLG,
- controlHeightSM
- } = token;
- return {
- [skeletonAvatarCls]: Object.assign({
- display: 'inline-block',
- verticalAlign: 'top',
- background: gradientFromColor
- }, genSkeletonElementAvatarSize(controlHeight)),
- [`${skeletonAvatarCls}${skeletonAvatarCls}-circle`]: {
- borderRadius: '50%'
- },
- [`${skeletonAvatarCls}${skeletonAvatarCls}-lg`]: Object.assign({}, genSkeletonElementAvatarSize(controlHeightLG)),
- [`${skeletonAvatarCls}${skeletonAvatarCls}-sm`]: Object.assign({}, genSkeletonElementAvatarSize(controlHeightSM))
- };
- };
- const genSkeletonElementInput = token => {
- const {
- controlHeight,
- borderRadiusSM,
- skeletonInputCls,
- controlHeightLG,
- controlHeightSM,
- gradientFromColor,
- calc
- } = token;
- return {
- [skeletonInputCls]: Object.assign({
- display: 'inline-block',
- verticalAlign: 'top',
- background: gradientFromColor,
- borderRadius: borderRadiusSM
- }, genSkeletonElementInputSize(controlHeight, calc)),
- [`${skeletonInputCls}-lg`]: Object.assign({}, genSkeletonElementInputSize(controlHeightLG, calc)),
- [`${skeletonInputCls}-sm`]: Object.assign({}, genSkeletonElementInputSize(controlHeightSM, calc))
- };
- };
- const genSkeletonElementImageSize = size => Object.assign({
- width: size
- }, genSkeletonElementCommonSize(size));
- const genSkeletonElementImage = token => {
- const {
- skeletonImageCls,
- imageSizeBase,
- gradientFromColor,
- borderRadiusSM,
- calc
- } = token;
- return {
- [skeletonImageCls]: Object.assign(Object.assign({
- display: 'inline-flex',
- alignItems: 'center',
- justifyContent: 'center',
- verticalAlign: 'middle',
- background: gradientFromColor,
- borderRadius: borderRadiusSM
- }, genSkeletonElementImageSize(calc(imageSizeBase).mul(2).equal())), {
- [`${skeletonImageCls}-path`]: {
- fill: '#bfbfbf'
- },
- [`${skeletonImageCls}-svg`]: Object.assign(Object.assign({}, genSkeletonElementImageSize(imageSizeBase)), {
- maxWidth: calc(imageSizeBase).mul(4).equal(),
- maxHeight: calc(imageSizeBase).mul(4).equal()
- }),
- [`${skeletonImageCls}-svg${skeletonImageCls}-svg-circle`]: {
- borderRadius: '50%'
- }
- }),
- [`${skeletonImageCls}${skeletonImageCls}-circle`]: {
- borderRadius: '50%'
- }
- };
- };
- const genSkeletonElementButtonShape = (token, size, buttonCls) => {
- const {
- skeletonButtonCls
- } = token;
- return {
- [`${buttonCls}${skeletonButtonCls}-circle`]: {
- width: size,
- minWidth: size,
- borderRadius: '50%'
- },
- [`${buttonCls}${skeletonButtonCls}-round`]: {
- borderRadius: size
- }
- };
- };
- const genSkeletonElementButtonSize = (size, calc) => Object.assign({
- width: calc(size).mul(2).equal(),
- minWidth: calc(size).mul(2).equal()
- }, genSkeletonElementCommonSize(size));
- const genSkeletonElementButton = token => {
- const {
- borderRadiusSM,
- skeletonButtonCls,
- controlHeight,
- controlHeightLG,
- controlHeightSM,
- gradientFromColor,
- calc
- } = token;
- return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({
- [skeletonButtonCls]: Object.assign({
- display: 'inline-block',
- verticalAlign: 'top',
- background: gradientFromColor,
- borderRadius: borderRadiusSM,
- width: calc(controlHeight).mul(2).equal(),
- minWidth: calc(controlHeight).mul(2).equal()
- }, genSkeletonElementButtonSize(controlHeight, calc))
- }, genSkeletonElementButtonShape(token, controlHeight, skeletonButtonCls)), {
- [`${skeletonButtonCls}-lg`]: Object.assign({}, genSkeletonElementButtonSize(controlHeightLG, calc))
- }), genSkeletonElementButtonShape(token, controlHeightLG, `${skeletonButtonCls}-lg`)), {
- [`${skeletonButtonCls}-sm`]: Object.assign({}, genSkeletonElementButtonSize(controlHeightSM, calc))
- }), genSkeletonElementButtonShape(token, controlHeightSM, `${skeletonButtonCls}-sm`));
- };
- // =============================== Base ===============================
- const genBaseStyle = token => {
- const {
- componentCls,
- skeletonAvatarCls,
- skeletonTitleCls,
- skeletonParagraphCls,
- skeletonButtonCls,
- skeletonInputCls,
- skeletonImageCls,
- controlHeight,
- controlHeightLG,
- controlHeightSM,
- gradientFromColor,
- padding,
- marginSM,
- borderRadius,
- titleHeight,
- blockRadius,
- paragraphLiHeight,
- controlHeightXS,
- paragraphMarginTop
- } = token;
- return {
- [componentCls]: {
- display: 'table',
- width: '100%',
- [`${componentCls}-header`]: {
- display: 'table-cell',
- paddingInlineEnd: padding,
- verticalAlign: 'top',
- // Avatar
- [skeletonAvatarCls]: Object.assign({
- display: 'inline-block',
- verticalAlign: 'top',
- background: gradientFromColor
- }, genSkeletonElementAvatarSize(controlHeight)),
- [`${skeletonAvatarCls}-circle`]: {
- borderRadius: '50%'
- },
- [`${skeletonAvatarCls}-lg`]: Object.assign({}, genSkeletonElementAvatarSize(controlHeightLG)),
- [`${skeletonAvatarCls}-sm`]: Object.assign({}, genSkeletonElementAvatarSize(controlHeightSM))
- },
- [`${componentCls}-content`]: {
- display: 'table-cell',
- width: '100%',
- verticalAlign: 'top',
- // Title
- [skeletonTitleCls]: {
- width: '100%',
- height: titleHeight,
- background: gradientFromColor,
- borderRadius: blockRadius,
- [`+ ${skeletonParagraphCls}`]: {
- marginBlockStart: controlHeightSM
- }
- },
- // paragraph
- [skeletonParagraphCls]: {
- padding: 0,
- '> li': {
- width: '100%',
- height: paragraphLiHeight,
- listStyle: 'none',
- background: gradientFromColor,
- borderRadius: blockRadius,
- '+ li': {
- marginBlockStart: controlHeightXS
- }
- }
- },
- [`${skeletonParagraphCls}> li:last-child:not(:first-child):not(:nth-child(2))`]: {
- width: '61%'
- }
- },
- [`&-round ${componentCls}-content`]: {
- [`${skeletonTitleCls}, ${skeletonParagraphCls} > li`]: {
- borderRadius
- }
- }
- },
- [`${componentCls}-with-avatar ${componentCls}-content`]: {
- // Title
- [skeletonTitleCls]: {
- marginBlockStart: marginSM,
- [`+ ${skeletonParagraphCls}`]: {
- marginBlockStart: paragraphMarginTop
- }
- }
- },
- // Skeleton element
- [`${componentCls}${componentCls}-element`]: Object.assign(Object.assign(Object.assign(Object.assign({
- display: 'inline-block',
- width: 'auto'
- }, genSkeletonElementButton(token)), genSkeletonElementAvatar(token)), genSkeletonElementInput(token)), genSkeletonElementImage(token)),
- // Skeleton Block Button, Input
- [`${componentCls}${componentCls}-block`]: {
- width: '100%',
- [skeletonButtonCls]: {
- width: '100%'
- },
- [skeletonInputCls]: {
- width: '100%'
- }
- },
- // With active animation
- [`${componentCls}${componentCls}-active`]: {
- [`
- ${skeletonTitleCls},
- ${skeletonParagraphCls} > li,
- ${skeletonAvatarCls},
- ${skeletonButtonCls},
- ${skeletonInputCls},
- ${skeletonImageCls}
- `]: Object.assign({}, genSkeletonColor(token))
- }
- };
- };
- // ============================== Export ==============================
- const prepareComponentToken = token => {
- const {
- colorFillContent,
- colorFill
- } = token;
- const gradientFromColor = colorFillContent;
- const gradientToColor = colorFill;
- return {
- color: gradientFromColor,
- colorGradientEnd: gradientToColor,
- gradientFromColor,
- gradientToColor,
- titleHeight: token.controlHeight / 2,
- blockRadius: token.borderRadiusSM,
- paragraphMarginTop: token.marginLG + token.marginXXS,
- paragraphLiHeight: token.controlHeight / 2
- };
- };
- exports.prepareComponentToken = prepareComponentToken;
- var _default = exports.default = (0, _internal.genStyleHooks)('Skeleton', token => {
- const {
- componentCls,
- calc
- } = token;
- const skeletonToken = (0, _internal.mergeToken)(token, {
- skeletonAvatarCls: `${componentCls}-avatar`,
- skeletonTitleCls: `${componentCls}-title`,
- skeletonParagraphCls: `${componentCls}-paragraph`,
- skeletonButtonCls: `${componentCls}-button`,
- skeletonInputCls: `${componentCls}-input`,
- skeletonImageCls: `${componentCls}-image`,
- imageSizeBase: calc(token.controlHeight).mul(1.5).equal(),
- borderRadius: 100,
- // Large number to make capsule shape
- skeletonLoadingBackground: `linear-gradient(90deg, ${token.gradientFromColor} 25%, ${token.gradientToColor} 37%, ${token.gradientFromColor} 63%)`,
- skeletonLoadingMotionDuration: '1.4s'
- });
- return genBaseStyle(skeletonToken);
- }, prepareComponentToken, {
- deprecatedTokens: [['color', 'gradientFromColor'], ['colorGradientEnd', 'gradientToColor']]
- });
|