mirror of
https://github.com/Prowlarr/Prowlarr
synced 2025-12-06 00:22:31 +01:00
New: Deprecate Readarr
This commit is contained in:
parent
e4fb36e08f
commit
20b82146ac
10 changed files with 94 additions and 7 deletions
|
|
@ -1,14 +1,18 @@
|
|||
import PropTypes from 'prop-types';
|
||||
import React, { Component } from 'react';
|
||||
import Label from 'Components/Label';
|
||||
import Button from 'Components/Link/Button';
|
||||
import Link from 'Components/Link/Link';
|
||||
import Menu from 'Components/Menu/Menu';
|
||||
import MenuContent from 'Components/Menu/MenuContent';
|
||||
import { sizes } from 'Helpers/Props';
|
||||
import { kinds, sizes } from 'Helpers/Props';
|
||||
import translate from 'Utilities/String/translate';
|
||||
import AddApplicationPresetMenuItem from './AddApplicationPresetMenuItem';
|
||||
import styles from './AddApplicationItem.css';
|
||||
|
||||
const DEPRECATED_APPLICATIONS = ['Readarr'];
|
||||
const OBSOLETE_APPLICATIONS = [];
|
||||
|
||||
class AddApplicationItem extends Component {
|
||||
|
||||
//
|
||||
|
|
@ -36,6 +40,8 @@ class AddApplicationItem extends Component {
|
|||
} = this.props;
|
||||
|
||||
const hasPresets = !!presets && !!presets.length;
|
||||
const isDeprecated = DEPRECATED_APPLICATIONS.includes(implementation);
|
||||
const isObsolete = OBSOLETE_APPLICATIONS.includes(implementation);
|
||||
|
||||
return (
|
||||
<div
|
||||
|
|
@ -49,6 +55,24 @@ class AddApplicationItem extends Component {
|
|||
<div className={styles.overlay}>
|
||||
<div className={styles.name}>
|
||||
{implementationName}
|
||||
{
|
||||
isDeprecated &&
|
||||
<Label
|
||||
kind={kinds.WARNING}
|
||||
title={translate('DeprecatedApplicationMessage', { applicationName: implementationName })}
|
||||
>
|
||||
{translate('Deprecated')}
|
||||
</Label>
|
||||
}
|
||||
{
|
||||
isObsolete &&
|
||||
<Label
|
||||
kind={kinds.DANGER}
|
||||
title={translate('ObsoleteApplicationMessage', { applicationName: implementationName })}
|
||||
>
|
||||
{translate('Obsolete')}
|
||||
</Label>
|
||||
}
|
||||
</div>
|
||||
|
||||
<div className={styles.actions}>
|
||||
|
|
|
|||
|
|
@ -10,6 +10,9 @@ import translate from 'Utilities/String/translate';
|
|||
import EditApplicationModalConnector from './EditApplicationModalConnector';
|
||||
import styles from './Application.css';
|
||||
|
||||
const DEPRECATED_APPLICATIONS = ['Readarr'];
|
||||
const OBSOLETE_APPLICATIONS = [];
|
||||
|
||||
class Application extends Component {
|
||||
|
||||
//
|
||||
|
|
@ -61,10 +64,13 @@ class Application extends Component {
|
|||
syncLevel,
|
||||
fields,
|
||||
tags,
|
||||
tagList
|
||||
tagList,
|
||||
implementation
|
||||
} = this.props;
|
||||
|
||||
const applicationUrl = fields.find((field) => field.name === 'baseUrl')?.value;
|
||||
const isDeprecated = DEPRECATED_APPLICATIONS.includes(implementation);
|
||||
const isObsolete = OBSOLETE_APPLICATIONS.includes(implementation);
|
||||
|
||||
return (
|
||||
<Card
|
||||
|
|
@ -88,6 +94,26 @@ class Application extends Component {
|
|||
}
|
||||
</div>
|
||||
|
||||
{
|
||||
isDeprecated &&
|
||||
<Label
|
||||
kind={kinds.WARNING}
|
||||
title={translate('DeprecatedApplicationMessage', { applicationName: implementation })}
|
||||
>
|
||||
{translate('Deprecated')}
|
||||
</Label>
|
||||
}
|
||||
|
||||
{
|
||||
isObsolete &&
|
||||
<Label
|
||||
kind={kinds.DANGER}
|
||||
title={translate('ObsoleteApplicationMessage', { applicationName: implementation })}
|
||||
>
|
||||
{translate('Obsolete')}
|
||||
</Label>
|
||||
}
|
||||
|
||||
{
|
||||
syncLevel === 'addOnly' &&
|
||||
<Label kind={kinds.WARNING}>
|
||||
|
|
@ -141,6 +167,7 @@ class Application extends Component {
|
|||
Application.propTypes = {
|
||||
id: PropTypes.number.isRequired,
|
||||
name: PropTypes.string.isRequired,
|
||||
implementation: PropTypes.string.isRequired,
|
||||
enable: PropTypes.bool.isRequired,
|
||||
syncLevel: PropTypes.string.isRequired,
|
||||
fields: PropTypes.arrayOf(PropTypes.object).isRequired,
|
||||
|
|
|
|||
|
|
@ -39,6 +39,9 @@ const syncLevelOptions = [
|
|||
}
|
||||
];
|
||||
|
||||
const DEPRECATED_APPLICATIONS = ['Readarr'];
|
||||
const OBSOLETE_APPLICATIONS = [];
|
||||
|
||||
function EditApplicationModalContent(props) {
|
||||
const {
|
||||
advancedSettings,
|
||||
|
|
@ -60,6 +63,7 @@ function EditApplicationModalContent(props) {
|
|||
|
||||
const {
|
||||
id,
|
||||
implementation,
|
||||
implementationName,
|
||||
name,
|
||||
syncLevel,
|
||||
|
|
@ -68,6 +72,9 @@ function EditApplicationModalContent(props) {
|
|||
message
|
||||
} = item;
|
||||
|
||||
const isDeprecated = DEPRECATED_APPLICATIONS.includes(implementation);
|
||||
const isObsolete = OBSOLETE_APPLICATIONS.includes(implementation);
|
||||
|
||||
return (
|
||||
<ModalContent onModalClose={onModalClose}>
|
||||
<ModalHeader>
|
||||
|
|
@ -90,6 +97,28 @@ function EditApplicationModalContent(props) {
|
|||
{
|
||||
!isFetching && !error &&
|
||||
<Form {...otherProps}>
|
||||
{
|
||||
isDeprecated &&
|
||||
<Alert
|
||||
className={styles.message}
|
||||
kind={kinds.WARNING}
|
||||
>
|
||||
<div>{translate('DeprecatedApplicationTitle', { applicationName: implementationName })}</div>
|
||||
<div>{translate('DeprecatedApplicationMessage', { applicationName: implementationName })}</div>
|
||||
</Alert>
|
||||
}
|
||||
|
||||
{
|
||||
isObsolete &&
|
||||
<Alert
|
||||
className={styles.message}
|
||||
kind={kinds.DANGER}
|
||||
>
|
||||
<div>{translate('ObsoleteApplicationTitle', { applicationName: implementationName })}</div>
|
||||
<div>{translate('ObsoleteApplicationMessage', { applicationName: implementationName })}</div>
|
||||
</Alert>
|
||||
}
|
||||
|
||||
{
|
||||
!!message &&
|
||||
<Alert
|
||||
|
|
|
|||
|
|
@ -159,7 +159,7 @@ private LidarrIndexer ExecuteIndexerRequest(HttpRequest request)
|
|||
case HttpStatusCode.BadRequest:
|
||||
if (ex.Response.Content.Contains("Query successful, but no results in the configured categories were returned from your indexer.", StringComparison.InvariantCultureIgnoreCase))
|
||||
{
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: Prowlarr will not sync X Indexer to App");
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: https://wiki.servarr.com/prowlarr/faq#prowlarr-will-not-sync-x-indexer-to-app");
|
||||
break;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -172,7 +172,7 @@ private RadarrIndexer ExecuteIndexerRequest(HttpRequest request)
|
|||
case HttpStatusCode.BadRequest:
|
||||
if (ex.Response.Content.Contains("Query successful, but no results in the configured categories were returned from your indexer.", StringComparison.InvariantCultureIgnoreCase))
|
||||
{
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: Prowlarr will not sync X Indexer to App");
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: https://wiki.servarr.com/prowlarr/faq#prowlarr-will-not-sync-x-indexer-to-app");
|
||||
break;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -14,6 +14,7 @@
|
|||
|
||||
namespace NzbDrone.Core.Applications.Readarr
|
||||
{
|
||||
[Obsolete("Readarr is deprecated and will be removed in a future version")]
|
||||
public class Readarr : ApplicationBase<ReadarrSettings>
|
||||
{
|
||||
public override string Name => "Readarr";
|
||||
|
|
|
|||
|
|
@ -146,7 +146,7 @@ private ReadarrIndexer ExecuteIndexerRequest(HttpRequest request)
|
|||
case HttpStatusCode.BadRequest:
|
||||
if (ex.Response.Content.Contains("Query successful, but no results in the configured categories were returned from your indexer.", StringComparison.InvariantCultureIgnoreCase))
|
||||
{
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: Prowlarr will not sync X Indexer to App");
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: https://wiki.servarr.com/prowlarr/faq#prowlarr-will-not-sync-x-indexer-to-app");
|
||||
break;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -159,7 +159,7 @@ private SonarrIndexer ExecuteIndexerRequest(HttpRequest request)
|
|||
case HttpStatusCode.BadRequest:
|
||||
if (ex.Response.Content.Contains("Query successful, but no results in the configured categories were returned from your indexer.", StringComparison.InvariantCultureIgnoreCase))
|
||||
{
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: Prowlarr will not sync X Indexer to App");
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: https://wiki.servarr.com/prowlarr/faq#prowlarr-will-not-sync-x-indexer-to-app");
|
||||
break;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -144,7 +144,7 @@ private WhisparrIndexer ExecuteIndexerRequest(HttpRequest request)
|
|||
case HttpStatusCode.BadRequest:
|
||||
if (ex.Response.Content.Contains("Query successful, but no results in the configured categories were returned from your indexer.", StringComparison.InvariantCultureIgnoreCase))
|
||||
{
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: Prowlarr will not sync X Indexer to App");
|
||||
_logger.Warn(ex, "No Results in configured categories. See FAQ Entry: https://wiki.servarr.com/prowlarr/faq#prowlarr-will-not-sync-x-indexer-to-app");
|
||||
break;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -538,6 +538,12 @@
|
|||
"NotificationsTelegramSettingsIncludeAppName": "Include {appName} in Title",
|
||||
"NotificationsTelegramSettingsIncludeAppNameHelpText": "Optionally prefix message title with {appName} to differentiate notifications from different applications",
|
||||
"OAuthPopupMessage": "Pop-ups are being blocked by your browser",
|
||||
"Obsolete": "Obsolete",
|
||||
"ObsoleteApplicationMessage": "{applicationName} is obsolete and has been removed",
|
||||
"ObsoleteApplicationTitle": "{applicationName} is Obsolete",
|
||||
"Deprecated": "Deprecated",
|
||||
"DeprecatedApplicationMessage": "{applicationName} is deprecated and will be removed in a future version",
|
||||
"DeprecatedApplicationTitle": "{applicationName} is Deprecated",
|
||||
"Ok": "Ok",
|
||||
"OnApplicationUpdate": "On Application Update",
|
||||
"OnApplicationUpdateHelpText": "On Application Update",
|
||||
|
|
|
|||
Loading…
Reference in a new issue