0ec483b668
Signed-off-by: Julius Härtl <jus@bitgrid.net>
1573 lines
25 KiB
SCSS
1573 lines
25 KiB
SCSS
/* Copyright (c) 2011, Jan-Christoph Borchardt, http://jancborchardt.net
|
|
This file is licensed under the Affero General Public License version 3 or later.
|
|
See the COPYING-README file. */
|
|
|
|
input {
|
|
&#openid, &#webdav {
|
|
width: 20em;
|
|
}
|
|
}
|
|
|
|
/* PERSONAL */
|
|
.clear {
|
|
clear: both;
|
|
}
|
|
|
|
/* icons for sidebar */
|
|
.nav-icon-personal-settings {
|
|
background-image: url('../img/personal.svg?v=1');
|
|
}
|
|
|
|
.nav-icon-security {
|
|
background-image: url('../img/toggle-filelist.svg?v=1');
|
|
}
|
|
|
|
.nav-icon-clientsbox {
|
|
background-image: url('../img/change.svg?v=1');
|
|
}
|
|
|
|
.nav-icon-federated-cloud {
|
|
background-image: url('../img/share.svg?v=1');
|
|
}
|
|
|
|
.nav-icon-second-factor-backup-codes, .nav-icon-ssl-root-certificate {
|
|
background-image: url('../img/password.svg?v=1');
|
|
}
|
|
|
|
#avatarform {
|
|
.avatardiv {
|
|
margin: 10px auto;
|
|
}
|
|
.warning {
|
|
width: 100%;
|
|
}
|
|
.jcrop-keymgr {
|
|
display: none !important;
|
|
}
|
|
}
|
|
|
|
#displayavatar {
|
|
text-align: center;
|
|
}
|
|
|
|
#uploadavatarbutton, #selectavatar, #removeavatar {
|
|
padding: 21px;
|
|
}
|
|
|
|
.jcrop-holder {
|
|
z-index: 500;
|
|
}
|
|
|
|
#cropper {
|
|
float: left;
|
|
z-index: 500;
|
|
/* float cropper above settings page to prevent unexpected flowing from dynamically sized element */
|
|
position: fixed;
|
|
background-color: rgba(0, 0, 0, 0.2);
|
|
box-sizing: border-box;
|
|
top: 45px;
|
|
left: 0;
|
|
width: 100%;
|
|
height: calc(100% - 45px);
|
|
.inner-container {
|
|
z-index: 2001;
|
|
/* above the top bar if needed */
|
|
position: absolute;
|
|
top: 50%;
|
|
left: 50%;
|
|
transform: translate(-50%, -50%);
|
|
background: #fff;
|
|
color: #333;
|
|
border-radius: var(--border-radius);
|
|
box-shadow: 0 0 7px #888;
|
|
padding: 15px;
|
|
.jcrop-holder {
|
|
box-shadow: 0 0 7px #888;
|
|
}
|
|
.button {
|
|
margin-top: 15px;
|
|
}
|
|
.primary {
|
|
float: right;
|
|
}
|
|
}
|
|
}
|
|
|
|
#personal-settings-avatar-container {
|
|
display: inline-grid;
|
|
grid-template-columns: 1fr;
|
|
grid-template-rows: 2fr 1fr;
|
|
vertical-align: top;
|
|
}
|
|
|
|
.profile-settings-container {
|
|
display: inline-grid;
|
|
grid-template-columns: 1fr;
|
|
grid-template-rows: 1fr 2fr;
|
|
}
|
|
|
|
.personal-show-container {
|
|
width: 100%;
|
|
}
|
|
|
|
.personal-settings-setting-box input {
|
|
&[type='text'], &[type='email'], &[type='tel'], &[type='url'] {
|
|
width: 100%;
|
|
}
|
|
}
|
|
|
|
select {
|
|
&#timezone,
|
|
&#languageinput,
|
|
&#localeinput {
|
|
width: 100%;
|
|
}
|
|
}
|
|
|
|
input {
|
|
&#pass1,
|
|
&#pass2,
|
|
&#passwordbutton {
|
|
width: 100%;
|
|
}
|
|
}
|
|
|
|
#personal-settings {
|
|
display: grid;
|
|
padding: 20px;
|
|
max-width: 1500px;
|
|
grid-template-columns:1fr 2fr 1fr;
|
|
.section {
|
|
padding: 10px 10px;
|
|
border: 0;
|
|
h2 {
|
|
margin-bottom: 12px;
|
|
}
|
|
}
|
|
.personal-info {
|
|
margin-right: 10%;
|
|
margin-bottom: 12px;
|
|
margin-top: 12px;
|
|
}
|
|
.personal-info[class^='icon-'], .personal-info[class*=' icon-'] {
|
|
background-position: 0px 2px;
|
|
padding-left: 30px;
|
|
opacity: 0.7;
|
|
}
|
|
}
|
|
|
|
|
|
@media (min-width: 1200px) and (max-width: 1400px) {
|
|
#personal-settings {
|
|
display: grid;
|
|
grid-template-columns: 1fr 2fr;
|
|
#personal-settings-avatar-container {
|
|
grid-template-columns: 1fr;
|
|
grid-template-rows: 1fr;
|
|
}
|
|
.personal-settings-container {
|
|
grid-template-columns: 1fr 1fr;
|
|
grid-template-rows: 1fr 1fr 1fr;
|
|
}
|
|
.profile-settings-container {
|
|
grid-template-columns: 1fr 1fr;
|
|
grid-template-rows: 1fr;
|
|
grid-column: 2;
|
|
}
|
|
}
|
|
}
|
|
|
|
@media (max-width: 1200px) {
|
|
#personal-settings {
|
|
display: grid;
|
|
grid-template-columns: 1fr;
|
|
#personal-settings-avatar-container {
|
|
grid-template-rows: 1fr;
|
|
}
|
|
.personal-settings-container {
|
|
grid-template-columns: 1fr 1fr;
|
|
grid-template-rows: 1fr 1fr 1fr;
|
|
}
|
|
.profile-settings-container {
|
|
grid-template-columns: 1fr 1fr;
|
|
grid-template-rows: 1fr;
|
|
}
|
|
}
|
|
}
|
|
|
|
@media (max-width: 560px) {
|
|
#personal-settings {
|
|
display: grid;
|
|
grid-template-columns: 1fr;
|
|
#personal-settings-avatar-container {
|
|
grid-template-rows: 1fr;
|
|
}
|
|
.personal-settings-container {
|
|
grid-template-columns: 1fr;
|
|
grid-template-rows: 1fr 1fr 1fr 1fr 1fr 1fr;
|
|
}
|
|
.profile-settings-container {
|
|
grid-template-columns: 1fr;
|
|
grid-template-rows: 1fr 1fr;
|
|
}
|
|
}
|
|
}
|
|
|
|
.personal-settings-container {
|
|
display: inline-grid;
|
|
grid-template-columns: 1fr 1fr;
|
|
grid-template-rows: 1fr 1fr 1fr;
|
|
&:after {
|
|
clear: both;
|
|
}
|
|
> div {
|
|
h2 {
|
|
position: relative;
|
|
display: inline-flex;
|
|
flex-wrap: nowrap;
|
|
justify-content: flex-start;
|
|
width: 100%;
|
|
> label {
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
overflow: hidden;
|
|
}
|
|
}
|
|
> form span {
|
|
&[class^='icon-checkmark'], &[class^='icon-error'] {
|
|
position: relative;
|
|
right: 8px;
|
|
top: -28px;
|
|
pointer-events: none;
|
|
float: right;
|
|
}
|
|
}
|
|
}
|
|
.verify {
|
|
position: relative;
|
|
left: 100%;
|
|
top: 0;
|
|
height: 0;
|
|
img {
|
|
padding: 12px 7px 6px;
|
|
}
|
|
}
|
|
.verify-action {
|
|
cursor: pointer;
|
|
}
|
|
input:disabled {
|
|
background-color: white;
|
|
color: black;
|
|
border: none;
|
|
opacity: 100;
|
|
}
|
|
}
|
|
|
|
|
|
#body-settings #quota {
|
|
cursor: default;
|
|
position: relative;
|
|
progress {
|
|
height: 6px;
|
|
&::-moz-progress-bar {
|
|
border-radius: 3px 0 0 3px;
|
|
}
|
|
&::-webkit-progress-value {
|
|
border-radius: 3px 0 0 3px;
|
|
}
|
|
}
|
|
div {
|
|
font-weight: normal;
|
|
white-space: nowrap;
|
|
}
|
|
}
|
|
|
|
|
|
/* verify accounts */
|
|
/* only show pointer cursor when popup will be there */
|
|
.verification-dialog {
|
|
display: none;
|
|
right: -9px;
|
|
top: 40px;
|
|
width: 275px;
|
|
p {
|
|
padding: 10px;
|
|
}
|
|
.verificationCode {
|
|
font-family: monospace;
|
|
display: block;
|
|
overflow-wrap: break-word;
|
|
}
|
|
}
|
|
|
|
.federation-menu {
|
|
position: relative;
|
|
cursor: pointer;
|
|
margin-left: 10px;
|
|
.icon-federation-menu {
|
|
padding-left: 16px;
|
|
background-size: 16px;
|
|
background-position: left center;
|
|
opacity: .3;
|
|
cursor: inherit;
|
|
.icon-triangle-s {
|
|
display: inline-block;
|
|
vertical-align: middle;
|
|
cursor: inherit;
|
|
}
|
|
}
|
|
.federationScopeMenu {
|
|
top: 44px;
|
|
&.popovermenu {
|
|
.menuitem {
|
|
// override h2 heading font size
|
|
font-size: 12.8px;
|
|
line-height: 1.6em;
|
|
.menuitem-text-detail {
|
|
opacity: .75;
|
|
}
|
|
&.active {
|
|
box-shadow: inset 2px 0 var(--color-primary);
|
|
.menuitem-text {
|
|
font-weight: 600;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
#groups-groups {
|
|
padding-top: 5px;
|
|
}
|
|
|
|
.clientsbox img {
|
|
height: 60px;
|
|
}
|
|
|
|
#sslCertificate {
|
|
tr.expired {
|
|
background-color: rgba(255, 0, 0, 0.5);
|
|
}
|
|
td {
|
|
padding: 5px;
|
|
}
|
|
}
|
|
|
|
#displaynameerror,
|
|
#displaynamechanged {
|
|
display: none;
|
|
}
|
|
|
|
input#identity {
|
|
width: 20em;
|
|
}
|
|
|
|
#showWizard {
|
|
display: inline-block;
|
|
}
|
|
|
|
.msg {
|
|
&.success {
|
|
color: #fff;
|
|
background-color: #47a447;
|
|
padding: 3px;
|
|
}
|
|
&.error {
|
|
color: #fff;
|
|
background-color: #d2322d;
|
|
padding: 3px;
|
|
}
|
|
}
|
|
|
|
.password-state {
|
|
display: inline-block;
|
|
}
|
|
|
|
table.nostyle {
|
|
label {
|
|
margin-right: 2em;
|
|
}
|
|
td {
|
|
padding: 0.2em 0;
|
|
}
|
|
}
|
|
|
|
#security {
|
|
table {
|
|
width: 100%;
|
|
min-height: 50px;
|
|
padding-top: 5px;
|
|
max-width: 580px;
|
|
th {
|
|
opacity: .5;
|
|
padding: 10px 10px 10px 0;
|
|
}
|
|
td {
|
|
padding: 10px 10px 10px 0;
|
|
&:first-child {
|
|
padding: 10px;
|
|
}
|
|
}
|
|
}
|
|
.token-list td {
|
|
&%icon {
|
|
overflow: visible;
|
|
position: relative;
|
|
width: 16px;
|
|
}
|
|
&.more {
|
|
@extend %icon;
|
|
}
|
|
&.client {
|
|
@extend %icon;
|
|
|
|
div {
|
|
opacity: 0.57;
|
|
width: inherit;
|
|
padding-top: 5px;
|
|
}
|
|
}
|
|
border-top: 1px solid var(--color-border);
|
|
text-overflow: ellipsis;
|
|
max-width: 200px;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
vertical-align: top;
|
|
position: relative;
|
|
}
|
|
tr > *:nth-child(3) {
|
|
text-align: right;
|
|
}
|
|
.token-list {
|
|
td > a.icon {
|
|
|
|
transition: opacity 0.5s;
|
|
}
|
|
a.icon {
|
|
margin-top: 4px;
|
|
display: block;
|
|
}
|
|
tr {
|
|
&:hover td > a.icon, &.active td > a.icon {
|
|
opacity: 0.6;
|
|
}
|
|
}
|
|
td div.configure {
|
|
display: none;
|
|
}
|
|
tr.active div.configure {
|
|
display: block;
|
|
position: absolute;
|
|
top: 45px;
|
|
right: -5px;
|
|
padding: 10px;
|
|
}
|
|
div.configure:after {
|
|
right: 13px;
|
|
}
|
|
tr.active {
|
|
div.configure > * {
|
|
margin-top: 5px;
|
|
margin-bottom: 5px;
|
|
display: inline-block;
|
|
}
|
|
a.icon-delete {
|
|
background-position: left;
|
|
padding-left: 20px;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
#new-app-login-name,
|
|
#new-app-password {
|
|
width: 245px;
|
|
font-family: monospace;
|
|
}
|
|
|
|
.app-password-row {
|
|
display: table-row;
|
|
.icon {
|
|
background-size: 16px 16px;
|
|
display: inline-block;
|
|
position: relative;
|
|
top: 3px;
|
|
margin-left: 5px;
|
|
margin-right: 8px;
|
|
}
|
|
}
|
|
|
|
.app-password-label {
|
|
display: table-cell;
|
|
padding-right: 1em;
|
|
}
|
|
|
|
.social-button {
|
|
padding-left: 0 !important;
|
|
margin-left: -10px;
|
|
img {
|
|
padding: 10px;
|
|
}
|
|
}
|
|
|
|
/* USERS */
|
|
|
|
.isgroup {
|
|
.groupname {
|
|
width: 85%;
|
|
display: block;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
&.active .groupname {
|
|
width: 65%;
|
|
}
|
|
}
|
|
|
|
li.active {
|
|
.delete,
|
|
.rename {
|
|
display: block;
|
|
}
|
|
}
|
|
|
|
.app-navigation-entry-utils {
|
|
.delete,
|
|
.rename {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
#usersearchform {
|
|
position: absolute;
|
|
top: 2px;
|
|
right: 0;
|
|
input {
|
|
width: 150px;
|
|
}
|
|
label {
|
|
font-weight: 700;
|
|
}
|
|
}
|
|
|
|
/* display table at full width */
|
|
table.grid {
|
|
width: 100%;
|
|
th {
|
|
height: 2em;
|
|
color: #999;
|
|
border-bottom: 1px solid var(--color-border);
|
|
padding: 0 .5em;
|
|
padding-left: .8em;
|
|
text-align: left;
|
|
font-weight: normal;
|
|
}
|
|
td {
|
|
border-bottom: 1px solid var(--color-border);
|
|
padding: 0 .5em;
|
|
padding-left: .8em;
|
|
text-align: left;
|
|
font-weight: normal;
|
|
}
|
|
}
|
|
|
|
td, th {
|
|
&.name {
|
|
padding-left: .8em;
|
|
min-width: 5em;
|
|
max-width: 12em;
|
|
text-overflow: ellipsis;
|
|
overflow: hidden;
|
|
}
|
|
&.password {
|
|
padding-left: .8em;
|
|
> img {
|
|
visibility: hidden;
|
|
}
|
|
}
|
|
&.displayName > img {
|
|
visibility: hidden;
|
|
}
|
|
&.password,
|
|
&.displayName,
|
|
&.mailAddress {
|
|
min-width: 5em;
|
|
max-width: 12em;
|
|
cursor: pointer;
|
|
span {
|
|
width: 90%;
|
|
display: inline-block;
|
|
text-overflow: ellipsis;
|
|
overflow: hidden;
|
|
}
|
|
}
|
|
&.mailAddress {
|
|
cursor: pointer;
|
|
}
|
|
&.password > span {
|
|
margin-right: 1.2em;
|
|
color: #C7C7C7;
|
|
}
|
|
}
|
|
|
|
span.usersLastLoginTooltip {
|
|
white-space: nowrap;
|
|
}
|
|
|
|
/* dropdowns will be relative to this element */
|
|
#userlist {
|
|
position: relative;
|
|
.storageLocation, .userBackend, .lastLogin {
|
|
display: none;
|
|
}
|
|
th.name {
|
|
color: #000;
|
|
}
|
|
tr {
|
|
height: 50px;
|
|
}
|
|
.mailAddress .loading-small {
|
|
width: 16px;
|
|
height: 16px;
|
|
margin-left: -26px;
|
|
position: relative;
|
|
top: 3px;
|
|
}
|
|
.groupsListContainer.hidden {
|
|
display: none;
|
|
}
|
|
thead th,
|
|
thead tr {
|
|
z-index: 100;
|
|
background-color: var(--color-main-background);
|
|
position: sticky;
|
|
// positional attribute is required for position to take affect.
|
|
top: 0;
|
|
}
|
|
}
|
|
|
|
#newuser {
|
|
.groupsListContainer.hidden {
|
|
display: none;
|
|
}
|
|
.multiselect {
|
|
min-width: 150px !important;
|
|
position: relative;
|
|
top: -1px;
|
|
}
|
|
input {
|
|
&:not([type='submit']),
|
|
&:not([type='reset']) {
|
|
width: 100%;
|
|
}
|
|
}
|
|
.userActions input {
|
|
width: 44px;
|
|
height: 44px;
|
|
&.icon-close {
|
|
border: none;
|
|
background-color: initial;
|
|
opacity: .5;
|
|
}
|
|
&:hover {
|
|
opacity: 1;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* used to highlight a user row in red */
|
|
|
|
#userlist tr.row-warning {
|
|
background-color: #FDD;
|
|
}
|
|
|
|
/* APPS */
|
|
#app-content > svg.app-filter {
|
|
float: left;
|
|
height: 0;
|
|
width: 0;
|
|
}
|
|
|
|
#app-category-app-bundles {
|
|
margin-bottom: 20px;
|
|
}
|
|
|
|
.appinfo {
|
|
margin: 1em 40px;
|
|
}
|
|
|
|
#app-navigation {
|
|
/* Navigation icons */
|
|
img {
|
|
margin-bottom: -3px;
|
|
margin-right: 6px;
|
|
width: 16px;
|
|
}
|
|
li span.no-icon {
|
|
padding-left: 32px;
|
|
}
|
|
ul li.active > span.utils {
|
|
.delete, .rename {
|
|
display: block;
|
|
}
|
|
}
|
|
.appwarning {
|
|
background: #fcc;
|
|
}
|
|
&.appwarning:hover {
|
|
background: #fbb;
|
|
}
|
|
.app-external, .app-version {
|
|
color: rgba(85, 85, 85, 0.5);
|
|
}
|
|
}
|
|
|
|
span.version {
|
|
margin-left: 1em;
|
|
margin-right: 1em;
|
|
color: #555;
|
|
}
|
|
|
|
.app-level {
|
|
margin-top: 8px;
|
|
span {
|
|
color: #555;
|
|
background-color: transparent;
|
|
border: 1px solid #555;
|
|
border-radius: var(--border-radius);
|
|
padding: 3px 6px;
|
|
}
|
|
a {
|
|
padding: 10px;
|
|
margin: -6px;
|
|
white-space: nowrap;
|
|
}
|
|
.official {
|
|
border-color: #37ce02;
|
|
background-position: left center;
|
|
background-position: 5px center;
|
|
padding-left: 25px;
|
|
}
|
|
}
|
|
|
|
.app-score {
|
|
position: relative;
|
|
top: 4px;
|
|
opacity: .5;
|
|
}
|
|
|
|
.app-settings-content {
|
|
#searchresults {
|
|
display: none;
|
|
}
|
|
}
|
|
#apps-list.store {
|
|
.section {
|
|
border: 0;
|
|
}
|
|
.app-name {
|
|
display: block;
|
|
margin: 5px 0;
|
|
}
|
|
.app-name, .app-image * {
|
|
cursor: pointer;
|
|
}
|
|
.app-summary {
|
|
opacity: .7;
|
|
}
|
|
.app-image-icon .icon-settings-dark {
|
|
width: 100%;
|
|
height: 150px;
|
|
background-size: 45px;
|
|
opacity: 0.5;
|
|
}
|
|
.app-score-image {
|
|
height: 14px;
|
|
}
|
|
.actions {
|
|
margin-top: 10px;
|
|
}
|
|
}
|
|
|
|
#app-sidebar #app-details-view {
|
|
h2 {
|
|
.icon-settings-dark,
|
|
svg {
|
|
display: inline-block;
|
|
width: 16px;
|
|
height: 16px;
|
|
margin-right: 10px;
|
|
opacity: .7;
|
|
}
|
|
}
|
|
.app-level {
|
|
margin-bottom: 10px;
|
|
}
|
|
.app-author, .app-licence {
|
|
color: var(--color-text-maxcontrast);
|
|
}
|
|
.app-dependencies {
|
|
margin: 10px 0;
|
|
}
|
|
.app-description p {
|
|
margin: 10px 0;
|
|
}
|
|
.close {
|
|
position: absolute;
|
|
top: 0;
|
|
right: 0;
|
|
padding: 14px;
|
|
opacity: 0.5;
|
|
z-index: 1;
|
|
}
|
|
.actions {
|
|
display: flex;
|
|
}
|
|
}
|
|
|
|
@media only screen and (min-width: 1601px) {
|
|
.store .section {
|
|
width: 25%;
|
|
}
|
|
.with-app-sidebar .store .section {
|
|
width: 33%;
|
|
}
|
|
}
|
|
|
|
@media only screen and (max-width: 1600px) {
|
|
.store .section {
|
|
width: 25%;
|
|
}
|
|
.with-app-sidebar .store .section {
|
|
width: 33%;
|
|
}
|
|
}
|
|
|
|
@media only screen and (max-width: 1400px) {
|
|
.store .section {
|
|
width: 33%;
|
|
}
|
|
.with-app-sidebar .store .section {
|
|
width: 50%;
|
|
}
|
|
}
|
|
|
|
@media only screen and (max-width: 900px) {
|
|
.store .section {
|
|
width: 50%;
|
|
}
|
|
.with-app-sidebar .store .section {
|
|
width: 100%;
|
|
}
|
|
}
|
|
|
|
@media only screen and (max-width: 768px) {
|
|
.store .section {
|
|
width: 50%;
|
|
}
|
|
}
|
|
/* hide app version and level on narrower screens */
|
|
@media only screen and (max-width: 900px) {
|
|
#apps-list.installed {
|
|
.app-version, .app-level {
|
|
display: none !important;
|
|
}
|
|
}
|
|
}
|
|
|
|
@media only screen and (max-width: 500px) {
|
|
#apps-list.installed .app-groups {
|
|
display: none !important;
|
|
}
|
|
}
|
|
|
|
.section {
|
|
margin-bottom: 0;
|
|
/* use 2nd child since app-navigation-toggle is the first */
|
|
&:not(:nth-child(2)) {
|
|
border-top: 1px solid var(--color-border);
|
|
}
|
|
|
|
/* correctly display help icons next to headings */
|
|
h2 {
|
|
margin-bottom: 22px;
|
|
.icon-info {
|
|
padding: 6px 20px;
|
|
vertical-align: text-bottom;
|
|
display: inline-block;
|
|
}
|
|
}
|
|
}
|
|
|
|
.personal-settings-setting-box .section {
|
|
padding: 10px 30px;
|
|
}
|
|
|
|
.followupsection {
|
|
display: block;
|
|
padding: 0 30px 30px 30px;
|
|
color: #555;
|
|
}
|
|
|
|
.app-image {
|
|
position: relative;
|
|
height: 150px;
|
|
opacity: 1;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.app-name, .app-version, .app-score, .app-level {
|
|
display: inline-block;
|
|
}
|
|
|
|
.app-description-toggle-show, .app-description-toggle-hide {
|
|
clear: both;
|
|
padding: 7px 0;
|
|
cursor: pointer;
|
|
opacity: .5;
|
|
}
|
|
|
|
.app-description-container {
|
|
clear: both;
|
|
position: relative;
|
|
top: 7px;
|
|
}
|
|
|
|
.app-description {
|
|
clear: both;
|
|
}
|
|
|
|
#app-category-1 {
|
|
margin-bottom: 18px;
|
|
}
|
|
|
|
/* capitalize 'Other' category */
|
|
|
|
#app-category-925 {
|
|
text-transform: capitalize;
|
|
}
|
|
|
|
.app-dependencies {
|
|
color: #ce3702;
|
|
}
|
|
|
|
.missing-dependencies {
|
|
list-style: initial;
|
|
list-style-type: initial;
|
|
list-style-position: inside;
|
|
}
|
|
|
|
.appslink {
|
|
text-decoration: underline;
|
|
}
|
|
|
|
|
|
#apps-list, #apps-list-search {
|
|
.section {
|
|
cursor: pointer;
|
|
}
|
|
&.installed {
|
|
display: table;
|
|
width: 100%;
|
|
height: auto;
|
|
margin-bottom: 100px;
|
|
.section {
|
|
display: table-row;
|
|
padding: 0;
|
|
margin: 0;
|
|
> * {
|
|
display: table-cell;
|
|
height: initial;
|
|
vertical-align: middle;
|
|
float: none;
|
|
border-bottom: 1px solid var(--color-border);
|
|
padding: 6px;
|
|
box-sizing: border-box;
|
|
}
|
|
&.selected {
|
|
background-color: var(--color-background-dark);
|
|
}
|
|
}
|
|
.groups-enable {
|
|
margin-top: 0;
|
|
label {
|
|
margin-right: 3px;
|
|
}
|
|
}
|
|
.app-image {
|
|
width: 44px;
|
|
height: auto;
|
|
text-align: right;
|
|
}
|
|
.app-image-icon svg,
|
|
.app-image-icon .icon-settings-dark {
|
|
margin-top: 5px;
|
|
width: 20px;
|
|
height: 20px;
|
|
opacity: .5;
|
|
background-size: cover;
|
|
display: inline-block;
|
|
}
|
|
.actions {
|
|
text-align: right;
|
|
.icon-loading-small {
|
|
display: inline-block;
|
|
top: 4px;
|
|
margin-right: 10px;
|
|
}
|
|
}
|
|
}
|
|
&:not(.installed) .app-image-icon svg {
|
|
position: absolute;
|
|
bottom: 43px;
|
|
/* position halfway vertically */
|
|
width: 64px;
|
|
height: 64px;
|
|
opacity: .1;
|
|
}
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
align-content: flex-start;
|
|
&.hidden {
|
|
display: none;
|
|
}
|
|
.section {
|
|
position: relative;
|
|
flex: 0 0 auto;
|
|
|
|
h2.app-name {
|
|
display: block;
|
|
margin: 8px 0;
|
|
}
|
|
}
|
|
.app-description {
|
|
p {
|
|
margin: 10px 0;
|
|
}
|
|
ul {
|
|
list-style: disc;
|
|
}
|
|
ol {
|
|
list-style: decimal;
|
|
ol, ul {
|
|
padding-left: 15px;
|
|
}
|
|
}
|
|
> {
|
|
ul, ol {
|
|
margin-left: 19px;
|
|
}
|
|
}
|
|
ul {
|
|
ol, ul {
|
|
padding-left: 15px;
|
|
}
|
|
}
|
|
}
|
|
/* Bundle header */
|
|
.apps-header {
|
|
display: table-row;
|
|
position: relative;
|
|
div {
|
|
display: table-cell;
|
|
height: 70px;
|
|
}
|
|
h2 {
|
|
display: table-cell;
|
|
position: absolute;
|
|
padding-left: 6px;
|
|
padding-top: 15px;
|
|
|
|
.enable {
|
|
position: relative;
|
|
top: -1px;
|
|
margin-left: 12px;
|
|
}
|
|
+ .section {
|
|
margin-top: 50px;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* LOG */
|
|
#log {
|
|
white-space: normal;
|
|
margin-bottom: 14px;
|
|
}
|
|
|
|
#lessLog {
|
|
display: none;
|
|
}
|
|
|
|
table.grid td.date {
|
|
white-space: nowrap;
|
|
}
|
|
|
|
#log-section p {
|
|
margin-top: 20px;
|
|
}
|
|
|
|
#security-warning-state-ok,
|
|
#security-warning-state-warning,
|
|
#security-warning-state-failure,
|
|
#security-warning-state-loading {
|
|
span {
|
|
vertical-align: middle;
|
|
|
|
&.message {
|
|
padding: 12px;
|
|
}
|
|
&.icon {
|
|
width: 32px;
|
|
height: 32px;
|
|
background-position: center center;
|
|
display: inline-block;
|
|
border-radius: 50%;
|
|
}
|
|
&.icon-checkmark-white {
|
|
background-color: var(--color-success);
|
|
}
|
|
&.icon-error-white {
|
|
background-color: var(--color-warning);
|
|
}
|
|
&.icon-close-white {
|
|
background-color: var(--color-error);
|
|
}
|
|
}
|
|
}
|
|
|
|
#shareAPI {
|
|
p {
|
|
padding-bottom: 0.8em;
|
|
}
|
|
input#shareapiExpireAfterNDays {
|
|
width: 40px;
|
|
}
|
|
.indent {
|
|
padding-left: 28px;
|
|
}
|
|
.double-indent {
|
|
padding-left: 56px;
|
|
}
|
|
.nocheckbox {
|
|
padding-left: 20px;
|
|
}
|
|
}
|
|
|
|
#shareApiDefaultPermissionsSection label {
|
|
margin-right: 20px;
|
|
}
|
|
|
|
#fileSharingSettings h3 {
|
|
display: inline-block;
|
|
}
|
|
|
|
#publicShareDisclaimerText {
|
|
width: calc(100% - 23px);
|
|
/* 20 px left margin, 3 px right margin */
|
|
max-width: 600px;
|
|
height: 150px;
|
|
margin-left: 20px;
|
|
box-sizing: border-box;
|
|
}
|
|
|
|
/* correctly display help icons next to headings */
|
|
|
|
.icon-info {
|
|
padding: 11px 20px;
|
|
vertical-align: text-bottom;
|
|
}
|
|
|
|
#shareAPI h2, #encryptionAPI h2, #mail_general_settings h2 {
|
|
display: inline-block;
|
|
}
|
|
|
|
#encryptionAPI li {
|
|
list-style-type: initial;
|
|
margin-left: 20px;
|
|
padding: 5px 0;
|
|
}
|
|
|
|
.mail_settings p {
|
|
label:first-child {
|
|
display: inline-block;
|
|
width: 300px;
|
|
text-align: right;
|
|
}
|
|
select:nth-child(2),
|
|
input {
|
|
width: 143px;
|
|
}
|
|
}
|
|
|
|
#mail_smtpport {
|
|
width: 40px;
|
|
}
|
|
|
|
.cronlog {
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.status {
|
|
display: inline-block;
|
|
height: 16px;
|
|
width: 16px;
|
|
vertical-align: text-bottom;
|
|
&.success {
|
|
border-radius: 50%;
|
|
}
|
|
}
|
|
|
|
#selectGroups select {
|
|
box-sizing: border-box;
|
|
display: inline-block;
|
|
height: 36px;
|
|
padding: 7px 10px;
|
|
}
|
|
|
|
#log .log-message {
|
|
word-break: break-all;
|
|
min-width: 180px;
|
|
}
|
|
|
|
span {
|
|
&.success {
|
|
background-color: var(--color-success);
|
|
border-radius: var(--border-radius);
|
|
}
|
|
&.error {
|
|
background-color: var(--color-error);
|
|
}
|
|
&.indeterminate {
|
|
background-color: var(--color-warning);
|
|
border-radius: 40% 0;
|
|
}
|
|
}
|
|
|
|
/* PASSWORD */
|
|
#passwordform .strengthify-wrapper {
|
|
position: absolute;
|
|
left: 0;
|
|
width: 100%;
|
|
border-radius: 0 0 2px 2px;
|
|
margin-top: -6px;
|
|
overflow: hidden;
|
|
height: 3px;
|
|
}
|
|
|
|
/* OPERA hack for strengthify*/
|
|
doesnotexist:-o-prefocus, .strengthify-wrapper {
|
|
left: 185px;
|
|
width: 129px;
|
|
}
|
|
|
|
.trusted-domain-warning {
|
|
color: #fff;
|
|
padding: 5px;
|
|
background: #ce3702;
|
|
border-radius: 5px;
|
|
font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
|
|
}
|
|
|
|
/* HELP */
|
|
.help-includes {
|
|
overflow: hidden !important;
|
|
}
|
|
|
|
.help-iframe {
|
|
width: 100%;
|
|
height: 100%;
|
|
margin: 0;
|
|
padding: 0;
|
|
border: 0;
|
|
overflow: auto;
|
|
}
|
|
|
|
#postsetupchecks {
|
|
ul {
|
|
margin-left: 44px;
|
|
list-style: disc;
|
|
|
|
li {
|
|
margin: 10px 0;
|
|
}
|
|
|
|
ul {
|
|
list-style: circle;
|
|
}
|
|
}
|
|
|
|
.loading {
|
|
height: 50px;
|
|
background-position: left center;
|
|
}
|
|
.errors, .errors a {
|
|
color: var(--color-error);
|
|
}
|
|
.warnings, .warnings a {
|
|
color: var(--color-warning);
|
|
}
|
|
|
|
.hint {
|
|
margin: 20px 0;
|
|
}
|
|
}
|
|
|
|
#security-warning {
|
|
a {
|
|
text-decoration: underline;
|
|
}
|
|
|
|
.extra-top-margin {
|
|
margin-top: 12px;
|
|
}
|
|
}
|
|
|
|
#admin-tips li {
|
|
list-style: initial;
|
|
a {
|
|
display: inline-block;
|
|
padding: 3px 0;
|
|
}
|
|
}
|
|
|
|
#selectEncryptionModules {
|
|
margin-left: 30px;
|
|
padding: 10px;
|
|
}
|
|
|
|
#encryptionModules {
|
|
padding: 10px;
|
|
}
|
|
|
|
#warning {
|
|
color: red;
|
|
}
|
|
|
|
.settings-hint {
|
|
margin-top: -12px;
|
|
margin-bottom: 12px;
|
|
opacity: .7;
|
|
}
|
|
|
|
|
|
/* USERS LIST -------------------------------------------------------------- */
|
|
#body-settings {
|
|
#app-navigation {
|
|
/* Hack to override the javascript orderBy */
|
|
#usergrouplist > li {
|
|
order: 4;
|
|
&#everyone {
|
|
order:1;
|
|
}
|
|
&#admin {
|
|
order:2;
|
|
}
|
|
&#disabled {
|
|
order:3;
|
|
}
|
|
}
|
|
}
|
|
$grid-row-height: 46px;
|
|
#app-content.user-list-grid {
|
|
display: grid;
|
|
grid-auto-columns: 1fr;
|
|
grid-auto-rows: $grid-row-height;
|
|
grid-column-gap: 20px;
|
|
.row {
|
|
// TODO replace with css4 subgrid when available
|
|
// fallback for ie11 no grid
|
|
display: flex;
|
|
display: grid;
|
|
grid-row-start: span 1;
|
|
grid-gap: 3px;
|
|
align-items: center;
|
|
/* let's define the column until storage path,
|
|
what follows will be manually defined */
|
|
grid-template-columns: 44px;
|
|
grid-auto-columns: min-content;
|
|
border-top: var(--color-border) 1px solid;
|
|
&.disabled {
|
|
opacity: .5;
|
|
}
|
|
|
|
/* grid col width */
|
|
.name,
|
|
.displayName,
|
|
.password {
|
|
width: 150px;
|
|
}
|
|
.mailAddress,
|
|
.groups,
|
|
.subadmins {
|
|
width: 200px;
|
|
}
|
|
.quota {
|
|
width: 150px;
|
|
}
|
|
.languages {
|
|
width: 200px;
|
|
}
|
|
.storageLocation {
|
|
width: 250px;
|
|
}
|
|
.userBackend,
|
|
.lastLogin {
|
|
width: 100px;
|
|
}
|
|
.obfuscated {
|
|
width: 400px;
|
|
opacity: .7;
|
|
}
|
|
|
|
/* various */
|
|
&#grid-header,
|
|
&#new-user {
|
|
position: sticky;
|
|
align-self: normal;
|
|
background-color: var(--color-main-background);
|
|
z-index: 55; /* above multiselect */
|
|
top: 0;
|
|
&.sticky {
|
|
box-shadow: 0 -2px 10px 1px var(--color-box-shadow);
|
|
}
|
|
/* fake input for groups validation */
|
|
input#newgroups {
|
|
position: absolute;
|
|
opacity: 0;
|
|
width: 80% !important;
|
|
margin: 0 10%;
|
|
z-index: 0;
|
|
}
|
|
}
|
|
// separate prop to set initial value to top:0
|
|
&#new-user {
|
|
top: $grid-row-height;
|
|
}
|
|
&#grid-header {
|
|
color: var(--color-background-darker);
|
|
z-index: 60; /* above new-user */
|
|
}
|
|
&:hover {
|
|
input:not([type='submit']):not(:focus):not(:active) {
|
|
border-color: var(--color-border) !important;
|
|
}
|
|
}
|
|
> div,
|
|
> form {
|
|
grid-row: 1;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
color: var(--color-text-lighter);
|
|
position: relative;
|
|
> input:not(:focus):not(:active) {
|
|
border-color: transparent;
|
|
cursor: pointer;
|
|
}
|
|
> input:focus, >input:active {
|
|
+ .icon-confirm {
|
|
display: block !important;
|
|
}
|
|
}
|
|
/* inputs like mail, username, password */
|
|
&:not(.userActions) > input:not([type='submit']) {
|
|
width: 100%;
|
|
min-width: 0;
|
|
}
|
|
&.name {
|
|
word-break: break-all;
|
|
}
|
|
&.displayName,
|
|
&.mailAddress {
|
|
> input {
|
|
text-overflow: ellipsis;
|
|
}
|
|
}
|
|
&.name,
|
|
&.storageLocation {
|
|
/* better multi-line visual */
|
|
line-height: 1.3em;
|
|
max-height: 2.6em;
|
|
overflow : hidden;
|
|
/* not supported by all browsers
|
|
so we keep the overflow hidden
|
|
as a fallback */
|
|
text-overflow: ellipsis;
|
|
display: -webkit-box;
|
|
-webkit-line-clamp: 2;
|
|
-webkit-box-orient: vertical;
|
|
}
|
|
&.quota {
|
|
.multiselect--active + progress {
|
|
display: none;
|
|
}
|
|
progress {
|
|
position: absolute;
|
|
width: calc(100% - 4px); /* minus left and right */
|
|
left: 2px;
|
|
bottom: 2px;
|
|
height: 3px;
|
|
z-index: 5; /* above multiselect */
|
|
}
|
|
}
|
|
.icon-confirm {
|
|
width: 32px;
|
|
height: 32px;
|
|
flex: 0 0 32px;
|
|
cursor: pointer;
|
|
&:not(:active) {
|
|
display: none;
|
|
}
|
|
}
|
|
&.avatar {
|
|
height: 32px;
|
|
width: 32px;
|
|
margin: 6px;
|
|
img {
|
|
display: block;
|
|
}
|
|
}
|
|
&.userActions {
|
|
.toggleUserActions {
|
|
position: relative;
|
|
.icon-more {
|
|
width: 44px;
|
|
height: 44px;
|
|
opacity: .5;
|
|
cursor: pointer;
|
|
&:hover {
|
|
opacity: .7;
|
|
}
|
|
}
|
|
}
|
|
.feedback {
|
|
display: flex;
|
|
align-items: center;
|
|
white-space: nowrap;
|
|
transition: opacity 200ms ease-in-out;
|
|
.icon-checkmark {
|
|
opacity: .5;
|
|
margin-right: 5px;
|
|
}
|
|
}
|
|
}
|
|
/* Fill the grid cell */
|
|
.multiselect.multiselect-vue {
|
|
width: 100%;
|
|
}
|
|
}
|
|
}
|
|
.infinite-loading-container {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
grid-row-start: span 4;
|
|
}
|
|
.users-list-end {
|
|
opacity: .5;
|
|
user-select: none;
|
|
}
|
|
}
|
|
}
|