1 @use '_variables' as *;
5 /* stylelint-disable */
6 @import '~primeng/resources/primeng.css';
8 // Override primeng style we don't want
10 border-radius: inherit;
13 p-table .p-datatable-header .caption {
17 // Taken from old nova light theme
25 display: inline-block;
26 vertical-align: middle;
31 body .p-checkbox .p-checkbox-box {
32 border: 1px solid #a6a6a6;
33 background-color: #ffffff;
38 transition: background-color 0.2s, border-color 0.2s, box-shadow 0.2s;
40 body .p-checkbox .p-checkbox-box:not(.p-disabled):hover {
41 border-color: #212121;
43 body .p-checkbox .p-checkbox-box .p-checkbox-icon {
51 background-color: #f4f4f4;
52 border: 1px solid #c8c8c8;
55 body .p-paginator .p-paginator-first,
56 body .p-paginator .p-paginator-prev,
57 body .p-paginator .p-paginator-next,
58 body .p-paginator .p-paginator-last {
67 transition: box-shadow 0.2s;
70 body .p-paginator .p-paginator-first:not(.p-disabled):not(.p-highlight):hover,
71 body .p-paginator .p-paginator-prev:not(.p-disabled):not(.p-highlight):hover,
72 body .p-paginator .p-paginator-next:not(.p-disabled):not(.p-highlight):hover,
73 body .p-paginator .p-paginator-last:not(.p-disabled):not(.p-highlight):hover {
74 background-color: #e0e0e0;
77 body .p-paginator .p-paginator-first:focus,
78 body .p-paginator .p-paginator-prev:focus,
79 body .p-paginator .p-paginator-next:focus,
80 body .p-paginator .p-paginator-last:focus {
83 box-shadow: 0 0 0 0.2em pvar(--mainColorLightest);
85 body .p-paginator .p-paginator-current {
91 body .p-paginator .p-dropdown {
94 body .p-paginator .p-dropdown .p-dropdown-trigger, body .p-paginator .p-dropdown .p-dropdown-label {
97 body .p-paginator .p-dropdown:hover .p-dropdown-trigger, body .p-paginator .p-dropdown:hover .p-dropdown-label {
100 body .p-paginator .p-paginator-first:before {
104 body .p-paginator .p-paginator-prev:before {
108 body .p-paginator .p-paginator-next:before {
112 body .p-paginator .p-paginator-last:before {
116 body .p-paginator .p-paginator-pages {
118 display: inline-block;
121 body .p-paginator .p-paginator-pages .p-paginator-page {
126 line-height: 2.286em;
130 transition: box-shadow 0.2s;
133 body .p-paginator .p-paginator-pages .p-paginator-page:not(.p-highlight):hover {
134 background-color: #e0e0e0;
137 body .p-paginator .p-paginator-pages .p-paginator-page:focus {
140 box-shadow: 0 0 0 0.2em pvar(--mainColorLightest);
142 body .p-paginator .p-dropdown {
143 @include margin-left(0.5em);
153 border: 1px solid #a6a6a6;
154 transition: border-color 0.2s, box-shadow 0.2s;
156 body .p-dropdown:not(.p-disabled):hover {
157 border-color: #212121;
159 body .p-dropdown:not(.p-disabled).p-focus {
162 box-shadow: 0 0 0 0.2em pvar(--mainColorLightest);
163 border-color: pvar(--mainColor);
165 body .p-dropdown .p-dropdown-label {
166 @include padding-right(2em);
168 body .p-dropdown .p-dropdown-trigger {
169 background-color: #ffffff;
176 body .p-dropdown .p-dropdown-clear-icon {
179 body .p-dropdown.p-dropdown-clearable .p-dropdown-label {
180 @include padding-right(4em);
182 body .p-dropdown-panel {
184 border: 1px solid #c8c8c8;
185 background-color: #ffffff;
186 box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
188 body .p-dropdown-panel .p-dropdown-filter-container {
189 padding: 0.429em 0.857em 0.429em 0.857em;
190 border-bottom: 1px solid #eaeaea;
192 background-color: #ffffff;
195 body .p-dropdown-panel .p-dropdown-filter-container .p-dropdown-filter {
196 @include padding-right(2em);
200 body .p-dropdown-panel .p-dropdown-filter-container .p-dropdown-filter-icon {
204 color: pvar(--mainColor);
206 body .p-dropdown-panel .p-dropdown-items {
209 body .p-dropdown-panel .p-dropdown-items .p-dropdown-item, body .p-dropdown-panel .p-dropdown-items .p-dropdown-item-group {
211 padding: 0.429em 0.857em;
214 background-color: transparent;
215 -moz-border-radius: 0;
216 -webkit-border-radius: 0;
219 body .p-dropdown-panel .p-dropdown-items .p-dropdown-item.p-highlight,
220 body .p-dropdown-panel .p-dropdown-items .p-dropdown-item-group.p-highlight {
222 background-color: pvar(--mainColor);
224 body .p-dropdown-panel .p-dropdown-items .p-dropdown-item:not(.p-highlight):not(.p-disabled):hover,
225 body .p-dropdown-panel .p-dropdown-items .p-dropdown-item-group:not(.p-highlight):not(.p-disabled):hover {
227 background-color: #eaeaea;
229 body p-dropdown.ng-dirty.ng-invalid > .p-dropdown {
230 border: 1px solid #a80000;
234 body .p-toast .p-toast-message {
235 box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
243 background-color: #ffffff;
245 border: 1px solid #a6a6a6;
248 body .p-datepicker:not(.p-datepicker-inline) {
249 border: 1px solid #c8c8c8;
250 box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
252 body .p-datepicker:not(.p-disabled) .p-datepicker-header .p-datepicker-prev:focus,
253 body .p-datepicker:not(.p-disabled) .p-datepicker-header .p-datepicker-next:focus {
256 box-shadow: 0 0 0 0.2em pvar(--mainColorLightest);
258 body .p-datepicker:not(.p-disabled) table td a:not(.p-highlight):not(.p-highlight):hover {
259 background-color: #eaeaea;
261 body .p-datepicker:not(.p-disabled) .p-monthpicker a.p-monthpicker-month:not(.p-highlight):hover {
262 background-color: #eaeaea;
264 body .p-datepicker .p-datepicker-header {
265 padding: 0.429em 0.857em 0.429em 0.857em;
266 background-color: #ffffff;
268 -moz-border-radius: 0;
269 -webkit-border-radius: 0;
272 body .p-datepicker .p-datepicker-header .p-datepicker-prev,
273 body .p-datepicker .p-datepicker-header .p-datepicker-next {
277 transition: color 0.2s, box-shadow 0.2s;
279 body .p-datepicker .p-datepicker-header .p-datepicker-title {
284 body .p-datepicker .p-datepicker-header .p-datepicker-title select {
287 transition: color 0.2s, box-shadow 0.2s;
289 body .p-datepicker .p-datepicker-header .p-datepicker-title select:focus {
292 box-shadow: 0 0 0 0.2em pvar(--mainColorLightest);
294 body .p-datepicker table {
296 margin: 0.857em 0 0 0;
299 body .p-datepicker table th {
302 body .p-datepicker table th.p-datepicker-weekheader {
303 border-right: 1px solid #a6a6a6;
305 body .p-datepicker table td {
308 body .p-datepicker table td > a,
309 body .p-datepicker table td > span {
314 transition: box-shadow 0.2s;
317 body .p-datepicker table td > a.p-highlight,
318 body .p-datepicker table td > span.p-highlight {
320 background-color: pvar(--mainColor);
322 body .p-datepicker table td > a {
325 body .p-datepicker table td > a:focus {
328 box-shadow: 0 0 0 0.2em pvar(--mainColorLightest);
330 body .p-datepicker table td.p-datepicker-today > a,
331 body .p-datepicker table td.p-datepicker-today > span {
332 background-color: #d0d0d0;
335 body .p-datepicker table td.p-datepicker-today > a.p-highlight,
336 body .p-datepicker table td.p-datepicker-today > span.p-highlight {
338 background-color: pvar(--mainColor);
340 body .p-datepicker table td.p-datepicker-weeknumber {
341 border-right: 1px solid #a6a6a6;
343 body .p-datepicker .p-datepicker-buttonbar {
344 border-top: 1px solid #d8dae2;
346 body .p-datepicker .p-timepicker {
348 border-top: 1px solid #d8dae2;
351 body .p-datepicker .p-timepicker a {
355 body .p-datepicker .p-timepicker a:hover {
356 color: pvar(--mainColor);
358 body .p-datepicker .p-timepicker span {
361 body .p-datepicker .p-monthpicker .p-monthpicker-month {
364 body .p-datepicker .p-monthpicker .p-monthpicker-month.p-highlight {
366 background-color: pvar(--mainColor);
368 body .p-datepicker.p-datepicker-timeonly {
371 body .p-datepicker.p-datepicker-timeonly .p-timepicker {
374 body .p-datepicker.p-datepicker-multiple-month .p-datepicker-group {
375 @include padding-right(0.857em);
376 @include padding-left(0.857em);
378 border-right: 1px solid #d8dae2;
382 body .p-datepicker.p-datepicker-multiple-month .p-datepicker-group:first-child {
383 @include padding-left(0);
385 body .p-datepicker.p-datepicker-multiple-month .p-datepicker-group:last-child {
386 @include padding-right(0);
387 border-right: 0 none;
389 body .p-calendar.p-calendar-w-btn .p-inputtext {
390 border-top-right-radius: 0;
391 border-bottom-right-radius: 0;
392 border-right: 0 none;
394 body .p-calendar.p-calendar-w-btn .p-inputtext:enabled:hover:not(.p-error),
395 body .p-calendar.p-calendar-w-btn .p-inputtext:enabled:focus:not(.p-error) {
396 border-right: 0 none;
398 body .p-calendar.p-calendar-w-btn .p-datepicker-trigger.p-button {
400 border-top-left-radius: 0;
401 border-bottom-left-radius: 0;
403 body .ui-fluid .p-calendar.p-calendar-w-btn input.p-inputtext {
404 width: calc(100% - 2.357em);
406 body p-calendar.ng-dirty.ng-invalid > .p-calendar > .p-inputtext {
407 border: 1px solid #a80000;
409 body .p-timepicker .p-separator {
410 @include margin-left(0);
415 body .p-autocomplete .p-autocomplete-input {
418 body .p-autocomplete-panel {
420 border: 1px solid #c8c8c8;
421 background-color: #ffffff;
422 box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
424 body .p-autocomplete-panel .p-autocomplete-items {
427 body .p-autocomplete-panel .p-autocomplete-items .p-autocomplete-item {
429 padding: 0.429em 0.857em;
432 background-color: transparent;
435 body .p-autocomplete-panel .p-autocomplete-items .p-autocomplete-item.p-highlight,
436 body .p-autocomplete-panel .p-autocomplete-items .p-autocomplete-item:hover {
438 background-color: pvar(--mainColor);
440 body .p-autocomplete-panel .p-autocomplete-items .p-autocomplete-group {
441 padding: 0.429em 0.857em;
442 background-color: #d8dae2;
445 body p-autocomplete.ng-dirty.ng-invalid > .p-autocomplete > .p-inputtext {
446 border: 1px solid #a80000;
449 // ---------------------------------------------------------------------------
450 // PeerTube customizations
451 // ---------------------------------------------------------------------------
454 .p-datatable-header {
455 border: none !important;
456 background-color: pvar(--mainBackgroundColor) !important;
461 display: inline-flex;
465 @include padding-left(15px);
471 background-color: pvar(--mainBackgroundColor) !important;
474 text-overflow: ellipsis;
479 font-family: $main-fonts;
481 color: pvar(--mainForegroundColor) !important;
485 @include padding-left(15px !important);
491 &:not(.action-cell):not(.expand-cell):not(.checkbox-cell) {
492 overflow: hidden !important;
493 text-overflow: ellipsis !important;
494 white-space: nowrap !important;
500 background-color: pvar(--mainBackgroundColor) !important;
504 background-color: pvar(--submenuBackgroundColor) !important;
507 color: pvar(--mainForegroundColor) !important;
515 background-color: pvar(--submenuBackgroundColor) !important;
519 border: none !important;
520 white-space: normal !important;
524 border-top: none !important;
528 border-bottom: none !important;
533 box-shadow: none !important;
545 border: none !important;
546 border-bottom: 1px solid !important;
547 border-color: pvar(--submenuBackgroundColor) !important;
548 text-align: left !important;
549 padding: 5px 0 5px 15px !important;
550 font-weight: $font-semibold !important;
551 color: pvar(--mainForegroundColor) !important;
553 &.p-sortable-column:hover {
554 background-color: pvar(--submenuBackgroundColor) !important;
555 border: 1px solid !important;
556 border-color: pvar(--submenuBackgroundColor) !important;
557 border-width: 0 1px !important;
560 border-width: 0 1px 0 0 !important;
565 background-color: pvar(--submenuBackgroundColor) !important;
567 .pi-sort-amount-up-alt,
568 .pi-sort-amount-down {
569 display: inline-block;
572 color: pvar(--mainForegroundColor) !important;
575 .pi-sort-amount-up-alt {
576 @include arrow-up(5px);
579 .pi-sort-amount-down {
580 @include arrow-down(5px);
586 width: 250px !important;
592 display: inline-block !important;
593 @include margin-left(5px);
596 @include margin-left(0)
602 .p-paginator-bottom {
603 background-color: pvar(--mainBackgroundColor) !important;
606 border-top: 1px solid !important;
607 border-color: pvar(--submenuBackgroundColor) !important;
610 justify-content: center;
619 box-shadow: #{$focus-box-shadow-form} pvar(--mainColorLightest);
623 color: pvar(--inputPlaceholderColor);
628 .p-dropdown-trigger {
629 color: pvar(--mainForegroundColor);
630 background-color: pvar(--mainBackgroundColor);
633 .p-paginator-current {
636 color: pvar(--inputPlaceholderColor);
639 @media screen and (max-width: $small-view) {
652 color: pvar(--mainForegroundColor);
656 box-shadow: #{$focus-box-shadow-form} pvar(--mainColorLightest);
660 background-color: #fff !important;
663 &.p-paginator-first {
667 background: url('../assets/images/feather/skip-back.svg') no-repeat;
668 background-size: contain;
673 @include margin-right(10px);
676 @include chevron-left-default;
681 @include margin-left(10px);
684 @include chevron-right-default;
692 background: url('../assets/images/feather/skip-forward.svg') no-repeat;
693 background-size: contain;
699 height: auto !important;
704 box-shadow: #{$focus-box-shadow-form} pvar(--mainColorLightest) !important;
707 color: pvar(--mainForegroundColor) !important;
708 font-weight: $font-semibold !important;
709 margin: 0 5px !important;
710 outline: 0 !important;
711 border-radius: 3px !important;
712 padding: 5px 2px !important;
713 height: auto !important;
714 line-height: initial !important;
717 &, &:hover, &:active, &:focus {
718 color: #fff !important;
719 background-color: pvar(--mainColor) !important;
729 text-transform: uppercase;
733 // overflow data table
735 .p-datatable-wrapper {
744 @media screen and (max-width: #{breakpoint(lg)}) {
747 .p-paginator-current,
755 @media screen and (max-width: $mobile-view) {
758 .p-paginator-pages > .p-paginator-page:not(.p-highlight) {
765 // PrimeNG calendar tweaks
766 p-calendar .p-datepicker {
768 @include disable-default-a-behaviour;
771 .p-datepicker-header {
774 @include margin-left(5px);
778 @include chevron-right-default;
780 color: #000 !important;
783 .pi.pi-chevron-right {
784 display: none !important;
789 @include chevron-left-default;
791 color: #000 !important;
794 .pi.pi-chevron-left {
795 display: none !important;
803 @include chevron-up-default;
805 color: #000 !important;
808 .pi.pi-chevron-down {
809 @include chevron-down-default;
811 color: #000 !important;
816 p-tablecheckbox:hover div .p-checkbox-box {
817 box-shadow: 0 0 0 .1rem rgba(87, 85, 217, .2);
823 width: 18px !important;
824 height: 18px !important;
829 border-color: pvar(--mainColor) !important;
830 background-color: pvar(--mainColor) !important;
835 overflow: visible !important;
845 transform: rotate(45deg) scale(0);
846 border-right: 2px solid pvar(--mainBackgroundColor);
847 border-bottom: 2px solid pvar(--mainBackgroundColor);
852 transform: rotate(45deg) scale(1);
864 .p-toast-icon-close {
871 background: url('../assets/images/feather/x.svg') no-repeat;
872 background-size: contain;
875 &:hover .p-toast-icon-close {
881 font-family: $main-fonts;
882 background-color: pvar(--mainBackgroundColor) !important;
883 color: pvar(--mainForegroundColor) !important;
885 box-sizing: border-box;
886 border: 1px solid #EBEEF5 !important;
887 box-shadow: 0 2px 12px 0 rgba(0, 0 , 0, .1);
890 .notification-block {
897 @include margin-right(20px);
906 @include peertube-word-wrap;
914 .p-toast-message-success my-global-icon {
915 color: #8BC34A !important;
918 .p-toast-message-error my-global-icon {
919 color: #F44336 !important;
922 .p-toast-message-warn my-global-icon {
923 color: #F1680D !important;
926 .p-toast-message-info my-global-icon {
927 color: #03A9F4 !important;
931 @media screen and (max-width: $primeng-breakpoint) {
944 padding-bottom: 15px;
946 border-bottom: 1px solid $separator-border-color !important;
952 @media screen and (max-width: $mobile-view) {
954 .p-datatable-header {
960 padding: 0 !important;