713 lines
12 KiB
SCSS
713 lines
12 KiB
SCSS
@import "mixin";
|
|
@import "properties";
|
|
|
|
.modal-body.modal-permission-editor {
|
|
padding: 0!important;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: stretch;
|
|
|
|
width: 1000000em; /* get us some width */
|
|
|
|
@include user-select(none);
|
|
|
|
.container {
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: stretch;
|
|
|
|
padding: 0!important;
|
|
|
|
width: 100%;
|
|
max-height: 90vh;
|
|
height: 100000000px; /* enforce max height */
|
|
}
|
|
|
|
.header {
|
|
height: 4em;
|
|
background-color: #19191b;
|
|
color: #e1e1e1;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: stretch;
|
|
|
|
> .entry {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
text-align: center;
|
|
|
|
height: 100%;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: space-around;
|
|
}
|
|
}
|
|
|
|
.container > .left, .container > .right {
|
|
max-height: 100%;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
|
|
> .header {
|
|
flex-shrink: 0;
|
|
flex-grow: 0;
|
|
}
|
|
|
|
> .body {
|
|
flex-shrink: 1;
|
|
flex-grow: 1;
|
|
}
|
|
}
|
|
|
|
.container >.right {
|
|
z-index: 2; /* because the left container overlaps the right container once */
|
|
|
|
width: 75%;
|
|
min-width: 30em;
|
|
|
|
background-color: #303036;
|
|
|
|
.header {
|
|
> .entry {
|
|
position: relative;
|
|
overflow: hidden;
|
|
|
|
cursor: pointer;
|
|
padding-bottom: 2px;
|
|
|
|
a {
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
&:hover {
|
|
border: none;
|
|
border-bottom: 2px solid #4e4e4e;
|
|
|
|
padding-bottom: 0;
|
|
|
|
&:before {
|
|
position: absolute;
|
|
content: '';
|
|
|
|
margin-right: -10em;
|
|
margin-left: -10em;
|
|
margin-bottom: -.2em;
|
|
bottom: 0;
|
|
|
|
height: 100%;
|
|
width: calc(100% + 20em);
|
|
|
|
box-shadow: inset 0px -1.2em 3em -20px #424242;
|
|
}
|
|
}
|
|
|
|
&.selected {
|
|
border: none;
|
|
border-bottom: 2px solid #0073d4;
|
|
|
|
padding-bottom: 0;
|
|
|
|
&:before {
|
|
position: absolute;
|
|
content: '';
|
|
|
|
margin-right: -10em;
|
|
margin-left: -10em;
|
|
margin-bottom: -.2em;
|
|
bottom: 0;
|
|
|
|
height: 100%;
|
|
width: calc(100% + 20em);
|
|
|
|
box-shadow: inset 0px -1.2em 3em -20px #0073d4;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.body {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
min-height: 16em;
|
|
|
|
> .container { /* container permission editor */
|
|
height: 100%;
|
|
width: 100%;
|
|
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
min-width: 30em;
|
|
|
|
.permission-editor {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
width: 100%;
|
|
padding: 5px;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.container >.left {
|
|
width: 25%;
|
|
min-width: 10em;
|
|
|
|
background-color: #222226;
|
|
|
|
.header {
|
|
font-weight: bold;
|
|
|
|
> .entry {
|
|
overflow: hidden;
|
|
|
|
a {
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
}
|
|
|
|
> * {
|
|
font-size: 1.5em;
|
|
}
|
|
}
|
|
|
|
.body {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
min-height: 16em;
|
|
|
|
.container {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
flex-direction: column;
|
|
}
|
|
}
|
|
|
|
|
|
/* server group left list layout */
|
|
.container-view-server-groups, .container-view-channel-groups, .container-view-channel-permissions, .container-view-client-channel-permissions, .container-view-client-channel-permissions {
|
|
height: 100%;
|
|
width: 100%;
|
|
|
|
.list-groups, .list-channel, .list-clients {
|
|
color: #999999;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: flex-start;
|
|
|
|
overflow: auto;
|
|
@include chat-scrollbar-vertical();
|
|
@include chat-scrollbar-horizontal();
|
|
|
|
width: 100%;
|
|
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
.entries {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: flex-start;
|
|
|
|
height: max-content;
|
|
|
|
min-width: 100%;
|
|
width: max-content;
|
|
|
|
.group, .channel, .client {
|
|
padding-left: .25em;
|
|
|
|
flex-shrink: 0;
|
|
flex-grow: 0;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: flex-start;
|
|
|
|
cursor: pointer;
|
|
|
|
width: 100%;
|
|
|
|
&:hover {
|
|
background-color: #28282c;
|
|
}
|
|
|
|
&.selected {
|
|
background-color: #111111;
|
|
|
|
&.client {
|
|
background-color: #1a1b1e;
|
|
}
|
|
}
|
|
|
|
@include transition(background-color .25s ease-in-out);
|
|
|
|
.icon-container, .icon {
|
|
align-self: center;
|
|
margin-right: .25em;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.container-buttons {
|
|
position: relative;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: stretch;
|
|
|
|
flex-grow: 0;
|
|
flex-shrink: 0;
|
|
|
|
height: 2.5em;
|
|
width: 100%;
|
|
|
|
.button {
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: space-around;
|
|
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
cursor: pointer;
|
|
|
|
background-color: #1b1b1b;
|
|
|
|
&:hover {
|
|
background-color: #262626;
|
|
}
|
|
|
|
&:disabled {
|
|
background-color: hsla(0, 0%, 9%, 1);
|
|
}
|
|
@include transition(background-color .25s ease-in-out);
|
|
|
|
img {
|
|
width: 2.2em;
|
|
height: 2.2em;
|
|
|
|
align-self: center;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.container-view-server-groups {
|
|
position: relative;
|
|
|
|
overflow: hidden;
|
|
|
|
$animation_length: .3s;
|
|
.container-group-list {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
|
|
&.hidden {
|
|
@include transform(translateX(-100%));
|
|
}
|
|
@include transition($animation_length ease-in-out);
|
|
}
|
|
|
|
.container-client-list {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
|
|
.container-current-group {
|
|
flex-shrink: 0;
|
|
flex-grow: 0;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: stretch;
|
|
|
|
background-color: #101012;
|
|
color: #999999;
|
|
padding-left: .25em;
|
|
|
|
|
|
height: 1.5em;
|
|
font-size: 1.125em;
|
|
|
|
> .icon-container {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: space-around;
|
|
|
|
height: 100%;
|
|
margin-right: .25em;
|
|
}
|
|
|
|
.name {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
height: 1.5em;
|
|
}
|
|
}
|
|
|
|
&.hidden {
|
|
@include transform(translateX(100%));
|
|
}
|
|
@include transition($animation_length ease-in-out);
|
|
}
|
|
}
|
|
|
|
.container-view-client-permissions, .container-view-client-channel-permissions {
|
|
.client-info {
|
|
width: 100%;
|
|
padding: .25em;
|
|
}
|
|
|
|
hr {
|
|
border: none;
|
|
border-top: 2px solid #1e1e1e;
|
|
}
|
|
}
|
|
|
|
.container-view-client-channel-permissions {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
|
|
}
|
|
}
|
|
|
|
.container-seperator {
|
|
width: 3px;
|
|
height: unset!important;
|
|
background-color: #222224!important;
|
|
}
|
|
}
|
|
|
|
/* canvas permission editor */
|
|
//TODO: Some styling needed
|
|
.container-permissions-canvas {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
width: 100%;
|
|
|
|
.container-permissions {
|
|
padding: .5em;
|
|
overflow-x: auto;
|
|
overflow-y: hidden;
|
|
}
|
|
|
|
.permission-explorer {
|
|
min-width: 750px;
|
|
}
|
|
|
|
.switch {
|
|
width: 5em;
|
|
}
|
|
|
|
.column-name {
|
|
align-self: center;
|
|
padding-left: 1em;
|
|
}
|
|
|
|
.entry-editor-container {
|
|
@include chat-scrollbar-vertical();
|
|
}
|
|
}
|
|
|
|
/* html permission editor */
|
|
.container-permissions-html {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
|
|
min-height: 10em;
|
|
width: 100%;
|
|
|
|
.container-filter, .container-footer {
|
|
flex-grow: 0;
|
|
flex-shrink: 0;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
}
|
|
|
|
.container-filter {
|
|
justify-content: stretch;
|
|
|
|
.button-toggle-clients {
|
|
flex-grow: 0;
|
|
flex-shrink: 0;
|
|
|
|
width: 16em;
|
|
height: 2.5em;
|
|
|
|
margin-right: 1em;
|
|
|
|
align-self: flex-end;
|
|
margin-bottom: 1rem;
|
|
}
|
|
|
|
.container-input {
|
|
flex-grow: 5;
|
|
flex-shrink: 1;
|
|
}
|
|
|
|
.container-granted-switch {
|
|
margin-left: 1em;
|
|
position: relative;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: flex-start;
|
|
|
|
flex-shrink: 1;
|
|
flex-grow: 1;
|
|
|
|
color: #999999;
|
|
min-width: 8em;
|
|
|
|
> label {
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: flex-start;
|
|
|
|
position: absolute;
|
|
bottom: 0;
|
|
left: 0;
|
|
|
|
pointer-events: all;
|
|
cursor: pointer;
|
|
|
|
> * {
|
|
align-self: flex-end;
|
|
}
|
|
|
|
a {
|
|
padding-left: .25em;
|
|
font-size: 1.45em;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.container-mode {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
min-height: 5em;
|
|
|
|
&.container-mode-permissions {
|
|
.container-permission-list {
|
|
width: 100%;
|
|
color: #999999;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
|
|
min-height: 5em;
|
|
|
|
.entry {
|
|
width: 100%;
|
|
|
|
flex-grow: 0;
|
|
flex-shrink: 0;
|
|
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: stretch;
|
|
|
|
height: 2em;
|
|
border: none;
|
|
border-bottom: 1px solid #1e2025;
|
|
|
|
color: #535455;
|
|
|
|
@mixin fixed-column($name, $width) {
|
|
.column-#{$name} {
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: stretch;
|
|
|
|
flex-grow: 0;
|
|
flex-shrink: 0;
|
|
|
|
width: $width;
|
|
|
|
align-items: center;
|
|
|
|
padding-left: 1em;
|
|
|
|
border: none;
|
|
border-right: 1px solid #1e2025;
|
|
}
|
|
}
|
|
|
|
@include fixed-column(name, 6em);
|
|
@include fixed-column(value, 6em);
|
|
@include fixed-column(skip, 5em);
|
|
@include fixed-column(negate, 5em);
|
|
@include fixed-column(granted, 6em);
|
|
|
|
.column-name {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
.arrow {
|
|
cursor: pointer;
|
|
border-color: #e1e1e1;
|
|
}
|
|
|
|
.group-name {
|
|
margin-left: .5em;
|
|
}
|
|
}
|
|
|
|
.column-granted {
|
|
border-right: none;
|
|
}
|
|
|
|
|
|
&.active {
|
|
color: #e1e1e1;
|
|
}
|
|
|
|
&.group {
|
|
color: #e1e1e1;
|
|
font-weight: bold;
|
|
}
|
|
|
|
input {
|
|
color: #e1e1e1;
|
|
|
|
outline: none;
|
|
background: transparent;
|
|
border: none;
|
|
|
|
height: 1.5em;
|
|
width: 5em; /* the column width minus one */
|
|
|
|
/* fix the column padding */
|
|
padding-left: 1em;
|
|
margin-left: -.5em; /* have a bit of space on both sides */
|
|
|
|
border-bottom: 2px solid transparent;
|
|
|
|
&:focus {
|
|
border-bottom-color: #3f7dbf;
|
|
}
|
|
@include transition(border-bottom-color $button_hover_animation_time ease-in-out);
|
|
}
|
|
}
|
|
|
|
.body {
|
|
flex-grow: 1;
|
|
flex-shrink: 1;
|
|
|
|
min-height: 6em; /* TODO: Width */
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: stretch;
|
|
|
|
overflow-y: scroll;
|
|
overflow-x: auto;
|
|
|
|
@include chat-scrollbar-vertical();
|
|
@include chat-scrollbar-horizontal();
|
|
|
|
.entry {
|
|
&.even {
|
|
background-color: #25252a;
|
|
}
|
|
&:hover {
|
|
background-color: #343a47;
|
|
}
|
|
/* We cant use this effect here because the odd/even effect would be a bit crazy then */
|
|
//@include transition(background-color $button_hover_animation_time ease-in-out);
|
|
}
|
|
}
|
|
|
|
.header {
|
|
background-color: unset;
|
|
|
|
color: #e1e1e1;
|
|
font-weight: bold;
|
|
|
|
.column-granted {
|
|
margin-right: .5em; /* scroll bar */
|
|
-moz-margin-end: 12px; /* moz scroll bar */
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
&.container-mode-no-permissions {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: space-around;
|
|
|
|
text-align: center;
|
|
font-size: 2em;
|
|
|
|
color: #222226;
|
|
}
|
|
}
|
|
|
|
.container-footer {
|
|
justify-content: flex-end;
|
|
margin-top: .5em;
|
|
}
|
|
}
|
|
|
|
.modal-group-add {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: flex-start;
|
|
|
|
.buttons {
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: space-between;
|
|
|
|
button {
|
|
min-width: 6em;
|
|
}
|
|
}
|
|
} |