mirror of
https://github.com/lidarr/lidarr.git
synced 2025-08-13 18:27:08 -07:00
New: Added Artist Monitoring Toggle to Artist Details
(cherry picked from commit 0ff889c3be1e8ee48759b233aeabf1bf1c4b4ff4)
This commit is contained in:
parent
6a65539ae6
commit
690b2c72c8
13 changed files with 288 additions and 26 deletions
|
@ -102,21 +102,21 @@ export const actionHandlers = handleThunks({
|
|||
[SAVE_ALBUM_STUDIO]: function(getState, payload, dispatch) {
|
||||
const {
|
||||
artistIds,
|
||||
monitored,
|
||||
monitor,
|
||||
monitored,
|
||||
monitorNewItems
|
||||
} = payload;
|
||||
|
||||
const artist = [];
|
||||
const artists = [];
|
||||
|
||||
artistIds.forEach((id) => {
|
||||
const artistToUpdate = { id };
|
||||
const artistsToUpdate = { id };
|
||||
|
||||
if (payload.hasOwnProperty('monitored')) {
|
||||
artistToUpdate.monitored = monitored;
|
||||
artistsToUpdate.monitored = monitored;
|
||||
}
|
||||
|
||||
artist.push(artistToUpdate);
|
||||
artists.push(artistsToUpdate);
|
||||
});
|
||||
|
||||
dispatch(set({
|
||||
|
@ -128,7 +128,7 @@ export const actionHandlers = handleThunks({
|
|||
url: '/albumStudio',
|
||||
method: 'POST',
|
||||
data: JSON.stringify({
|
||||
artist,
|
||||
artist: artists,
|
||||
monitoringOptions: { monitor },
|
||||
monitorNewItems
|
||||
}),
|
||||
|
|
|
@ -2,11 +2,12 @@ import _ from 'lodash';
|
|||
import { createAction } from 'redux-actions';
|
||||
import { batchActions } from 'redux-batched-actions';
|
||||
import { filterTypePredicates, filterTypes, sortDirections } from 'Helpers/Props';
|
||||
import { fetchAlbums } from 'Store/Actions/albumActions';
|
||||
import { createThunk, handleThunks } from 'Store/thunks';
|
||||
import createAjaxRequest from 'Utilities/createAjaxRequest';
|
||||
import dateFilterPredicate from 'Utilities/Date/dateFilterPredicate';
|
||||
import translate from 'Utilities/String/translate';
|
||||
import { updateItem } from './baseActions';
|
||||
import { set, updateItem } from './baseActions';
|
||||
import createFetchHandler from './Creators/createFetchHandler';
|
||||
import createHandleActions from './Creators/createHandleActions';
|
||||
import createRemoveItemHandler from './Creators/createRemoveItemHandler';
|
||||
|
@ -177,6 +178,7 @@ export const DELETE_ARTIST = 'artist/deleteArtist';
|
|||
|
||||
export const TOGGLE_ARTIST_MONITORED = 'artist/toggleArtistMonitored';
|
||||
export const TOGGLE_ALBUM_MONITORED = 'artist/toggleAlbumMonitored';
|
||||
export const UPDATE_ARTISTS_MONITOR = 'artist/updateArtistsMonitor';
|
||||
|
||||
export const SET_DELETE_OPTION = 'artist/setDeleteOption';
|
||||
|
||||
|
@ -212,6 +214,7 @@ export const deleteArtist = createThunk(DELETE_ARTIST, (payload) => {
|
|||
|
||||
export const toggleArtistMonitored = createThunk(TOGGLE_ARTIST_MONITORED);
|
||||
export const toggleAlbumMonitored = createThunk(TOGGLE_ALBUM_MONITORED);
|
||||
export const updateArtistsMonitor = createThunk(UPDATE_ARTISTS_MONITOR);
|
||||
|
||||
export const setArtistValue = createAction(SET_ARTIST_VALUE, (payload) => {
|
||||
return {
|
||||
|
@ -342,6 +345,61 @@ export const actionHandlers = handleThunks({
|
|||
seasons: artist.seasons
|
||||
}));
|
||||
});
|
||||
},
|
||||
|
||||
[UPDATE_ARTISTS_MONITOR]: function(getState, payload, dispatch) {
|
||||
const {
|
||||
artistIds,
|
||||
monitor,
|
||||
monitored,
|
||||
monitorNewItems
|
||||
} = payload;
|
||||
|
||||
const artists = [];
|
||||
|
||||
artistIds.forEach((id) => {
|
||||
const artistsToUpdate = { id };
|
||||
|
||||
if (monitored != null) {
|
||||
artistsToUpdate.monitored = monitored;
|
||||
}
|
||||
|
||||
artists.push(artistsToUpdate);
|
||||
});
|
||||
|
||||
dispatch(set({
|
||||
section,
|
||||
isSaving: true
|
||||
}));
|
||||
|
||||
const promise = createAjaxRequest({
|
||||
url: '/albumStudio',
|
||||
method: 'POST',
|
||||
data: JSON.stringify({
|
||||
artist: artists,
|
||||
monitoringOptions: { monitor },
|
||||
monitorNewItems
|
||||
}),
|
||||
dataType: 'json'
|
||||
}).request;
|
||||
|
||||
promise.done((data) => {
|
||||
dispatch(fetchAlbums({ artistId: artistIds[0] }));
|
||||
|
||||
dispatch(set({
|
||||
section,
|
||||
isSaving: false,
|
||||
saveError: null
|
||||
}));
|
||||
});
|
||||
|
||||
promise.fail((xhr) => {
|
||||
dispatch(set({
|
||||
section,
|
||||
isSaving: false,
|
||||
saveError: xhr
|
||||
}));
|
||||
});
|
||||
}
|
||||
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue