Skip to content

Instantly share code, notes, and snippets.

@Petercopter
Created March 30, 2018 21:03
Show Gist options
  • Save Petercopter/f487421715623db8b905e96bd36a5c4f to your computer and use it in GitHub Desktop.
Save Petercopter/f487421715623db8b905e96bd36a5c4f to your computer and use it in GitHub Desktop.
react-table v6 Dark Theme
.ReactTable {
position: relative;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
border: 1px solid rgba(256, 256, 256, 0.1);
}
.ReactTable * {
box-sizing: border-box
}
.ReactTable .rt-table {
-webkit-box-flex: 1;
-ms-flex: auto 1;
flex: auto 1;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
-webkit-box-align: stretch;
-ms-flex-align: stretch;
align-items: stretch;
width: 100%;
border-collapse: collapse;
overflow: auto
}
.ReactTable .rt-thead {
-webkit-box-flex: 1;
-ms-flex: 1 0 auto;
flex: 1 0 auto;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.ReactTable .rt-thead.-headerGroups {
background: rgba(255, 255, 255, 0.03);
border-bottom: 1px solid rgba(256, 256, 256, 0.05)
}
.ReactTable .rt-thead.-filters {
border-bottom: 1px solid rgba(256, 256, 256, 0.05);
}
.ReactTable .rt-thead.-filters input,
.ReactTable .rt-thead.-filters select {
border: 1px solid rgba(256, 256, 256, 0.1);
background: #f0f0f0;
padding: 5px 7px;
font-size: inherit;
border-radius: 3px;
font-weight: normal;
outline: none
}
.ReactTable .rt-thead.-filters .rt-th {
border-right: 1px solid rgba(256, 256, 256, 0.02)
}
.ReactTable .rt-thead.-header {
box-shadow: 0 2px 15px 0 rgba(256, 256, 256, 0.15)
}
.ReactTable .rt-thead .rt-tr {
text-align: center
}
.ReactTable .rt-thead .rt-th,
.ReactTable .rt-thead .rt-td {
padding: 5px 5px;
line-height: normal;
position: relative;
border-right: 1px solid rgba(256, 256, 256, 0.05);
transition: box-shadow .3s cubic-bezier(.175, .885, .32, 1.275);
box-shadow: inset 0 0 0 0 transparent;
}
.ReactTable .rt-thead .rt-th.-sort-asc,
.ReactTable .rt-thead .rt-td.-sort-asc {
box-shadow: inset 0 3px 0 0 rgba(256, 256, 256, 0.6)
}
.ReactTable .rt-thead .rt-th.-sort-desc,
.ReactTable .rt-thead .rt-td.-sort-desc {
box-shadow: inset 0 -3px 0 0 rgba(256, 256, 256, 0.6)
}
.ReactTable .rt-thead .rt-th.-cursor-pointer,
.ReactTable .rt-thead .rt-td.-cursor-pointer {
cursor: pointer
}
.ReactTable .rt-thead .rt-th:last-child,
.ReactTable .rt-thead .rt-td:last-child {
border-right: 0
}
.ReactTable .rt-thead .rt-resizable-header {
overflow: visible;
}
.ReactTable .rt-thead .rt-resizable-header:last-child {
overflow: hidden
}
.ReactTable .rt-thead .rt-resizable-header-content {
overflow: hidden;
text-overflow: ellipsis
}
.ReactTable .rt-thead .rt-header-pivot {
border-right-color: #080808
}
.ReactTable .rt-thead .rt-header-pivot:after,
.ReactTable .rt-thead .rt-header-pivot:before {
left: 100%;
top: 50%;
border: solid transparent;
content: " ";
height: 0;
width: 0;
position: absolute;
pointer-events: none
}
.ReactTable .rt-thead .rt-header-pivot:after {
border-color: rgba(255, 255, 255, 0);
border-left-color: #f0f0f0;
border-width: 8px;
margin-top: -8px
}
.ReactTable .rt-thead .rt-header-pivot:before {
border-color: rgba(153, 153, 153, 0);
border-left-color: #080808;
border-width: 10px;
margin-top: -10px
}
.ReactTable .rt-tbody {
-webkit-box-flex: 99999;
-ms-flex: 99999 1 auto;
flex: 99999 1 auto;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
overflow: auto;
}
.ReactTable .rt-tbody .rt-tr-group {
border-bottom: solid 1px rgba(256, 256, 256, 0.05);
}
.ReactTable .rt-tbody .rt-tr-group:last-child {
border-bottom: 0
}
.ReactTable .rt-tbody .rt-td {
border-right: 1px solid rgba(256, 256, 256, 0.02);
}
.ReactTable .rt-tbody .rt-td:last-child {
border-right: 0
}
.ReactTable .rt-tbody .rt-expandable {
cursor: pointer
}
.ReactTable .rt-tr-group {
-webkit-box-flex: 1;
-ms-flex: 1 0 auto;
flex: 1 0 auto;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
-webkit-box-align: stretch;
-ms-flex-align: stretch;
align-items: stretch
}
.ReactTable .rt-tr {
-webkit-box-flex: 1;
-ms-flex: 1 0 auto;
flex: 1 0 auto;
display: -webkit-inline-box;
display: -ms-inline-flexbox;
display: inline-flex
}
.ReactTable .rt-th,
.ReactTable .rt-td {
-webkit-box-flex: 1;
-ms-flex: 1 0 0px;
flex: 1 0 0;
white-space: nowrap;
text-overflow: ellipsis;
padding: 7px 5px;
overflow: hidden;
transition: .3s ease;
transition-property: width, min-width, padding, opacity;
}
.ReactTable .rt-th.-hidden,
.ReactTable .rt-td.-hidden {
width: 0 !important;
min-width: 0 !important;
padding: 0 !important;
border: 0 !important;
opacity: 0 !important
}
.ReactTable .rt-expander {
display: inline-block;
position: relative;
margin: 0;
color: transparent;
margin: 0 10px;
}
.ReactTable .rt-expander:after {
content: '';
position: absolute;
width: 0;
height: 0;
top: 50%;
left: 50%;
-webkit-transform: translate(-50%, -50%) rotate(-90deg);
transform: translate(-50%, -50%) rotate(-90deg);
border-left: 5.04px solid transparent;
border-right: 5.04px solid transparent;
border-top: 7px solid rgba(256, 256, 256, 0.8);
transition: all .3s cubic-bezier(.175, .885, .32, 1.275);
cursor: pointer
}
.ReactTable .rt-expander.-open:after {
-webkit-transform: translate(-50%, -50%) rotate(0);
transform: translate(-50%, -50%) rotate(0)
}
.ReactTable .rt-resizer {
display: inline-block;
position: absolute;
width: 36px;
top: 0;
bottom: 0;
right: -18px;
cursor: col-resize;
z-index: 10
}
.ReactTable .rt-tfoot {
-webkit-box-flex: 1;
-ms-flex: 1 0 auto;
flex: 1 0 auto;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
box-shadow: 0 0 15px 0 rgba(256, 256, 256, 0.15);
}
.ReactTable .rt-tfoot .rt-td {
border-right: 1px solid rgba(256, 256, 256, 0.05);
}
.ReactTable .rt-tfoot .rt-td:last-child {
border-right: 0
}
.ReactTable.-striped .rt-tr.-odd {
background: rgba(255, 255, 255, 0.03)
}
.ReactTable.-highlight .rt-tbody .rt-tr:not(.-padRow):hover {
background: rgba(255, 255, 255, 0.05)
}
.ReactTable .-pagination {
z-index: 1;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: justify;
-ms-flex-pack: justify;
justify-content: space-between;
-webkit-box-align: stretch;
-ms-flex-align: stretch;
align-items: stretch;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
padding: 3px;
box-shadow: 0 0 15px 0 rgba(256, 256, 256, 0.1);
border-top: 2px solid rgba(256, 256, 256, 0.1);
}
.ReactTable .-pagination input,
.ReactTable .-pagination select {
border: 1px solid rgba(256, 256, 256, 0.1);
background: #f0f0f0;
padding: 5px 7px;
font-size: inherit;
border-radius: 3px;
font-weight: normal;
outline: none
}
.ReactTable .-pagination .-btn {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
display: block;
width: 100%;
height: 100%;
border: 0;
border-radius: 3px;
padding: 6px;
font-size: 1em;
color: rgba(256, 256, 256, 0.6);
background: rgba(255, 255, 255, 0.1);
transition: all .1s ease;
cursor: pointer;
outline: none;
}
.ReactTable .-pagination .-btn[disabled] {
opacity: .5;
cursor: default
}
.ReactTable .-pagination .-btn:not([disabled]):hover {
background: rgba(255, 255, 255, 0.3);
color: #f0f0f0
}
.ReactTable .-pagination .-previous,
.ReactTable .-pagination .-next {
-webkit-box-flex: 1;
-ms-flex: 1;
flex: 1;
text-align: center
}
.ReactTable .-pagination .-center {
-webkit-box-flex: 1.5;
-ms-flex: 1.5;
flex: 1.5;
text-align: center;
margin-bottom: 0;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: horizontal;
-webkit-box-direction: normal;
-ms-flex-direction: row;
flex-direction: row;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
-ms-flex-pack: distribute;
justify-content: space-around
}
.ReactTable .-pagination .-pageInfo {
display: inline-block;
margin: 3px 10px;
white-space: nowrap
}
.ReactTable .-pagination .-pageJump {
display: inline-block;
}
.ReactTable .-pagination .-pageJump input {
width: 70px;
text-align: center
}
.ReactTable .-pagination .-pageSizeOptions {
margin: 3px 10px
}
.ReactTable .rt-noData {
display: block;
position: absolute;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
background: rgba(0, 0, 0, 0.8);
transition: all .3s ease;
z-index: 1;
pointer-events: none;
padding: 20px;
color: rgba(256, 256, 256, 0.5)
}
.ReactTable .-loading {
display: block;
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.8);
transition: all .3s ease;
z-index: -1;
opacity: 0;
pointer-events: none;
}
.ReactTable .-loading > div {
position: absolute;
display: block;
text-align: center;
width: 100%;
top: 50%;
left: 0;
font-size: 15px;
color: rgba(256, 256, 256, 0.6);
-webkit-transform: translateY(-52%);
transform: translateY(-52%);
transition: all .3s cubic-bezier(.25, .46, .45, .94)
}
.ReactTable .-loading.-active {
opacity: 1;
z-index: 2;
pointer-events: all;
}
.ReactTable .-loading.-active > div {
-webkit-transform: translateY(50%);
transform: translateY(50%)
}
.ReactTable .rt-resizing .rt-th,
.ReactTable .rt-resizing .rt-td {
transition: none !important;
cursor: col-resize;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment