mirror of
https://github.com/Sonarr/Sonarr.git
synced 2025-01-27 11:21:43 +02:00
parent
e792db4d33
commit
9884f6f282
@ -52,6 +52,10 @@ $fullColorGradient: rgba(244, 245, 246, 0.2);
|
|||||||
.statusContainer {
|
.statusContainer {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
|
||||||
|
&:global(.fullColor) {
|
||||||
|
filter: var(--calendarFullColorFilter)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.statusIcon {
|
.statusIcon {
|
||||||
|
@ -102,7 +102,12 @@ class CalendarEvent extends Component {
|
|||||||
{series.title}
|
{series.title}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className={styles.statusContainer}>
|
<div
|
||||||
|
className={classNames(
|
||||||
|
styles.statusContainer,
|
||||||
|
fullColorEvents && 'fullColor'
|
||||||
|
)}
|
||||||
|
>
|
||||||
{
|
{
|
||||||
missingAbsoluteNumber ?
|
missingAbsoluteNumber ?
|
||||||
<Icon
|
<Icon
|
||||||
@ -128,6 +133,7 @@ class CalendarEvent extends Component {
|
|||||||
<span className={styles.statusIcon}>
|
<span className={styles.statusIcon}>
|
||||||
<CalendarEventQueueDetails
|
<CalendarEventQueueDetails
|
||||||
{...queueItem}
|
{...queueItem}
|
||||||
|
fullColorEvents={fullColorEvents}
|
||||||
/>
|
/>
|
||||||
</span> :
|
</span> :
|
||||||
null
|
null
|
||||||
@ -150,7 +156,7 @@ class CalendarEvent extends Component {
|
|||||||
<Icon
|
<Icon
|
||||||
className={styles.statusIcon}
|
className={styles.statusIcon}
|
||||||
name={icons.EPISODE_FILE}
|
name={icons.EPISODE_FILE}
|
||||||
kind={fullColorEvents ? kinds.DEFAULT : kinds.WARNING}
|
kind={kinds.WARNING}
|
||||||
title={translate('QualityCutoffNotMet')}
|
title={translate('QualityCutoffNotMet')}
|
||||||
/> :
|
/> :
|
||||||
null
|
null
|
||||||
@ -160,9 +166,8 @@ class CalendarEvent extends Component {
|
|||||||
episodeNumber === 1 && seasonNumber > 0 ?
|
episodeNumber === 1 && seasonNumber > 0 ?
|
||||||
<Icon
|
<Icon
|
||||||
className={styles.statusIcon}
|
className={styles.statusIcon}
|
||||||
name={icons.INFO}
|
name={icons.PREMIERE}
|
||||||
kind={kinds.INFO}
|
kind={kinds.INFO}
|
||||||
darken={fullColorEvents}
|
|
||||||
title={seasonNumber === 1 ? translate('SeriesPremiere') : translate('SeasonPremiere')}
|
title={seasonNumber === 1 ? translate('SeriesPremiere') : translate('SeasonPremiere')}
|
||||||
/> :
|
/> :
|
||||||
null
|
null
|
||||||
@ -173,8 +178,8 @@ class CalendarEvent extends Component {
|
|||||||
finaleType ?
|
finaleType ?
|
||||||
<Icon
|
<Icon
|
||||||
className={styles.statusIcon}
|
className={styles.statusIcon}
|
||||||
name={icons.INFO}
|
name={finaleType === 'series' ? icons.FINALE_SERIES : icons.FINALE_SEASON}
|
||||||
kind={fullColorEvents ? kinds.DEFAULT : kinds.WARNING}
|
kind={finaleType === 'series' ? kinds.DANGER : kinds.WARNING}
|
||||||
title={getFinaleTypeName(finaleType)}
|
title={getFinaleTypeName(finaleType)}
|
||||||
/> :
|
/> :
|
||||||
null
|
null
|
||||||
@ -187,7 +192,6 @@ class CalendarEvent extends Component {
|
|||||||
className={styles.statusIcon}
|
className={styles.statusIcon}
|
||||||
name={icons.INFO}
|
name={icons.INFO}
|
||||||
kind={kinds.PINK}
|
kind={kinds.PINK}
|
||||||
darken={fullColorEvents}
|
|
||||||
title={translate('Special')}
|
title={translate('Special')}
|
||||||
/> :
|
/> :
|
||||||
null
|
null
|
||||||
|
@ -50,6 +50,15 @@
|
|||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.statusContainer {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
|
||||||
|
&:global(.fullColor) {
|
||||||
|
filter: var(--calendarFullColorFilter)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.statusIcon {
|
.statusIcon {
|
||||||
margin-left: 3px;
|
margin-left: 3px;
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@ interface CssExports {
|
|||||||
'onAir': string;
|
'onAir': string;
|
||||||
'premiere': string;
|
'premiere': string;
|
||||||
'seriesTitle': string;
|
'seriesTitle': string;
|
||||||
|
'statusContainer': string;
|
||||||
'statusIcon': string;
|
'statusIcon': string;
|
||||||
'unaired': string;
|
'unaired': string;
|
||||||
'unmonitored': string;
|
'unmonitored': string;
|
||||||
|
@ -145,6 +145,12 @@ class CalendarEventGroup extends Component {
|
|||||||
{series.title}
|
{series.title}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div
|
||||||
|
className={classNames(
|
||||||
|
styles.statusContainer,
|
||||||
|
fullColorEvents && 'fullColor'
|
||||||
|
)}
|
||||||
|
>
|
||||||
{
|
{
|
||||||
isMissingAbsoluteNumber &&
|
isMissingAbsoluteNumber &&
|
||||||
<Icon
|
<Icon
|
||||||
@ -167,9 +173,8 @@ class CalendarEventGroup extends Component {
|
|||||||
firstEpisode.episodeNumber === 1 && seasonNumber > 0 &&
|
firstEpisode.episodeNumber === 1 && seasonNumber > 0 &&
|
||||||
<Icon
|
<Icon
|
||||||
containerClassName={styles.statusIcon}
|
containerClassName={styles.statusIcon}
|
||||||
name={icons.INFO}
|
name={icons.PREMIERE}
|
||||||
kind={kinds.INFO}
|
kind={kinds.INFO}
|
||||||
darken={fullColorEvents}
|
|
||||||
title={seasonNumber === 1 ? translate('SeriesPremiere') : translate('SeasonPremiere')}
|
title={seasonNumber === 1 ? translate('SeriesPremiere') : translate('SeasonPremiere')}
|
||||||
/>
|
/>
|
||||||
}
|
}
|
||||||
@ -179,12 +184,13 @@ class CalendarEventGroup extends Component {
|
|||||||
lastEpisode.finaleType ?
|
lastEpisode.finaleType ?
|
||||||
<Icon
|
<Icon
|
||||||
containerClassName={styles.statusIcon}
|
containerClassName={styles.statusIcon}
|
||||||
name={icons.INFO}
|
name={lastEpisode.finaleType === 'series' ? icons.FINALE_SERIES : icons.FINALE_SEASON}
|
||||||
kind={fullColorEvents ? kinds.DEFAULT : kinds.WARNING}
|
kind={lastEpisode.finaleType === 'series' ? kinds.DANGER : kinds.WARNING}
|
||||||
title={getFinaleTypeName(lastEpisode.finaleType)}
|
title={getFinaleTypeName(lastEpisode.finaleType)}
|
||||||
/> : null
|
/> : null
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div className={styles.airingInfo}>
|
<div className={styles.airingInfo}>
|
||||||
<div className={styles.airTime}>
|
<div className={styles.airTime}>
|
||||||
|
@ -22,9 +22,20 @@ function Legend(props) {
|
|||||||
if (showFinaleIcon) {
|
if (showFinaleIcon) {
|
||||||
iconsToShow.push(
|
iconsToShow.push(
|
||||||
<LegendIconItem
|
<LegendIconItem
|
||||||
name="Finale"
|
name={translate('SeasonFinale')}
|
||||||
icon={icons.INFO}
|
icon={icons.FINALE_SEASON}
|
||||||
kind={fullColorEvents ? kinds.DEFAULT : kinds.WARNING}
|
kind={kinds.WARNING}
|
||||||
|
fullColorEvents={fullColorEvents}
|
||||||
|
tooltip={translate('CalendarLegendSeriesFinaleTooltip')}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
|
||||||
|
iconsToShow.push(
|
||||||
|
<LegendIconItem
|
||||||
|
name={translate('SeriesFinale')}
|
||||||
|
icon={icons.FINALE_SERIES}
|
||||||
|
kind={kinds.DANGER}
|
||||||
|
fullColorEvents={fullColorEvents}
|
||||||
tooltip={translate('CalendarLegendSeriesFinaleTooltip')}
|
tooltip={translate('CalendarLegendSeriesFinaleTooltip')}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
@ -33,10 +44,10 @@ function Legend(props) {
|
|||||||
if (showSpecialIcon) {
|
if (showSpecialIcon) {
|
||||||
iconsToShow.push(
|
iconsToShow.push(
|
||||||
<LegendIconItem
|
<LegendIconItem
|
||||||
name="Special"
|
name={translate('Special')}
|
||||||
icon={icons.INFO}
|
icon={icons.INFO}
|
||||||
kind={kinds.PINK}
|
kind={kinds.PINK}
|
||||||
darken={fullColorEvents}
|
fullColorEvents={fullColorEvents}
|
||||||
tooltip={translate('SpecialEpisode')}
|
tooltip={translate('SpecialEpisode')}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
@ -45,9 +56,10 @@ function Legend(props) {
|
|||||||
if (showCutoffUnmetIcon) {
|
if (showCutoffUnmetIcon) {
|
||||||
iconsToShow.push(
|
iconsToShow.push(
|
||||||
<LegendIconItem
|
<LegendIconItem
|
||||||
name="Cutoff Not Met"
|
name={translate('Cutoff Not Met')}
|
||||||
icon={icons.EPISODE_FILE}
|
icon={icons.EPISODE_FILE}
|
||||||
kind={fullColorEvents ? kinds.DEFAULT : kinds.WARNING}
|
kind={kinds.WARNING}
|
||||||
|
fullColorEvents={fullColorEvents}
|
||||||
tooltip={translate('QualityCutoffNotMet')}
|
tooltip={translate('QualityCutoffNotMet')}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
@ -112,10 +124,10 @@ function Legend(props) {
|
|||||||
|
|
||||||
<div>
|
<div>
|
||||||
<LegendIconItem
|
<LegendIconItem
|
||||||
name="Premiere"
|
name={translate('Premiere')}
|
||||||
icon={icons.INFO}
|
icon={icons.PREMIERE}
|
||||||
kind={kinds.INFO}
|
kind={kinds.INFO}
|
||||||
darken={true}
|
fullColorEvents={fullColorEvents}
|
||||||
tooltip={translate('CalendarLegendSeriesPremiereTooltip')}
|
tooltip={translate('CalendarLegendSeriesPremiereTooltip')}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
@ -129,6 +141,12 @@ function Legend(props) {
|
|||||||
{iconsToShow[2]}
|
{iconsToShow[2]}
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
{
|
||||||
|
iconsToShow.length > 3 &&
|
||||||
|
<div>
|
||||||
|
{iconsToShow[3]}
|
||||||
|
</div>
|
||||||
|
}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -7,4 +7,8 @@
|
|||||||
|
|
||||||
.icon {
|
.icon {
|
||||||
margin-right: 5px;
|
margin-right: 5px;
|
||||||
|
|
||||||
|
&:global(.fullColorEvents) {
|
||||||
|
filter: var(--calendarFullColorFilter)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import classNames from 'classnames';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Icon from 'Components/Icon';
|
import Icon from 'Components/Icon';
|
||||||
@ -6,9 +7,9 @@ import styles from './LegendIconItem.css';
|
|||||||
function LegendIconItem(props) {
|
function LegendIconItem(props) {
|
||||||
const {
|
const {
|
||||||
name,
|
name,
|
||||||
|
fullColorEvents,
|
||||||
icon,
|
icon,
|
||||||
kind,
|
kind,
|
||||||
darken,
|
|
||||||
tooltip
|
tooltip
|
||||||
} = props;
|
} = props;
|
||||||
|
|
||||||
@ -18,9 +19,11 @@ function LegendIconItem(props) {
|
|||||||
title={tooltip}
|
title={tooltip}
|
||||||
>
|
>
|
||||||
<Icon
|
<Icon
|
||||||
className={styles.icon}
|
className={classNames(
|
||||||
|
styles.icon,
|
||||||
|
fullColorEvents && 'fullColorEvents'
|
||||||
|
)}
|
||||||
name={icon}
|
name={icon}
|
||||||
darken={darken}
|
|
||||||
kind={kind}
|
kind={kind}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
@ -31,14 +34,10 @@ function LegendIconItem(props) {
|
|||||||
|
|
||||||
LegendIconItem.propTypes = {
|
LegendIconItem.propTypes = {
|
||||||
name: PropTypes.string.isRequired,
|
name: PropTypes.string.isRequired,
|
||||||
|
fullColorEvents: PropTypes.bool.isRequired,
|
||||||
icon: PropTypes.object.isRequired,
|
icon: PropTypes.object.isRequired,
|
||||||
kind: PropTypes.string.isRequired,
|
kind: PropTypes.string.isRequired,
|
||||||
darken: PropTypes.bool.isRequired,
|
|
||||||
tooltip: PropTypes.string.isRequired
|
tooltip: PropTypes.string.isRequired
|
||||||
};
|
};
|
||||||
|
|
||||||
LegendIconItem.defaultProps = {
|
|
||||||
darken: false
|
|
||||||
};
|
|
||||||
|
|
||||||
export default LegendIconItem;
|
export default LegendIconItem;
|
||||||
|
@ -12,18 +12,10 @@
|
|||||||
|
|
||||||
.info {
|
.info {
|
||||||
color: var(--infoColor);
|
color: var(--infoColor);
|
||||||
|
|
||||||
&:global(.darken) {
|
|
||||||
color: color(var(--infoColor) shade(30%));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.pink {
|
.pink {
|
||||||
color: var(--pink);
|
color: var(--pink);
|
||||||
|
|
||||||
&:global(.darken) {
|
|
||||||
color: color(var(--pink) shade(30%));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.success {
|
.success {
|
||||||
|
@ -18,7 +18,6 @@ class Icon extends PureComponent {
|
|||||||
kind,
|
kind,
|
||||||
size,
|
size,
|
||||||
title,
|
title,
|
||||||
darken,
|
|
||||||
isSpinning,
|
isSpinning,
|
||||||
...otherProps
|
...otherProps
|
||||||
} = this.props;
|
} = this.props;
|
||||||
@ -27,8 +26,7 @@ class Icon extends PureComponent {
|
|||||||
<FontAwesomeIcon
|
<FontAwesomeIcon
|
||||||
className={classNames(
|
className={classNames(
|
||||||
className,
|
className,
|
||||||
styles[kind],
|
styles[kind]
|
||||||
darken && 'darken'
|
|
||||||
)}
|
)}
|
||||||
icon={name}
|
icon={name}
|
||||||
spin={isSpinning}
|
spin={isSpinning}
|
||||||
@ -61,7 +59,6 @@ Icon.propTypes = {
|
|||||||
kind: PropTypes.string.isRequired,
|
kind: PropTypes.string.isRequired,
|
||||||
size: PropTypes.number.isRequired,
|
size: PropTypes.number.isRequired,
|
||||||
title: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),
|
title: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),
|
||||||
darken: PropTypes.bool.isRequired,
|
|
||||||
isSpinning: PropTypes.bool.isRequired,
|
isSpinning: PropTypes.bool.isRequired,
|
||||||
fixedWidth: PropTypes.bool.isRequired
|
fixedWidth: PropTypes.bool.isRequired
|
||||||
};
|
};
|
||||||
@ -69,7 +66,6 @@ Icon.propTypes = {
|
|||||||
Icon.defaultProps = {
|
Icon.defaultProps = {
|
||||||
kind: kinds.DEFAULT,
|
kind: kinds.DEFAULT,
|
||||||
size: 14,
|
size: 14,
|
||||||
darken: false,
|
|
||||||
isSpinning: false,
|
isSpinning: false,
|
||||||
fixedWidth: false
|
fixedWidth: false
|
||||||
};
|
};
|
||||||
|
@ -41,6 +41,9 @@ import {
|
|||||||
faChevronCircleUp as fasChevronCircleUp,
|
faChevronCircleUp as fasChevronCircleUp,
|
||||||
faCircle as fasCircle,
|
faCircle as fasCircle,
|
||||||
faCircleDown as fasCircleDown,
|
faCircleDown as fasCircleDown,
|
||||||
|
faCirclePause as fasCirclePause,
|
||||||
|
faCirclePlay as fasCirclePlay,
|
||||||
|
faCircleStop as fasCircleStop,
|
||||||
faCloud as fasCloud,
|
faCloud as fasCloud,
|
||||||
faCloudDownloadAlt as fasCloudDownloadAlt,
|
faCloudDownloadAlt as fasCloudDownloadAlt,
|
||||||
faCog as fasCog,
|
faCog as fasCog,
|
||||||
@ -149,6 +152,8 @@ export const FATAL = fasTimesCircle;
|
|||||||
export const FILE = farFile;
|
export const FILE = farFile;
|
||||||
export const FILE_MISSING = fasFileCircleQuestion;
|
export const FILE_MISSING = fasFileCircleQuestion;
|
||||||
export const FILTER = fasFilter;
|
export const FILTER = fasFilter;
|
||||||
|
export const FINALE_SEASON = fasCirclePause;
|
||||||
|
export const FINALE_SERIES = fasCircleStop;
|
||||||
export const FOOTNOTE = fasAsterisk;
|
export const FOOTNOTE = fasAsterisk;
|
||||||
export const FOLDER = farFolder;
|
export const FOLDER = farFolder;
|
||||||
export const FOLDER_OPEN = fasFolderOpen;
|
export const FOLDER_OPEN = fasFolderOpen;
|
||||||
@ -180,6 +185,7 @@ export const PARENT = fasLevelUpAlt;
|
|||||||
export const PARSE = fasCalculator;
|
export const PARSE = fasCalculator;
|
||||||
export const PAUSED = fasPause;
|
export const PAUSED = fasPause;
|
||||||
export const PENDING = farClock;
|
export const PENDING = farClock;
|
||||||
|
export const PREMIERE = fasCirclePlay;
|
||||||
export const PROFILE = fasUser;
|
export const PROFILE = fasUser;
|
||||||
export const POSTER = fasTh;
|
export const POSTER = fasTh;
|
||||||
export const QUEUED = fasCloud;
|
export const QUEUED = fasCloud;
|
||||||
|
@ -213,6 +213,8 @@ module.exports = {
|
|||||||
calendarTextDim: '#eee',
|
calendarTextDim: '#eee',
|
||||||
calendarTextDimAlternate: '#fff',
|
calendarTextDimAlternate: '#fff',
|
||||||
|
|
||||||
|
calendarFullColorFilter: 'grayscale(90%) contrast(200%) saturate(50%)',
|
||||||
|
|
||||||
//
|
//
|
||||||
// Table
|
// Table
|
||||||
|
|
||||||
|
@ -215,6 +215,8 @@ module.exports = {
|
|||||||
calendarTextDim: '#666',
|
calendarTextDim: '#666',
|
||||||
calendarTextDimAlternate: '#242424',
|
calendarTextDimAlternate: '#242424',
|
||||||
|
|
||||||
|
calendarFullColorFilter: 'brightness(30%)',
|
||||||
|
|
||||||
//
|
//
|
||||||
// Table
|
// Table
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
export interface UiSettings {
|
export interface UiSettings {
|
||||||
|
theme: string;
|
||||||
showRelativeDates: boolean;
|
showRelativeDates: boolean;
|
||||||
shortDateFormat: string;
|
shortDateFormat: string;
|
||||||
longDateFormat: string;
|
longDateFormat: string;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user