]> Untitled Git - lemmy-ui.git/blob - src/shared/components/home/setup.tsx
Change from using Link to NavLink. resolve #269
[lemmy-ui.git] / src / shared / components / home / setup.tsx
1 import { Component, linkEvent } from "inferno";
2 import { Helmet } from "inferno-helmet";
3 import { LoginResponse, Register, UserOperation } from "lemmy-js-client";
4 import { Subscription } from "rxjs";
5 import { delay, retryWhen, take } from "rxjs/operators";
6 import { i18n } from "../../i18next";
7 import { UserService, WebSocketService } from "../../services";
8 import { toast, wsClient, wsJsonToRes, wsUserOp } from "../../utils";
9 import { Spinner } from "../common/icon";
10 import { SiteForm } from "./site-form";
11
12 interface State {
13   userForm: Register;
14   doneRegisteringUser: boolean;
15   userLoading: boolean;
16 }
17
18 export class Setup extends Component<any, State> {
19   private subscription: Subscription;
20
21   private emptyState: State = {
22     userForm: {
23       username: undefined,
24       password: undefined,
25       password_verify: undefined,
26       show_nsfw: true,
27       // The first admin signup doesn't need a captcha
28       captcha_uuid: "",
29       captcha_answer: "",
30     },
31     doneRegisteringUser: false,
32     userLoading: false,
33   };
34
35   constructor(props: any, context: any) {
36     super(props, context);
37
38     this.state = this.emptyState;
39
40     this.subscription = WebSocketService.Instance.subject
41       .pipe(retryWhen(errors => errors.pipe(delay(3000), take(10))))
42       .subscribe(
43         msg => this.parseMessage(msg),
44         err => console.error(err),
45         () => console.log("complete")
46       );
47   }
48
49   componentWillUnmount() {
50     this.subscription.unsubscribe();
51   }
52
53   get documentTitle(): string {
54     return `${i18n.t("setup")} - Lemmy`;
55   }
56
57   render() {
58     return (
59       <div class="container">
60         <Helmet title={this.documentTitle} />
61         <div class="row">
62           <div class="col-12 offset-lg-3 col-lg-6">
63             <h3>{i18n.t("lemmy_instance_setup")}</h3>
64             {!this.state.doneRegisteringUser ? (
65               this.registerUser()
66             ) : (
67               <SiteForm />
68             )}
69           </div>
70         </div>
71       </div>
72     );
73   }
74
75   registerUser() {
76     return (
77       <form onSubmit={linkEvent(this, this.handleRegisterSubmit)}>
78         <h5>{i18n.t("setup_admin")}</h5>
79         <div class="form-group row">
80           <label class="col-sm-2 col-form-label" htmlFor="username">
81             {i18n.t("username")}
82           </label>
83           <div class="col-sm-10">
84             <input
85               type="text"
86               class="form-control"
87               id="username"
88               value={this.state.userForm.username}
89               onInput={linkEvent(this, this.handleRegisterUsernameChange)}
90               required
91               minLength={3}
92               pattern="[a-zA-Z0-9_]+"
93             />
94           </div>
95         </div>
96         <div class="form-group row">
97           <label class="col-sm-2 col-form-label" htmlFor="email">
98             {i18n.t("email")}
99           </label>
100
101           <div class="col-sm-10">
102             <input
103               type="email"
104               id="email"
105               class="form-control"
106               placeholder={i18n.t("optional")}
107               value={this.state.userForm.email}
108               onInput={linkEvent(this, this.handleRegisterEmailChange)}
109               minLength={3}
110             />
111           </div>
112         </div>
113         <div class="form-group row">
114           <label class="col-sm-2 col-form-label" htmlFor="password">
115             {i18n.t("password")}
116           </label>
117           <div class="col-sm-10">
118             <input
119               type="password"
120               id="password"
121               value={this.state.userForm.password}
122               onInput={linkEvent(this, this.handleRegisterPasswordChange)}
123               class="form-control"
124               required
125               maxLength={60}
126             />
127           </div>
128         </div>
129         <div class="form-group row">
130           <label class="col-sm-2 col-form-label" htmlFor="verify-password">
131             {i18n.t("verify_password")}
132           </label>
133           <div class="col-sm-10">
134             <input
135               type="password"
136               id="verify-password"
137               value={this.state.userForm.password_verify}
138               onInput={linkEvent(this, this.handleRegisterPasswordVerifyChange)}
139               class="form-control"
140               required
141               maxLength={60}
142             />
143           </div>
144         </div>
145         <div class="form-group row">
146           <div class="col-sm-10">
147             <button type="submit" class="btn btn-secondary">
148               {this.state.userLoading ? <Spinner /> : i18n.t("sign_up")}
149             </button>
150           </div>
151         </div>
152       </form>
153     );
154   }
155
156   handleRegisterSubmit(i: Setup, event: any) {
157     event.preventDefault();
158     i.state.userLoading = true;
159     i.setState(i.state);
160     event.preventDefault();
161     WebSocketService.Instance.send(wsClient.register(i.state.userForm));
162   }
163
164   handleRegisterUsernameChange(i: Setup, event: any) {
165     i.state.userForm.username = event.target.value;
166     i.setState(i.state);
167   }
168
169   handleRegisterEmailChange(i: Setup, event: any) {
170     i.state.userForm.email = event.target.value;
171     i.setState(i.state);
172   }
173
174   handleRegisterPasswordChange(i: Setup, event: any) {
175     i.state.userForm.password = event.target.value;
176     i.setState(i.state);
177   }
178
179   handleRegisterPasswordVerifyChange(i: Setup, event: any) {
180     i.state.userForm.password_verify = event.target.value;
181     i.setState(i.state);
182   }
183
184   parseMessage(msg: any) {
185     let op = wsUserOp(msg);
186     if (msg.error) {
187       toast(i18n.t(msg.error), "danger");
188       this.state.userLoading = false;
189       this.setState(this.state);
190       return;
191     } else if (op == UserOperation.Register) {
192       let data = wsJsonToRes<LoginResponse>(msg).data;
193       this.state.userLoading = false;
194       this.state.doneRegisteringUser = true;
195       UserService.Instance.login(data);
196       this.setState(this.state);
197     } else if (op == UserOperation.CreateSite) {
198       window.location.href = "/";
199     }
200   }
201 }