forked from Ivasoft/mattermost-mobile
* update dependencies * update dependencies * feedback review * update @mattermost/react-native-turbo-mailer
75 lines
2.5 KiB
TypeScript
75 lines
2.5 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import DatabaseProvider from '@nozbe/watermelondb/DatabaseProvider';
|
|
import React, {ComponentType, useEffect, useState} from 'react';
|
|
|
|
import ServerProvider from '@context/server';
|
|
import ThemeProvider from '@context/theme';
|
|
import UserLocaleProvider from '@context/user_locale';
|
|
import DatabaseManager from '@database/manager';
|
|
import {subscribeActiveServers} from '@database/subscription/servers';
|
|
|
|
import type {Database} from '@nozbe/watermelondb';
|
|
import type ServersModel from '@typings/database/models/app/servers';
|
|
|
|
type State = {
|
|
database: Database;
|
|
serverUrl: string;
|
|
serverDisplayName: string;
|
|
};
|
|
|
|
export function withServerDatabase<T extends JSX.IntrinsicAttributes>(Component: ComponentType<T>): ComponentType<T> {
|
|
return function ServerDatabaseComponent(props: T) {
|
|
const [state, setState] = useState<State | undefined>();
|
|
|
|
const observer = (servers: ServersModel[]) => {
|
|
const server = servers?.length ? servers.reduce((a, b) =>
|
|
(b.lastActiveAt > a.lastActiveAt ? b : a),
|
|
) : undefined;
|
|
|
|
if (server) {
|
|
const database =
|
|
DatabaseManager.serverDatabases[server.url]?.database;
|
|
|
|
if (database) {
|
|
setState({
|
|
database,
|
|
serverUrl: server.url,
|
|
serverDisplayName: server.displayName,
|
|
});
|
|
}
|
|
} else {
|
|
setState(undefined);
|
|
}
|
|
};
|
|
|
|
useEffect(() => {
|
|
const subscription = subscribeActiveServers(observer);
|
|
|
|
return () => {
|
|
subscription?.unsubscribe();
|
|
};
|
|
}, []);
|
|
|
|
if (!state?.database) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<DatabaseProvider
|
|
database={state.database}
|
|
key={state.serverUrl}
|
|
>
|
|
<UserLocaleProvider database={state.database}>
|
|
<ServerProvider server={{displayName: state.serverDisplayName, url: state.serverUrl}}>
|
|
<ThemeProvider database={state.database}>
|
|
<Component {...props}/>
|
|
</ThemeProvider>
|
|
</ServerProvider>
|
|
</UserLocaleProvider>
|
|
</DatabaseProvider>
|
|
);
|
|
};
|
|
}
|