1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/scripts/deleteHelper.js

82 lines
2.6 KiB
JavaScript
Raw Normal View History

2020-08-14 08:46:34 +02:00
2024-08-14 13:31:34 -04:00
import globalize from '../lib/globalize';
2023-04-28 15:38:51 +12:00
import alert from '../components/alert';
2020-08-14 08:46:34 +02:00
import confirm from '../components/confirm/confirm';
2023-05-01 10:04:13 -04:00
import { appRouter } from '../components/router/appRouter';
import ServerConnections from '../components/ServerConnections';
import { BaseItemKind } from '@jellyfin/sdk/lib/generated-client/models/base-item-kind';
2018-10-23 01:05:09 +03:00
2020-05-03 17:53:23 +05:30
function alertText(options) {
return alert(options);
2020-05-03 17:53:23 +05:30
}
2018-10-23 01:05:09 +03:00
2024-03-13 01:24:33 +02:00
function getDeletionConfirmContent(item) {
if (item.Type === BaseItemKind.Series) {
const totalEpisodes = item.RecursiveItemCount;
return {
title: globalize.translate('HeaderDeleteSeries'),
text: globalize.translate('ConfirmDeleteSeries', totalEpisodes),
2024-03-13 01:24:33 +02:00
confirmText: globalize.translate('DeleteEntireSeries', totalEpisodes),
primary: 'delete'
};
}
return {
title: globalize.translate('HeaderDeleteItem'),
text: globalize.translate('ConfirmDeleteItem'),
2024-03-13 01:24:33 +02:00
confirmText: globalize.translate('Delete'),
primary: 'delete'
};
}
2020-05-03 17:53:23 +05:30
export function deleteItem(options) {
2020-05-10 14:46:28 +05:30
const item = options.item;
const parentId = item.SeasonId || item.SeriesId || item.ParentId;
const apiClient = ServerConnections.getApiClient(item.ServerId);
2024-03-13 01:24:33 +02:00
return confirm(getDeletionConfirmContent(item)).then(function () {
2020-05-03 23:59:23 +05:30
return apiClient.deleteItem(item.Id).then(function () {
2020-05-03 17:53:23 +05:30
if (options.navigate) {
if (parentId) {
2020-05-03 23:59:23 +05:30
appRouter.showItem(parentId, item.ServerId);
2020-05-03 17:53:23 +05:30
} else {
appRouter.goHome();
}
2020-05-03 17:53:23 +05:30
}
}, function (err) {
const result = function () {
2020-05-03 17:53:23 +05:30
return Promise.reject(err);
};
2020-05-03 17:53:23 +05:30
return alertText(globalize.translate('ErrorDeletingItem')).then(result, result);
});
2020-05-03 17:53:23 +05:30
});
}
2023-04-28 15:38:51 +12:00
export function deleteLyrics (item) {
return confirm({
title: globalize.translate('HeaderDeleteLyrics'),
text: globalize.translate('ConfirmDeleteLyrics'),
confirmText: globalize.translate('Delete'),
primary: 'delete'
}).then(() => {
const apiClient = ServerConnections.getApiClient(item.ServerId);
return apiClient.ajax({
url: apiClient.getUrl('Audio/' + item.Id + '/Lyrics'),
type: 'DELETE'
}).catch((err) => {
const result = function () {
return Promise.reject(err);
};
return alertText(globalize.translate('ErrorDeletingLyrics')).then(result, result);
});
});
}
2020-05-03 17:53:23 +05:30
export default {
2023-04-28 15:38:51 +12:00
deleteItem,
deleteLyrics
2020-05-03 17:53:23 +05:30
};