aboutsummaryrefslogtreecommitdiff
path: root/src/views/login/register.js
blob: 69bb20bd741dc978c164aabfbde8db05ec733270 (plain)
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/* OpenBills-web - Web based libre billing software
 * Copyright (C) 2022  Vidhu Kant Sharma <vidhukant@vidhukant.xyz>

 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.

 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.

 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 */

import './scss/login.scss';
import { User, validateEmail, validateUsername, validatePassword, saveUser } from '../../classes/user';
import { notificationConfig } from "./../../classes/notifications";

import { Store } from "react-notifications-component";
import { useNavigate } from 'react-router-dom';
import { useState } from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
import { faEye } from '@fortawesome/free-solid-svg-icons'

const RegisterPage = () => {
  const navigate = useNavigate();
  const [user, setUser] = useState(new User());
  const [showPassword, setShowPassword] = useState(false);

  const validate = () =>
    validateUsername(user.UserName.trim()) &&
    validateEmail(user.Email) &&
    validatePassword(user.Password);

  const handleInput = ({target: {name, value}}) =>
    setUser(prev => ({...prev, [name]: value}));

  const handleSubmit = (e) => {
    e.preventDefault();
    if (validate()) saveUser(user, handleSuccess, handleError);
  }

  // for some reason pressing enter on the from clicks the /register link
  const handleEnter = e => {
    if (e.code === "Enter" || e.code === "NumpadEnter") {
      handleSubmit(e);
    }
  }

  const handleSuccess = () => {
    Store.addNotification({
      title: "Created new account",
      message: `Welcome to OpenBills, ${user.UserName}!`,
      ...notificationConfig("default")
    });
    navigate(`/login?user=${user.UserName}`);
  }

  const handleError = err => {
    Store.addNotification({
      title: "An error occoured",
      message: `Failed to create new account. ${err.message}`,
      ...notificationConfig("danger")
    });
  }

  return (
    <div className={"register-page-wrapper"}>
      <div className={"register-page"}>
        <h1>Sign Up To OpenBills</h1>
        <form onSubmit={handleSubmit} onKeyDown={handleEnter}>
          <label>
            Username:
            <input
              className={"wider"}
              name="UserName"
              type="text"
              value={user.UserName}
              onChange={handleInput}/>
          </label>
          <label>
            E-mail:
            <input
              className={"wider"}
              name="Email"
              type="text"
              value={user.Email}
              onChange={handleInput}/>
          </label>
          <label>
            Password:
            <span className={"input-with-icon"}>
              <input
                name="Password"
                type={showPassword ? "text" : "password"}
                value={user.Password}
                onChange={handleInput} />
              <FontAwesomeIcon
                icon={faEye}
                className={`icon ${showPassword ? "active" : ""}`}
                onClick={(e) => {
                  e.preventDefault();
                  setShowPassword(i => !i);
                }}/>
            </span>
          </label>
          <hr/>
          <div className={"buttons"}>
            <button onClick={_ => navigate("/login")}>Log In Instead</button>
            <input type="submit" value="Sign Up" disabled={!validate()}/>
          </div>
        </form>
      </div>
    </div>
  );
}

export default RegisterPage;