nextcloud/settings/css/settings.scss

1449 lines
22 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: $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 1fr;
vertical-align: top;
}
.profile-settings-container {
display: inline-grid;
grid-template-columns: 1fr;
grid-template-rows: 1fr 2fr 1fr;
}
.personal-show-container {
width: 100%;
}
.personal-settings-setting-box input {
&[type='text'], &[type='email'], &[type='tel'], &[type='url'] {
width: 100%;
}
}
select {
&#timezone,
&#languageinput {
width: 100%;
}
}
input {
&#pass1,
&#pass2,
&#passwordbutton {
width: 100%;
}
}
#personal-settings {
.section {
border: 0;
}
}
#personal-settings {
display: grid;
padding: 20px;
max-width: 1500px;
grid-template-columns:1fr 2fr 1fr;
.section {
padding: 10px 10px;
}
.personal-info {
margin-right: 10%;
margin-bottom: 20px;
}
.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 1fr;
&:after {
clear: both;
}
> div {
h2 {
position: relative;
margin-bottom: 12px;
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 $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;
}
}
.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 #DDD;
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;
background-color: lightyellow;
}
.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 $color-border;
padding: 0 .5em;
padding-left: .8em;
text-align: left;
font-weight: normal;
}
td {
border-bottom: 1px solid $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: $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: $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;
}
@media (min-width: 1601px) {
#apps-list .section {
width: 22%;
box-sizing: border-box;
&:nth-child(4n) {
margin-right: 20px;
}
}
}
@media (min-width: 1201px) and (max-width: 1600px) {
#apps-list .section {
width: 30%;
box-sizing: border-box;
&:nth-child(3n) {
margin-right: 20px;
}
}
}
@media (min-width: 901px) and (max-width: 1200px), (min-width: 601px) and (max-width: 770px) {
#apps-list .section {
width: 40%;
box-sizing: border-box;
&:nth-child(2n) {
margin-right: 20px;
}
}
}
/* hide app version and level on narrower screens */
@media only screen and (max-width: 768px) {
#apps-list.installed {
.app-version, .app-level {
display: none !important;
}
}
}
@media only screen and (max-width: 700px) {
#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 $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;
}
/* Transition to complete width! */
.app {
&:hover, &:active {
max-width: inherit;
}
}
.appslink {
text-decoration: underline;
}
.score {
color: #666;
font-weight: bold;
font-size: 0.8em;
}
.appinfo .documentation {
margin-top: 1em;
margin-bottom: 1em;
}
#apps-list {
&.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 $color-border;
padding: 6px;
box-sizing: border-box;
}
}
.groups-enable {
margin-top: 0;
label {
margin-right: 3px;
}
}
.app-image {
width: 44px;
height: auto;
text-align: right;
}
.app-image-icon svg {
margin-top: 5px;
width: 20px;
height: 20px;
opacity: .5;
}
}
&:not(.installed) .app-image-icon svg {
position: absolute;
bottom: 43px;
/* position halfway vertically */
width: 64px;
height: 64px;
opacity: .1;
}
position: relative;
height: 100%;
display: flex;
flex-wrap: wrap;
align-content: flex-start;
&.hidden {
display: none;
}
.section {
position: relative;
flex: 0 0 auto;
margin-left: 20px;
&.apps-experimental {
flex-basis: 90%;
}
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;
}
}
}
}
.installed .actions {
text-align: right;
}
/* 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 span {
padding-left: 25px;
background-position: 5px center;
margin-left: -5px;
}
#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: $color-success;
border-radius: $border-radius;
}
&.error {
background-color: $color-error;
}
&.indeterminate {
background-color: $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: $color-error;
}
.warnings, .warnings a {
color: $color-warning;
}
.hint {
margin: 20px 0;
}
}
#security-warning > ul {
color: $color-error;
}
#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;
}
.settings-caption {
font-weight: bold;
line-height: 44px;
padding: 0 44px;
white-space: nowrap;
text-overflow: ellipsis;
// !important to overwrite specific hover and focus
opacity: .4 !important;
box-shadow: none !important;
&:not(:first-child) {
margin-top: 22px;
}
}
/* 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: $color-border 1px solid;
&.disabled {
opacity: .5;
}
.name,
.displayName,
.password {
width: 150px;
}
.mailAddress,
.groups,
.subadmins {
width: 200px;
}
.quota {
width: 150px;
}
.languages {
width: 200px;
}
.storageLocation {
width: 250px;
}
.userBackend,
.lastLogin,
.userActions {
width: 100px;
}
.obfuscated {
width: 400px;
opacity: .7;
}
&#grid-header,
&#new-user {
position: sticky;
align-self: normal;
background-color: $color-main-background;
z-index: 55; /* above multiselect */
top: 0;
&.sticky {
box-shadow: 0 -2px 10px 1px $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: nc-lighten($color-main-text, 60%);
z-index: 60; /* above new-user */
}
&:hover {
input:not([type='submit']):not(:focus):not(:active) {
border-color: nc-darken($color-main-background, 14%) !important;
}
}
> div,
> form {
grid-row: 1;
display: inline-flex;
align-items: center;
color: nc-lighten($color-main-text, 33%);
position: relative;
> input:not(:focus):not(:active) {
border-color: transparent;
cursor: pointer;
}
> input:focus, >input:active {
+ .icon-confirm {
display: block !important;
}
}
&:not(.userActions) > input:not([type='submit']) {
width: 100%;
min-width: 0;
}
&.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;
}
}
.toggleUserActions {
position: relative;
.icon-more {
width: 44px;
height: 44px;
opacity: .5;
cursor: pointer;
:hover {
opacity: .7;
}
}
}
/* 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;
}
}
}