mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-30 06:09:34 +08:00
060b7ded20
* #18237 add skeleton button * update snapshot * refactoring demo code * lint code * update test snapshots * add test * update snapshot * fix deps lint issue * set avatar siz and update test snapshots * fix lint issue * remove button and just keep skeleton * add active switch for button demo * add size and shape radio for skeleton button demo * add button tests * add skeleton tests * update doc * update test snapshots * omit avatar and button props * refactoring skeleton and update test snapshots
176 lines
3.5 KiB
Plaintext
176 lines
3.5 KiB
Plaintext
@import '../../style/themes/index';
|
|
@import '../../style/mixins/index';
|
|
|
|
@skeleton-prefix-cls: ~'@{ant-prefix}-skeleton';
|
|
@skeleton-avatar-prefix-cls: ~'@{skeleton-prefix-cls}-avatar';
|
|
@skeleton-title-prefix-cls: ~'@{skeleton-prefix-cls}-title';
|
|
@skeleton-paragraph-prefix-cls: ~'@{skeleton-prefix-cls}-paragraph';
|
|
@skeleton-button-prefix-cls: ~'@{skeleton-prefix-cls}-button';
|
|
|
|
@skeleton-to-color: shade(@skeleton-color, 5%);
|
|
|
|
.@{skeleton-prefix-cls} {
|
|
display: table;
|
|
width: 100%;
|
|
|
|
&-header {
|
|
display: table-cell;
|
|
padding-right: 16px;
|
|
vertical-align: top;
|
|
|
|
// Avatar
|
|
.@{skeleton-avatar-prefix-cls} {
|
|
display: inline-block;
|
|
vertical-align: top;
|
|
background: @skeleton-color;
|
|
|
|
.skeleton-element-avatar-size(@avatar-size-base);
|
|
|
|
&-lg {
|
|
.skeleton-element-avatar-size(@avatar-size-lg);
|
|
}
|
|
|
|
&-sm {
|
|
.skeleton-element-avatar-size(@avatar-size-sm);
|
|
}
|
|
}
|
|
}
|
|
|
|
&-content {
|
|
display: table-cell;
|
|
width: 100%;
|
|
vertical-align: top;
|
|
|
|
// Title
|
|
.@{skeleton-title-prefix-cls} {
|
|
width: 100%;
|
|
height: 16px;
|
|
margin-top: 16px;
|
|
background: @skeleton-color;
|
|
|
|
+ .@{skeleton-paragraph-prefix-cls} {
|
|
margin-top: 24px;
|
|
}
|
|
}
|
|
|
|
// paragraph
|
|
.@{skeleton-paragraph-prefix-cls} {
|
|
padding: 0;
|
|
|
|
> li {
|
|
width: 100%;
|
|
height: 16px;
|
|
list-style: none;
|
|
background: @skeleton-color;
|
|
|
|
&:last-child:not(:first-child):not(:nth-child(2)) {
|
|
width: 61%;
|
|
}
|
|
|
|
+ li {
|
|
margin-top: 16px;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
&-with-avatar &-content {
|
|
// Title
|
|
.@{skeleton-title-prefix-cls} {
|
|
margin-top: 12px;
|
|
|
|
+ .@{skeleton-paragraph-prefix-cls} {
|
|
margin-top: 28px;
|
|
}
|
|
}
|
|
}
|
|
|
|
// With active animation
|
|
&.@{skeleton-prefix-cls}-active {
|
|
& .@{skeleton-prefix-cls}-content {
|
|
.@{skeleton-title-prefix-cls},
|
|
.@{skeleton-paragraph-prefix-cls} > li {
|
|
.skeleton-color();
|
|
}
|
|
}
|
|
|
|
.@{skeleton-avatar-prefix-cls} {
|
|
.skeleton-color();
|
|
}
|
|
|
|
.@{skeleton-button-prefix-cls} {
|
|
.skeleton-color();
|
|
}
|
|
}
|
|
|
|
// Skeleton element
|
|
&-element {
|
|
display: inline-block;
|
|
// Button
|
|
.@{skeleton-button-prefix-cls} {
|
|
display: inline-block;
|
|
vertical-align: top;
|
|
background: @skeleton-color;
|
|
border-radius: @border-radius-base;
|
|
|
|
.skeleton-element-button-size(@btn-height-base);
|
|
|
|
&-lg {
|
|
.skeleton-element-button-size(@btn-height-lg);
|
|
}
|
|
|
|
&-sm {
|
|
.skeleton-element-button-size(@btn-height-sm);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.skeleton-element-avatar-size(@size) {
|
|
width: @size;
|
|
.skeleton-element-common-size(@size);
|
|
|
|
&.@{skeleton-avatar-prefix-cls}-circle {
|
|
border-radius: 50%;
|
|
}
|
|
}
|
|
|
|
.skeleton-element-button-size(@size) {
|
|
width: @size * 2;
|
|
.skeleton-element-common-size(@size);
|
|
|
|
&.@{skeleton-button-prefix-cls}-circle {
|
|
width: @size;
|
|
border-radius: 50%;
|
|
}
|
|
|
|
&.@{skeleton-button-prefix-cls}-round {
|
|
border-radius: @size;
|
|
}
|
|
}
|
|
|
|
.skeleton-element-common-size(@size) {
|
|
height: @size;
|
|
line-height: @size;
|
|
}
|
|
|
|
.skeleton-color() {
|
|
background: linear-gradient(
|
|
90deg,
|
|
@skeleton-color 25%,
|
|
@skeleton-to-color 37%,
|
|
@skeleton-color 63%
|
|
);
|
|
background-size: 400% 100%;
|
|
animation: ~'@{skeleton-prefix-cls}-loading' 1.4s ease infinite;
|
|
}
|
|
|
|
@keyframes ~"@{skeleton-prefix-cls}-loading" {
|
|
0% {
|
|
background-position: 100% 50%;
|
|
}
|
|
100% {
|
|
background-position: 0 50%;
|
|
}
|
|
}
|