mirror of
https://github.com/Stremio/stremio-web.git
synced 2026-04-14 04:50:26 +00:00
86 lines
3.3 KiB
JavaScript
86 lines
3.3 KiB
JavaScript
// Copyright (C) 2017-2023 Smart code 203358507
|
|
|
|
const React = require('react');
|
|
const { useNavigate } = require('react-router');
|
|
const { useTranslate } = require('stremio/common');
|
|
|
|
const mapSelectableInputs = (discover, t, navigate) => {
|
|
const typeSelect = {
|
|
title: t.string('SELECT_TYPE'),
|
|
options: discover.selectable.types
|
|
.map(({ type, deepLinks }) => ({
|
|
value: deepLinks.discover,
|
|
label: t.stringWithPrefix(type, 'TYPE_')
|
|
})),
|
|
selected: discover.selectable.types
|
|
.filter(({ selected }) => selected)
|
|
.map(({ deepLinks }) => deepLinks.discover),
|
|
renderLabelText: discover.selected !== null ?
|
|
() => t.stringWithPrefix(discover.selected.request.path.type, 'TYPE_')
|
|
:
|
|
null,
|
|
onSelect: (event) => {
|
|
navigate(event.value.replace('#', ''));
|
|
}
|
|
};
|
|
const catalogSelect = {
|
|
title: t.string('SELECT_CATALOG'),
|
|
options: discover.selectable.catalogs
|
|
.map(({ id, name, addon, deepLinks }) => ({
|
|
value: deepLinks.discover,
|
|
label: t.catalogTitle({ addon, id, name }),
|
|
title: `${name} (${addon.manifest.name})`
|
|
})),
|
|
selected: discover.selectable.catalogs
|
|
.filter(({ selected }) => selected)
|
|
.map(({ deepLinks }) => deepLinks.discover),
|
|
renderLabelText: discover.selected !== null ?
|
|
() => {
|
|
const selectableCatalog = discover.selectable.catalogs
|
|
.find(({ id }) => id === discover.selected.request.path.id);
|
|
return selectableCatalog ? t.catalogTitle(selectableCatalog, false) : discover.selected.request.path.id;
|
|
}
|
|
:
|
|
null,
|
|
onSelect: (event) => {
|
|
navigate(event.value.replace('#', ''));
|
|
}
|
|
};
|
|
const extraSelects = discover.selectable.extra.map(({ name, isRequired, options }) => ({
|
|
title: t.stringWithPrefix(name, 'SELECT_'),
|
|
isRequired: isRequired,
|
|
options: options.map(({ value, deepLinks }) => ({
|
|
label: typeof value === 'string' ? t.stringWithPrefix(value) : t.string('NONE'),
|
|
value: JSON.stringify({
|
|
href: deepLinks.discover,
|
|
value
|
|
})
|
|
})),
|
|
selected: options
|
|
.filter(({ selected }) => selected)
|
|
.map(({ value, deepLinks }) => JSON.stringify({
|
|
href: deepLinks.discover,
|
|
value
|
|
})),
|
|
renderLabelText: options.some(({ selected, value }) => selected && value === null) ?
|
|
() => t.stringWithPrefix(name, 'SELECT_')
|
|
:
|
|
null,
|
|
onSelect: (event) => {
|
|
const { href } = JSON.parse(event.value);
|
|
navigate(href.replace('#', ''));
|
|
}
|
|
}));
|
|
return [[typeSelect, catalogSelect, ...extraSelects], discover.selectable.nextPage];
|
|
};
|
|
|
|
const useSelectableInputs = (discover) => {
|
|
const t = useTranslate();
|
|
const navigate = useNavigate();
|
|
const selectableInputs = React.useMemo(() => {
|
|
return mapSelectableInputs(discover, t, navigate);
|
|
}, [discover.selected, discover.selectable]);
|
|
return selectableInputs;
|
|
};
|
|
|
|
module.exports = useSelectableInputs;
|