Merge pull request #7347 from thornbill/base-theme-light

This commit is contained in:
Bill Thornton
2025-12-01 15:54:57 -05:00
committed by GitHub
6 changed files with 127 additions and 519 deletions

View File

@@ -76,7 +76,7 @@ progress[aria-valuenow]::before {
}
a[data-role=button] {
background: #292929 !important;
background: #292929;
background-clip: padding-box;
-webkit-font-smoothing: antialiased;
user-select: none;

View File

@@ -1,26 +1,27 @@
@use '../styles/mixins' as *;
@use './palette' as palette;
// Theme options
$dark: true !default;
// Color palette
$common-white: #fff !default;
$background-default: #101010 !default;
$background-paper: #202020 !default;
$primary-main: #00a4dc !default;
$primary-dark: #00729a !default;
$primary-light: #33b6e3 !default;
$primary-hover: rgba(0, 164, 220, 0.2) !default;
$primary-contrastText: rgba(0, 0, 0, 0.87) !default;
$error-main: #c62828 !default;
$error-dark: #8a1c1c !default;
$error-light: #d15353 !default;
$error-contrastText: #fff !default;
$text-primary: #fff !default;
$text-secondary: rgba(255, 255, 255, 0.7) !default;
$action-focus: rgba(255, 255, 255, 0.12) !default;
$action-hover: rgba(255, 255, 255, 0.08) !default;
$divider: rgba(255, 255, 255, 0.12) !default;
$common-white: palette.$common-white !default;
$background-default: palette.$background-default !default;
$background-paper: palette.$background-paper !default;
$primary-main: palette.$primary-main !default;
$primary-dark: palette.$primary-dark !default;
$primary-light: palette.$primary-light !default;
$primary-hover: palette.$primary-hover !default;
$primary-contrastText: palette.$primary-contrastText !default;
$error-main: palette.$error-main !default;
$error-dark: palette.$error-dark !default;
$error-light: palette.$error-light !default;
$error-contrastText: palette.$error-contrastText !default;
$text-primary: palette.$text-primary !default;
$text-secondary: palette.$text-secondary !default;
$action-focus: palette.$action-focus !default;
$action-hover: palette.$action-hover !default;
$divider: palette.$divider !default;
// Components
$appBar-defaultBg: #202020 !default;
@@ -34,6 +35,11 @@ $button-inheritContainedHoverBg: #616161 !default;
$snackbarContent-bg: #303030 !default;
$snackbarContent-color: rgba(255, 255, 255, 0.87) !default;
// Assign custom css variables not part of the MUI theme palette
:root {
--jf-palette-AppBar-transparentBg: #{$appBar-transparentBg};
}
* {
scrollbar-width: thin;
scrollbar-color: #3b3b3b #202020;
@@ -105,6 +111,7 @@ html {
@include var(color, --jf-palette-primary-main, $primary-main);
}
a[data-role=button],
.fab,
.raised {
@include var(background, --jf-palette-Button-inheritContainedBg, $button-inheritContainedBg);
@@ -120,8 +127,9 @@ html {
@include var(background, --jf-palette-primary-main, $primary-main);
@include var(color, --jf-palette-primary-contrastText, $primary-contrastText);
&:focus {
@include var(background, --jf-palette-primary-light, $primary-light);
&:focus,
&:hover {
@include var(background, --jf-palette-primary-dark, $primary-dark);
}
}
@@ -253,7 +261,7 @@ html {
}
.mediaInfoText {
@include var(border-color, --jf-palette-text-secondary, $text-secondary);
border-color: inherit;
border-style: solid;
border-width: 1px;
}
@@ -273,11 +281,14 @@ html {
}
.emby-select-withcolor {
@include var(background, --jf-palette-FilledInput-bg, $filledInput-bg);
// NOTE: This should use `FilledInput-bg` to match other form elements,
// but that will break the native dropdown styling
@include var(background, --jf-palette-background-paper, $background-paper);
@include var(border-color, --jf-palette-FilledInput-bg, $filledInput-bg);
color: inherit;
border-width: 0.07em;
border-width: 0.16em;
border-style: solid;
border-radius: 0.2em;
}
.emby-select-withcolor > option {
@@ -361,6 +372,26 @@ html {
border-color: rgba(255, 255, 255, 0.05);
}
.programCell-sports {
background: #3949ab !important;
}
.programCell-movie {
background: #5e35b1 !important;
}
.programCell-kids {
background: #039be5 !important;
}
.programCell-news {
background: #43a047 !important;
}
.programCell-active {
background: #1e1e1e !important;
}
.guide-channelHeaderCell:focus,
.programCell:focus {
@include var(background-color, --jf-palette-primary-main, $primary-main, true);

17
src/themes/_palette.scss Normal file
View File

@@ -0,0 +1,17 @@
$common-white: #fff;
$background-default: #101010;
$background-paper: #202020;
$primary-main: #00a4dc;
$primary-dark: #00729a;
$primary-light: #33b6e3;
$primary-hover: rgba(0, 164, 220, 0.2);
$primary-contrastText: rgba(0, 0, 0, 0.87);
$error-main: #c62828;
$error-dark: #8a1c1c;
$error-light: #d15353;
$error-contrastText: #fff;
$text-primary: #fff;
$text-secondary: rgba(255, 255, 255, 0.7);
$action-focus: rgba(255, 255, 255, 0.12);
$action-hover: rgba(255, 255, 255, 0.08);
$divider: rgba(255, 255, 255, 0.12);

View File

@@ -31,30 +31,3 @@
background: none;
}
}
/* Live TV guide */
.channelPrograms,
.guide-channelHeaderCell,
.programCell {
border-color: rgba(255, 255, 255, 0.05);
}
.programCell-sports {
background: #3949ab !important;
}
.programCell-movie {
background: #5e35b1 !important;
}
.programCell-kids {
background: #039be5 !important;
}
.programCell-news {
background: #43a047 !important;
}
.programCell-active {
background: #1e1e1e !important;
}

View File

@@ -1,148 +1,36 @@
* {
scrollbar-width: thin;
}
.skinHeader,
html {
color: #222;
color: rgba(0, 0, 0, 0.87);
}
.wizardStartForm,
.ui-corner-all,
.ui-shadow {
background-color: #303030;
}
.emby-collapsible-button {
border-color: #ccc;
border-color: rgba(0, 0, 0, 0.158);
}
.collapseContent {
background-color: #eaeaea;
}
.skinHeader-withBackground {
background-color: #303030;
color: #ccc;
color: rgba(255, 255, 255, 0.87);
}
.osdHeader {
box-shadow: none !important;
}
.skinHeader.semiTransparent {
backdrop-filter: none !important;
background-color: rgba(0, 0, 0, 0.4);
}
.layout-tv .skinHeader.semiTransparent {
background: none;
color: inherit;
}
.pageTitleWithDefaultLogo {
background-image: url(@jellyfin/ux-web/banner-light.png);
}
.layout-tv .pageTitleWithDefaultLogo {
background-image: url(@jellyfin/ux-web/icon-transparent.png);
}
.backgroundContainer,
html {
background-color: #f2f2f2;
}
.backgroundContainer.withBackdrop {
background-color: rgba(255, 255, 255, 0.8);
}
.dialog,
.nowPlayingPlaylist,
.nowPlayingContextMenu {
background-color: #f0f0f0;
}
.emby-scrollbuttons .paper-icon-button-light {
color: #000;
}
@media (hover: hover) and (pointer: fine) {
.paper-icon-button-light:hover:not(:disabled) {
color: #00a4dc;
background-color: rgba(0, 164, 220, 0.2);
}
}
.paper-icon-button-light:active:not(:disabled) {
color: #00a4dc;
background-color: rgba(0, 164, 220, 0.2);
}
.paper-icon-button-light.show-focus:focus {
color: #00a4dc;
}
.fab,
.raised {
background: #d8d8d8;
color: inherit;
}
.fab:focus,
.raised:focus {
background: #ccc;
}
a[data-role=button] {
background: #d8d8d8 !important;
}
.button-submit {
background: #00a4dc;
color: #fff;
}
.button-submit:focus {
background: #0cb0e8;
}
.button-delete {
background: rgb(247, 0, 0);
color: rgba(255, 255, 255, 0.87);
}
.checkboxLabel {
color: inherit;
}
.checkboxListLabel,
.inputLabel,
.inputLabelUnfocused,
.paperListLabel,
.textareaLabelUnfocused {
color: #555;
}
.button-link,
.inputLabelFocused,
.selectLabelFocused,
.textareaLabelFocused {
color: #00a4dc;
}
.checkboxOutline {
border-color: currentColor;
}
.paperList,
.visualCardBox {
background-color: #fff;
@use '../../styles/mixins' as *;
@use '../palette' as palette;
/* Import the base theme with overrides */
@use '../base' with (
// Theme options
$dark: false,
// Color palette
$background-default: #f2f2f2,
$background-paper: #e8e8e8,
$text-primary: #000,
$text-secondary: rgba(0, 0, 0, 0.87),
$action-focus: #bbb,
$action-hover: #ddd,
$divider: rgba(0, 0, 0, 0.14),
// Components
$appBar-defaultBg: #e8e8e8,
$appBar-transparentBg: rgba(232, 232, 232, 0.86),
$alert-infoFilledBg: #fff3a5,
$alert-infoFilledColor: #000,
$button-inheritContainedBg: #d8d8d8,
$button-inheritContainedHoverBg: #ccc
);
// Override the alpha picker selected colors
.alphaPickerButton-selected {
@include var(background-color, --jf-palette-primary-main, palette.$primary-main);
@include var(color, --jf-palette-primary-contrastText, palette.$primary-contrastText);
}
/* Card background color variants */
.defaultCardBackground1 {
background-color: #009688;
}
@@ -163,339 +51,25 @@ a[data-role=button] {
background-color: #f57f17;
}
.formDialogHeader:not(.formDialogHeader-clear) {
background-color: #00a4dc;
color: #fff;
}
.formDialogFooter:not(.formDialogFooter-clear) {
background-color: #f0f0f0;
border-top: 1px solid #ddd;
border-top: 1px solid rgba(0, 0, 0, 0.08);
color: inherit;
}
.layout-tv .formDialogFooter:not(.formDialogFooter-clear) {
background-color: transparent;
border: none;
}
.cardText-secondary,
.fieldDescription,
.guide-programNameCaret,
.listItem .secondary,
.nowPlayingBarSecondaryText,
.programSecondaryTitle,
.secondaryText {
color: #888;
}
.actionsheetDivider {
background: #ddd;
background: rgba(0, 0, 0, 0.14);
}
.cardFooter-vibrant .cardText-secondary {
color: inherit;
opacity: 0.5;
}
.formDialogHeader a,
.toast {
color: #fff;
}
.toast {
background: #303030;
color: rgba(255, 255, 255, 0.87);
}
.appfooter,
.playlistSectionButton {
background: #282828;
color: #ccc;
color: rgba(255, 255, 255, 0.78);
}
.nowPlayingBarSecondaryText {
color: #999;
}
.itemSelectionPanel {
border: 1px solid #00a4dc;
}
.selectionCommandsPanel {
background: #00a4dc;
color: #fff;
}
.upNextDialog-countdownText {
color: #00a4dc;
}
.alphaPickerButton {
color: #555;
color: rgba(0, 0, 0, 0.7);
background-color: transparent;
}
.alphaPickerButton-selected,
.alphaPickerButton-tv:focus {
background-color: #00a4dc;
color: #fff !important;
}
/* Detail ribbon on item details pages */
.detailRibbon {
background-color: #303030;
color: #ccc;
color: rgba(255, 255, 255, 0.87);
.layout-tv & {
background: none;
color: inherit;
}
}
.layout-tv .detailRibbon {
background: none;
color: inherit;
}
.noBackdropTransparency .detailPagePrimaryContainer,
.noBackdropTransparency .detailPageSecondaryContainer {
background-color: #f2f2f2;
}
.detailTableBodyRow-shaded:nth-child(even) {
background: #f8f8f8;
}
.listItem-border {
border-color: #a7a7a7 !important;
}
.listItem:focus {
background: #bbb;
}
.listItem:hover {
background: #ddd;
}
.progressring-spiner {
border-color: #00a4dc;
}
.mediaInfoText {
color: #333;
background: #fff;
}
.emby-input,
.emby-textarea {
color: inherit;
background: #fff;
border: 0.16em solid rgba(0, 0, 0, 0.158);
border-radius: 0.2em;
}
.emby-input:focus,
.emby-textarea:focus {
border-color: #00a4dc;
}
.emby-select-withcolor {
color: inherit;
background: #fff;
border: 0.07em solid rgba(0, 0, 0, 0.158);
}
.emby-checkbox:checked + span + .checkboxOutline,
.emby-select-withcolor:focus {
border-color: #00a4dc;
}
.emby-checkbox:focus + span + .checkboxOutline {
border-color: #000;
}
.emby-checkbox:checked + span + .checkboxOutline,
.itemProgressBarForeground {
background-color: #00a4dc;
}
.emby-checkbox:focus:not(:checked) + span + .checkboxOutline {
border-color: #00a4dc;
}
.emby-select-withcolor > option {
color: #000;
background: #fff;
}
.emby-select-tv-withcolor:focus {
background-color: #00a4dc;
color: #fff;
}
.itemProgressBarForeground-recording {
background-color: #cb272a;
}
.countIndicator,
.fullSyncIndicator,
.mediaSourceIndicator,
.playedIndicator {
background: #00a4dc;
}
.fullSyncIndicator {
color: #fff;
}
.mainDrawer {
background: #fff;
}
.navMenuOption:hover {
background: #f2f2f2;
}
.navMenuOption-selected {
background: #00a4dc !important;
color: #fff;
}
.emby-button.show-focus:focus {
background: #00a4dc;
color: #fff;
}
.emby-tab-button {
color: #999;
}
.emby-tab-button-active {
color: #00a4dc;
}
.emby-tab-button.show-focus:focus {
color: #00a4dc;
}
.emby-tab-button:hover {
color: #00a4dc;
}
/* Live TV guide */
.channelPrograms,
.guide-channelHeaderCell,
.programCell {
border-color: rgba(0, 0, 0, 0.12);
}
.programCell-sports {
background: #3949ab !important;
}
.programCell-movie {
background: #5e35b1 !important;
}
.programCell-kids {
background: #039be5 !important;
}
.programCell-news {
background: #43a047 !important;
}
.programCell-active {
background: rgba(0, 0, 0, 0.1) !important;
}
.guide-channelHeaderCell:focus,
.programCell:focus {
background-color: #00a4dc !important;
color: #fff !important;
}
.guide-programTextIcon {
color: #1e1e1e;
background: #555;
}
.guide-headerTimeslots {
color: inherit;
}
.guide-date-tab-button {
color: #555;
color: rgba(0, 0, 0, 0.54);
}
.guide-date-tab-button.emby-tab-button-active,
.guide-date-tab-button:focus {
color: #00a4dc;
}
.guide-date-tab-button.show-focus:focus {
background-color: #00a4dc;
color: #fff;
}
.infoBanner {
color: #000;
background: #fff3a5;
padding: 1em;
border-radius: 0.25em;
}
.ratingbutton-icon-withrating {
color: #c33;
}
.downloadbutton-icon-complete,
.downloadbutton-icon-on {
color: #4285f4;
}
.playstatebutton-icon-played {
color: #c33;
}
.buttonActive {
color: #00a4dc !important;
}
.cardBox:not(.visualCardBox) .cardPadder {
background-color: #fff;
}
.cardPadder .cardImageIcon {
color: #ddd;
}
.card:focus .cardBox.visualCardBox,
.card:focus .cardBox:not(.visualCardBox) .cardScalable {
border-color: #00a4dc !important;
}
::-webkit-scrollbar-track {
box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
}
.layout-desktop ::-webkit-scrollbar,
.layout-tv ::-webkit-scrollbar {
width: 0.4em;
height: 0.4em;
}
::-webkit-scrollbar-thumb:horizontal,
::-webkit-scrollbar-thumb:vertical {
border-radius: 2px;
background: center no-repeat #999;
}
.timeslotHeaders-desktop::-webkit-scrollbar {
height: 0.7em;
}
.metadataSidebarIcon {
color: #00a4dc;
}

View File

@@ -31,7 +31,7 @@ const defaultMuiTheme = extendTheme({
* Default color schemes ('dark' or 'light') will automatically be merged with MUI's corresponding default color
* scheme. For custom schemes, we need to merge these manually.
*/
const buildCustomColorScheme = (options: ColorSystemOptions) => merge(
const buildCustomColorScheme = (options: ColorSystemOptions) => merge<ColorSystemOptions, ColorSystemOptions | undefined, ColorSystemOptions, ColorSystemOptions>(
{},
options.palette?.mode === 'light' ? defaultMuiTheme.colorSchemes.light : defaultMuiTheme.colorSchemes.dark,
DEFAULT_COLOR_SCHEME,
@@ -75,18 +75,31 @@ const dark = merge({}, DEFAULT_COLOR_SCHEME, {
});
/** The "Light" color scheme. */
const light = merge({}, DEFAULT_COLOR_SCHEME, {
const light = merge<ColorSystemOptions, ColorSystemOptions, ColorSystemOptions>({}, DEFAULT_COLOR_SCHEME, {
palette: {
mode: 'light',
background: {
default: '#f2f2f2',
// NOTE: The original theme uses #303030 for the drawer and app bar but we would need the drawer to use
// dark mode for a color that dark to work properly which would require a separate ThemeProvider just for
// the drawer... which is not worth the trouble in my opinion
paper: '#e8e8e8'
},
text: {
primary: '#000',
secondary: 'rgba(0, 0, 0, 0.87)'
},
action: {
focus: '#bbb',
hover: '#ddd'
},
Alert: {
infoFilledBg: '#fff3a5',
infoFilledColor: '#000'
},
AppBar: {
defaultBg: '#e8e8e8'
},
Button: {
inheritContainedBg: '#d8d8d8',
inheritContainedHoverBg: '#ccc'
}
}
});