element/packages/theme-chalk/src/table.scss

558 lines
9.6 KiB
SCSS
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

@import "mixins/mixins";
@import "checkbox";
@import "tag";
@import "tooltip";
@import "common/var";
@include b(table) {
position: relative;
overflow: hidden;
box-sizing: border-box;
flex: 1;
width: 100%;
max-width: 100%;
background-color: $--color-white;
font-size: 14px;
color: $--table-text-color;
// 数据为空
@include e(empty-block) {
position: relative;
min-height: 60px;
text-align: center;
width: 100%;
height: 100%;
}
@include e(empty-text) {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
color: $--color-text-secondary;
}
// 展开行
@include e(expand-column) {
.cell {
padding: 0;
text-align: center;
}
}
@include e(expand-icon) {
position: relative;
cursor: pointer;
color: #666;
font-size: 12px;
transition: transform 0.2s ease-in-out;
height: 20px;
@include m(expanded) {
transform: rotate(90deg);
}
> .el-icon {
position: absolute;
left: 50%;
top: 50%;
margin-left: -5px;
margin-top: -5px;
}
}
@include e(expanded-cell) {
background-color: $--color-white;
// 纯属为了增加权重
&[class*=cell] {
padding: 20px 50px;
}
&:hover {
background-color: transparent !important;
}
}
@include m(fit) {
border-right: 0;
border-bottom: 0;
th.gutter, td.gutter {
border-right-width: 1px;
}
}
@include m(scrollable-x) {
.el-table__body-wrapper {
overflow-x: auto;
}
}
@include m(scrollable-y) {
.el-table__body-wrapper {
overflow-y: auto;
}
}
thead {
color: $--table-header-color;
font-weight: 500;
&.is-group {
th {
background: $--background-color-base;
}
}
}
th, td {
padding: 12px 0;
min-width: 0;
box-sizing: border-box;
text-overflow: ellipsis;
vertical-align: middle;
position: relative;
@include when(center) {
text-align: center;
}
@include when(left) {
text-align: left;
}
@include when(right) {
text-align: right;
}
&.gutter {
width: 15px;
border-right-width: 0;
border-bottom-width: 0;
padding: 0;
}
&.is-hidden {
> * {
visibility: hidden;
}
}
}
@include m(medium) {
th, td {
padding: 10px 0;
}
}
@include m(small) {
font-size: 12px;
th, td {
padding: 8px 0;
}
}
@include m(mini) {
font-size: 12px;
th, td {
padding: 6px 0;
}
}
tr {
background-color: $--color-white;
input[type="checkbox"] {
margin: 0;
}
}
th.is-leaf, td {
border-bottom: $--table-border;
}
th.is-sortable {
cursor: pointer;
}
th {
white-space: nowrap;
overflow: hidden;
user-select: none;
text-align: left;
background-color: $--table-header-background;
div {
display: inline-block;
padding-left: 10px;
padding-right: 10px;
line-height: 40px;
box-sizing: border-box;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
> .cell {
position: relative;
word-wrap: normal;
text-overflow: ellipsis;
display: inline-block;
vertical-align: middle;
width: 100%;
box-sizing: border-box;
&.highlight {
color: $--color-primary;
}
}
&.required > div::before {
display: inline-block;
content: "";
width: 8px;
height: 8px;
border-radius: 50%;
background: #ff4d51;
margin-right: 5px;
vertical-align: middle;
}
}
td {
div {
box-sizing: border-box;
}
&.gutter {
width: 0;
}
}
.cell {
box-sizing: border-box;
overflow: hidden;
text-overflow: ellipsis;
white-space: normal;
word-break: break-all;
line-height: 23px;
padding-left: 10px;
padding-right: 10px;
&.el-tooltip {
white-space: nowrap;
min-width: 50px;
}
}
// 拥有多级表头
@include m((group, border)) {
border: $--table-border;
@include share-rule(border-pseudo) {
content: '';
position: absolute;
background-color: $--border-color-lighter;
z-index: 1;
}
// 表格右部伪 border
&::after {
@include extend-rule(border-pseudo);
top: 0;
right: 0;
width: 1px;
height: 100%;
}
}
// 表格底部伪 border总是有的
&::before {
@include extend-rule(border-pseudo);
left: 0;
bottom: 0;
width: 100%;
height: 1px;
}
// table--border
@include m(border) {
border-right: none;
border-bottom: none;
&.el-loading-parent--relative {
border: none;
}
th, td {
border-right: $--table-border;
&:first-child .cell {
padding-left: 10px;
}
}
th.gutter:last-of-type {
border-bottom: $--table-border;
border-bottom-width: 1px;
}
& th {
border-bottom: $--table-border;
}
}
@include m(hidden) {
visibility: hidden;
}
@include e((fixed, fixed-right)) {
position: absolute;
top: 0;
left: 0;
overflow-x: hidden;
overflow-y: hidden;
box-shadow: $--table-fixed-box-shadow;
&::before {
content: '';
position: absolute;
left: 0;
bottom: 0;
width: 100%;
height: 1px;
background-color: $--border-color-lighter;
z-index: 4;
}
}
@include e(fixed-right-patch) {
position: absolute;
top: -1px;
right: 0;
background-color: $--color-white;
border-bottom: $--table-border;
}
@include e(fixed-right) {
top: 0;
left: auto;
right: 0;
.el-table__fixed-header-wrapper,
.el-table__fixed-body-wrapper,
.el-table__fixed-footer-wrapper {
left: auto;
right: 0;
}
}
@include e(fixed-header-wrapper) {
position: absolute;
left: 0;
top: 0;
z-index: 3;
}
@include e(fixed-footer-wrapper) {
position: absolute;
left: 0;
bottom: 0;
z-index: 3;
& tbody td {
border-top: $--table-border;
background-color: $--table-row-hover-background;
color: $--table-text-color;
}
}
@include e(fixed-body-wrapper) {
position: absolute;
left: 0;
top: 37px;
overflow: hidden;
z-index: 3;
}
@include e((header-wrapper, body-wrapper, footer-wrapper)) {
width: 100%;
}
@include e(footer-wrapper) {
margin-top: -1px;
td {
border-top: $--table-border;
}
}
@include e((header, body, footer)) {
table-layout: fixed;
border-collapse: separate;
}
@include e((header-wrapper, footer-wrapper)) {
overflow: hidden;
& tbody td {
background-color: $--table-row-hover-background;
color: $--table-text-color;
}
}
@include e(body-wrapper) {
overflow: hidden;
position: relative;
@include when(scrolling-none) {
~ .el-table__fixed,
~ .el-table__fixed-right {
box-shadow: none;
}
}
@include when(scrolling-left) {
~ .el-table__fixed {
box-shadow: none;
}
}
@include when(scrolling-right) {
~ .el-table__fixed-right {
box-shadow: none;
}
}
.el-table--border {
@include when(scrolling-right) {
~ .el-table__fixed-right {
border-left: $--table-border;
}
}
@include when(scrolling-left) {
~ .el-table__fixed {
border-right: $--table-border;
}
}
}
}
.caret-wrapper {
display: inline-flex;
flex-direction: column;
align-items: center;
height: 34px;
width: 24px;
vertical-align: middle;
cursor: pointer;
overflow: initial;
position: relative;
}
.sort-caret {
width: 0;
height: 0;
border: solid 5px transparent;
position: absolute;
left: 7px;
&.ascending {
border-bottom-color: $--color-text-placeholder;
top: 5px;
}
&.descending {
border-top-color: $--color-text-placeholder;
bottom: 7px;
}
}
.ascending .sort-caret.ascending {
border-bottom-color: $--color-primary;
}
.descending .sort-caret.descending {
border-top-color: $--color-primary;
}
.hidden-columns {
visibility: hidden;
position: absolute;
z-index: -1;
}
@include m(striped) {
& .el-table__body {
& tr.el-table__row--striped {
td {
background: #FAFAFA;
}
&.current-row td {
background-color: $--table-current-row-background;
}
}
}
}
@include e(body) {
tr.hover-row {
&, &.el-table__row--striped {
&, &.current-row {
> td {
background-color: $--table-current-row-background;
}
}
}
}
tr.current-row > td {
background-color: $--table-current-row-background;
}
}
@include e(column-resize-proxy) {
position: absolute;
left: 200px;
top: 0;
bottom: 0;
width: 0;
border-left: $--table-border;
z-index: 10;
}
@include e(column-filter-trigger) {
display: inline-block;
line-height: 34px;
cursor: pointer;
& i {
color: $--color-info;
font-size: 12px;
transform: scale(.75);
}
}
@include m(enable-row-transition) {
.el-table__body td {
transition: background-color .25s ease;
}
}
@include m(enable-row-hover) {
.el-table__body tr:hover > td {
background-color: $--table-row-hover-background;
}
}
@include m(fluid-height) {
.el-table__fixed,
.el-table__fixed-right {
bottom: 0;
overflow: hidden;
}
}
}