NodeBB/NodeBB

View on GitHub
public/scss/generics.scss

Summary

Maintainability
Test Coverage

.flex-1 {
    flex: 1 1 0%!important;
}
.flex-0 {
    flex: 0!important;
}

.pointer {
    @include pointer;
}

.text-md { font-size: 1.125rem!important; } // 18px on harmony
.text-sm { font-size: 0.875rem!important; } // 14px on harmony
.text-xs { font-size: 0.75rem!important; } // 12px on harmony

.overscroll-behavior-contain {
    overscroll-behavior: contain;
}

[component="category-selector"], .category-dropdown-container {
    #category-dropdown-check:checked + .dropdown-menu {
        display: block;
    }
}
.dropdown-left .dropdown-menu {
    --bs-position: start;
}
.dropdown-right .dropdown-menu {
    --bs-position: end;
}

.category-dropdown-menu {
    max-height: 500px;
    overflow-y: auto;
    overflow-x: hidden;
}

.bootstrap-tagsinput {
    @extend .form-control;
    box-shadow: none;
    input {
        &::placeholder{
            color: $input-placeholder-color;
        }
        color: $input-color;
    }
}

@mixin user-icon() {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    color: $white;
    font-weight: normal;
    overflow: hidden;    /* stops alt text from overflowing past boundaries if image does not load */
    white-space: nowrap;
}

.avatar {
    /* Contains the user icon class as a mixin, so there's no need to include that in the template */
    @include user-icon;

    $size: var(--avatar-size);
    @include user-icon-style($size, calc($size * 0.6));

    &.avatar-rounded {
        border-radius: 50%;
    }

    &+.avatar {
        display: none;
    }
}

blockquote {
    background-color: $light;
    font-style: italic;
    border-left: 4px solid $primary;
    padding: 1rem;
    p:last-child {
        margin-bottom: 0;
    }
}

.necro-post {
    text-align: center;
    text-transform: uppercase;
}

.timeline-event {
    display: flex;
    align-items: center;
    justify-content: center;

    .timeline-badge {
        padding: 1rem;
    }
}

.imagedrop {
    position: absolute;
    text-align: center;
    font-size: 24px;
    color: $gray-600;
    width: 100%;
    display: none;
}

.hover-parent {
    .hover-d-block, .hover-d-flex {
        display: none!important;
    }
    .hover-visible {
        visibility: hidden;
    }
    &:hover {
        .hover-d-block {
            display: block!important;
        }
        .hover-d-flex {
            display: flex!important;
        }
        .hover-visible {
            visibility: visible;
        }
    }
}

.border-muted {
    border-color: $text-muted!important;
}

.hidden-empty {
    &:empty {
        display: none!important;
    }
}

// some classes that are used commonly in themes from bs3
.hidden, .hide {
    display: none!important;
}

// for backwards compat, replace with float-start, float-end respectively
.pull-left {
    float: left!important;
}

.pull-right {
    float: right!important;
}