mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-10 02:03:07 +08:00
126 lines
3.6 KiB
JavaScript
126 lines
3.6 KiB
JavaScript
/* eslint react/sort-comp: 0 */
|
|
import _ from 'underscore';
|
|
import React from 'react';
|
|
import {remote} from 'electron';
|
|
|
|
import {
|
|
Message,
|
|
Actions,
|
|
DraftStore,
|
|
ComponentRegistry,
|
|
WorkspaceStore,
|
|
} from 'nylas-exports';
|
|
import ComposeButton from './compose-button';
|
|
import ComposerView from './composer-view';
|
|
|
|
import InflateDraftClientId from './decorators/inflate-draft-client-id';
|
|
const ComposerViewForDraftClientId = InflateDraftClientId(ComposerView);
|
|
|
|
class ComposerWithWindowProps extends React.Component {
|
|
static displayName = 'ComposerWithWindowProps';
|
|
static containerRequired = false;
|
|
|
|
constructor(props) {
|
|
super(props);
|
|
|
|
// We'll now always have windowProps by the time we construct this.
|
|
const windowProps = NylasEnv.getWindowProps()
|
|
const {draftJSON, draftClientId} = windowProps;
|
|
if (!draftJSON) {
|
|
throw new Error("Initialize popout composer windows with valid draftJSON")
|
|
}
|
|
const draft = new Message().fromJSON(draftJSON);
|
|
DraftStore._createSession(draftClientId, draft);
|
|
this.state = windowProps
|
|
}
|
|
|
|
onDraftReady = () => {
|
|
this.refs.composer.focus().then(() => {
|
|
NylasEnv.displayWindow();
|
|
if (this.state.errorMessage) {
|
|
this._showInitialErrorDialog(this.state.errorMessage);
|
|
}
|
|
|
|
// Give the composer some time to render before hitting another wall
|
|
// of javascript.
|
|
window.setTimeout(() => {
|
|
NylasEnv.getCurrentWindow().updateLoadSettings({
|
|
windowType: "composer",
|
|
})
|
|
|
|
// The call to updateLoadSettings will start loading the remaining
|
|
// packages. Once those packages load it'll cause a change in the
|
|
// root Sheet-level InjectedComponentSet, which will cause
|
|
// everything to re-render losing our focus. We have to manually
|
|
// refocus it but defer it so the event loop of the package
|
|
// activation happens first.
|
|
window.setTimeout(() => {
|
|
this.refs.composer.focus()
|
|
}, 32)
|
|
}, 32)
|
|
});
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<ComposerViewForDraftClientId
|
|
ref="composer"
|
|
onDraftReady={this.onDraftReady}
|
|
draftClientId={this.state.draftClientId}
|
|
className="composer-full-window"
|
|
/>
|
|
);
|
|
}
|
|
|
|
_showInitialErrorDialog(msg) {
|
|
const dialog = remote.require('dialog');
|
|
// We delay so the view has time to update the restored draft. If we
|
|
// don't delay the modal may come up in a state where the draft looks
|
|
// like it hasn't been restored or has been lost.
|
|
_.delay(() => {
|
|
dialog.showMessageBox(remote.getCurrentWindow(), {
|
|
type: 'warning',
|
|
buttons: ['Okay'],
|
|
message: "Error",
|
|
detail: msg,
|
|
});
|
|
}, 100);
|
|
}
|
|
}
|
|
|
|
export function activate() {
|
|
// Register our composer as the window-wide Composer
|
|
ComponentRegistry.register(ComposerViewForDraftClientId, {
|
|
role: 'Composer',
|
|
});
|
|
|
|
if (NylasEnv.isMainWindow()) {
|
|
ComponentRegistry.register(ComposeButton, {
|
|
location: WorkspaceStore.Location.RootSidebar.Toolbar,
|
|
});
|
|
}
|
|
|
|
NylasEnv.getCurrentWindow().setMinimumSize(480, 250);
|
|
|
|
const silent = !NylasEnv.isMainWindow()
|
|
WorkspaceStore.defineSheet('Main', {root: true, silent}, {
|
|
popout: ['Center'],
|
|
});
|
|
ComponentRegistry.register(ComposerWithWindowProps, {
|
|
location: WorkspaceStore.Location.Center,
|
|
});
|
|
|
|
if (silent) {
|
|
Actions.selectRootSheet(WorkspaceStore.Sheet.Main)
|
|
}
|
|
}
|
|
|
|
export function deactivate() {
|
|
ComponentRegistry.unregister(ComposerViewForDraftClientId);
|
|
ComponentRegistry.unregister(ComposeButton);
|
|
ComponentRegistry.unregister(ComposerWithWindowProps);
|
|
}
|
|
|
|
export function serialize() {
|
|
return this.state;
|
|
}
|