jellyfish-web/src/hooks/useApi.tsx

68 lines
2.2 KiB
TypeScript
Raw Normal View History

2022-11-18 12:55:46 -05:00
import type { Api } from '@jellyfin/sdk';
import type { UserDto } from '@jellyfin/sdk/lib/generated-client';
2022-11-28 16:51:57 -05:00
import type { ApiClient, Event } from 'jellyfin-apiclient';
2022-11-18 12:55:46 -05:00
import React, { createContext, FC, useContext, useEffect, useState } from 'react';
2022-11-30 14:18:49 -05:00
import ServerConnections from '../components/ServerConnections';
2022-11-18 12:55:46 -05:00
import events from '../utils/events';
import { toApi } from '../utils/jellyfin-apiclient/compat';
interface JellyfinApiContext {
__legacyApiClient__?: ApiClient
api?: Api
user?: UserDto
}
export const ApiContext = createContext<JellyfinApiContext>({});
export const useApi = () => useContext(ApiContext);
2022-11-30 14:18:49 -05:00
export const ApiProvider: FC = ({ children }) => {
2022-11-18 12:55:46 -05:00
const [ legacyApiClient, setLegacyApiClient ] = useState<ApiClient>();
const [ api, setApi ] = useState<Api>();
const [ user, setUser ] = useState<UserDto>();
useEffect(() => {
2022-11-30 14:18:49 -05:00
ServerConnections.currentApiClient()
?.getCurrentUser()
2022-11-28 16:51:57 -05:00
.then(newUser => updateApiUser(undefined, newUser))
2022-11-18 12:55:46 -05:00
.catch(err => {
2022-11-28 16:51:57 -05:00
console.info('[ApiProvider] Could not get current user', err);
2022-11-18 12:55:46 -05:00
});
2022-11-28 16:51:57 -05:00
const updateApiUser = (_e: Event | undefined, newUser: UserDto) => {
2022-11-18 12:55:46 -05:00
setUser(newUser);
if (newUser.ServerId) {
2022-11-30 14:18:49 -05:00
setLegacyApiClient(ServerConnections.getApiClient(newUser.ServerId));
2022-11-18 12:55:46 -05:00
}
};
const resetApiUser = () => {
setLegacyApiClient(undefined);
setUser(undefined);
};
2022-11-30 14:18:49 -05:00
events.on(ServerConnections, 'localusersignedin', updateApiUser);
events.on(ServerConnections, 'localusersignedout', resetApiUser);
2022-11-18 12:55:46 -05:00
return () => {
2022-11-30 14:18:49 -05:00
events.off(ServerConnections, 'localusersignedin', updateApiUser);
events.off(ServerConnections, 'localusersignedout', resetApiUser);
2022-11-18 12:55:46 -05:00
};
2022-11-30 14:18:49 -05:00
}, [ setLegacyApiClient, setUser ]);
2022-11-18 12:55:46 -05:00
useEffect(() => {
setApi(legacyApiClient ? toApi(legacyApiClient) : undefined);
}, [ legacyApiClient, setApi ]);
return (
<ApiContext.Provider value={{
__legacyApiClient__: legacyApiClient,
api,
user
}}>
{children}
</ApiContext.Provider>
);
};