overleaf/services/web/frontend/stylesheets/bootstrap-5/pages/project-list.scss
Rebeka Dekany 024048b6fb Merge pull request #19370 from overleaf/rd-dashboard-left-sidebar
[web] Migrate the left menu on the project dashboard part #1

GitOrigin-RevId: e22685e521bd7e56e426940cb56331d86d20cada
2024-07-18 08:04:22 +00:00

751 lines
14 KiB
SCSS

.project-list-empty-col {
display: flex;
height: 100%;
flex-flow: column nowrap;
flex-wrap: nowrap;
.row:first-child {
flex-grow: 1; /* fill vertical space so notifications are pushed to bottom */
}
.card-body {
// h2 + .card-thin top padding
padding-bottom: calc(var(--line-height-03) + var(--line-height-03) / 2);
}
}
.action-btn {
padding: 0 var(--spacing-02);
}
.project-list-react {
body > &.content {
padding-top: $header-height;
padding-bottom: 0;
min-height: calc(100vh - #{$header-height});
display: flex;
flex-direction: column;
}
.project-list-wrapper {
display: flex;
align-items: stretch;
width: 100%;
min-height: calc(100vh - #{$header-height});
}
.project-list-sidebar-wrapper-react {
position: relative;
background-color: var(--bg-dark-secondary);
flex: 0 0 15%;
min-height: calc(100vh - #{$header-height});
max-width: 320px;
min-width: 200px;
.project-list-sidebar-subwrapper {
display: flex;
flex-direction: column;
height: 100%;
.project-list-sidebar-react {
flex-grow: 1;
padding: var(--spacing-08) var(--spacing-06);
-ms-overflow-style: -ms-autohiding-scrollbar;
padding-top: var(--spacing-08);
padding-bottom: var(--spacing-08);
color: var(--neutral-40);
.small {
color: var(--neutral-40);
}
button {
white-space: normal;
word-wrap: anywhere;
// prevents buttons from expanding sidebar width
}
> .dropdown {
width: 100%;
.new-project-button {
width: 100%;
}
}
}
}
}
.project-list-welcome-wrapper {
width: 100%;
padding-bottom: var(--spacing-08);
.welcome-new-wrapper {
.welcome-title {
@include heading-xl;
margin-top: var(--spacing-08);
}
.welcome-message-cards-wrapper {
display: flex;
flex-direction: column;
justify-content: space-between;
align-items: center;
margin-top: var(--spacing-11);
@include media-breakpoint-up(lg) {
flex-direction: row;
justify-content: center;
}
}
.welcome-message-card {
border: 1px solid $bg-light-tertiary;
border-radius: $border-radius-large;
display: flex;
flex-direction: column;
align-items: center;
justify-content: space-between;
padding: var(--spacing-08) var(--spacing-06);
margin: var(--spacing-05) 0;
width: 280px;
height: 200px;
position: relative;
cursor: pointer;
@include media-breakpoint-up(lg) {
margin: 0 var(--spacing-06);
height: 240px;
}
&:hover {
background-color: $bg-light-secondary;
}
.welcome-message-card-img {
@include media-breakpoint-up(lg) {
margin-bottom: var(--spacing-07);
}
}
}
.create-new-project-dropdown {
transform: none !important;
top: 100% !important;
left: var(--spacing-06) !important;
right: var(--spacing-06) !important;
margin-top: var(--spacing-04);
margin-left: var(--spacing-06);
margin-right: var(--spacing-06);
@include media-breakpoint-down(lg) {
left: 0 !important;
right: 0 !important;
margin-top: calc((var(--spacing-05) - var(--spacing-04)) * -1);
}
}
.welcome-message-card-link {
&,
&:hover {
text-decoration: none;
color: $neutral-60;
}
}
}
}
.project-list-main-react {
flex: 1;
overflow-x: hidden;
padding: var(--spacing-08) var(--spacing-06);
}
ul.project-list-filters {
margin: var(--spacing-05) calc(-1 * var(--spacing-06));
.subdued {
color: var(--content-disabled);
}
> li {
cursor: pointer;
position: relative;
> button {
width: 100%;
font-weight: normal;
text-align: left;
color: var(--white);
background-color: transparent;
border-radius: unset;
border: none;
border-bottom: solid 1px transparent;
padding: var(--spacing-03) var(--spacing-06);
&:hover {
background-color: var(--neutral-70);
text-decoration: none;
}
&:focus {
text-decoration: none;
outline: none;
}
}
&.separator {
padding: var(--spacing-03) var(--spacing-06);
cursor: auto;
}
}
> li.active {
border-radius: 0;
> button {
background-color: var(--neutral-90);
font-weight: 700;
color: var(--white);
.subdued {
color: var(--white);
}
}
}
h2 {
font-size: var(--font-size-02);
margin-bottom: var(--spacing-00);
color: var(--content-disabled);
text-transform: uppercase;
padding: var(--spacing-03) var(--spacing-00);
}
> li.tag {
&.active {
.tag-menu > button {
color: var(--white);
border-color: var(--white);
&:hover {
background-color: var(--neutral-90);
}
}
}
&.untagged {
button.tag-name {
span.name {
font-style: italic;
padding-left: 0;
}
}
}
&:hover {
&:not(.active) {
background-color: var(--neutral-70);
}
.tag-menu {
display: block;
}
}
&:not(.active) {
.tag-menu > a:hover {
background-color: var(--neutral-90);
}
}
button.tag-name {
position: relative;
padding: var(--spacing-03) var(--spacing-09) var(--spacing-03)
var(--spacing-06);
display: flex;
align-items: center;
word-wrap: anywhere;
.tag-list-icon {
vertical-align: sub;
font-weight: bold;
}
span.name {
padding-left: 0.5em;
line-height: 1.4;
}
}
}
.tag-menu {
button.dropdown-toggle {
border: 1px solid var(--white);
border-radius: var(--border-radius-base);
background-color: transparent;
color: var(--white);
display: block;
width: 16px;
height: 16px;
position: relative;
padding: var(--spacing-01) var(--spacing-03);
&::after {
position: absolute;
top: 4px;
left: -2px;
}
}
display: none;
width: auto;
position: absolute;
top: 50%;
margin-top: -8px; // Half the element height.
right: 4px;
&.open {
display: block;
}
button.tag-action {
border-radius: unset;
width: 100%;
background-color: transparent;
border-color: transparent;
color: var(--neutral-70);
text-align: left;
font-weight: normal;
&:hover {
color: var(--white);
background-color: var(--bg-accent-01);
}
&:active {
outline: none;
}
}
}
}
}
.add-affiliation-mobile-wrapper {
padding: var(--spacing-07) 0;
}
.add-affiliation {
.progress {
height: var(--spacing-05);
margin-bottom: var(--spacing-03);
}
p {
margin-bottom: var(--spacing-03);
}
&.is-mobile p {
@include body-xs;
white-space: normal;
}
.project-dash-table {
width: 100%;
table-layout: fixed;
@include media-breakpoint-down(md) {
tr:not(:last-child) {
border-bottom: 1px solid $table-border-color;
}
td {
border-bottom-width: 0;
}
}
tbody {
tr.no-projects:hover {
td {
box-shadow: none;
}
}
}
.table-header-sort-btn {
border: 0;
text-align: left;
color: var(--content-secondary);
background-color: transparent;
padding: 0;
font-weight: bold;
max-width: 100%;
overflow: hidden;
text-overflow: ellipsis;
text-decoration: none;
&:hover,
&:focus {
color: var(--content-secondary);
text-decoration: none;
}
.material-symbols {
vertical-align: bottom;
font-size: var(--font-size-06);
}
}
.dash-cell-name {
hyphens: auto;
width: 50%;
word-break: break-word;
}
.dash-cell-owner {
width: 20%;
}
.dash-cell-date {
width: 25%;
}
.dash-cell-actions {
display: none;
text-align: right;
.btn {
text-decoration: none;
}
}
.dash-cell-date-owner {
font-size: $font-size-sm;
@include text-truncate;
}
@include media-breakpoint-up(sm) {
.dash-cell-checkbox {
width: 4%;
}
.dash-cell-name {
width: 50%;
}
.dash-cell-owner {
width: 21%;
}
.dash-cell-date {
width: 25%;
}
.dash-cell-actions {
width: 0%;
}
}
@include media-breakpoint-up(md) {
.dash-cell-checkbox {
width: 4%;
}
.dash-cell-name {
width: 44%;
}
.dash-cell-owner {
width: 16%;
}
.dash-cell-date {
width: 21%;
}
.dash-cell-actions {
display: table-cell;
width: 15%;
}
.project-tools {
float: none;
}
}
@include media-breakpoint-up(lg) {
.dash-cell-checkbox {
width: 3%;
}
.dash-cell-name {
width: 46%;
}
.dash-cell-owner {
width: 13%;
}
.dash-cell-date {
width: 16%;
}
.dash-cell-actions {
width: 22%;
}
tbody {
.dash-cell-actions {
white-space: nowrap;
}
}
}
@include media-breakpoint-up(xl) {
.dash-cell-checkbox {
width: 3%;
}
.dash-cell-name {
width: 46%;
}
.dash-cell-owner {
width: 15%;
}
.dash-cell-date {
width: 19%;
}
.dash-cell-actions {
width: 17%;
}
}
@include media-breakpoint-up(xxl) {
.dash-cell-checkbox {
width: 2%;
}
.dash-cell-name {
width: 49%;
}
.dash-cell-owner {
width: 16%;
}
.dash-cell-date {
width: 19%;
}
.dash-cell-actions {
width: 14%;
}
}
@include media-breakpoint-down(md) {
tr {
position: relative;
display: flex;
flex-direction: column;
}
.dash-cell-name,
.dash-cell-owner,
.dash-cell-date,
.dash-cell-tag,
.dash-cell-actions {
display: block;
width: auto;
}
.dash-cell-actions {
position: absolute;
top: var(--spacing-04);
right: var(--spacing-04);
padding: 0 !important;
}
.dropdown-table-button-toggle {
padding: var(--spacing-04);
font-size: 0;
line-height: 1;
border-radius: 50%;
color: var(--content-primary);
background-color: transparent;
&:hover,
&:active {
background-color: rgba($neutral-90, 0.08);
}
}
}
}
}
.project-list-upload-project-modal-uppy-dashboard .uppy-Root {
.uppy-Dashboard-AddFiles-title {
display: flex;
flex-direction: column;
color: var(--neutral-60);
white-space: pre-line;
button.uppy-Dashboard-browse {
@extend .btn;
@extend .btn-lg;
@extend .btn-primary;
}
}
}
.survey-notification {
display: flex;
flex-wrap: wrap;
padding: var(--spacing-06);
background-color: var(--bg-dark-tertiary);
border-color: transparent;
color: var(--neutral-20);
box-shadow: 2px 4px 6px rgb(0 0 0 / 25%);
border-radius: var(--border-radius-base);
@include media-breakpoint-up(md) {
flex-wrap: nowrap;
}
button.close {
@extend .text-white;
padding: 0;
}
}
.project-list-sidebar-survey-wrapper {
position: sticky;
bottom: 0;
.survey-notification {
font-size: var(--font-size-02);
a {
text-decoration: none;
}
}
@include media-breakpoint-down(md) {
position: static;
margin-top: var(--spacing-05);
.survey-notification {
font-size: unset;
.project-list-sidebar-survey-link {
display: block;
align-items: center;
min-width: 48px;
min-height: 48px;
padding-top: var(--spacing-07);
}
}
}
}
.project-list-load-more-button {
margin-bottom: var(--spacing-05);
}
form.project-search {
.form-group {
margin-bottom: 0;
}
}
.project-search-clear-btn {
@include reset-button;
}
.color-picker-item {
height: 28px;
width: 28px;
cursor: pointer;
position: relative;
outline: none;
border-radius: var(--border-radius-base);
margin: 0 var(--spacing-06) 0 0;
display: inline-block;
vertical-align: middle;
&:focus-visible {
box-shadow:
0 0 0 2px var(--white),
0 0 0 3px var(--blue-50),
0 0 0 5px var(--blue-30);
}
&.more-button {
border: 1px solid var(--neutral-70);
.color-picker-more {
color: var(--neutral-70);
margin: 3px; // it's centered, no matching spacing variable
font-weight: bold;
@include media-breakpoint-down(sm) {
margin: 5px; // it's centered, no matching spacing variable
}
}
.color-picker-more-open {
color: var(--neutral-70);
margin: 3px;
font-weight: bold;
@include media-breakpoint-down(sm) {
margin: 5px;
}
}
}
.color-picker-item-icon {
margin: 3px; // it's centered, no matching spacing variable
color: var(--white);
font-weight: bold;
}
@include media-breakpoint-down(sm) {
height: 32px;
width: 32px;
margin: var(--spacing-08);
.color-picker-item-icon {
margin: 5px; // it's centered, no matching spacing variable
color: var(--white);
}
}
}
.color-picker-more-wrapper {
position: relative;
display: inline-block;
.custom-picker {
position: absolute;
user-select: none;
z-index: 1;
@include media-breakpoint-down(sm) {
top: 56px;
left: 24px;
}
}
.popover-backdrop {
position: fixed;
inset: 0;
}
}