source: client_app/src/components/main/App.js@ 4302312

Last change on this file since 4302312 was 21175ba, checked in by Vzdra <vladko.zdravkovski@…>, 3 years ago

Update App.js

  • Property mode set to 100644
File size: 7.3 KB
Line 
1import React, {Component} from 'react';
2import {BrowserRouter as Router, Route, Redirect} from 'react-router-dom';
3import Login from '../login/login';
4import Profile from "../profiles/profile";
5import 'semantic-ui-css/semantic.min.css';
6import HeaderComp from '../template/header';
7import './App.css';
8import UserLogin from "../../repository/login_repo";
9import UserJobs from "../work/user_jobs";
10import UserInternships from "../work/user_internships";
11import UserProjects from "../work/user_projects";
12import CompanyJobs from "../work/company_jobs";
13import TeamProjects from "../work/team_projects";
14import TeamJobs from "../work/team_jobs";
15import CompanyInternships from "../work/company_internships";
16import RegisterUser from "../register/register_user_form";
17import RegisterCompany from "../register/register_company_form";
18import RegisterTeam from "../register/register_team_form";
19import Search from "../filter/search";
20import EditUser from "../account_edit/user_edit";
21import EditCompany from "../account_edit/company_edit";
22import EditTeam from "../account_edit/team_edit";
23import JobRegister from "../work_register/job_register";
24import InternshipRegister from "../work_register/internship_register";
25import ProjectRegister from "../work_register/project_register";
26import EditJob from "../work_edit/test";
27
28class App extends Component{
29 constructor(props) {
30 super(props);
31 this.state = {
32 logged: false,
33 error: null,
34 success: null,
35 currentUser: {
36 }
37 }
38 }
39
40 render(){
41 return(
42 <Router>
43 <HeaderComp acc={this.state.currentUser.email} accType={this.state.currentUser.type} name={this.state.currentUser.name} removeState={this.removeState}/>
44 <main>
45 <Route path={"/login"} render={() => <Login success={this.state.success} error={this.state.error} onCompleteForm={this.attemptLogin} loggedIn={this.state.logged}/>}/>
46 <Route path={"/profile"} render={() => <Profile userProfile={this.state.currentUser}/>}/>
47 <Route path={"/user/jobs"} render={() => <UserJobs userProfile={this.state.currentUser}/>}/>
48 <Route path={"/user/internships"} render={() => <UserInternships userProfile={this.state.currentUser}/>}/>
49 <Route path={"/user/projects"} render={() => <UserProjects userProfile={this.state.currentUser}/>}/>
50 <Route path={"/team/jobs"} render={() => <TeamJobs userProfile={this.state.currentUser}/>}/>
51 <Route path={"/team/projects"} render={() => <TeamProjects userProfile={this.state.currentUser}/>}/>
52 <Route path={"/company/jobs"} render={() => <CompanyJobs userProfile={this.state.currentUser}/>}/>
53 <Route path={"/company/internships"} render={() => <CompanyInternships userProfile={this.state.currentUser}/>}/>
54 <Route path={"/register/user"} render={() => <RegisterUser message={this.setSuccess} />}/>
55 <Route path={"/register/company"} render={() => <RegisterCompany message={this.setSuccess} />}/>
56 <Route path={"/register/team"} render={() => <RegisterTeam message={this.setSuccess}/>}/>
57 <Route path={"/user/search"} render={() => <Search loggedIn={this.state.logged}/>}/>
58 <Route path={"/user/edit"} render={() => <EditUser oldUser={this.state.currentUser} updateUser={this.updateUser} message={this.setSuccess}/>}/>
59 <Route path={"/company/edit"} render={() => <EditCompany oldUser={this.state.currentUser} updateUser={this.updateUser} message={this.setSuccess}/>}/>
60 <Route path={"/team/edit"} render={() => <EditTeam oldUser={this.state.currentUser} updateUser={this.updateUser} message={this.setSuccess}/>}/>
61 <Route path={"/register/job"} render={() => <JobRegister accountId={this.state.currentUser.id} type={this.state.currentUser.type} updateJobs={this.updateJobs} />}/>
62 <Route path={"/register/internship"} render={() => <InternshipRegister accountId={this.state.currentUser.id} type={this.state.currentUser.type} updateInternships={this.updateInternships} />}/>
63 <Route path={"/register/project"} render={() => <ProjectRegister accountId={this.state.currentUser.id} type={this.state.currentUser.type} updateProjects={this.updateProjects} />}/>
64 <Route path={"/edit/job"} render={(props) => <EditJob {...props} editJob={this.editJob}/>} />
65 <Route path={"/edit/internship"} render={(props) => <EditInternship {...props} editJob={this.editInternship}/>} />
66 <Route path={"/edit/project"} render={(props) => <EditProject {...props} editJob={this.editProject}/>} />
67 <Route path={"/logout"} render={() => <Redirect to={"/login"}/>}/>
68 <Route path={"/"} render={() => <Redirect to={"/login"}/>}/>
69 </main>
70 </Router>
71 );
72 }
73
74 removeState = () => {
75 this.setState({
76 logged: false,
77 error: null,
78 currentUser: {}
79 })
80 }
81
82 updateUser = (user) =>{
83 this.setState({
84 currentUser: user
85 })
86 }
87
88 setSuccess = (message) => {
89 this.setState({
90 success: message,
91 error: null
92 })
93 }
94
95 updateJobs = (job) => {
96 this.setState(prevState => ({
97 currentUser:{
98 ...prevState.currentUser,
99 jobs: [...prevState.currentUser.jobs, job]
100 }
101 }))
102 }
103
104 updateInternships = (internship) => {
105 this.setState(prevState => ({
106 currentUser:{
107 ...prevState.currentUser,
108 internships: [...prevState.currentUser.internships, internship]
109 }
110 }))
111 }
112
113 updateProjects = (project) => {
114 this.setState(prevState => ({
115 currentUser:{
116 ...prevState.currentUser,
117 projects: [...prevState.currentUser.projects, project]
118 }
119 }))
120 }
121
122 editJob = (job, index) => {
123 this.setState(prevState => ({
124 currentUser:{
125 ...prevState.currentUser,
126 jobs: Object.assign([],this.state.jobs,{[index]: job})
127 }
128 }))
129 }
130
131 editInternship = (internship, index) => {
132 this.setState(prevState => ({
133 currentUser:{
134 ...prevState.currentUser,
135 internships: Object.assign([],this.state.jobs,{[index]: internship})
136 }
137 }))
138 }
139
140 editProject = (project, index) => {
141 this.setState(prevState => ({
142 currentUser:{
143 ...prevState.currentUser,
144 projects: Object.assign([],this.state.jobs,{[index]: project})
145 }
146 }))
147 }
148
149 attemptLogin = (email, password, type) => {
150 UserLogin.login(email, password, type).then((res) =>{
151 if(res.data.email==null){
152 this.setState({
153 logged: false,
154 error: res.data.error,
155 });
156 }else{
157 this.setState({
158 logged: true,
159 currentUser: res.data,
160 error: null,
161 });
162 }
163 });
164
165 if(this.state.currentUser.email!=null){
166 return <Redirect to={"/profile"}/>;
167 }
168 }
169}
170
171export default App;
Note: See TracBrowser for help on using the repository browser.