-$icon-font-path: '~@neos21/bootstrap3-glyphicons/assets/fonts/';
-@import '_bootstrap';
+@use '_variables' as *;
+@use '_mixins' as *;
-@import '_variables';
-@import '_mixins';
+@import './_bootstrap-variables';
-// Thanks https://gist.github.com/alexandrevicenzi/680147013e902a4eaa5d
-.glyphicon-refresh-animate {
- animation: spin .7s infinite linear;
+@import '~bootstrap/scss/functions';
+@import '~bootstrap/scss/variables';
+@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';
+
+.flex-auto {
+ flex: auto;
}
-@keyframes spin {
- from { transform: scale(1) rotate(0deg);}
- to { transform: scale(1) rotate(360deg);}
+.c-hand {
+ cursor: pointer !important;
}
+// ---------------------------------------------------------------------------
+// Dropdown
+// ---------------------------------------------------------------------------
+
.dropdown-menu {
- border-radius: 3px;
- box-shadow: 0 3px 6px;
- font-size: 15px;
+ color: pvar(--mainForegroundColor);
+ background-color: pvar(--mainBackgroundColor);
+
+ .dropdown-header {
+ @include padding-left(1rem);
+ }
.dropdown-item {
padding: 3px 15px;
- &:active {
- color: #000 !important;
+ &.active {
+ color: pvar(--mainBackgroundColor) !important;
+ background-color: pvar(--mainHoverColor);
+ opacity: 0.9;
}
- }
- button {
- @include disable-default-a-behaviour;
+ &::after {
+ display: none;
+ }
}
a {
@include disable-default-a-behaviour;
- color: #000 !important;
+ }
+}
+
+.dropdown-divider {
+ margin: 0.3rem 0;
+}
+
+// ---------------------------------------------------------------------------
+// Alert
+// ---------------------------------------------------------------------------
+
+.alert {
+ p:last-child {
+ margin-bottom: 0;
+ }
+}
+
+// ---------------------------------------------------------------------------
+// Modal
+// ---------------------------------------------------------------------------
+
+@media screen and (min-width: #{breakpoint(md)}) {
+ .modal::before {
+ vertical-align: middle;
+ content: ' ';
+ height: 100%;
+ }
+
+ .modal-dialog {
+ text-align: start;
+
+ &:not(.modal-lg):not(.modal-xl) {
+ min-width: 500px;
+ width: 40vw;
+ max-width: 900px;
+ }
}
}
.modal {
+ text-align: center;
+
.modal-content {
- background-color: var(--mainBackgroundColor);
+ background-color: pvar(--mainBackgroundColor);
+ word-break: break-word;
}
.modal-header {
- border-bottom: none;
+ border-bottom: 0;
margin-bottom: 5px;
.modal-title {
}
my-global-icon {
- @include icon(24px);
+ @include icon(22px);
- position: relative;
- top: 3px;
- float: right;
+ opacity: 0.5;
- margin: 0;
- padding: 0;
- opacity: 1;
+ &:hover {
+ opacity: 0.8;
+ }
}
}
.inputs {
margin-bottom: 0;
- text-align: right;
-
- .action-button-cancel {
- @include peertube-button;
- @include grey-button;
+ text-align: end;
- display: inline-block;
- margin-right: 10px;
+ > *:not(:first-child) {
+ @include margin-left(10px);
}
+ }
+}
+
- .action-button-submit {
- @include peertube-button;
- @include orange-button;
+// On desktop browsers, make the content and header horizontally sticked to right not move when modal open and close
+.modal-open {
+ overflow-y: scroll !important; // Make sure vertical scroll bar is always visible on desktop browsers to get disabled scrollbar effect
+ width: 100vw; // Make sure the content fits all the available width
+}
+
+// On touchscreen devices, simply overflow: hidden to avoid detached overlay on scroll
+@media (hover: none) and (pointer: coarse) {
+ .modal-open,
+ .menu-open {
+ overflow: hidden !important;
+ }
+
+ // On touchscreen devices display content overlay when opened menu
+ .menu-open {
+ .main-col {
+ &::before {
+ background-color: #000;
+ width: 100vw;
+ height: 100vh;
+ opacity: 0.75;
+ content: '';
+ display: block;
+ }
}
}
}
-// Nav customizations
+// ---------------------------------------------------------------------------
+// Nav
+// ---------------------------------------------------------------------------
+
.nav .nav-link {
display: flex !important;
align-items: center;
.nav.nav-pills {
font-size: 16px !important;
+ font-weight: $font-semibold !important;
- .nav-link.active {
- font-weight: $font-semibold !important;
+ .nav-link {
+ opacity: 0.7 !important;
+
+ &.active,
+ &:hover,
+ &:active,
+ &:focus {
+ opacity: 1 !important;
+ }
}
a {
@include disable-default-a-behaviour;
- color: var(--mainForegroundColor);
+ color: pvar(--mainForegroundColor);
}
}
-ngb-tabset.bootstrap {
+.nav-tabs .nav-link {
+ @include disable-default-a-behaviour;
- .nav-link {
- &, & a {
- @include disable-default-a-behaviour;
+ color: pvar(--mainForegroundColor);
+ font-weight: $font-semibold;
+ border: 0;
+ border-bottom: 2px solid transparent;
+ opacity: 0.7;
- color: var(--mainForegroundColor) !important;
- }
+ &.active {
+ color: pvar(--mainForegroundColor);
+ background-color: pvar(--mainBackgroundColor) !important;
+ border-bottom-color: pvar(--mainColor);
}
- .nav-pills .nav-link.active {
- color: #000 !important;
+ &.active,
+ &:hover,
+ &:active,
+ &:focus {
+ opacity: 1;
}
}
-.nav-tabs .nav-link.active {
- background-color: var(--mainBackgroundColor) !important;
- border-bottom: none;
-}
+// ---------------------------------------------------------------------------
+// Card, collapse and accordion
+// ---------------------------------------------------------------------------
.card {
- background-color: var(--mainBackgroundColor);
+ background-color: pvar(--mainBackgroundColor);
border-color: #dee2e6;
}
&.show {
max-height: 1500px;
+ overflow: inherit !important;
+ }
+}
+
+// ---------------------------------------------------------------------------
+// Buttons & form controls
+// ---------------------------------------------------------------------------
+
+.btn:not(.btn-sm) {
+ font-size: $button-font-size;
+ line-height: 1.2;
+}
+
+.btn-outline-secondary {
+ border-color: $input-border-color;
+
+ &:focus-within,
+ &:focus,
+ &:hover {
+ color: #fff;
+ background-color: #6c757d;
+ }
+}
+
+.btn-group.select-button {
+ font-weight: $font-semibold;
+
+ .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;
+ }
+ }
+}
+
+.form-control {
+ color: pvar(--mainForegroundColor);
+ background-color: pvar(--inputBackgroundColor);
+ outline: none;
+
+ // Input box-shadow on focus
+ &: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 {
+ > .btn,
+ > .input-group-text {
+ height: $button-height;
+ }
+
+ > .input-group-text {
+ line-height: normal;
+ opacity: 0.9;
+ }
+
+ .input-group-text > .dropdown-toggle {
+ display: flex;
+ }
+
+ .last-in-group {
+ border-top-right-radius: 3px !important;
+ border-bottom-right-radius: 3px !important;
+ }
+}
+
+.has-clear {
+ input {
+ @include padding-right(1.5rem !important);
+ }
+
+ .form-control-clear {
+ color: rgba(0, 0, 0, 0.4);
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ height: 95%;
+ font-size: 14px;
+ position: absolute;
+ right: .5rem;
+
+ &:hover {
+ color: rgba(0, 0, 0, 0.7);
+ cursor: pointer;
+ }
+ }
+
+ input:placeholder-shown + .form-control-clear {
+ display: none;
}
}