signal-desktop/ts/state/smart/App.tsx

90 lines
2.8 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2021 Signal Messenger, LLC
2021-06-17 21:15:09 +00:00
// SPDX-License-Identifier: AGPL-3.0-only
import React from 'react';
import { connect } from 'react-redux';
2023-08-29 00:41:32 +00:00
import type { VerificationTransport } from '../../types/VerificationTransport';
import { App } from '../../components/App';
import OS from '../../util/os/osMain';
2023-08-29 00:41:32 +00:00
import { strictAssert } from '../../util/assert';
2021-06-17 21:15:09 +00:00
import { SmartCallManager } from './CallManager';
import { SmartGlobalModalContainer } from './GlobalModalContainer';
2022-12-10 02:02:22 +00:00
import { SmartLightbox } from './Lightbox';
2022-07-06 19:06:20 +00:00
import { SmartStoryViewer } from './StoryViewer';
import type { StateType } from '../reducer';
import {
getIntl,
getLocaleMessages,
getTheme,
getIsMainWindowMaximized,
getIsMainWindowFullScreen,
getMenuOptions,
} from '../selectors/user';
2023-08-09 00:53:06 +00:00
import { hasSelectedStoryData } from '../selectors/stories';
import { getHideMenuBar } from '../selectors/items';
2021-06-17 21:15:09 +00:00
import { mapDispatchToProps } from '../actions';
2022-07-29 00:10:07 +00:00
import { ErrorBoundary } from '../../components/ErrorBoundary';
import { ModalContainer } from '../../components/ModalContainer';
2023-01-02 21:34:41 +00:00
import { SmartInbox } from './Inbox';
function renderInbox(): JSX.Element {
return <SmartInbox />;
}
2021-06-17 21:15:09 +00:00
const mapStateToProps = (state: StateType) => {
2022-07-29 00:10:07 +00:00
const i18n = getIntl(state);
2021-06-17 21:15:09 +00:00
return {
...state.app,
2022-07-29 00:10:07 +00:00
i18n,
localeMessages: getLocaleMessages(state),
isMaximized: getIsMainWindowMaximized(state),
isFullScreen: getIsMainWindowFullScreen(state),
menuOptions: getMenuOptions(state),
OS: OS.getName(),
osClassName: OS.getClassName(),
hideMenuBar: getHideMenuBar(state),
renderCallManager: () => (
<ModalContainer className="module-calling__modal-container">
<SmartCallManager />
</ModalContainer>
),
2021-06-17 21:15:09 +00:00
renderGlobalModalContainer: () => <SmartGlobalModalContainer />,
2022-12-10 02:02:22 +00:00
renderLightbox: () => <SmartLightbox />,
hasSelectedStoryData: hasSelectedStoryData(state),
renderStoryViewer: (closeView: () => unknown) => (
<ErrorBoundary name="App/renderStoryViewer" closeView={closeView}>
2022-07-29 00:10:07 +00:00
<SmartStoryViewer />
</ErrorBoundary>
),
2023-01-02 21:34:41 +00:00
renderInbox,
2021-11-30 17:51:53 +00:00
requestVerification: (
number: string,
2023-08-29 00:41:32 +00:00
captcha: string,
transport: VerificationTransport
): Promise<{ sessionId: string }> => {
const { server } = window.textsecure;
strictAssert(server !== undefined, 'WebAPI not available');
2021-11-30 17:51:53 +00:00
2023-08-29 00:41:32 +00:00
return server.requestVerification(number, captcha, transport);
2021-11-30 17:51:53 +00:00
},
2023-08-29 00:41:32 +00:00
registerSingleDevice: (
number: string,
code: string,
sessionId: string
): Promise<void> => {
return window
.getAccountManager()
.registerSingleDevice(number, code, sessionId);
2021-11-30 17:51:53 +00:00
},
2021-06-17 21:15:09 +00:00
theme: getTheme(state),
toast: state.toast.toast,
2021-06-17 21:15:09 +00:00
};
};
const smart = connect(mapStateToProps, mapDispatchToProps);
export const SmartApp = smart(App);