64 lines
1.9 KiB
JavaScript
Raw Normal View History

import genericProxyHandler from "utils/proxy/handlers/generic";
2023-06-02 14:57:27 +02:00
import { asJson, jsonArrayFilter } from "utils/proxy/api-helpers";
2022-09-25 19:43:47 +03:00
const widget = {
api: "{url}/api/v3/{endpoint}?apikey={key}",
proxyHandler: genericProxyHandler,
mappings: {
movie: {
endpoint: "movie",
map: (data) => ({
wanted: jsonArrayFilter(data, (item) => item.monitored && !item.hasFile && item.isAvailable).length,
2022-10-20 16:33:02 -07:00
have: jsonArrayFilter(data, (item) => item.hasFile).length,
missing: jsonArrayFilter(data, (item) => item.monitored && !item.hasFile).length,
2023-06-02 14:57:27 +02:00
all: asJson(data),
2022-09-25 19:43:47 +03:00
}),
},
"queue/status": {
endpoint: "queue/status",
validate: ["totalCount"],
2022-09-25 19:43:47 +03:00
},
2023-06-02 14:57:27 +02:00
"queue/details": {
endpoint: "queue/details",
map: (data) =>
asJson(data)
.map((entry) => ({
trackedDownloadState: entry.trackedDownloadState,
trackedDownloadStatus: entry.trackedDownloadStatus,
timeLeft: entry.timeleft,
size: entry.size,
sizeLeft: entry.sizeleft,
movieId: entry.movieId ?? entry.id,
status: entry.status,
}))
.sort((a, b) => {
const downloadingA = a.trackedDownloadState === "downloading";
const downloadingB = b.trackedDownloadState === "downloading";
if (downloadingA && !downloadingB) {
return -1;
}
if (downloadingB && !downloadingA) {
return 1;
}
2023-06-02 14:57:27 +02:00
const percentA = a.sizeLeft / a.size;
const percentB = b.sizeLeft / b.size;
if (percentA < percentB) {
return -1;
}
if (percentA > percentB) {
return 1;
}
return 0;
}),
2023-06-02 14:57:27 +02:00
},
calendar: {
endpoint: "calendar",
params: ["start", "end", "unmonitored"],
},
2022-09-25 19:43:47 +03:00
},
};
export default widget;