@import "../../style/themes/default"; @import "../../style/mixins/index"; @card-prefix-cls: ~"@{ant-prefix}-card"; @card-head-height: 48px; .@{card-prefix-cls} { .reset-component; background: @component-background; border-radius: @border-radius-sm; position: relative; transition: all .3s; &-hoverable { cursor: pointer; &:hover { box-shadow: @card-shadow; border-color: transparent; } } &-bordered { border: @border-width-base @border-style-base @border-color-split; } &-head { background: @card-head-background; border-bottom: @border-width-base @border-style-base @border-color-split; padding: 0 @card-padding-base; border-radius: @border-radius-sm @border-radius-sm 0 0; .clearfix; margin-bottom: -1px; // Fix card grid overflow bug: https://gw.alipayobjects.com/zos/rmsportal/XonYxBikwpgbqIQBeuhk.png min-height: @card-head-height; &-wrapper { display: flex; } &-title { font-size: @font-size-lg; padding: @card-head-padding 0; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; color: @card-head-color; font-weight: 500; display: inline-block; flex: 1; } .@{ant-prefix}-tabs { margin-bottom: -17px; margin-top: 4px; clear: both; &-bar { border-bottom: @border-width-base @border-style-base @border-color-split; } } } &-extra { float: right; padding: @card-head-padding + 1.5px 0; text-align: right; // https://stackoverflow.com/a/22429853/3040605 margin-left: auto; } &-body { padding: @card-padding-base; .clearfix; } &-loading &-body { user-select: none; padding: 0; } &-loading-content { padding: @card-padding-base; p { margin: 0; } } &-loading-block { display: inline-block; margin: 5px 2% 0 0; height: 14px; border-radius: @border-radius-sm; background: linear-gradient(90deg, rgba(207, 216, 220, .2), rgba(207, 216, 220, .4), rgba(207, 216, 220, .2)); animation: card-loading 1.4s ease infinite; background-size: 600% 600%; } &-contain-grid &-body { margin: -1px 0 0 -1px; padding: 0; } &-grid { border-radius: 0; border: 0; box-shadow: 1px 0 0 0 @border-color-split, 0 1px 0 0 @border-color-split, 1px 1px 0 0 @border-color-split, 1px 0 0 0 @border-color-split inset, 0 1px 0 0 @border-color-split inset; width: 33.33%; float: left; padding: @card-padding-base; transition: all .3s; &:hover { position: relative; z-index: 1; box-shadow: @box-shadow-base; } } &-contain-tabs &-head-title { padding-bottom: 0; min-height: @card-head-height - @card-head-padding; } &-contain-tabs &-extra { padding-bottom: 0; } &-cover > * { width: 100%; display: block; } &-actions { border-top: @border-width-base @border-style-base @border-color-split; background: @card-actions-background; .clearfix; list-style: none; margin: 0; padding: 0; & > li { float: left; text-align: center; height: 16px; margin: 12px 0; color: @text-color-secondary; & > span { display: inline-block; font-size: 14px; cursor: pointer; height: 32px; line-height: 32px; min-width: 32px; position: relative; top: -8px; &:hover { color: @primary-color; transition: color .3s; } & > .anticon { font-size: 16px; } a { color: @text-color-secondary; &:hover { color: @primary-color; } } } &:not(:last-child) { border-right: @border-width-base @border-style-base @border-color-split; } } } &-wider-padding &-head { padding: 0 @card-padding-wider; } &-wider-padding &-body { padding: @card-padding-base @card-padding-wider; } &-padding-transition &-head, &-padding-transition &-body { transition: padding .3s; } &-padding-transition &-extra { transition: right .3s; } &-type-inner &-head { padding: 0 @card-padding-base; background: @background-color-base; &-title { padding: @card-inner-head-padding 0; } } &-type-inner &-body { padding: 16px @card-padding-base; } &-type-inner &-extra { padding: @card-inner-head-padding + 1.5px 0; } &-meta { &-content { display: table-row; } &-avatar { padding-right: 16px; display: table-cell; } &-detail { display: table-cell; vertical-align: top; position: relative; & > div:not(:last-child) { margin-bottom: 8px; } } &-title { font-size: @font-size-lg; text-overflow: ellipsis; width: 100%; overflow: hidden; white-space: nowrap; color: @card-head-color; font-weight: 500; } &-desscription { color: @text-color-secondary; } } } @keyframes card-loading { 0%, 100% { background-position: 0 50%; } 50% { background-position: 100% 50%; } }