session-desktop/ts/components/session/SessionInboxView.tsx

107 lines
3.2 KiB
TypeScript
Raw Normal View History

2020-11-13 04:29:59 +01:00
import React from 'react';
import { Provider } from 'react-redux';
import { bindActionCreators } from 'redux';
2021-03-04 23:24:25 +01:00
import { ConversationModel } from '../../models/conversation';
2021-01-29 01:29:24 +01:00
import { ConversationController } from '../../session/conversations';
import { UserUtils } from '../../session/utils';
2020-11-13 04:29:59 +01:00
import { createStore } from '../../state/createStore';
2020-11-17 03:30:24 +01:00
import { actions as conversationActions } from '../../state/ducks/conversations';
2020-11-13 04:29:59 +01:00
import { SmartLeftPane } from '../../state/smart/LeftPane';
import { SmartSessionMainPanel } from '../../state/smart/SessionMainPanel';
2021-02-08 06:18:36 +01:00
import { makeLookup } from '../../util';
2020-11-13 04:29:59 +01:00
// Workaround: A react component's required properties are filtering up through connect()
// https://github.com/DefinitelyTyped/DefinitelyTyped/issues/31363
const FilteredLeftPane = SmartLeftPane as any;
type State = {
isInitialLoadComplete: boolean;
isExpired: boolean;
2020-11-13 04:29:59 +01:00
};
export class SessionInboxView extends React.Component<any, State> {
private store: any;
constructor(props: any) {
super(props);
this.state = {
isInitialLoadComplete: false,
isExpired: false,
};
void this.setupLeftPane();
// not reactified yet. this is a callback called once we were able to check for expiration of this Session version
window.extension.expired((expired: boolean) => {
if (expired) {
this.setState({
isExpired: true,
});
}
});
}
2020-11-13 04:29:59 +01:00
public render() {
if (!this.state.isInitialLoadComplete) {
return <></>;
}
2020-11-13 04:29:59 +01:00
return (
<Provider store={this.store}>
<div className="gutter">
<div className="network-status-container" />
{this.renderLeftPane()}
</div>
<SmartSessionMainPanel />
</Provider>
);
}
2020-11-13 04:29:59 +01:00
private renderLeftPane() {
return <FilteredLeftPane isExpired={this.state.isExpired} />;
}
private async setupLeftPane() {
// Here we set up a full redux store with initial state for our LeftPane Root
const convoCollection = ConversationController.getInstance().getConversations();
const conversations = convoCollection.map(
2021-03-04 23:24:25 +01:00
(conversation: ConversationModel) => conversation.getProps()
);
2021-02-08 06:18:36 +01:00
const filledConversations = conversations.map((conv: any) => {
return { ...conv, messages: [] };
});
const fullFilledConversations = await Promise.all(filledConversations);
const initialState = {
conversations: {
2021-02-08 06:18:36 +01:00
conversationLookup: makeLookup(fullFilledConversations, 'id'),
},
user: {
2021-01-19 01:25:03 +01:00
ourPrimary: window.storage.get('primaryDevicePubKey'),
2021-01-29 01:29:24 +01:00
ourNumber: UserUtils.getOurPubKeyStrFromCache(),
i18n: window.i18n,
},
section: {
focusedSection: 1,
},
};
this.store = createStore(initialState);
window.inboxStore = this.store;
// Enables our redux store to be updated by backbone events in the outside world
const { messageExpired } = bindActionCreators(
conversationActions,
this.store.dispatch
);
window.actionsCreators = conversationActions;
// messageExpired is currently inboked fropm js. So we link it to Redux that way
window.Whisper.events.on('messageExpired', messageExpired);
this.setState({ isInitialLoadComplete: true });
}
2020-11-13 04:29:59 +01:00
}