aboutsummaryrefslogtreecommitdiff
path: root/src/components/Form/Items/RegisterItemForm.tsx
blob: dc48d3c547d4fa911bba66490ff9d33908144999 (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
122
123
124
125
/*
 * OpenBills - Self hosted browser app to generate and keep track of simple invoices
 * Version - 0
 * Licensed under the MIT license - https://opensource.org/licenses/MIT
 *
 * Copyright (c) 2021 Vidhu Kant Sharma
*/

// TODO: Code isn't tested properly
// I'd be surprised if it < 10 bugs

// TODO: Implement override protection

import React, { useState } from "react";
import axios from "axios";
import "./../Form.scss";

interface props {
  defGSTValue: number
  setVisibility: any // this component's visibility
  updateItemsList: () => Promise<void>
}

const RegisterItemForm: React.FC<props> = (props) => {
  const [newItemNameValue, setNewItemNameValue] = useState<string>("");
  const [newItemDescValue, setNewItemDescValue] = useState<string>("");
  const [newItemPriceValue, setNewItemPriceValue] = useState<number>(0.00);
  const [newItemHSNValue, setNewItemHSNValue] = useState<number>();
  const [newItemGSTValue, setNewItemGSTValue] = useState<number>(props.defGSTValue);
  // const [newItemBrandValue, setNewItemBrandValue] = useState("");
  // const [newItemTypeValue, setNewItemTypeValue] = useState("");

  const hideSelf = () => props.setVisibility(false);

  const closeOnBGClicked = (event: any) => 
    event.target.className === "floatingMenuBG" && hideSelf();

  const postForm = (event: any) => {
    event.preventDefault();
    // TODO: show confirmation before being invisible
    axios.post(
      `/api/items/register/`
      + `?model=${newItemNameValue}`
      + `&desc=${newItemDescValue}`
      + `&price=${newItemPriceValue}`
      + `&hsn=${newItemHSNValue}`
      + `&gst=${newItemGSTValue}`
    )
      .then((res) => {
        console.log(res);
        hideSelf();
        props.updateItemsList();
      })
      .catch((err) => {
        console.log(err);
        alert("Something went wrong, please check the log by opening the console.")
      });
  }


  return (
    <div className={"floatingMenuBG"} onClick={closeOnBGClicked}>
      <div className={"floatingMenu"}>
        <div className={"formContainer"}>
          <form className={"floatingForm"} onSubmit={postForm}>
            <div className={"twoPaneForm"}>
              <div className={"widePane formPane"}>
                <label>
                  Item/Service: <input className={"wideInputBox"} type="text" value={newItemNameValue} onChange={
                    (event) => setNewItemNameValue(event.target.value)
                  } required />
                </label>

                <label>
                  Description: <input className={"wideInputBox"} type="text" value={newItemDescValue} onChange={
                    (event) => setNewItemDescValue(event.target.value)
                  } />
                </label>

              </div>
              <div className={"widePane formPane"}>
                <label>
                  Price: <input className={"smallInputBox"} type="number" min="0.00" step="0.001" value={newItemPriceValue} onChange={
                    (event: React.FormEvent<HTMLInputElement>) => 
                      setNewItemPriceValue(parseInt(event.currentTarget.value))
                  } />
                </label>

                <label>
                  HSN: <input className={"smallInputBox"} type="number" min="0" value={newItemHSNValue} onChange={
                    (event: React.FormEvent<HTMLInputElement>) => 
                      setNewItemHSNValue(parseInt(event.currentTarget.value))
                  } />
                </label>

                <label>
                  GST: <input className={"smallInputBox"} type="number" min="0" value={newItemGSTValue} onChange={
                    (event: React.FormEvent<HTMLInputElement>) => 
                      setNewItemGSTValue(parseInt(event.currentTarget.value))
                  } />
                </label>
              </div>
            </div>

            <div className={"menu"}>
              <input
                type="button"
                value="cancel"
                onClick={() => hideSelf()}
              />

              <input
                type="submit"
                value="Register/Add"
                disabled={newItemNameValue === "" ? true : false}
              />
            </div>
          </form>
        </div>
      </div>
    </div>
  );
}

export default RegisterItemForm;