forked from owid/owid-grapher
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPostEditorPage.tsx
62 lines (54 loc) · 1.63 KB
/
PostEditorPage.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import React from "react"
import { observer } from "mobx-react"
import { observable, runInAction } from "mobx"
import { LoadingBlocker, BindString } from "./Forms.js"
import { AdminLayout } from "./AdminLayout.js"
import { AdminAppContext, AdminAppContextType } from "./AdminAppContext.js"
interface Post {
id: number
title: string
slug: string
publishedAt?: string
updatedAt: string
content: string
}
class PostEditor extends React.Component<{ post: Post }> {
render() {
const { post } = this.props
return (
<div className="PostEditor">
<BindString store={post} field="title" />
<BindString store={post} field="slug" />
<BindString store={post} field="content" textarea />
</div>
)
}
}
@observer
export class PostEditorPage extends React.Component<{ postId?: number }> {
static contextType = AdminAppContext
context!: AdminAppContextType
@observable.ref post?: Post
async fetchPost() {
const { postId } = this.props
const { admin } = this.context
const json = await admin.getJSON(`/api/posts/${postId}.json`)
runInAction(() => (this.post = json as Post))
}
componentDidMount() {
void this.fetchPost()
}
render() {
return (
<AdminLayout>
<main className="PostEditorPage">
{this.post ? (
<PostEditor post={this.post} />
) : (
<LoadingBlocker />
)}
</main>
</AdminLayout>
)
}
}