import { useTranslation } from "next-i18next";
import Container from "components/services/widget/container";
import Block from "components/services/widget/block";
import useWidgetAPI from "utils/proxy/use-widget-api";
/**
* @param {string[]|null} Fields
* @returns {string[]}
*/
function makeFields(Fields = []) {
let fields = Fields ?? [];
if (fields.length === 0) {
fields = ["download", "nonDownload", "read", "unRead"];
}
if (fields.length > 4) {
fields.length = 4;
}
fields = fields.map((field) => field.toLowerCase());
return fields;
}
export default function Component({ service }) {
const { t } = useTranslation();
/**
* @type {{
* widget: {
* fields: string[]|null
* }
* }}
*/
const { widget } = service;
/**
* @type {{
* error: unknown
* data: ({
* label: string, count: number
* }[]),
* }}
*/
const { data: suwayomiData, error: suwayomiError } = useWidgetAPI(widget);
if (suwayomiError) {
return ;
}
if (!suwayomiData) {
const fields = makeFields(widget.fields);
return (
{fields.map((field) => (
))}
);
}
return (
{suwayomiData.map((data) => (
))}
);
}