implement filtered bookmarks that error check the provider

Co-authored-by: William Oldham <wegg7250@gmail.com>
This commit is contained in:
mrjvs 2022-03-06 12:11:16 +01:00
parent 079c514455
commit 356b9af4ff
7 changed files with 67 additions and 21 deletions

View file

@ -63,6 +63,7 @@ Check out [this project's issues](https://github.com/JamesHawkinss/movie-web/iss
- [ ] Implement all scrapers - [ ] Implement all scrapers
- [ ] implement sources that are not mp4 - [ ] implement sources that are not mp4
- [ ] Migrate old video progress - [ ] Migrate old video progress
- [ ] Bug: go back doesn't work if used directly from link
## After all rewrite code has been written ## After all rewrite code has been written

View file

@ -1,5 +1,5 @@
import { MWMediaType } from "providers"; import { MWMediaType, MWMediaProviderMetadata } from "providers";
import { mediaProviders } from "./providers"; import { mediaProviders, mediaProvidersUnchecked } from "./providers";
/* /*
** Fetch all enabled providers for a specific type ** Fetch all enabled providers for a specific type
@ -14,3 +14,27 @@ import { mediaProviders } from "./providers";
export function getProviderFromId(id: string) { export function getProviderFromId(id: string) {
return mediaProviders.find((v) => v.id === id); return mediaProviders.find((v) => v.id === id);
} }
/*
** Get a provider metadata
*/
export function getProviderMetadata(id: string): MWMediaProviderMetadata {
const provider = mediaProvidersUnchecked.find((v) => v.id === id);
if (!provider) {
return {
exists: false,
type: [],
enabled: false,
id,
};
}
return {
exists: true,
type: provider.type,
enabled: provider.enabled,
id,
provider,
};
}

View file

@ -2,9 +2,10 @@ import { tempScraper } from "providers/list/temp";
import { theFlixScraper } from "providers/list/theflix"; import { theFlixScraper } from "providers/list/theflix";
import { MWWrappedMediaProvider, WrapProvider } from "providers/wrapper"; import { MWWrappedMediaProvider, WrapProvider } from "providers/wrapper";
const mediaProvidersUnchecked: MWWrappedMediaProvider[] = [ export const mediaProvidersUnchecked: MWWrappedMediaProvider[] = [
WrapProvider(theFlixScraper), WrapProvider(theFlixScraper),
WrapProvider(tempScraper), WrapProvider(tempScraper),
]; ];
export const mediaProviders: MWWrappedMediaProvider[] = export const mediaProviders: MWWrappedMediaProvider[] =
mediaProvidersUnchecked.filter((v) => v.enabled); mediaProvidersUnchecked.filter((v) => v.enabled);

View file

@ -43,6 +43,14 @@ export interface MWMediaProvider {
getStream(media: MWPortableMedia): Promise<MWMediaStream>; getStream(media: MWPortableMedia): Promise<MWMediaStream>;
} }
export interface MWMediaProviderMetadata {
exists: boolean;
id?: string;
enabled: boolean;
type: MWMediaType[];
provider?: MWMediaProvider;
}
export interface MWMassProviderOutput { export interface MWMassProviderOutput {
providers: { providers: {
id: string; id: string;

View file

@ -1,4 +1,4 @@
import { MWMediaMeta } from "providers"; import { getProviderMetadata, MWMediaMeta } from "providers";
import { createContext, ReactNode, useContext, useState } from "react"; import { createContext, ReactNode, useContext, useState } from "react";
import { BookmarkStore } from "./store"; import { BookmarkStore } from "./store";
@ -8,11 +8,13 @@ interface BookmarkStoreData {
interface BookmarkStoreDataWrapper { interface BookmarkStoreDataWrapper {
setItemBookmark(media: MWMediaMeta, bookedmarked: boolean): void; setItemBookmark(media: MWMediaMeta, bookedmarked: boolean): void;
getFilteredBookmarks(): MWMediaMeta[];
bookmarkStore: BookmarkStoreData; bookmarkStore: BookmarkStoreData;
} }
const BookmarkedContext = createContext<BookmarkStoreDataWrapper>({ const BookmarkedContext = createContext<BookmarkStoreDataWrapper>({
setItemBookmark: () => {}, setItemBookmark: () => {},
getFilteredBookmarks: () => [],
bookmarkStore: { bookmarkStore: {
bookmarks: [], bookmarks: [],
}, },
@ -40,7 +42,7 @@ export function BookmarkContextProvider(props: { children: ReactNode }) {
setItemBookmark(media: MWMediaMeta, bookmarked: boolean) { setItemBookmark(media: MWMediaMeta, bookmarked: boolean) {
setBookmarked((data: BookmarkStoreData) => { setBookmarked((data: BookmarkStoreData) => {
if (bookmarked) { if (bookmarked) {
const itemIndex = getBookmarkIndexFromPortable(data, media); const itemIndex = getBookmarkIndexFromMedia(data.bookmarks, media);
if (itemIndex === -1) { if (itemIndex === -1) {
const item = { const item = {
mediaId: media.mediaId, mediaId: media.mediaId,
@ -54,7 +56,7 @@ export function BookmarkContextProvider(props: { children: ReactNode }) {
data.bookmarks.push(item); data.bookmarks.push(item);
} }
} else { } else {
const itemIndex = getBookmarkIndexFromPortable(data, media); const itemIndex = getBookmarkIndexFromMedia(data.bookmarks, media);
if (itemIndex !== -1) { if (itemIndex !== -1) {
data.bookmarks.splice(itemIndex); data.bookmarks.splice(itemIndex);
} }
@ -62,6 +64,11 @@ export function BookmarkContextProvider(props: { children: ReactNode }) {
return data; return data;
}); });
}, },
getFilteredBookmarks() {
return bookmarkStorage.bookmarks.filter((bookmark) => {
return getProviderMetadata(bookmark.providerId)?.enabled;
});
},
bookmarkStore: bookmarkStorage, bookmarkStore: bookmarkStorage,
}; };
@ -76,11 +83,11 @@ export function useBookmarkContext() {
return useContext(BookmarkedContext); return useContext(BookmarkedContext);
} }
function getBookmarkIndexFromPortable( function getBookmarkIndexFromMedia(
store: BookmarkStoreData, bookmarks: MWMediaMeta[],
media: MWMediaMeta media: MWMediaMeta
): number { ): number {
const a = store.bookmarks.findIndex((v) => { const a = bookmarks.findIndex((v) => {
return ( return (
v.mediaId === media.mediaId && v.mediaId === media.mediaId &&
v.providerId === media.providerId && v.providerId === media.providerId &&
@ -92,9 +99,9 @@ function getBookmarkIndexFromPortable(
} }
export function getIfBookmarkedFromPortable( export function getIfBookmarkedFromPortable(
store: BookmarkStoreData, bookmarks: MWMediaMeta[],
media: MWMediaMeta media: MWMediaMeta
): boolean { ): boolean {
const bookmarked = getBookmarkIndexFromPortable(store, media); const bookmarked = getBookmarkIndexFromMedia(bookmarks, media);
return bookmarked !== -1; return bookmarked !== -1;
} }

View file

@ -36,8 +36,11 @@ function StyledMediaView(props: StyledMediaViewProps) {
store.watched, store.watched,
props.media props.media
)?.progress; )?.progress;
const { setItemBookmark, bookmarkStore } = useBookmarkContext(); const { setItemBookmark, getFilteredBookmarks } = useBookmarkContext();
const isBookmarked = getIfBookmarkedFromPortable(bookmarkStore, props.media); const isBookmarked = getIfBookmarkedFromPortable(
getFilteredBookmarks(),
props.media
);
function updateProgress(e: Event) { function updateProgress(e: Event) {
if (!props.media) return; if (!props.media) return;

View file

@ -171,20 +171,22 @@ export function SearchView() {
} }
function ExtraItems() { function ExtraItems() {
const { bookmarkStore } = useBookmarkContext(); const { getFilteredBookmarks } = useBookmarkContext();
const { watched } = useWatchedContext(); const { watched } = useWatchedContext();
const bookmarks = getFilteredBookmarks();
const watchedItems = watched.items.filter( const watchedItems = watched.items.filter(
(v) => !getIfBookmarkedFromPortable(bookmarkStore, v) (v) => !getIfBookmarkedFromPortable(bookmarks, v)
); );
if (watchedItems.length === 0 && bookmarkStore.bookmarks.length === 0) if (watchedItems.length === 0 && bookmarks.length === 0) return null;
return null;
return ( return (
<div className="mb-16 mt-32"> <div className="mb-16 mt-32">
{bookmarkStore.bookmarks.length > 0 ? ( {bookmarks.length > 0 ? (
<SectionHeading title="Bookmarks" icon={Icons.BOOKMARK}> <SectionHeading title="Bookmarks" icon={Icons.BOOKMARK}>
{bookmarkStore.bookmarks.map((v) => ( {bookmarks.map((v) => (
<WatchedMediaCard <WatchedMediaCard
key={[v.mediaId, v.providerId].join("|")} key={[v.mediaId, v.providerId].join("|")}
media={v} media={v}