mirror of
https://github.com/movie-web/movie-web.git
synced 2025-01-04 07:15:59 +00:00
Add thumbnail generation as a setting
Co-authored-by: Jip Frijlink <JipFr@users.noreply.github.com>
This commit is contained in:
parent
965cc56570
commit
3b2be31691
|
@ -11,6 +11,7 @@ import { VideoClickTarget } from "@/components/player/internals/VideoClickTarget
|
||||||
import { VideoContainer } from "@/components/player/internals/VideoContainer";
|
import { VideoContainer } from "@/components/player/internals/VideoContainer";
|
||||||
import { PlayerHoverState } from "@/stores/player/slices/interface";
|
import { PlayerHoverState } from "@/stores/player/slices/interface";
|
||||||
import { usePlayerStore } from "@/stores/player/store";
|
import { usePlayerStore } from "@/stores/player/store";
|
||||||
|
import { usePreferencesStore } from "@/stores/preferences";
|
||||||
|
|
||||||
export interface PlayerProps {
|
export interface PlayerProps {
|
||||||
children?: ReactNode;
|
children?: ReactNode;
|
||||||
|
@ -78,6 +79,7 @@ function BaseContainer(props: { children?: ReactNode }) {
|
||||||
|
|
||||||
export function Container(props: PlayerProps) {
|
export function Container(props: PlayerProps) {
|
||||||
const propRef = useRef(props.onLoad);
|
const propRef = useRef(props.onLoad);
|
||||||
|
const enableThumbnails = usePreferencesStore((s) => s.enableThumbnails);
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
propRef.current?.();
|
propRef.current?.();
|
||||||
}, []);
|
}, []);
|
||||||
|
@ -86,7 +88,7 @@ export function Container(props: PlayerProps) {
|
||||||
<div className="relative">
|
<div className="relative">
|
||||||
<BaseContainer>
|
<BaseContainer>
|
||||||
<MetaReporter />
|
<MetaReporter />
|
||||||
<ThumbnailScraper />
|
{enableThumbnails ? <ThumbnailScraper /> : null}
|
||||||
<CastingInternal />
|
<CastingInternal />
|
||||||
<VideoContainer />
|
<VideoContainer />
|
||||||
<ProgressSaver />
|
<ProgressSaver />
|
||||||
|
|
|
@ -49,6 +49,7 @@ export function useSettingsState(
|
||||||
icon: string;
|
icon: string;
|
||||||
}
|
}
|
||||||
| undefined,
|
| undefined,
|
||||||
|
enableThumbnails: boolean,
|
||||||
) {
|
) {
|
||||||
const [proxyUrlsState, setProxyUrls, resetProxyUrls, proxyUrlsChanged] =
|
const [proxyUrlsState, setProxyUrls, resetProxyUrls, proxyUrlsChanged] =
|
||||||
useDerived(proxyUrls);
|
useDerived(proxyUrls);
|
||||||
|
@ -71,6 +72,12 @@ export function useSettingsState(
|
||||||
] = useDerived(deviceName);
|
] = useDerived(deviceName);
|
||||||
const [profileState, setProfileState, resetProfile, profileChanged] =
|
const [profileState, setProfileState, resetProfile, profileChanged] =
|
||||||
useDerived(profile);
|
useDerived(profile);
|
||||||
|
const [
|
||||||
|
enableThumbnailsState,
|
||||||
|
setEnableThumbnailsState,
|
||||||
|
resetEnableThumbnails,
|
||||||
|
enableThumbnailsChanged,
|
||||||
|
] = useDerived(enableThumbnails);
|
||||||
|
|
||||||
function reset() {
|
function reset() {
|
||||||
resetTheme();
|
resetTheme();
|
||||||
|
@ -80,6 +87,7 @@ export function useSettingsState(
|
||||||
resetBackendUrl();
|
resetBackendUrl();
|
||||||
resetDeviceName();
|
resetDeviceName();
|
||||||
resetProfile();
|
resetProfile();
|
||||||
|
resetEnableThumbnails();
|
||||||
}
|
}
|
||||||
|
|
||||||
const changed =
|
const changed =
|
||||||
|
@ -89,7 +97,8 @@ export function useSettingsState(
|
||||||
deviceNameChanged ||
|
deviceNameChanged ||
|
||||||
backendUrlChanged ||
|
backendUrlChanged ||
|
||||||
proxyUrlsChanged ||
|
proxyUrlsChanged ||
|
||||||
profileChanged;
|
profileChanged ||
|
||||||
|
enableThumbnailsChanged;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
reset,
|
reset,
|
||||||
|
@ -129,5 +138,10 @@ export function useSettingsState(
|
||||||
set: setProfileState,
|
set: setProfileState,
|
||||||
changed: profileChanged,
|
changed: profileChanged,
|
||||||
},
|
},
|
||||||
|
enableThumbnails: {
|
||||||
|
state: enableThumbnailsState,
|
||||||
|
set: setEnableThumbnailsState,
|
||||||
|
changed: enableThumbnailsChanged,
|
||||||
|
},
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,11 +31,12 @@ import { ThemePart } from "@/pages/parts/settings/ThemePart";
|
||||||
import { PageTitle } from "@/pages/parts/util/PageTitle";
|
import { PageTitle } from "@/pages/parts/util/PageTitle";
|
||||||
import { AccountWithToken, useAuthStore } from "@/stores/auth";
|
import { AccountWithToken, useAuthStore } from "@/stores/auth";
|
||||||
import { useLanguageStore } from "@/stores/language";
|
import { useLanguageStore } from "@/stores/language";
|
||||||
|
import { usePreferencesStore } from "@/stores/preferences";
|
||||||
import { useSubtitleStore } from "@/stores/subtitles";
|
import { useSubtitleStore } from "@/stores/subtitles";
|
||||||
import { useThemeStore } from "@/stores/theme";
|
import { useThemeStore } from "@/stores/theme";
|
||||||
|
|
||||||
import { SubPageLayout } from "./layouts/SubPageLayout";
|
import { SubPageLayout } from "./layouts/SubPageLayout";
|
||||||
import { LocalePart } from "./parts/settings/LocalePart";
|
import { PreferencesPart } from "./parts/settings/PreferencesPart";
|
||||||
|
|
||||||
function SettingsLayout(props: { children: React.ReactNode }) {
|
function SettingsLayout(props: { children: React.ReactNode }) {
|
||||||
const { isMobile } = useIsMobile();
|
const { isMobile } = useIsMobile();
|
||||||
|
@ -115,6 +116,9 @@ export function SettingsPage() {
|
||||||
const backendUrlSetting = useAuthStore((s) => s.backendUrl);
|
const backendUrlSetting = useAuthStore((s) => s.backendUrl);
|
||||||
const setBackendUrl = useAuthStore((s) => s.setBackendUrl);
|
const setBackendUrl = useAuthStore((s) => s.setBackendUrl);
|
||||||
|
|
||||||
|
const enableThumbnails = usePreferencesStore((s) => s.enableThumbnails);
|
||||||
|
const setEnableThumbnails = usePreferencesStore((s) => s.setEnableThumbnails);
|
||||||
|
|
||||||
const account = useAuthStore((s) => s.account);
|
const account = useAuthStore((s) => s.account);
|
||||||
const updateProfile = useAuthStore((s) => s.setAccountProfile);
|
const updateProfile = useAuthStore((s) => s.setAccountProfile);
|
||||||
const updateDeviceName = useAuthStore((s) => s.updateDeviceName);
|
const updateDeviceName = useAuthStore((s) => s.updateDeviceName);
|
||||||
|
@ -136,6 +140,7 @@ export function SettingsPage() {
|
||||||
proxySet,
|
proxySet,
|
||||||
backendUrlSetting,
|
backendUrlSetting,
|
||||||
account?.profile,
|
account?.profile,
|
||||||
|
enableThumbnails,
|
||||||
);
|
);
|
||||||
|
|
||||||
const saveChanges = useCallback(async () => {
|
const saveChanges = useCallback(async () => {
|
||||||
|
@ -168,6 +173,7 @@ export function SettingsPage() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setEnableThumbnails(state.enableThumbnails.state);
|
||||||
setAppLanguage(state.appLanguage.state);
|
setAppLanguage(state.appLanguage.state);
|
||||||
setTheme(state.theme.state);
|
setTheme(state.theme.state);
|
||||||
setSubStyling(state.subtitleStyling.state);
|
setSubStyling(state.subtitleStyling.state);
|
||||||
|
@ -186,6 +192,7 @@ export function SettingsPage() {
|
||||||
state,
|
state,
|
||||||
account,
|
account,
|
||||||
backendUrl,
|
backendUrl,
|
||||||
|
setEnableThumbnails,
|
||||||
setAppLanguage,
|
setAppLanguage,
|
||||||
setTheme,
|
setTheme,
|
||||||
setSubStyling,
|
setSubStyling,
|
||||||
|
@ -225,10 +232,12 @@ export function SettingsPage() {
|
||||||
<RegisterCalloutPart />
|
<RegisterCalloutPart />
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
<div id="settings-locale" className="mt-48">
|
<div id="settings-preferences" className="mt-48">
|
||||||
<LocalePart
|
<PreferencesPart
|
||||||
language={state.appLanguage.state}
|
language={state.appLanguage.state}
|
||||||
setLanguage={state.appLanguage.set}
|
setLanguage={state.appLanguage.set}
|
||||||
|
enableThumbnails={state.enableThumbnails.state}
|
||||||
|
setEnableThumbnails={state.enableThumbnails.set}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div id="settings-appearance" className="mt-48">
|
<div id="settings-appearance" className="mt-48">
|
||||||
|
|
|
@ -6,9 +6,11 @@ import { Heading1 } from "@/components/utils/Text";
|
||||||
import { appLanguageOptions } from "@/setup/i18n";
|
import { appLanguageOptions } from "@/setup/i18n";
|
||||||
import { getLocaleInfo, sortLangCodes } from "@/utils/language";
|
import { getLocaleInfo, sortLangCodes } from "@/utils/language";
|
||||||
|
|
||||||
export function LocalePart(props: {
|
export function PreferencesPart(props: {
|
||||||
language: string;
|
language: string;
|
||||||
setLanguage: (l: string) => void;
|
setLanguage: (l: string) => void;
|
||||||
|
enableThumbnails: boolean;
|
||||||
|
setEnableThumbnails: (v: boolean) => void;
|
||||||
}) {
|
}) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const sorted = sortLangCodes(appLanguageOptions.map((item) => item.code));
|
const sorted = sortLangCodes(appLanguageOptions.map((item) => item.code));
|
||||||
|
@ -39,6 +41,9 @@ export function LocalePart(props: {
|
||||||
selectedItem={selected || options[0]}
|
selectedItem={selected || options[0]}
|
||||||
setSelectedItem={(opt) => props.setLanguage(opt.id)}
|
setSelectedItem={(opt) => props.setLanguage(opt.id)}
|
||||||
/>
|
/>
|
||||||
|
<p onClick={() => props.setEnableThumbnails(!props.enableThumbnails)}>
|
||||||
|
thumbnails: {props.enableThumbnails.toString()}
|
||||||
|
</p>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
24
src/stores/preferences/index.tsx
Normal file
24
src/stores/preferences/index.tsx
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
import { create } from "zustand";
|
||||||
|
import { persist } from "zustand/middleware";
|
||||||
|
import { immer } from "zustand/middleware/immer";
|
||||||
|
|
||||||
|
export interface PreferencesStore {
|
||||||
|
enableThumbnails: boolean;
|
||||||
|
setEnableThumbnails(v: boolean): void;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const usePreferencesStore = create(
|
||||||
|
persist(
|
||||||
|
immer<PreferencesStore>((set) => ({
|
||||||
|
enableThumbnails: false,
|
||||||
|
setEnableThumbnails(v) {
|
||||||
|
set((s) => {
|
||||||
|
s.enableThumbnails = v;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
})),
|
||||||
|
{
|
||||||
|
name: "__MW::preferences",
|
||||||
|
},
|
||||||
|
),
|
||||||
|
);
|
Loading…
Reference in a new issue