//Main Theme Variables $backgroundColor: #888 !default; //background color of tabulator $borderColor:#999 !default; //border to tabulator $textSize:14px !default; //table text size //header themeing $headerBackgroundColor:#e6e6e6 !default; //border to tabulator $headerTextColor:#555 !default; //header text colour $headerBorderColor:#aaa !default; //header border color $headerSeperatorColor:#999 !default; //header bottom seperator color $headerMargin:4px !default; //padding round header //column header arrows $sortArrowActive: #666 !default; $sortArrowInactive: #bbb !default; //row themeing $rowBackgroundColor:#fff !default; //table row background color $rowAltBackgroundColor:#EFEFEF !default; //table row background color $rowBorderColor:#aaa !default; //table border color $rowTextColor:#333 !default; //table text color $rowHoverBackground:#bbb !default; //row background color on hover $rowSelectedBackground: #9ABCEA !default; //row background color when selected $rowSelectedBackgroundHover: #769BCC !default;//row background color when selected and hovered $editBoxColor:#1D68CD !default; //border color for edit boxes $errorColor:#dd0000 !default; //error indication //footer themeing $footerBackgroundColor:#e6e6e6 !default; //border to tabulator $footerTextColor:#555 !default; //footer text colour $footerBorderColor:#aaa !default; //footer border color $footerSeperatorColor:#999 !default; //footer bottom seperator color $footerActiveColor:#d00 !default; //footer bottom active text color //Tabulator Containing Element .tabulator{ position: relative; border: 1px solid $borderColor; background-color: $backgroundColor; font-size:$textSize; text-align: left; overflow:hidden; -webkit-transform: translatez(0); -moz-transform: translatez(0); -ms-transform: translatez(0); -o-transform: translatez(0); transform: translatez(0); &[tabulator-layout="fitDataFill"]{ .tabulator-tableHolder{ .tabulator-table{ min-width:100%; } } } &.tabulator-block-select{ user-select: none; } //column header containing element .tabulator-header{ position:relative; box-sizing: border-box; width:100%; border-bottom:1px solid $headerSeperatorColor; background-color: $headerBackgroundColor; color: $headerTextColor; font-weight:bold; white-space: nowrap; overflow:hidden; -moz-user-select: none; -khtml-user-select: none; -webkit-user-select: none; -o-user-select: none; //individual column header element .tabulator-col{ display:inline-block; position:relative; box-sizing:border-box; border-right:1px solid $headerBorderColor; background:$headerBackgroundColor; text-align:left; vertical-align: bottom; overflow: hidden; &.tabulator-moving{ position: absolute; border:1px solid $headerSeperatorColor; background:darken($headerBackgroundColor, 10%); pointer-events: none; } //hold content of column header .tabulator-col-content{ box-sizing:border-box; position: relative; padding:4px; //hold title of column header .tabulator-col-title{ box-sizing:border-box; width: 100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; vertical-align:bottom; //element to hold title editor .tabulator-title-editor{ box-sizing: border-box; width: 100%; border:1px solid #999; padding:1px; background: #fff; } } //column sorter arrow .tabulator-arrow{ display: inline-block; position: absolute; top:9px; right:8px; width: 0; height: 0; border-left: 6px solid transparent; border-right: 6px solid transparent; border-bottom: 6px solid $sortArrowInactive; } } //complex header column group &.tabulator-col-group{ //gelement to hold sub columns in column group .tabulator-col-group-cols{ position:relative; display: flex; border-top:1px solid $headerBorderColor; overflow: hidden; .tabulator-col:last-child{ margin-right:-1px; } } } //hide left resize handle on first column &:first-child{ .tabulator-col-resize-handle.prev{ display: none; } } //placeholder element for sortable columns &.ui-sortable-helper{ position: absolute; background-color: $headerBackgroundColor !important; border:1px solid $headerBorderColor; } //header filter containing element .tabulator-header-filter{ position: relative; box-sizing: border-box; margin-top:2px; width:100%; text-align: center; //styling adjustment for inbuilt editors textarea{ height:auto !important; } svg{ margin-top: 3px; } input{ &::-ms-clear { width : 0; height: 0; } } } //styling child elements for sortable columns &.tabulator-sortable{ .tabulator-col-title{ padding-right:25px; } &:hover{ cursor:pointer; background-color:darken($headerBackgroundColor, 10%); } &[aria-sort="none"]{ .tabulator-col-content .tabulator-arrow{ border-top: none; border-bottom: 6px solid $sortArrowInactive; } } &[aria-sort="asc"]{ .tabulator-col-content .tabulator-arrow{ border-top: none; border-bottom: 6px solid $sortArrowActive; } } &[aria-sort="desc"]{ .tabulator-col-content .tabulator-arrow{ border-top: 6px solid $sortArrowActive; border-bottom: none; } } } &.tabulator-col-vertical{ .tabulator-col-content{ .tabulator-col-title{ writing-mode: vertical-rl; text-orientation: mixed; display:flex; align-items:center; justify-content:center; } } &.tabulator-col-vertical-flip{ .tabulator-col-title{ transform: rotate(180deg); } } &.tabulator-sortable{ .tabulator-col-title{ padding-right:0; padding-top:20px; } &.tabulator-col-vertical-flip{ .tabulator-col-title{ padding-right:0; padding-bottom:20px; } } .tabulator-arrow{ right:calc(50% - 6px); } } } } .tabulator-frozen{ display: inline-block; position: absolute; // background-color: inherit; z-index: 10; &.tabulator-frozen-left{ border-right:2px solid $rowBorderColor; } &.tabulator-frozen-right{ border-left:2px solid $rowBorderColor; } } .tabulator-calcs-holder{ box-sizing:border-box; min-width:400%; background:lighten($headerBackgroundColor, 5%) !important; .tabulator-row{ background:lighten($headerBackgroundColor, 5%) !important; .tabulator-col-resize-handle{ display: none; } } border-top:1px solid $rowBorderColor; border-bottom:1px solid $headerBorderColor; overflow: hidden; } .tabulator-frozen-rows-holder{ min-width:400%; &:empty{ display: none; } } } //scrolling element to hold table .tabulator-tableHolder{ position:relative; width:100%; white-space: nowrap; overflow:auto; -webkit-overflow-scrolling: touch; &:focus{ outline: none; } //default placeholder element .tabulator-placeholder{ box-sizing:border-box; display: flex; align-items:center; &[tabulator-render-mode="virtual"]{ position: absolute; top:0; left:0; height:100%; } width:100%; span{ display: inline-block; margin:0 auto; padding:10px; color:#ccc; font-weight: bold; font-size: 20px; } } //element to hold table rows .tabulator-table{ position:relative; display:inline-block; background-color:$rowBackgroundColor; white-space: nowrap; overflow:visible; color:$rowTextColor; //row element .tabulator-row{ &.tabulator-calcs{ font-weight: bold; background:darken($rowAltBackgroundColor, 5%) !important; &.tabulator-calcs-top{ border-bottom:2px solid $rowBorderColor; } &.tabulator-calcs-bottom{ border-top:2px solid $rowBorderColor; } } } } } //footer element .tabulator-footer{ padding:5px 10px; border-top:1px solid $footerSeperatorColor; background-color: $footerBackgroundColor; text-align: right; color: $footerTextColor; font-weight:bold; white-space:nowrap; user-select:none; -moz-user-select: none; -khtml-user-select: none; -webkit-user-select: none; -o-user-select: none; .tabulator-calcs-holder{ box-sizing:border-box; width:calc(100% + 20px); margin:-5px -10px 5px -10px; text-align: left; background:lighten($footerBackgroundColor, 5%) !important; .tabulator-row{ background:lighten($footerBackgroundColor, 5%) !important; .tabulator-col-resize-handle{ display: none; } } border-bottom:1px solid $rowBorderColor; border-top:1px solid $rowBorderColor; overflow: hidden; &:only-child{ margin-bottom:-5px; border-bottom:none; } } //pagination container element .tabulator-pages{ margin:0 7px; } //pagination button .tabulator-page{ display:inline-block; margin:0 2px; padding:2px 5px; border:1px solid $footerBorderColor; border-radius:3px; background:rgba(255,255,255,.2); color: $footerTextColor; font-family:inherit; font-weight:inherit; font-size:inherit; &.active{ color:$footerActiveColor; } &:disabled{ opacity:.5; } &:not(.disabled){ &:hover{ cursor:pointer; background:rgba(0,0,0,.2); color:#fff; } } } } //column resize handles .tabulator-col-resize-handle{ position:absolute; right:0; top:0; bottom:0; width:5px; &.prev{ left:0; right:auto; } &:hover{ cursor:ew-resize; } } //holding div that contains loader and covers tabulator element to prevent interaction .tabulator-loader{ position:absolute; display: flex; align-items:center; top:0; left:0; z-index:100; height:100%; width:100%; background:rgba(0,0,0,.4); text-align:center; //loading message element .tabulator-loader-msg{ display:inline-block; margin:0 auto; padding:10px 20px; border-radius:10px; background:#fff; font-weight:bold; font-size:16px; //loading message &.tabulator-loading{ border:4px solid #333; color:#000; } //error message &.tabulator-error{ border:4px solid #D00; color:#590000; } } } } //row element .tabulator-row{ position: relative; box-sizing: border-box; min-height:$textSize + ($headerMargin * 2); background-color: $rowBackgroundColor; &.tabulator-row-even{ background-color: $rowAltBackgroundColor; } &.tabulator-selectable:hover{ background-color:$rowHoverBackground; cursor: pointer; } &.tabulator-selected{ background-color:$rowSelectedBackground; } &.tabulator-selected:hover{ background-color:$rowSelectedBackgroundHover; cursor: pointer; } &.tabulator-row-moving{ border:1px solid #000; background:#fff; } &.tabulator-moving{ position: absolute; border-top:1px solid $rowBorderColor; border-bottom:1px solid $rowBorderColor; pointer-events: none; z-index:15; } //row resize handles .tabulator-row-resize-handle{ position:absolute; right:0; bottom:0; left:0; height:5px; &.prev{ top:0; bottom:auto; } &:hover{ cursor:ns-resize; } } .tabulator-frozen{ display: inline-block; position: absolute; background-color: inherit; z-index: 10; &.tabulator-frozen-left{ border-right:2px solid $rowBorderColor; } &.tabulator-frozen-right{ border-left:2px solid $rowBorderColor; } } .tabulator-responsive-collapse{ box-sizing:border-box; padding:5px; border-top:1px solid $rowBorderColor; border-bottom:1px solid $rowBorderColor; &:empty{ display:none; } table{ font-size:$textSize; tr{ td{ position: relative; &:first-of-type{ padding-right:10px; } } } } } //cell element .tabulator-cell{ display:inline-block; position: relative; box-sizing:border-box; padding:4px; border-right:1px solid $rowBorderColor; vertical-align:middle; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; &.tabulator-editing{ border:1px solid $editBoxColor; padding: 0; input, select{ border:1px; background:transparent; } } &.tabulator-validation-fail{ border:1px solid $errorColor; input, select{ border:1px; background:transparent; color: $errorColor; } } //hide left resize handle on first column &:first-child{ .tabulator-col-resize-handle.prev{ display: none; } } //movable row handle &.tabulator-row-handle{ display: inline-flex; align-items:center; justify-content:center; -moz-user-select: none; -khtml-user-select: none; -webkit-user-select: none; -o-user-select: none; //handle holder .tabulator-row-handle-box{ width:80%; //Hamburger element .tabulator-row-handle-bar{ width:100%; height:3px; margin-top:2px; background:#666; } } } .tabulator-data-tree-branch{ display:inline-block; vertical-align:middle; height:9px; width:7px; margin-top:-9px; margin-right:5px; border-bottom-left-radius:1px; border-left:2px solid $rowBorderColor; border-bottom:2px solid $rowBorderColor; } .tabulator-data-tree-control{ display:inline-flex; justify-content:center; align-items:center; vertical-align:middle; height:11px; width:11px; margin-right:5px; border:1px solid $rowTextColor; border-radius:2px; background:rgba(0, 0, 0, .1); overflow:hidden; &:hover{ cursor:pointer; background:rgba(0, 0, 0, .2); } .tabulator-data-tree-control-collapse{ display:inline-block; position: relative; height: 7px; width: 1px; background: transparent; &:after { position: absolute; content: ""; left: -3px; top: 3px; height: 1px; width: 7px; background: $rowTextColor; } } .tabulator-data-tree-control-expand{ display:inline-block; position: relative; height: 7px; width: 1px; background: $rowTextColor; &:after { position: absolute; content: ""; left: -3px; top: 3px; height: 1px; width: 7px; background: $rowTextColor; } } } .tabulator-responsive-collapse-toggle{ display: inline-flex; align-items:center; justify-content:center; -moz-user-select: none; -khtml-user-select: none; -webkit-user-select: none; -o-user-select: none; height:15px; width:15px; border-radius:20px; background:#666; color:$rowBackgroundColor; font-weight:bold; font-size:1.1em; &:hover{ opacity:.7; } &.open{ .tabulator-responsive-collapse-toggle-close{ display:initial; } .tabulator-responsive-collapse-toggle-open{ display:none; } } .tabulator-responsive-collapse-toggle-close{ display:none; } } } //row grouping element &.tabulator-group{ box-sizing:border-box; border-bottom:1px solid #999; border-right:1px solid $rowBorderColor; border-top:1px solid #999; padding:5px; padding-left:10px; background:#ccc; font-weight:bold; min-width: 100%; &:hover{ cursor:pointer; background-color:rgba(0,0,0,.1); } &.tabulator-group-visible{ .tabulator-arrow{ margin-right:10px; border-left: 6px solid transparent; border-right: 6px solid transparent; border-top: 6px solid $sortArrowActive; border-bottom: 0; } } &.tabulator-group-level-1{ .tabulator-arrow{ margin-left:20px; } } &.tabulator-group-level-2{ .tabulator-arrow{ margin-left:40px; } } &.tabulator-group-level-3{ .tabulator-arrow{ margin-left:60px; } } &.tabulator-group-level-4{ .tabulator-arrow{ margin-left:80px; } } &.tabulator-group-level-5{ .tabulator-arrow{ margin-left:100px; } } //sorting arrow .tabulator-arrow{ display: inline-block; width: 0; height: 0; margin-right:16px; border-top: 6px solid transparent; border-bottom: 6px solid transparent; border-right: 0; border-left: 6px solid $sortArrowActive; vertical-align:middle; } span{ margin-left:10px; color:#d00; } } } .tabulator-edit-select-list{ position: absolute; display:inline-block; box-sizing:border-box; max-height:200px; background:$rowBackgroundColor; border:1px solid $rowBorderColor; font-size:$textSize; overflow-y:auto; -webkit-overflow-scrolling: touch; z-index: 10000; .tabulator-edit-select-list-item{ padding:4px; color:$rowTextColor; &.active{ color:$rowBackgroundColor; background:$editBoxColor; } &:hover{ cursor:pointer; color:$rowBackgroundColor; background:$editBoxColor; } } .tabulator-edit-select-list-group{ border-bottom:1px solid $rowBorderColor; padding:4px; padding-top:6px; color:$rowTextColor; font-weight:bold; } }