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()
|
2022-12-08 14:32:50 -05:00
|
|
|
?.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>
|
|
|
|
);
|
|
|
|
};
|