Spaces:
Running
Running
"use client" | |
import { create } from "zustand" | |
import { ChannelInfo, MediaInfo, InterfaceDisplayMode, InterfaceView, InterfaceMenuMode, InterfaceHeaderMode, CommentInfo, UserInfo } from "@/types/general" | |
import { BasicSearchResult } from "../api/v1/search/types" | |
export const useStore = create<{ | |
displayMode: InterfaceDisplayMode | |
setDisplayMode: (displayMode: InterfaceDisplayMode) => void | |
headerMode: InterfaceHeaderMode | |
setHeaderMode: (headerMode: InterfaceHeaderMode) => void | |
menuMode: InterfaceMenuMode | |
setMenuMode: (menuMode: InterfaceMenuMode) => void | |
view: InterfaceView | |
setView: (view?: InterfaceView) => void | |
setPathname: (pathname: string) => void | |
jwtToken: string | |
setJwtToken: (jwtToken: string) => void | |
searchQuery: string | |
setSearchQuery: (searchQuery?: string) => void | |
showAutocompleteBox: boolean | |
setShowAutocompleteBox: (showAutocompleteBox: boolean) => void | |
searchAutocompleteQuery: string | |
setSearchAutocompleteQuery: (searchAutocompleteQuery?: string) => void | |
searchAutocompleteResults: BasicSearchResult[] | |
setSearchAutocompleteResults: (searchAutocompleteResults: BasicSearchResult[]) => void | |
searchResults: MediaInfo[] | |
setSearchResults: (searchResults: MediaInfo[]) => void | |
currentUser?: UserInfo | |
setCurrentUser: (currentUser?: UserInfo) => void | |
publicChannel?: ChannelInfo | |
setPublicChannel: (setPublicChannel?: ChannelInfo) => void | |
publicChannels: ChannelInfo[] | |
setPublicChannels: (publicChannels?: ChannelInfo[]) => void | |
userChannel?: ChannelInfo | |
setUserChannel: (userChannel?: ChannelInfo) => void | |
userChannels: ChannelInfo[] | |
setUserChannels: (userChannels?: ChannelInfo[]) => void | |
currentTag?: string | |
setCurrentTag: (currentTag?: string) => void | |
currentTags: string[] | |
setCurrentTags: (currentTags?: string[]) => void | |
currentModels: string[] | |
setCurrentModels: (currentModels?: string[]) => void | |
currentModel?: string | |
setCurrentModel: (currentModel?: string) => void | |
publicMedia?: MediaInfo | |
setPublicMedia: (publicMedia?: MediaInfo) => void | |
publicComments: CommentInfo[] | |
setPublicComments: (publicComment: CommentInfo[]) => void | |
publicMedias: MediaInfo[] | |
setPublicMedias: (publicMedias?: MediaInfo[]) => void | |
latentMedia?: MediaInfo | |
setPublicLatentMedia: (latentMedia?: MediaInfo) => void | |
latentMedias: MediaInfo[] | |
setPublicLatentMedias: (latentMedias?: MediaInfo[]) => void | |
publicChannelVideos: MediaInfo[] | |
setPublicChannelVideos: (publicChannelVideos: MediaInfo[]) => void | |
publicTrack?: MediaInfo | |
setPublicTrack: (publicTrack?: MediaInfo) => void | |
publicTracks: MediaInfo[] | |
setPublicTracks: (publicTracks: MediaInfo[]) => void | |
userVideo?: MediaInfo | |
setUserVideo: (userVideo?: MediaInfo) => void | |
userVideos: MediaInfo[] | |
setUserVideos: (userVideos: MediaInfo[]) => void | |
recommendedVideos: MediaInfo[] | |
setRecommendedVideos: (recommendedVideos: MediaInfo[]) => void | |
// currentPrompts: MediaInfo[] | |
// setCurrentPrompts: (currentPrompts: MediaInfo[]) => void | |
}>((set, get) => ({ | |
displayMode: "desktop", | |
setDisplayMode: (displayMode: InterfaceDisplayMode) => { | |
set({ displayMode }) | |
}, | |
view: "home", | |
setView: (view?: InterfaceView) => { | |
// TODO: download videos for this new channel | |
set({ view: view || "home" }) | |
}, | |
setPathname: (pathname: string) => { | |
const routes: Record<string, InterfaceView> = { | |
"/": "home", | |
"/watch": "public_media", | |
"/embed": "public_media_embed", | |
"/music": "public_music_videos", | |
"/channels": "public_channels", | |
"/latent/search": "public_latent_search", | |
"/latent/watch": "public_latent_media", | |
"/latent/embed": "public_latent_media_embed", | |
"/channel": "public_channel", | |
// those are reserved for future use | |
"/gaming": "public_music_videos", | |
"/live": "public_music_videos", | |
"/tv": "public_music_videos", | |
"/account": "user_account", | |
"/account/channel": "user_channel", | |
} | |
set({ view: routes[pathname] || "not_found" }) | |
}, | |
jwtToken: "", | |
setJwtToken: (jwtToken: string) => { | |
set({ jwtToken }) | |
}, | |
searchAutocompleteQuery: "", | |
setSearchAutocompleteQuery: (searchAutocompleteQuery?: string) => { | |
set({ searchAutocompleteQuery }) | |
}, | |
showAutocompleteBox: false, | |
setShowAutocompleteBox: (showAutocompleteBox: boolean) => { | |
set({ showAutocompleteBox }) | |
}, | |
searchAutocompleteResults: [] as BasicSearchResult[], | |
setSearchAutocompleteResults: (searchAutocompleteResults: BasicSearchResult[]) => { | |
set({ searchAutocompleteResults }) | |
}, | |
searchQuery: "", | |
setSearchQuery: (searchQuery?: string) => { | |
set({ searchQuery }) | |
}, | |
searchResults: [] as MediaInfo[], | |
setSearchResults: (searchResults: MediaInfo[]) => { | |
set({ searchResults }) | |
}, | |
currentUser: undefined, | |
setCurrentUser: (currentUser?: UserInfo) => { | |
set({ currentUser }) | |
}, | |
headerMode: "normal" as InterfaceHeaderMode, | |
setHeaderMode: (headerMode: InterfaceHeaderMode) => { | |
set({ headerMode }) | |
}, | |
menuMode: "normal_icon", | |
setMenuMode: (menuMode: InterfaceMenuMode) => { | |
set({ menuMode }) | |
}, | |
publicChannel: undefined, | |
setPublicChannel: (publicChannel?: ChannelInfo) => { | |
// TODO: download videos for this new channel | |
set({ publicChannel }) | |
}, | |
publicChannels: [], | |
setPublicChannels: (publicChannels: ChannelInfo[] = []) => { | |
// TODO: download videos for this new channel | |
set({ publicChannels: Array.isArray(publicChannels) ? publicChannels : [] }) | |
}, | |
userChannel: undefined, | |
setUserChannel: (userChannel?: ChannelInfo) => { | |
// TODO: download videos for this new channel | |
set({ userChannel }) | |
}, | |
userChannels: [], | |
setUserChannels: (userChannels: ChannelInfo[] = []) => { | |
// TODO: download videos for this new channel | |
set({ userChannels: Array.isArray(userChannels) ? userChannels : [] }) | |
}, | |
currentTag: undefined, | |
setCurrentTag: (currentTag?: string) => { | |
set({ currentTag }) | |
}, | |
currentTags: [], | |
setCurrentTags: (currentTags?: string[]) => { | |
set({ currentTags }) | |
}, | |
currentModels: [], | |
setCurrentModels: (currentModels?: string[]) => { | |
set({ currentModels }) | |
}, | |
currentModel: undefined, | |
setCurrentModel: (currentModel?: string) => { | |
set({ currentModel }) | |
}, | |
publicMedia: undefined, | |
setPublicMedia: (publicMedia?: MediaInfo) => { | |
set({ publicMedia }) | |
}, | |
publicComments: [], | |
setPublicComments: (publicComments: CommentInfo[]) => { | |
set({ publicComments }) | |
}, | |
publicMedias: [], | |
setPublicMedias: (publicMedias: MediaInfo[] = []) => { | |
set({ | |
publicMedias: Array.isArray(publicMedias) ? publicMedias : [] | |
}) | |
}, | |
latentMedia: undefined, | |
setPublicLatentMedia: (latentMedia?: MediaInfo) => { | |
set({ latentMedia }) | |
}, | |
latentMedias: [], | |
setPublicLatentMedias: (latentMedias: MediaInfo[] = []) => { | |
set({ | |
latentMedias: Array.isArray(latentMedias) ? latentMedias : [] | |
}) | |
}, | |
publicTrack: undefined, | |
setPublicTrack: (publicTrack?: MediaInfo) => { | |
set({ publicTrack }) | |
}, | |
publicTracks: [], | |
setPublicTracks: (publicTracks: MediaInfo[] = []) => { | |
set({ | |
publicTracks: Array.isArray(publicTracks) ? publicTracks : [] | |
}) | |
}, | |
publicChannelVideos: [], | |
setPublicChannelVideos: (publicChannelVideos: MediaInfo[] = []) => { | |
set({ | |
publicMedias: Array.isArray(publicChannelVideos) ? publicChannelVideos : [] | |
}) | |
}, | |
userVideo: undefined, | |
setUserVideo: (userVideo?: MediaInfo) => { set({ userVideo }) }, | |
userVideos: [], | |
setUserVideos: (userVideos: MediaInfo[] = []) => { | |
set({ | |
userVideos: Array.isArray(userVideos) ? userVideos : [] | |
}) | |
}, | |
recommendedVideos: [], | |
setRecommendedVideos: (recommendedVideos: MediaInfo[]) => { | |
set({ | |
recommendedVideos: Array.isArray(recommendedVideos) ? recommendedVideos : [] | |
}) | |
}, | |
})) |