59 lines
1.5 KiB
JavaScript
59 lines
1.5 KiB
JavaScript
// @flow
|
||
import { inject } from "mobx-react";
|
||
import queryString from "query-string";
|
||
import * as React from "react";
|
||
import {
|
||
type RouterHistory,
|
||
type Location,
|
||
type Match,
|
||
} from "react-router-dom";
|
||
import DocumentsStore from "stores/DocumentsStore";
|
||
import UiStore from "stores/UiStore";
|
||
import CenteredContent from "components/CenteredContent";
|
||
import Flex from "components/Flex";
|
||
import LoadingPlaceholder from "components/LoadingPlaceholder";
|
||
import { editDocumentUrl } from "utils/routeHelpers";
|
||
|
||
type Props = {
|
||
history: RouterHistory,
|
||
location: Location,
|
||
documents: DocumentsStore,
|
||
ui: UiStore,
|
||
match: Match,
|
||
};
|
||
|
||
class DocumentNew extends React.Component<Props> {
|
||
async componentDidMount() {
|
||
const params = queryString.parse(this.props.location.search);
|
||
|
||
try {
|
||
const document = await this.props.documents.create({
|
||
collectionId: this.props.match.params.id,
|
||
parentDocumentId: params.parentDocumentId,
|
||
templateId: params.templateId,
|
||
template: params.template,
|
||
title: "",
|
||
text: "",
|
||
});
|
||
this.props.history.replace(editDocumentUrl(document));
|
||
} catch (err) {
|
||
this.props.ui.showToast("Couldn’t create the document, try again?", {
|
||
type: "error",
|
||
});
|
||
this.props.history.goBack();
|
||
}
|
||
}
|
||
|
||
render() {
|
||
return (
|
||
<Flex column auto>
|
||
<CenteredContent>
|
||
<LoadingPlaceholder />
|
||
</CenteredContent>
|
||
</Flex>
|
||
);
|
||
}
|
||
}
|
||
|
||
export default inject("documents", "ui")(DocumentNew);
|