mirror of
https://github.com/Readarr/Readarr
synced 2026-02-11 17:23:26 +01:00
* Cache result of GetAllArtists
* Fixed: Manual import not respecting album import notifications
* Fixed: partial album imports stay in queue, prompting manual import
* Fixed: Allow release if tracks are missing
* Fixed: Be tolerant of missing/extra "The" at start of artist name
* Improve manual import UI
* Omit video tracks from DB entirely
* Revert "faster test packaging in build.sh"
This reverts commit 2723e2a7b8.
-u and -T are not supported on macOS
* Fix tests on linux and macOS
* Actually lint on linux
On linux yarn runs scripts with sh not bash so ** doesn't recursively glob
* Match whole albums
* Option to disable fingerprinting
* Rip out MediaInfo
* Don't split up things that have the same album selected in manual import
* Try to speed up IndentificationService
* More speedups
* Some fixes and increase power of recording id
* Fix NRE when no tags
* Fix NRE when some (but not all) files in a directory have missing tags
* Bump taglib, tidy up tag parsing
* Add a health check
* Remove media info setting
* Tags -> audioTags
* Add some tests where tags are null
* Rename history events
* Add missing method to interface
* Reinstate MediaInfo tags and update info with artist scan
Also adds migration to remove old format media info
* This file no longer exists
* Don't penalise year if missing from tags
* Formatting improvements
* Use correct system newline
* Switch to the netstandard2.0 library to support net 461
* TagLib.File is IDisposable so should be in a using
* Improve filename matching and add tests
* Neater logging of parsed tags
* Fix disk scan tests for new media info update
* Fix quality detection source
* Fix Inexact Artist/Album match
* Add button to clear track mapping
* Fix warning
* Pacify eslint
* Use \ not /
* Fix UI updates
* Fix media covers
Prevent localizing URL propaging back to the metadata object
* Reduce database overhead broadcasting UI updates
* Relax timings a bit to make test pass
* Remove irrelevant tests
* Test framework for identification service
* Fix PreferMissingToBadMatch test case
* Make fingerprinting more robust
* More logging
* Penalize unknown media format and country
* Prefer USA to UK
* Allow Data CD
* Fix exception if fingerprinting fails for all files
* Fix tests
* Fix NRE
* Allow apostrophes and remove accents in filename aggregation
* Address codacy issues
* Cope with old versions of fpcalc and suggest upgrade
* fpcalc health check passes if fingerprinting disabled
* Get the Artist meta with the artist
* Fix the mapper so that lazy loaded lists will be populated on Join
And therefore we can join TrackFiles on Tracks by default and avoid an
extra query
* Rename subtitle -> lyric
* Tidy up MediaInfoFormatter
74 lines
2 KiB
JavaScript
74 lines
2 KiB
JavaScript
import $ from 'jquery';
|
|
import { batchActions } from 'redux-batched-actions';
|
|
import createAjaxRequest from 'Utilities/createAjaxRequest';
|
|
import getProviderState from 'Utilities/State/getProviderState';
|
|
import { set, updateItem } from '../baseActions';
|
|
|
|
const abortCurrentRequests = {};
|
|
|
|
export function createCancelSaveProviderHandler(section) {
|
|
return function(getState, payload, dispatch) {
|
|
if (abortCurrentRequests[section]) {
|
|
abortCurrentRequests[section]();
|
|
abortCurrentRequests[section] = null;
|
|
}
|
|
};
|
|
}
|
|
|
|
function createSaveProviderHandler(section, url, options = {}) {
|
|
return function(getState, payload, dispatch) {
|
|
dispatch(set({ section, isSaving: true }));
|
|
|
|
const {
|
|
id,
|
|
queryParams = {},
|
|
...otherPayload
|
|
} = payload;
|
|
|
|
const saveData = Array.isArray(id) ? id.map((x) => getProviderState({ id: x, ...otherPayload }, getState, section)) : getProviderState({ id, ...otherPayload }, getState, section);
|
|
|
|
const ajaxOptions = {
|
|
url: `${url}?${$.param(queryParams, true)}`,
|
|
method: 'POST',
|
|
contentType: 'application/json',
|
|
dataType: 'json',
|
|
data: JSON.stringify(saveData)
|
|
};
|
|
|
|
if (id) {
|
|
ajaxOptions.method = 'PUT';
|
|
if (!Array.isArray(id)) {
|
|
ajaxOptions.url = `${url}/${id}?${$.param(queryParams, true)}`;
|
|
}
|
|
}
|
|
|
|
const { request, abortRequest } = createAjaxRequest(ajaxOptions);
|
|
|
|
abortCurrentRequests[section] = abortRequest;
|
|
|
|
request.done((data) => {
|
|
if (!Array.isArray(data)) {
|
|
data = [data];
|
|
}
|
|
dispatch(batchActions(
|
|
data.map((item) => updateItem({ section, ...item })).concat(
|
|
set({
|
|
section,
|
|
isSaving: false,
|
|
saveError: null,
|
|
pendingChanges: {}
|
|
})
|
|
)));
|
|
});
|
|
|
|
request.fail((xhr) => {
|
|
dispatch(set({
|
|
section,
|
|
isSaving: false,
|
|
saveError: xhr.aborted ? null : xhr
|
|
}));
|
|
});
|
|
};
|
|
}
|
|
|
|
export default createSaveProviderHandler;
|