mirror of
https://github.com/Stremio/stremio-web.git
synced 2026-03-11 21:27:05 +00:00
useInLibrary hook linked with the core
This commit is contained in:
parent
e2961e50f4
commit
b2bfcee2f8
2 changed files with 70 additions and 9 deletions
|
|
@ -1,12 +1,60 @@
|
|||
const useBinaryState = require('stremio/common/useBinaryState');
|
||||
const React = require('react');
|
||||
const { useServices } = require('stremio/services');
|
||||
const useModelState = require('stremio/common/useModelState');
|
||||
|
||||
const useInLibrary = (id) => {
|
||||
const [inLibrary, addToLibrary, removeFromLibrary, toggleInLibrary] = useBinaryState(false);
|
||||
if (typeof id === 'string') {
|
||||
return [inLibrary, addToLibrary, removeFromLibrary, toggleInLibrary];
|
||||
} else {
|
||||
return [false, null, null, null];
|
||||
}
|
||||
const useInLibrary = (metaItem) => {
|
||||
const { core } = useServices();
|
||||
const initLibraryItemsState = React.useCallback(() => {
|
||||
return core.getState('library_items');
|
||||
}, []);
|
||||
const libraryItems = useModelState({
|
||||
model: 'library_items',
|
||||
init: initLibraryItemsState
|
||||
});
|
||||
const addToLibrary = React.useCallback((metaItem) => {
|
||||
core.dispatch({
|
||||
action: 'UserOp',
|
||||
args: {
|
||||
userOp: 'AddToLibrary',
|
||||
args: {
|
||||
meta_item: metaItem,
|
||||
now: new Date()
|
||||
}
|
||||
}
|
||||
});
|
||||
}, []);
|
||||
const removeFromLibrary = React.useCallback((id) => {
|
||||
core.dispatch({
|
||||
action: 'UserOp',
|
||||
args: {
|
||||
userOp: 'RemoveFromLibrary',
|
||||
args: {
|
||||
id,
|
||||
now: new Date()
|
||||
}
|
||||
}
|
||||
});
|
||||
}, []);
|
||||
const inLibrary = React.useMemo(() => {
|
||||
return typeof metaItem === 'object' && metaItem !== null ?
|
||||
libraryItems.ids.includes(metaItem.id)
|
||||
:
|
||||
false;
|
||||
}, [metaItem, libraryItems]);
|
||||
const toggleInLibrary = React.useMemo(() => {
|
||||
if (typeof metaItem !== 'object' || metaItem === null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return () => {
|
||||
if (inLibrary) {
|
||||
removeFromLibrary(metaItem.id);
|
||||
} else {
|
||||
addToLibrary(metaItem);
|
||||
}
|
||||
};
|
||||
}, [metaItem, inLibrary]);
|
||||
return [inLibrary, toggleInLibrary];
|
||||
};
|
||||
|
||||
module.exports = useInLibrary;
|
||||
|
|
|
|||
|
|
@ -11,7 +11,20 @@ const MetaDetails = ({ urlParams }) => {
|
|||
const [metaResourceRef, metaResources, selectedMetaResource] = useSelectableResource(metaDetails.selected.meta_resource_ref, metaDetails.meta_resources);
|
||||
const streamsResourceRef = metaDetails.selected.streams_resource_ref;
|
||||
const streamsResources = metaDetails.streams_resources;
|
||||
const [inLibrary, , , toggleInLibrary] = useInLibrary(metaResourceRef !== null ? metaResourceRef.id : null);
|
||||
const metaItem = React.useMemo(() => {
|
||||
return selectedMetaResource !== null ?
|
||||
selectedMetaResource.content.content
|
||||
:
|
||||
metaResourceRef !== null ?
|
||||
{
|
||||
id: metaResourceRef.id,
|
||||
type: metaResourceRef.type_name,
|
||||
name: ''
|
||||
}
|
||||
:
|
||||
null;
|
||||
}, [metaResourceRef, selectedMetaResource]);
|
||||
const [inLibrary, toggleInLibrary] = useInLibrary(metaItem);
|
||||
return (
|
||||
<div className={styles['metadetails-container']}>
|
||||
<NavBar
|
||||
|
|
|
|||
Loading…
Reference in a new issue