123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- <template>
- <a-card :loading="loading" :body-style="{ padding: '20px 24px 8px' }" :bordered="false">
- <div class="chart-card-header">
- <div class="meta">
- <span class="chart-card-title">{{ title }}</span>
- <span class="chart-card-action">
- <slot name="action"></slot>
- </span>
- </div>
- <div class="total"><span>{{ total }}</span></div>
- </div>
- <div class="chart-card-content">
- <div class="content-fix">
- <slot></slot>
- </div>
- </div>
- <div class="chart-card-footer">
- <div class="field">
- <slot name="footer"></slot>
- </div>
- </div>
- </a-card>
- </template>
- <script>
- export default {
- name: "ChartCard",
- props: {
- title: {
- type: String,
- default: ''
- },
- total: {
- type: String,
- default: ''
- },
- loading: {
- type: Boolean,
- default: false
- }
- }
- }
- </script>
- <style lang="less" scoped>
- .chart-card-header {
- position: relative;
- overflow: hidden;
- width: 100%;
- .meta {
- position: relative;
- overflow: hidden;
- width: 100%;
- color: rgba(0, 0, 0, .45);
- font-size: 14px;
- line-height: 22px;
- }
- }
- .chart-card-action {
- cursor: pointer;
- position: absolute;
- top: 0;
- right: 0;
- }
- .chart-card-footer {
- border-top: 1px solid #e8e8e8;
- padding-top: 9px;
- margin-top: 8px;
- > * {
- position: relative;
- }
- .field {
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- margin: 0;
- }
- }
- .chart-card-content {
- margin-bottom: 12px;
- position: relative;
- height: 46px;
- width: 100%;
- .content-fix {
- position: absolute;
- left: 0;
- bottom: 0;
- width: 100%;
- }
- }
- .total {
- overflow: hidden;
- text-overflow: ellipsis;
- word-break: break-all;
- white-space: nowrap;
- color: #000;
- margin-top: 4px;
- margin-bottom: 0;
- font-size: 30px;
- line-height: 38px;
- height: 38px;
- }
- </style>
|