Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
193 changes: 193 additions & 0 deletions App.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,193 @@
import React, { useEffect, useState } from "react";
import "../App.css";
import { connect } from "react-redux";
import Amplify, { PubSub } from "aws-amplify";
import { AuthState, onAuthUIStateChange } from "@aws-amplify/ui-components";
import * as projectsActions from "../actions/projects";
import * as notesActions from "../actions/notes";
import * as appActions from "../actions/app";
import * as userActions from "../actions/user";
import aws_exports from "../aws-exports";
import { Route, useHistory, useRouteMatch } from "react-router-dom";
import ProjectsPanel from "./ProjectsPanel";
import SidePanel from "./SidePanel";
import NotesPanel from "./NotesPanel";
import Loading from "./Loading";
import Login from "./Login";
Amplify.configure(aws_exports);
PubSub.configure(aws_exports);
import {ToastProvider, DefaultToast} from 'react-toast-notifications'
const App = (props) => {


const { dispatch, user, projects, app } = props;
const [state, setState] = useState({
projectPanel: false,
sidePanel: false,
});
const history = useHistory();
const routeMatch = useRouteMatch({
exact: true,
sensitive: true,
path: [
"/local/:projectPermalink",
"/:username/:projectPermalink/:notePermalink",
"/:username/:projectPermalink",
"/",
],
});

const fetchLocalProjects = () => {
if (user.state !== AuthState.SignedIn) {
dispatch(projectsActions.handleFetchOwnedProjects());
}
};

const setHideShowProjectPanel = () => {
setState((state) => {
return { ...state, sidePanel: false, projectPanel: !state.projectPanel };
});
};

const setHideShowSidePanel = () => {
setState((state) => {
return { ...state, projectPanel: false, sidePanel: !state.sidePanel };
});
};

useEffect(() => {
dispatch(appActions.setHistory(history));
onAuthUIStateChange(async (nextAuthState, authData) => {
dispatch(userActions.handleSetData(authData));
dispatch(userActions.setState(nextAuthState));
if (nextAuthState === AuthState.SignedIn) {
window.removeEventListener("storage", fetchLocalProjects);
}
});
if (user.state !== AuthState.SignedIn) {
window.addEventListener("storage", fetchLocalProjects);
}
}, []);
useEffect(() => {
if (routeMatch) {
const {
params: { username, projectPermalink, notePermalink },
} = routeMatch;
if (history.action === "POP") {
if (!app.isLoading) {
if (user.state === AuthState.SignedIn) {
if (username && projectPermalink) {
const allProjects = Object.values({
...projects.owned,
...projects.assigned,
});
const reqUserProjects = allProjects.filter(
(x) => x.owner === username
);
if (reqUserProjects.length > 0) {
const reqProject = reqUserProjects.filter(
(x) => x.permalink === projectPermalink
)[0];
if (reqProject) {
dispatch(appActions.handleSetProject(reqProject.id, false));
if (notePermalink) {
dispatch(notesActions.handleFetchNotes(reqProject.id)).then(
(notes) => {
const reqNote = Object.values(notes).filter(
(x) =>
x.permalink === parseInt(params.notePermalink, 10)
)[0];
if (reqNote) {
dispatch(appActions.handleSetNote(reqNote.id, false));
}
}
);
} else {
history.replace(`/${username}/${projectPermalink}`);
}
} else {
history.replace("/");
}
} else {
history.replace("/");
}
}
} else {
if (projectPermalink) {
const reqProject = Object.values(projects.owned).filter(
(x) => x.permalink === projectPermalink
)[0];
if (reqProject) {
dispatch(appActions.handleSetProject(reqProject.id, false));
} else {
history.replace("/");
}
}
}
}
}
}
}, [routeMatch, app, user]);
const MyCustomToast = ({ children, ...props }) => (
<DefaultToast {...props}>
<div style={{backgroundColor: '#fff', color: '#000'}} class="css-1rjh2i2-icon">
<div class="css-1rjh2i2-icon"></div>
{children}</div>
</DefaultToast>
);
return (
<ToastProvider placement='bottom-left' components={{Toast: MyCustomToast}}>


<div className="App">
<Route
exact
path="/login"
render={(routeProps) => <Login route={routeProps} />}
/>
<Route
exact
sensitive
path={[
"/local/:projectPermalink",
"/:username/:projectPermalink/:notePermalink",
"/:username/:projectPermalink",
"/",
]}
render={(routeProps) => (
<>
{app.isLoading ? (
<Loading route={routeProps} />
) : (
<div className="mainPage">
<ProjectsPanel
projectPanel={state.projectPanel}
setHideShowProjectPanel={setHideShowProjectPanel}
/>
<NotesPanel
setHideShowSidePanel={setHideShowSidePanel}
setHideShowProjectPanel={setHideShowProjectPanel}
/>
<SidePanel
sidePanel={state.sidePanel}
setHideShowSidePanel={setHideShowSidePanel}
readOnly={
!Object.keys(projects.owned).includes(app.selectedProject)
}
/>
</div>
)}
</>
)}
/>
</div>
</ToastProvider>
);
};

export default connect((state) => ({
user: state.user,
projects: state.projects,
notes: state.notes,
app: state.app,
}))(App);
Loading