forked from owid/owid-grapher
-
Notifications
You must be signed in to change notification settings - Fork 0
/
UserEditPage.tsx
70 lines (62 loc) · 2.01 KB
/
UserEditPage.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
63
64
65
66
67
68
69
70
import React from "react"
import { observer } from "mobx-react"
import { observable, runInAction } from "mobx"
import { BindString, Toggle } from "./Forms.js"
import { Redirect } from "react-router-dom"
import { AdminLayout } from "./AdminLayout.js"
import { AdminAppContext, AdminAppContextType } from "./AdminAppContext.js"
import { UserIndexMeta } from "./UserMeta.js"
@observer
export class UserEditPage extends React.Component<{ userId: number }> {
static contextType = AdminAppContext
context!: AdminAppContextType
@observable user?: UserIndexMeta
@observable isSaved: boolean = false
render() {
const { user, isSaved } = this
if (!user) return null
else if (isSaved) return <Redirect to="/users" />
return (
<AdminLayout>
<main className="UserEditPage">
<BindString
label="Full Name"
field="fullName"
store={user}
/>
<Toggle
label="User has access"
value={user.isActive}
onValue={(v) => (user.isActive = v)}
/>
<button
className="btn btn-success"
onClick={() => this.save()}
>
Update user
</button>
</main>
</AdminLayout>
)
}
async save() {
if (this.user) {
await this.context.admin.requestJSON(
`/api/users/${this.props.userId}`,
this.user,
"PUT"
)
this.isSaved = true
}
}
async getData() {
const { admin } = this.context
const json = await admin.getJSON(`/api/users/${this.props.userId}.json`)
runInAction(() => {
this.user = json.user
})
}
componentDidMount() {
void this.getData()
}
}