-$icon-font-path: '~@neos21/bootstrap3-glyphicons/assets/fonts/';
-@import '_bootstrap';
+@use '_variables' as *;
+@use '_mixins' as *;
+
+@import './_bootstrap-variables';
+
+@import 'bootstrap/scss/functions';
+@import 'bootstrap/scss/variables';
+@import 'bootstrap/scss/maps';
+@import 'bootstrap/scss/mixins';
+@import 'bootstrap/scss/utilities';
+
+@import 'bootstrap/scss/root';
+@import 'bootstrap/scss/reboot';
+@import 'bootstrap/scss/type';
+@import 'bootstrap/scss/grid';
+@import 'bootstrap/scss/forms';
+@import 'bootstrap/scss/buttons';
+@import 'bootstrap/scss/dropdown';
+@import 'bootstrap/scss/button-group';
+@import 'bootstrap/scss/nav';
+@import 'bootstrap/scss/card';
+@import 'bootstrap/scss/accordion';
+@import 'bootstrap/scss/alert';
+@import 'bootstrap/scss/close';
+@import 'bootstrap/scss/modal';
+@import 'bootstrap/scss/tooltip';
+@import 'bootstrap/scss/popover';
+@import 'bootstrap/scss/spinners';
+
+@import 'bootstrap/scss/helpers';
+@import 'bootstrap/scss/utilities/api';
+
+:root {
+ --bs-border-color-translucent: #{pvar(--inputBorderColor)};
+}
-@import '_variables';
-@import '_mixins';
+.accordion {
+ --bs-accordion-color: #{pvar(--mainForegroundColor)};
+ --bs-accordion-bg: #{pvar(--mainBackgroundColor)};
-// Thanks https://gist.github.com/alexandrevicenzi/680147013e902a4eaa5d
-.glyphicon-refresh-animate {
- animation: spin .7s infinite linear;
+ --bs-accordion-btn-color: var(--bs-accordion-color);
+ --bs-accordion-btn-bg: var(--bs-accordion-bg);
}
-.glyphicon-duplicate {
- font-size: 70%;
+.popover {
+ --bs-popover-bg: #{pvar(--mainBackgroundColor)};
+ --bs-popover-body-color: #{pvar(--mainForegroundColor)};
+ --bs-popover-header-color: #{pvar(--mainForegroundColor)};
+
+ font-family: $main-fonts;
}
.flex-auto {
}
.c-hand {
- cursor: pointer;
-}
-
-@keyframes spin {
- from {
- transform: scale(1) rotate(0deg);
- }
- to {
- transform: scale(1) rotate(360deg);
- }
+ cursor: pointer !important;
}
-/* rules for dropdowns excepts when in button group, to avoid impacting the dropdown-toggle */
-.dropdown {
- z-index: z(dropdown) !important;
-}
-
-.list-overflow-menu,
-.parent-entry {
- z-index: z(header) - 1 !important;
-}
-
-.btn-group,
-.dropdown-root,
-.action-dropdown,
-.input-group-prepend,
-.column-toggle {
- z-index: inherit !important;
-}
-
-.btn-group > .btn:not(:first-child) {
- border-top-left-radius: 0 !important;
- border-bottom-left-radius: 0 !important;
-}
+// ---------------------------------------------------------------------------
+// Dropdown
+// ---------------------------------------------------------------------------
.dropdown-menu {
- z-index: z(dropdown) + 1 !important;
-
- border-radius: 3px;
- box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12), 0 3px 1px -2px rgba(0, 0, 0, 0.2);
- font-size: 15px;
+ --bs-dropdown-link-hover-bg: #{pvar(--mainBackgroundHoverColor)};
+ --bs-dropdown-link-color: #{pvar(--mainForegroundColor)};
+ --bs-dropdown-border-color: #{pvar(--inputBorderColor)};
.dropdown-header {
- padding-left: 1rem;
+ @include padding-left(1rem);
}
.dropdown-item {
&.active {
color: pvar(--mainBackgroundColor) !important;
background-color: pvar(--mainHoverColor);
- opacity: .9;
- }
-
- &:active {
- color: pvar(--mainForegroundColor) !important;
+ opacity: 0.9;
}
&::after {
}
}
- button {
- @include disable-default-a-behaviour;
- }
-
a {
@include disable-default-a-behaviour;
- color: #000 !important;
}
}
-.badge {
- line-height: 1.1;
+.dropdown-divider {
+ margin: 0.3rem 0;
+}
+
+// ---------------------------------------------------------------------------
+// Alert
+// ---------------------------------------------------------------------------
+
+.alert {
+ p:last-child {
+ margin-bottom: 0;
+ }
}
+// ---------------------------------------------------------------------------
+// Modal
+// ---------------------------------------------------------------------------
+
@media screen and (min-width: #{breakpoint(md)}) {
- .modal:before {
+ .modal::before {
vertical-align: middle;
- content: " ";
+ content: ' ';
height: 100%;
}
.modal-dialog {
- text-align: left;
+ text-align: start;
&:not(.modal-lg):not(.modal-xl) {
min-width: 500px;
.modal-content {
background-color: pvar(--mainBackgroundColor);
- word-break: break-all;
+ word-break: break-word;
}
.modal-header {
- border-bottom: none;
+ border-bottom: 0;
margin-bottom: 5px;
.modal-title {
my-global-icon {
@include icon(22px);
- position: relative;
- top: 5px;
- float: right;
+ opacity: 0.5;
- margin: 0;
- padding: 0;
- opacity: .5;
-
- &[iconName="cross"] {
- @include icon(16px);
- top: -3px;
+ &:hover {
+ opacity: 0.8;
}
}
}
.inputs {
margin-bottom: 0;
- text-align: right;
+ text-align: end;
- > .peertube-button:not(:first-child) {
- margin-left: 10px
+ > *:not(:first-child) {
+ @include margin-left(10px);
}
}
}
// On touchscreen devices, simply overflow: hidden to avoid detached overlay on scroll
@media (hover: none) and (pointer: coarse) {
- .modal-open, .menu-open {
+ .modal-open,
+ .menu-open {
overflow: hidden !important;
}
.menu-open {
.main-col {
&::before {
- background-color: black;
+ background-color: #000;
width: 100vw;
height: 100vh;
opacity: 0.75;
content: '';
display: block;
position: fixed;
- z-index: z('menu') - 1;
+ z-index: z(overlay);
}
}
}
}
-// Nav customizations
+// ---------------------------------------------------------------------------
+// Nav
+// ---------------------------------------------------------------------------
+
.nav .nav-link {
display: flex !important;
align-items: center;
font-weight: $font-semibold !important;
.nav-link {
- opacity: 0.6 !important;
+ opacity: 0.7 !important;
- &.active, &:hover, &:active, &:focus {
+ &.active,
+ &:hover,
+ &:active,
+ &:focus {
opacity: 1 !important;
}
}
color: pvar(--mainForegroundColor);
font-weight: $font-semibold;
- border: none;
+ border: 0;
border-bottom: 2px solid transparent;
- opacity: 0.6;
+ opacity: 0.7;
&.active {
color: pvar(--mainForegroundColor);
border-bottom-color: pvar(--mainColor);
}
- &.active, &:hover, &:active, &:focus {
+ &.active,
+ &:hover,
+ &:active,
+ &:focus {
opacity: 1;
}
}
+// ---------------------------------------------------------------------------
+// Card, collapse and accordion
+// ---------------------------------------------------------------------------
+
.card {
background-color: pvar(--mainBackgroundColor);
border-color: #dee2e6;
&.show {
max-height: 1500px;
+ overflow: inherit !important;
}
}
-.dropdown-divider {
- margin: 0.3rem 0;
-}
+.accordion-button {
+ font-size: 18px;
-ngb-modal-backdrop {
- z-index: z(modal) - 1 !important;
-}
+ &:not(.collapsed) {
+ font-weight: $font-bold;
-ngb-modal-window {
- z-index: z(modal) !important;
+ my-global-icon {
+ color: pvar(--mainColorLighter);
+ }
+ }
}
-ngb-popover-window {
- z-index: z(popover) !important;
-}
+// ---------------------------------------------------------------------------
+// Buttons & form controls
+// ---------------------------------------------------------------------------
-ngb-tooltip-window {
- z-index: z(tooltip) !important;
+.btn:not(.btn-sm) {
+ font-size: $button-font-size;
+ line-height: 1.2;
}
.btn-outline-secondary {
- border-color: $input-border-color;
+ border-color: pvar(--inputBorderColor);
&:focus-within,
&:focus,
}
}
-.btn-outline-tertiary {
- color: pvar(--secondaryColor);
- border-color: pvar(--secondaryColor);
+.btn-group.select-button {
+ font-weight: $font-semibold;
- &:focus-within,
- &:focus,
- &:hover {
- color: pvar(--mainBackgroundColor);
- background-color: pvar(--secondaryColor);
+ .active {
+ @include orange-button;
+ }
+
+ :not(.active) {
+ @include grey-button;
+ }
+
+ > * {
+ @include peertube-button-link;
+
+ box-shadow: none !important;
+
+ &:not(:first-child) {
+ border-top-left-radius: 0 !important;
+ border-bottom-left-radius: 0 !important;
+ }
+
+ &:not(:last-child) {
+ border-top-right-radius: 0 !important;
+ border-bottom-right-radius: 0 !important;
+ }
}
}
-// input box-shadow on focus
.form-control {
- font-size: 15px;
color: pvar(--mainForegroundColor);
background-color: pvar(--inputBackgroundColor);
outline: none;
-
- &:focus-within,
- &:focus {
- box-shadow: #{$focus-box-shadow-form} pvar(--mainColorLightest);
-
- &.input-error {
- box-shadow: #{$focus-box-shadow-form} #{scale-color($red, $alpha: -75%)};
- }
- }
}
.input-group {
- & > .form-control {
- flex: initial;
+ > .btn,
+ > .input-group-text {
+ padding-top: 4px;
+ padding-bottom: 4px;
}
- input.form-control {
- width: unset !important;
- flex-grow: 1;
+
+ > .input-group-text {
+ line-height: normal;
+ opacity: 0.9;
+ background-color: pvar(--greyBackgroundColor);
}
- .input-group-prepend + input {
- border-top-left-radius: 0 !important;
- border-bottom-left-radius: 0 !important;
+ .input-group-text > .dropdown-toggle {
+ display: flex;
}
}
-.has-feedback.has-clear {
- position: relative;
+.input-group,
+.btn-group {
+ .last-in-group {
+ border-top-right-radius: 3px !important;
+ border-bottom-right-radius: 3px !important;
+ }
+}
+.has-clear {
input {
- padding-right: 1.5rem !important;
+ @include padding-right(1.5rem !important);
}
.form-control-clear {
- color: rgba(0, 0, 0, 0.4);
- /*
- * Enable pointer events as they have been disabled since Bootstrap 3.3
- * See https://github.com/twbs/bootstrap/pull/14104
- */
- pointer-events: all;
display: flex;
justify-content: center;
align-items: center;
- position: absolute;
- right: .5rem;
height: 95%;
font-size: 14px;
+ position: absolute;
+ right: .5rem;
+ opacity: 0.4;
&:hover {
- color: rgba(0, 0, 0, 0.7);
+ opacity: 0.7;
cursor: pointer;
}
}
display: none;
}
}
-
-.callout {
- padding: 1.25rem;
- border: 1px solid #eee;
- border-radius: .25rem;
-
- & > label {
- position: relative;
- top: -5px;
- left: -10px;
- color: #6c757d !important;
- }
-
- &:not(.callout-light) {
- border-left-width: .25rem;
- }
-
- &.callout-info {
- border-color: pvar(--mainColorLightest);
- border-left-color: pvar(--mainColor);
- }
-}