/*
- todo {
- loading overlay colors {
- rich select colors {
 */

$ag-icons-path: './icons/' !default;
$ag-icons-filter: 'initial' !default;

@mixin icon-background($icon) {
    width: 12px;
    height: 12px;
    background: transparent url('#{$ag-icons-path}#{$icon}.svg') center no-repeat;
    background-size: 12px 12px;
    filter: $ag-icons-filter;
}

.ag-icon:not(.ag-faded) {
    opacity: 0.8;
}

$cell-padding: 2px;
$checkbox-horizontal-margin: 4px;
$tool-panel-box-padding: 4px 4px 10px 4px;
 
.ag-#{$ag-style} {
    .ag-numeric-cell {
        text-align: right;
    }

    .ag-header-cell-label {
        display: flex;
        & > span {
            float: left;
        }
        .ag-header-icon {
            margin-top: 2px;
        }

        .ag-header-cell-text {
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis; 
        }
    }

    .ag-numeric-header {
        .ag-header-cell-label {
            flex-direction: row-reverse;
        }

        .ag-header-cell-menu-button {
            float: left;
        }

        .ag-header-cell-label {
            width: calc(100% - 12px);
            float: right;
            & > span {
                float: right;
            }
        }
    }

    .ag-header-cell-resize {
        position: absolute;
        right: 0;
    }

    .ag-rtl .ag-header-cell-resize {
        position: absolute;
        left: 0;
        right: auto;
    }

    // copying bootstrap with line-height, sorts out alignment problems with images beside text
    line-height: 1.4;
    font-family: $ag-root-font-family;
    font-size: $ag-root-font-size;
    color: $ag-foreground-1;
    // changing the image is same as what bootstrap does, without the images didn't align right
    img {
        vertical-align: middle;
        border: 0;
    }
    .ag-root {
        border: $ag-border-1;
    }
    .ag-cell-data-changed {
        background-color: $ag-value-change-value-highlight-background-color;
    }

    .ag-cell-data-changed-animation {
        background-color: transparent;
        transition: background-color 1s;
    }
    .ag-cell {}
    //
    .ag-cell-not-inline-editing {
        padding: $ag-cell-padding;
        /* compensate for the transparent borders; */
        padding-left: $ag-cell-padding - 1;
    }
    // we do not want to color the range color when the cell is also focused
    .ag-cell-range-selected-1:not(.ag-cell-focus) {
        background-color: $ag-range-selected-color-1;
    }
    .ag-cell-range-selected-2:not(.ag-cell-focus) {
        background-color: $ag-range-selected-color-2;
    }
    .ag-cell-range-selected-3:not(.ag-cell-focus) {
        background-color: $ag-range-selected-color-3;
    }
    .ag-cell-range-selected-4:not(.ag-cell-focus) {
        background-color: $ag-range-selected-color-4;
    }
    .ag-cell-focus {
        border: $ag-cell-focused-border;
    }
    .ag-cell-no-focus {
        border-top: $ag-cell-no-focus-border-top;
        border-bottom: $ag-cell-no-focus-border-bottom;
    }
    .ag-ltr .ag-cell-no-focus {
        border-right: $ag-cell-ltr-no-focus-border-right;
        border-left: $ag-cell-ltr-no-focus-border-left;
    }
    .ag-rtl .ag-cell-no-focus {
        border-right: $ag-cell-rtl-no-focus-border-right;
        border-left: $ag-cell-rtl-no-focus-border-left;
    }

    $toolpanel-indent-size: 10px;
    $row-group-indent-size: 10px;
    // indentation loop
    @for $i from 1 to 50 {
        .ag-ltr .ag-toolpanel-indent-#{$i} { padding-left: $i * $toolpanel-indent-size; }
        .ag-rtl .ag-toolpanel-indent-#{$i} { padding-right: $i * $toolpanel-indent-size; }

        .ag-ltr .ag-row-group-indent-#{$i} { padding-left: $i * $row-group-indent-size; }
        .ag-rtl .ag-row-group-indent-#{$i} { padding-right: $i * $row-group-indent-size; }
    }

    // we use rtl and ltr below, even though it's the same style, so it propertly
    .ag-rtl .ag-cell-first-right-pinned {
        border-left: $ag-border-1;
    }
    .ag-ltr .ag-cell-first-right-pinned {
        border-left: $ag-border-1;
    }
    .ag-rtl .ag-cell-last-left-pinned {
        border-right: $ag-border-1;
    }
    .ag-ltr .ag-cell-last-left-pinned {
        border-right: $ag-border-1;
    }
    // this needs to be after the other cell items, so the boarder gets preference
    .ag-cell-highlight {
        border: $ag-cell-highlight-border;
    }
    .ag-cell-highlight-animation {
        transition: border 1s;
    }
    // used by the animateShowChangedCellRenderer
    .ag-value-change-delta {
        padding-right: 2px;
    }
    .ag-value-change-delta-up {
        color: $ag-value-change-delta-up-color;
    }
    .ag-value-change-delta-down {
        color: $ag-value-change-delta-down-color;
    }
    .ag-value-change-value {
        background-color: transparent;
        border-radius: 1px;
        padding-left: 1px;
        padding-right: 1px;
        transition: background-color 1s;
    }
    .ag-value-change-value-highlight {
        background-color: $ag-value-change-value-highlight-background-color;
        transition: background-color 0.1s;
    }
    .ag-rich-select {
        font-size: 14px;
        border: $ag-border-1;
        background-color: $ag-select-background;
    }
    .ag-rich-select-value {
        padding: 2px;
    }
    .ag-rich-select-list {
        border-top: 1px solid $ag-separator-color;
    }
    .ag-rich-select-row {
        padding: 2px;
    }
    .ag-rich-select-row-selected {
        background-color: $ag-menu-option-active-color;
    }
    .ag-large-text {
        border: $ag-border-1;
    }
    .ag-large-textarea {}
    //
    // HEADER SECTION
    .ag-header-select-all, .ag-header-cell-menu-button {
        margin-top: 3px;
        line-height: 1rem;
    }
    .ag-header-select-all {
        padding-right: $checkbox-horizontal-margin;
    }

    .ag-filter-header-container > label {
        margin-bottom: 0;
    }

    .ag-header-cell {
        padding: 2px;
        padding-top: 4px;
    }

    .ag-header {
        color: $ag-header-foreground-1;
        background: $ag-header-background-1;
        border-bottom: $ag-border-1;
        font-weight: $ag-header-font-weight;
    }
    .ag-header-icon {
        color: $ag-header-foreground-1;
        stroke: none;
        fill: $ag-header-foreground-1;
    }

    .ag-filter-icon {
        display: inline-block;
    }
    .ag-sort-ascending-icon:empty {
        display: inline-block;
        @include icon-background('asc');
    }

    .ag-sort-descending-icon:empty {
        display: inline-block;
        @include icon-background('desc');
    }

    .ag-sort-none-icon:empty {
        display: inline-block;
        @include icon-background('none');
    }

    .ag-layout-for-print .ag-header-container {
        background: $ag-header-background-1;
        border-bottom: $ag-border-1;
    }
    .ag-ltr .ag-header-cell {
        border-right: $ag-border-1;
    }
    .ag-rtl .ag-header-cell {
        border-left: $ag-border-1;
    }
    .ag-header-cell-moving .ag-header-cell-label {
        opacity: 0.5;
    }
    .ag-header-cell-moving {
        background-color: rgb(190,190,190);
    }
    .ag-ltr .ag-header-group-cell {
        border-right: $ag-border-1;
    }
    .ag-rtl .ag-header-group-cell {
        border-left: $ag-border-1;
    }
    .ag-header-group-cell-with-group {
        border-bottom: $ag-border-1;
    }
    .ag-header-cell-label {
    }
    .ag-header-cell-text {
    }
    .ag-header-group-cell-label {
        padding: 2px;
        padding-top: 4px;
    }
    .ag-rtl .ag-header-group-text {
        margin-left: 2px;
    }
    .ag-ltr .ag-header-group-text {
        margin-right: 2px;
    }

    .ag-header-cell-menu-button:empty {
        @include icon-background('menu');
    }

    .ag-ltr .ag-pinned-right-header {
        border-left: $ag-border-1;
    }
    .ag-rtl .ag-pinned-left-header {
        border-right: $ag-border-1;
    }
    .ag-header-cell-menu-button:hover {
    }
    .ag-body {
        background-color: $ag-background-1;
    }
    .ag-row-odd {
        background-color: $ag-row-odd-background-color;
    }
    .ag-row-even {
        background-color: $ag-row-even-background-color;
    }
    .ag-row-selected {
        background-color: $ag-row-selected-background-color;
    }
    .ag-row-stub {
        background-color: $ag-row-stub-background-color;
    }
    .ag-stub-cell {
        padding: 2px 2px 2px 10px;
    }
    .ag-floating-top {
        background-color: $ag-row-floating-background-color;
    }
    .ag-floating-top {
        .ag-row {
            background-color: $ag-row-floating-background-color;
        }
    }
    .ag-floating-bottom {
        background-color: $ag-row-floating-background-color;
    }
    .ag-floating-bottom {
        .ag-row {
            background-color: $ag-row-floating-background-color;
        }
    }
    .ag-overlay-loading-wrapper {
        background-color: rgba(255, 255, 255, 0.5);
    }
    .ag-overlay-loading-center {
        background-color: #ffffff;
        border: $ag-border-1;
        border-radius: 10px;
        padding: 10px;
        color: black;
    }
    .ag-overlay-no-rows-center {
        background-color: #ffffff;
        border: $ag-border-1;
        border-radius: 10px;
        padding: 10px;
    }
    .ag-group-cell-entire-row {
        background-color: $ag-background-1;
        padding: $ag-cell-padding;
    }
    .ag-footer-cell-entire-row {
        background-color: $ag-background-1;
        padding: $ag-cell-padding;
    }
    .ag-group-cell {
        font-style: italic;
    }
    .ag-ltr .ag-group-expanded {
        padding-right: 4px;
    }
    .ag-rtl .ag-group-expanded {
        padding-left: 4px;
    }
    .ag-ltr .ag-group-contracted {
        padding-right: 4px;
    }
    .ag-rtl .ag-group-contracted {
        padding-left: 4px;
    }
    .ag-ltr .ag-group-loading {
        padding-right: 4px;
    }
    .ag-rtl .ag-group-loading {
        padding-left: 4px;
    }
    .ag-ltr .ag-group-value {
        padding-right: 2px;
    }
    .ag-rtl .ag-group-value {
        padding-left: 2px;
    }
    .ag-ltr .ag-group-checkbox {
        padding-right: 2px;
    }
    .ag-rtl .ag-group-checkbox {
        padding-left: 2px;
    }
    .ag-group-child-count {
        /* display: inline-block; */ // this breaks the overlow ellipsis
    }
    .ag-footer-cell {
        font-style: italic;
    }

    .ag-menu {
        border: 1px solid $ag-border-color-2;
        background-color: $ag-background-1;
        //color ag-foreground-1
        cursor: default;
        font-family: $ag-root-font-family;
        font-size: $ag-root-font-size;

        .ag-tab-header {
            background-color: $ag-tab-background;
        }
        .ag-tab {
            padding: $ag-tab-padding;
            margin: 2px 2px 0px 2px;
            display: inline-block;
            border-right: 1px solid transparent;
            border-left: 1px solid transparent;
            border-top: 1px solid transparent;
            border-top-right-radius: 2px;
            border-top-left-radius: 2px;
            // need to specify color and stroke again here because
            // for blue, the tab header is different to the grid header
        }
        .ag-tab-selected {
            background-color: $ag-tab-selected-background;
            border-right: $ag-tab-border;
            border-left: $ag-tab-border;
            border-top: $ag-tab-border;
        }
    }
    .ag-menu-separator {
        border-top: 1px solid $ag-separator-color;
    }
    .ag-menu-option {}
    //
    .ag-menu-option-active {
        background-color: $ag-menu-option-active-color;
    }
    .ag-menu-option-icon {
        padding: $ag-menu-option-padding;
        vertical-align: middle;
    }
    .ag-menu-option-text {
        padding: $ag-menu-option-padding;
        vertical-align: middle;
    }
    .ag-menu-option-shortcut {
        padding: $ag-menu-option-shortcut-padding;
        vertical-align: middle;
    }
    .ag-menu-option-popup-pointer {
        padding: $ag-menu-option-padding;
        vertical-align: middle;
        display: table-cell;
    }
    .ag-menu-option-disabled {
        opacity: 0.5;
    }
    .ag-menu-column-select-wrapper {
        margin: 2px;
    }
    .ag-filter-checkbox {
        margin-right: 4px;
        margin-bottom: 0;
        display: inline-block;
    }
    .ag-filter-header-container {
        padding: 2px 4px 2px 4px;
        border-bottom: 1px solid $ag-separator-color;
    }
    .ag-filter-apply-panel {
        border-top: 1px solid $ag-separator-color;
        padding: 2px 0px 2px 4px;
    }
    .ag-filter-value {
    }
    .ag-virtual-list-container {
        padding: $tool-panel-box-padding;
    }
    .ag-filter-header-container {
        
    }
    .ag-ltr .ag-selection-checkbox {
        padding-right: $checkbox-horizontal-margin;
    }
    .ag-rtl .ag-selection-checkbox {
        padding-left: $checkbox-horizontal-margin;
    }
    .ag-paging-panel {
        padding: 4px;
    }
    .ag-paging-button {
        margin-left: 4px;
        margin-right: 4px;
    }
    .ag-paging-row-summary-panel {
        display: inline-block;
        width: 300px;
    }
    .ag-column-panel {
        background-color: $ag-background-1;
        border-bottom: $ag-border-1;
        border-top: $ag-border-1;
        color: $ag-foreground-1;
    }
    .ltr .ag-column-panel {
        border-right: $ag-border-1;
    }
    .rtl .ag-column-panel {
        border-left: $ag-border-1;
    }
    .ag-status-bar {
        color: $ag-foreground-1;
        background-color: $ag-background-1;
        font-size: $ag-root-font-size;
        height: 22px;
        border-bottom: $ag-border-1;
        border-left: $ag-border-1;
        border-right: $ag-border-1;
        padding: 2px;
    }
    .ag-status-bar-aggregations {
        float: right;
    }
    .ag-status-bar-item {
        padding-left: 10px;
    }
    .ag-column-drop-cell {
        background: $ag-button-background-1;
        color: $ag-button-foreground-1;
        border: 1px solid $ag-button-border-1;
    }
    .ag-column-drop-cell-ghost {
        opacity: 0.5;
    }
    .ag-column-drop-cell-text {
        padding-left: 2px;
        padding-right: 2px;
    }
    .ag-column-drop-cell-button {
        border: 1px solid transparent;
        padding-left: 2px;
        padding-right: 2px;
        border-radius: 3px;
    }
    .ag-column-drop-cell-button:hover {
        border: $ag-border-1;
    }

    .ag-column-drop-empty-message {
        padding-left: 2px;
        padding-right: 2px;
        color: grey;
    }

    .ag-column-drop-icon {
        margin: 6px 3px 0px 3px;
    }
    .ag-column-drop {
        background-color: $ag-background-1;
    }
    /* this is for the rowGroupPanel, that appears along the top of the grid */
    .ag-column-drop-horizontal {
        padding: 2px;
        border-top: $ag-border-1;
        border-left: $ag-border-1;
        border-right: $ag-border-1;
        //.ag-column-drop-cell
        //    padding 2px
    }
    /* this is for the column drops that appear in the toolPanel */
    .ag-column-drop-vertical {
        padding: $tool-panel-box-padding;
        border-bottom: $ag-border-1;
        overflow: auto;

        .ag-column-drop-cell {
            margin-top: 2px;
        }

        .ag-column-drop-empty-message {
            padding: 5px;
        }
    }

    .ag-pivot-mode {
        border-bottom: $ag-border-1;
        padding: 2px 4px 3px 4px;
        background-color: $ag-background-1;
    }
    .ag-column-panel {
        .ag-column-select-panel {
            padding: $tool-panel-box-padding;
            padding-left: 0; // compensate for eIndent
            border-bottom: $ag-border-1;
            overflow: auto;
        }
    }

    .ag-select-agg-func-popup {
        cursor: default;
        position: absolute;
        font-size: 14px;
        background-color: $ag-select-background;
        border: $ag-border-1;
    }
    .ag-select-agg-func-item {
        padding-left: 2px;
        padding-right: 2px;
    }

    .ag-select-agg-func-item:hover {
        background-color: $ag-menu-option-active-color;
    }

    .ag-floating-filter-body {
        margin-right: 20px;
        width: calc(100% - 20px);
    }

    .ag-floating-filter-button {
        margin-top: -20px;
        display: inline-block;
        float: right;
        button {
            border: 0;
            background: transparent;
            padding: 3px;
            margin: 0;
        }
    }

    .ag-rtl {
        .ag-floating-filter-body {
            margin-right: 0;
            margin-left: 20px;
            float: right;
        }

        .ag-floating-filter-button {
            float: left;
        }
    }

    .ag-sort-order {
        margin-left: .5em;
        font-size: 0.80em;
        &::before {
            content: '(';
        }

        &::after {
            content: ')';
        }
    }

    .ag-details-row {
        padding: 20px;
        box-sizing: border-box;
    }
}

