From 728f12e2215a142e0f0f72d9ae93b778bba204cf Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 22 May 2018 16:46:38 +0200 Subject: [PATCH 001/160] FLUX-160 Updated routing to be more localized inside the container --- src/components/projects/Project.jsx | 17 +- src/components/room/Room.jsx | 17 +- src/containers/app/App.jsx | 108 +------------ src/containers/layout/Layout.jsx | 14 +- src/containers/projects/ProjectsContainer.jsx | 150 ++++++++++++++++++ .../projects/ProjectsContainer.test.jsx | 16 ++ src/utils/NumberHelper.jsx | 5 + 7 files changed, 204 insertions(+), 123 deletions(-) create mode 100644 src/containers/projects/ProjectsContainer.jsx create mode 100644 src/containers/projects/ProjectsContainer.test.jsx create mode 100644 src/utils/NumberHelper.jsx diff --git a/src/components/projects/Project.jsx b/src/components/projects/Project.jsx index bd71203..da839c6 100644 --- a/src/components/projects/Project.jsx +++ b/src/components/projects/Project.jsx @@ -4,17 +4,30 @@ import Box from "grommet/components/Box"; import Header from "grommet/components/Header"; import Heading from "grommet/components/Heading"; +import NotFound from "../../components/notfound/NotFound"; import ContentBox from "../contentBox/ContentBox"; import ProjectModel from "../../models/Project"; import ItemsList from "../list/ItemsList"; import AnchorRoomItemRenderer from "../room/AnchorRoomItemRenderer"; type Props = { - project: ProjectModel, + projects: ProjectModel[], match: any }; -export default function Project({ project, match }: Props) { +function findProject(projects: ProjectModel[], projectId: number) { + return projects.find( + project => project.projectId === parseInt(projectId, 10) + ); +} + +export default function Project({ projects, match }: Props) { + const project = findProject(projects, match.params.projectId); + + if (!project) { + return ; + } + return ( diff --git a/src/components/room/Room.jsx b/src/components/room/Room.jsx index 9ea8808..961a806 100644 --- a/src/components/room/Room.jsx +++ b/src/components/room/Room.jsx @@ -7,7 +7,6 @@ import Article from "grommet/components/Article"; // eslint-disable-next-line import { BrowserRouter as Router, Route, Switch } from "react-router-dom"; -import ProjectModel from "../../models/Project"; import Measurement from "../../models/Measurement"; import RoomModel from "../../models/Room"; import ItemsList from "../list/ItemsList"; @@ -16,11 +15,10 @@ import AnchorMeasurementItemRenderer from "../measurements/AnchorMeasurementItem type Props = { match: any, - room: RoomModel, - parentProject: ProjectModel + room: RoomModel }; -export default function Room({ match, room, parentProject }: Props) { +export default function Room({ match, room }: Props) { return (
@@ -52,15 +50,18 @@ export default function Room({ match, room, parentProject }: Props) { } function ShowMeasurement({ room, match }) { - let currentMeasurement: ?Measurement = null; + let currentMeasurement; if (match.params.measurementId) { currentMeasurement = room.measurements.find( measurement => measurement.measurementId === parseInt(match.params.measurementId, 10) ); - return ( - - ); + + if (currentMeasurement) { + return ( + + ); + } } return null; } diff --git a/src/containers/app/App.jsx b/src/containers/app/App.jsx index 6fc8c06..828cd2b 100644 --- a/src/containers/app/App.jsx +++ b/src/containers/app/App.jsx @@ -2,16 +2,12 @@ import React from "react"; import GrommetApp from "grommet/components/App"; import { BrowserRouter as Router, Route, Switch } from "react-router-dom"; -import axios, { CancelToken, CancelTokenSource } from "axios"; +import axios from "axios"; -import RoomModel from "../../models/Room"; -import ProjectModel from "../../models/Project"; -import Room from "../../components/room/Room"; import Dashboard from "../../components/dashboard/Dashboard"; import NotFound from "../../components/notfound/NotFound"; -import Projects from "../../components/projects/Projects"; +import ProjectsContainer from "./../projects/ProjectsContainer"; import Layout from "../layout/Layout"; -import Project from "../../components/projects/Project"; import ImportExportContainer from "../importexport/ImportExportContainer"; import EditProject from "./../../containers/projects/EditProject"; import Login from "../login/LoginContainer"; @@ -21,123 +17,29 @@ import type { ToastMetadata } from "./../../components/toast/Toast"; type Prop = {}; type State = { - projects: ProjectModel[], - loading: boolean, toast?: ToastMetadata }; export default class App extends React.Component { - source: CancelTokenSource = CancelToken.source(); - constructor() { super(); (axios.defaults: Object).baseURL = process.env.REACT_APP_SERVICE_URI; // Sets the default URL for the rest of the applications lifetime. } - state = { - projects: [], - loading: true - }; - - componentDidMount() { - this.getProjects(); - } - - componentWillUnmount() { - this.source.cancel(); - } - - getProjects = () => { - this.setState({ loading: true }); - axios - .get(`/projects?limit=0`, { - cancelToken: this.source.token - }) - .then(result => { - const projs: ProjectModel[] = []; - result.data.forEach(d => { - projs.push(ProjectModel.fromObject(d)); - }); - this.setState({ projects: projs, loading: false }); - }) - .catch(error => { - if (!axios.isCancel(error)) { - this.setState({ projects: [], loading: false }); - } - }); - }; - - renderProjectsPage = () => ( - - ); - - renderProjectPage = ({ match }: { match: any }) => { - const { projects } = this.state; - - const foundProject = projects.find( - project => project.projectId === parseInt(match.params.projectId, 10) - ); - - if (foundProject) { - return ; - } - const infoMessage = `Das Projekt mit der ID ${ - match.params.projectId - } konnte nicht gefunden werden.`; - return ; - }; - - renderRoomPage = ({ match }: any) => { - const foundProject: ?ProjectModel = this.state.projects.find( - (project: ProjectModel) => - project.projectId === parseInt(match.params.projectId, 10) - ); - - if (foundProject) { - const foundRoom: ?RoomModel = foundProject.rooms.find( - (room: RoomModel) => room.roomId === parseInt(match.params.roomId, 10) - ); - - if (foundRoom) { - return ( - - ); - } - } - - const infoMessage = `Der Raum mit der ID ${ - match.params.roomId - } konnte nicht gefunden werden.`; - return ; - }; - render() { return (
- + - - - + - + diff --git a/src/containers/layout/Layout.jsx b/src/containers/layout/Layout.jsx index 614027d..45fa9ea 100644 --- a/src/containers/layout/Layout.jsx +++ b/src/containers/layout/Layout.jsx @@ -6,16 +6,12 @@ import Box from "grommet/components/Box"; import Button from "grommet/components/Button"; import SidebarIcon from "grommet/components/icons/base/Sidebar"; -import Project from "../../models/Project"; import Header from "../../components/header/Header"; import NavMenu from "../../components/navmenu/NavMenu"; import Sidebar from "../../components/sidebar/Sidebar"; -import Loading from "../../components/loading/Loading"; type Prop = { - children?: React.Node, - projects: Project[], - loading: boolean + children?: React.Node }; type State = { @@ -63,7 +59,7 @@ export default class Layout extends React.Component { }; render() { - const { children, projects, loading } = this.props; + const { children } = this.props; const title = "Flux-Coordinator"; const sidebarToggler: React.Node = this.state.isMobileScreen ? ( @@ -80,8 +76,6 @@ export default class Layout extends React.Component { } }; - const loadingOrChildren: React.Node = loading ? : children; - return ( { separator={false} > - + {this.state.isMobileScreen && header} - {loadingOrChildren} + {children} ); diff --git a/src/containers/projects/ProjectsContainer.jsx b/src/containers/projects/ProjectsContainer.jsx new file mode 100644 index 0000000..b9759ff --- /dev/null +++ b/src/containers/projects/ProjectsContainer.jsx @@ -0,0 +1,150 @@ +// @flow +import * as React from "react"; +import axios, { CancelToken, CancelTokenSource } from "axios"; +// eslint-disable-next-line +import { BrowserRouter as Router, Route, Switch } from "react-router-dom"; + +import NotFound from "../../components/notfound/NotFound"; +import RoomComponent from "./../../components/room/Room"; +import ProjectComponent from "../../components/projects/Project"; +import ProjectsComponent from "../../components/projects/Projects"; +import LoadingComponent from "./../../components/loading/Loading"; +import Room from "../../models/Room"; +import Project from "../../models/Project"; +import { isNumber } from "./../../utils/NumberHelper"; + +type Props = { + match: any +}; + +type State = { + loading: boolean, + projects: Project[] +}; + +export default class ProjectsContainer extends React.Component { + source: CancelTokenSource = CancelToken.source(); + + state = { + loading: false, + projects: [] + }; + + loadProjects = () => { + this.setState({ loading: true }); + axios + .get(`/projects?limit=0`, { + cancelToken: this.source.token + }) + .then(result => { + const projs: Project[] = []; + result.data.forEach(d => { + projs.push(Project.fromObject(d)); + }); + this.setState({ projects: projs, loading: false }); + }) + .catch(error => { + if (!axios.isCancel(error)) { + this.setState({ projects: [], loading: false }); + } + }); + }; + + findProjectById = (projects: Project[], projectId: number | string) => { + const projectIdInt = parseInt(projectId, 10); + + return projects.find(project => project.projectId === projectIdInt); + }; + + findRoomInProject = (project: Project, roomId: number | string) => { + const roomIdInt = parseInt(roomId, 10); + for (const room of project.rooms) { + if (room.roomId === roomIdInt) return room; + } + }; + + findRoomById = ( + project: Project | Project[], + roomId: number | string, + projectId?: number | string + ) => { + const roomIdInt = parseInt(roomId, 10); + const projectIdInt = parseInt(projectId, 10); + + if (Array.isArray(project)) { + if (isNumber(projectIdInt)) { + const maybeProject = this.findProjectById(project, projectIdInt); + if (maybeProject) { + return this.findRoomInProject(maybeProject, roomIdInt); + } + return null; + } + + for (const p of project) { + const maybeRoom: Room = this.findRoomInProject(p, roomIdInt); + if (maybeRoom) { + return maybeRoom; + } + } + return null; + } + return this.findRoomInProject(project, roomIdInt); + }; + + componentDidMount() { + this.loadProjects(); + } + + componentWillUnmount() { + this.source.cancel(); + } + + render() { + const { match } = this.props; + const { loading, projects } = this.state; + + if (loading) { + return ; + } + + return ( + + { + const foundRoom = this.findRoomById( + projects, + match.params.roomId, + match.params.projectId + ); + return foundRoom ? ( + + ) : ( + + ); + }} + /> + ( + + )} + /> + ( + + )} + /> + + ); + } +} diff --git a/src/containers/projects/ProjectsContainer.test.jsx b/src/containers/projects/ProjectsContainer.test.jsx new file mode 100644 index 0000000..7c3c000 --- /dev/null +++ b/src/containers/projects/ProjectsContainer.test.jsx @@ -0,0 +1,16 @@ +// @flow +import * as React from "react"; +import { shallow } from "enzyme"; +import { MemoryRouter, Route } from "react-router"; + +import ProjectsContainer from "./ProjectsContainer"; + +describe("", () => { + it("should render", () => { + shallow( + + } /> + + ); + }); +}); diff --git a/src/utils/NumberHelper.jsx b/src/utils/NumberHelper.jsx new file mode 100644 index 0000000..01d2a79 --- /dev/null +++ b/src/utils/NumberHelper.jsx @@ -0,0 +1,5 @@ +// @flow + +export function isNumber(n: number) { + return !isNaN(parseFloat(n)) && isFinite(n); +} From b7c232df5d821033c0a8ac124654dda62fb82584 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 22 May 2018 18:05:03 +0200 Subject: [PATCH 002/160] Added toast through context --- src/components/contentBox/ContentBox.jsx | 17 ---------- src/components/toast/ToastContext.jsx | 6 ++++ src/containers/app/App.jsx | 16 +++++++-- src/containers/projects/EditProject.jsx | 43 ++++++++++++++---------- 4 files changed, 45 insertions(+), 37 deletions(-) create mode 100644 src/components/toast/ToastContext.jsx diff --git a/src/components/contentBox/ContentBox.jsx b/src/components/contentBox/ContentBox.jsx index 9c7ed37..bb29ca6 100644 --- a/src/components/contentBox/ContentBox.jsx +++ b/src/components/contentBox/ContentBox.jsx @@ -6,27 +6,14 @@ import Article from "grommet/components/Article"; import Box from "grommet/components/Box"; import { withRouter } from "react-router"; -import Toast from "./../toast/Toast"; - -import type { ToastMetadata } from "./../toast/Toast"; - type Props = { heading: React.Node, children: React.Node, location: any }; -type State = { - toast?: ToastMetadata -}; - class ContentBox extends React.Component { - state = {}; - render() { - const toast = this.props.location.state - ? this.props.location.state.toast - : undefined; return (
@@ -35,10 +22,6 @@ class ContentBox extends React.Component {
{this.props.children} - this.setState({ toast: undefined })} - />
); } diff --git a/src/components/toast/ToastContext.jsx b/src/components/toast/ToastContext.jsx new file mode 100644 index 0000000..5f6308d --- /dev/null +++ b/src/components/toast/ToastContext.jsx @@ -0,0 +1,6 @@ +// @flow +import * as React from "react"; + +export const ToastContext = React.createContext({ + showToast: () => {} +}); diff --git a/src/containers/app/App.jsx b/src/containers/app/App.jsx index 828cd2b..d0ec32f 100644 --- a/src/containers/app/App.jsx +++ b/src/containers/app/App.jsx @@ -11,6 +11,8 @@ import Layout from "../layout/Layout"; import ImportExportContainer from "../importexport/ImportExportContainer"; import EditProject from "./../../containers/projects/EditProject"; import Login from "../login/LoginContainer"; +import Toast from "./../../components/toast/Toast"; +import { ToastContext } from "./../../components/toast/ToastContext"; import type { ToastMetadata } from "./../../components/toast/Toast"; @@ -26,9 +28,15 @@ export default class App extends React.Component { (axios.defaults: Object).baseURL = process.env.REACT_APP_SERVICE_URI; // Sets the default URL for the rest of the applications lifetime. } + state = {}; + + showToast = (metadata: ToastMetadata) => { + this.setState({ toast: metadata }); + }; + render() { return ( -
+ @@ -43,8 +51,12 @@ export default class App extends React.Component { + this.setState({ toast: undefined })} + /> -
+ ); } } diff --git a/src/containers/projects/EditProject.jsx b/src/containers/projects/EditProject.jsx index 7e0507e..f33dc94 100644 --- a/src/containers/projects/EditProject.jsx +++ b/src/containers/projects/EditProject.jsx @@ -8,6 +8,7 @@ import { Redirect } from "react-router-dom"; import Form from "./../../components/form/Form"; import Project from "../../models/Project"; +import { ToastContext } from "./../../components/toast/ToastContext"; import type { ToastMetadata } from "./../../components/toast/Toast"; @@ -52,7 +53,7 @@ export default class EditProject extends React.Component { }); }; - onSubmit = () => { + onSubmit = (showToast: () => void) => { this.saveProject(this.state.project) .then(result => { if (result.status === 201) { @@ -61,6 +62,12 @@ export default class EditProject extends React.Component { children: "Projekt abgespeichert" }; this.setState({ toast: toast, shouldRedirect: true }); + if (showToast) { + showToast({ + status: "ok", + children: "Projekt gespeichert" + }); + } } }) .catch(error => { @@ -102,24 +109,24 @@ export default class EditProject extends React.Component { return ; } return ( -
- - - - {this.state.shouldRedirect && ( - + + {showToast => ( + this.onSubmit(showToast)} + > + + + + {this.state.shouldRedirect && } + )} - + ); } } From b2d01ed582638edf99510f48006d031d421de0bf Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 10:01:28 +0200 Subject: [PATCH 003/160] Updated toast initialization --- src/containers/projects/EditProject.jsx | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/src/containers/projects/EditProject.jsx b/src/containers/projects/EditProject.jsx index f33dc94..a88f6d6 100644 --- a/src/containers/projects/EditProject.jsx +++ b/src/containers/projects/EditProject.jsx @@ -53,7 +53,7 @@ export default class EditProject extends React.Component { }); }; - onSubmit = (showToast: () => void) => { + onSubmit = (showToast: (toast: ToastMetadata) => void) => { this.saveProject(this.state.project) .then(result => { if (result.status === 201) { @@ -61,12 +61,8 @@ export default class EditProject extends React.Component { status: "ok", children: "Projekt abgespeichert" }; - this.setState({ toast: toast, shouldRedirect: true }); if (showToast) { - showToast({ - status: "ok", - children: "Projekt gespeichert" - }); + showToast(toast); } } }) @@ -75,7 +71,9 @@ export default class EditProject extends React.Component { status: "critical", children: "Projekt konnte nicht gespeichert werden" }; - this.setState({ toast: toast }); + if (showToast) { + showToast(toast); + } }); }; From 4d9cc828f2d77e6c3aa70f00b9129b165542bd05 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 10:03:40 +0200 Subject: [PATCH 004/160] Updated toast typings --- src/components/toast/ToastContext.jsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/components/toast/ToastContext.jsx b/src/components/toast/ToastContext.jsx index 5f6308d..15a22ce 100644 --- a/src/components/toast/ToastContext.jsx +++ b/src/components/toast/ToastContext.jsx @@ -1,6 +1,8 @@ // @flow import * as React from "react"; +import type { ToastMetadata } from "./Toast"; + export const ToastContext = React.createContext({ - showToast: () => {} + showToast: (toast: ToastMetadata) => {} }); From d0f924719f52ce6ec27a6b65d8ebcce1d79b4435 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 10:19:11 +0200 Subject: [PATCH 005/160] Fixed type bug when using context Context can not be typed with Flow --- src/components/toast/ToastContext.jsx | 6 +++++- src/containers/projects/EditProject.jsx | 7 +++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/components/toast/ToastContext.jsx b/src/components/toast/ToastContext.jsx index 15a22ce..605ac05 100644 --- a/src/components/toast/ToastContext.jsx +++ b/src/components/toast/ToastContext.jsx @@ -3,6 +3,10 @@ import * as React from "react"; import type { ToastMetadata } from "./Toast"; +type ShowToast = { + showToast: () => void +}; + export const ToastContext = React.createContext({ - showToast: (toast: ToastMetadata) => {} + showToast: () => {} }); diff --git a/src/containers/projects/EditProject.jsx b/src/containers/projects/EditProject.jsx index a88f6d6..b7f043f 100644 --- a/src/containers/projects/EditProject.jsx +++ b/src/containers/projects/EditProject.jsx @@ -22,6 +22,9 @@ type State = { shouldRedirect: boolean, toast?: ToastMetadata }; +type Test = { + t?: () => void +}; export default class EditProject extends React.Component { source: CancelTokenSource = CancelToken.source(); @@ -53,7 +56,7 @@ export default class EditProject extends React.Component { }); }; - onSubmit = (showToast: (toast: ToastMetadata) => void) => { + onSubmit = (showToast?: (toast: ToastMetadata) => void) => { this.saveProject(this.state.project) .then(result => { if (result.status === 201) { @@ -111,7 +114,7 @@ export default class EditProject extends React.Component { {showToast => (
this.onSubmit(showToast)} + onSubmit={() => this.onSubmit((showToast: any))} > Date: Wed, 23 May 2018 10:25:52 +0200 Subject: [PATCH 006/160] Fixed several typing bugs --- src/components/contentBox/ContentBox.jsx | 2 +- src/components/toast/ToastContext.jsx | 6 +----- src/containers/app/App.jsx | 2 +- src/containers/projects/EditProject.jsx | 1 + src/containers/projects/ProjectsContainer.jsx | 2 +- 5 files changed, 5 insertions(+), 8 deletions(-) diff --git a/src/components/contentBox/ContentBox.jsx b/src/components/contentBox/ContentBox.jsx index bb29ca6..7a6e842 100644 --- a/src/components/contentBox/ContentBox.jsx +++ b/src/components/contentBox/ContentBox.jsx @@ -12,7 +12,7 @@ type Props = { location: any }; -class ContentBox extends React.Component { +class ContentBox extends React.Component { render() { return (
diff --git a/src/components/toast/ToastContext.jsx b/src/components/toast/ToastContext.jsx index 605ac05..2c52380 100644 --- a/src/components/toast/ToastContext.jsx +++ b/src/components/toast/ToastContext.jsx @@ -3,10 +3,6 @@ import * as React from "react"; import type { ToastMetadata } from "./Toast"; -type ShowToast = { - showToast: () => void -}; - export const ToastContext = React.createContext({ - showToast: () => {} + showToast: (metadata: ToastMetadata) => {} }); diff --git a/src/containers/app/App.jsx b/src/containers/app/App.jsx index d0ec32f..3ea8316 100644 --- a/src/containers/app/App.jsx +++ b/src/containers/app/App.jsx @@ -36,7 +36,7 @@ export default class App extends React.Component { render() { return ( - + diff --git a/src/containers/projects/EditProject.jsx b/src/containers/projects/EditProject.jsx index b7f043f..38ba12d 100644 --- a/src/containers/projects/EditProject.jsx +++ b/src/containers/projects/EditProject.jsx @@ -67,6 +67,7 @@ export default class EditProject extends React.Component { if (showToast) { showToast(toast); } + this.setState({ shouldRedirect: true }); } }) .catch(error => { diff --git a/src/containers/projects/ProjectsContainer.jsx b/src/containers/projects/ProjectsContainer.jsx index b9759ff..0235ca7 100644 --- a/src/containers/projects/ProjectsContainer.jsx +++ b/src/containers/projects/ProjectsContainer.jsx @@ -81,7 +81,7 @@ export default class ProjectsContainer extends React.Component { } for (const p of project) { - const maybeRoom: Room = this.findRoomInProject(p, roomIdInt); + const maybeRoom: ?Room = this.findRoomInProject(p, roomIdInt); if (maybeRoom) { return maybeRoom; } From 799fea0addd81d55fddb8f882533afd8b8c2d553 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 10:33:43 +0200 Subject: [PATCH 007/160] Added several render tests --- src/components/form/Form.test.jsx | 17 +++++++++ src/components/importexport/Export.test.jsx | 12 ++++++ src/components/importexport/Import.test.jsx | 12 ++++++ .../measurements/MeasurementSummary.test.jsx | 38 +++++++++++++++++++ 4 files changed, 79 insertions(+) create mode 100644 src/components/form/Form.test.jsx create mode 100644 src/components/importexport/Export.test.jsx create mode 100644 src/components/importexport/Import.test.jsx create mode 100644 src/components/measurements/MeasurementSummary.test.jsx diff --git a/src/components/form/Form.test.jsx b/src/components/form/Form.test.jsx new file mode 100644 index 0000000..aeb2976 --- /dev/null +++ b/src/components/form/Form.test.jsx @@ -0,0 +1,17 @@ +// @flow +import * as React from "react"; +import { shallow } from "enzyme"; +import Title from "grommet/components/Title"; + +import Form from "./Form"; + +describe("", () => { + it("should render", () => { + const wrapper = shallow( + + Header + + ); + expect(wrapper).toHaveLength(1); + }); +}); diff --git a/src/components/importexport/Export.test.jsx b/src/components/importexport/Export.test.jsx new file mode 100644 index 0000000..89b75a7 --- /dev/null +++ b/src/components/importexport/Export.test.jsx @@ -0,0 +1,12 @@ +// @flow +import * as React from "react"; +import { shallow } from "enzyme"; + +import Export from "./Export"; + +describe("", () => { + it("should render", () => { + const wrapper = shallow(); + expect(wrapper).toHaveLength(1); + }); +}); diff --git a/src/components/importexport/Import.test.jsx b/src/components/importexport/Import.test.jsx new file mode 100644 index 0000000..9545657 --- /dev/null +++ b/src/components/importexport/Import.test.jsx @@ -0,0 +1,12 @@ +// @flow +import * as React from "react"; +import { shallow } from "enzyme"; + +import Import from "./Import"; + +describe("", () => { + it("should render", () => { + const wrapper = shallow( {}} />); + expect(wrapper).toHaveLength(1); + }); +}); diff --git a/src/components/measurements/MeasurementSummary.test.jsx b/src/components/measurements/MeasurementSummary.test.jsx new file mode 100644 index 0000000..9c8a6be --- /dev/null +++ b/src/components/measurements/MeasurementSummary.test.jsx @@ -0,0 +1,38 @@ +// @flow +import * as React from "react"; +import { shallow } from "enzyme"; + +import Measurement from "./../../models/Measurement"; +import Room from "./../../models/Room"; +import MeasurementSummary from "./MeasurementSummary"; + +describe("", () => { + it("should render", () => { + const measurement = new Measurement( + 1, + "Test measurement", + new Date(), + new Date(), + "READY" + ); + const room = new Room( + "Test room", + "Test room", + ([measurement]: Measurement[]), + "", + 1, + 100, + 200, + 0.15, + 1 + ); + const wrapper = shallow( + {}} + /> + ); + expect(wrapper).toHaveLength(1); + }); +}); From fd2edf3eacc7da28cb1ca39d6066377bf6e7ee61 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 10:42:13 +0200 Subject: [PATCH 008/160] Updated some dependencies and flow-types --- .../npm/@storybook/addon-actions_v3.x.x.js | 6 +- flow-typed/npm/babel-core_vx.x.x.js | 13 +- flow-typed/npm/babel-eslint_vx.x.x.js | 4 +- flow-typed/npm/babel-jest_vx.x.x.js | 4 +- flow-typed/npm/babel-preset-env_vx.x.x.js | 4 +- flow-typed/npm/babel-preset-react_vx.x.x.js | 4 +- flow-typed/npm/concurrently_vx.x.x.js | 4 +- flow-typed/npm/cross-env_vx.x.x.js | 4 +- .../npm/enzyme-adapter-react-16_vx.x.x.js | 4 +- flow-typed/npm/eslint-config-airbnb_vx.x.x.js | 4 +- .../npm/eslint-config-prettier_vx.x.x.js | 4 +- .../npm/eslint-config-react-app_vx.x.x.js | 4 +- .../npm/eslint-plugin-flowtype_vx.x.x.js | 4 +- flow-typed/npm/eslint-plugin-import_vx.x.x.js | 4 +- .../npm/eslint-plugin-jsx-a11y_vx.x.x.js | 4 +- .../npm/eslint-plugin-prettier_vx.x.x.js | 4 +- flow-typed/npm/eslint-plugin-react_vx.x.x.js | 4 +- flow-typed/npm/eslint_vx.x.x.js | 4 +- flow-typed/npm/flow-typed_vx.x.x.js | 4 +- flow-typed/npm/grommet-addons_vx.x.x.js | 4 +- flow-typed/npm/heatmapjs_vx.x.x.js | 144 ++++++++++ flow-typed/npm/husky_vx.x.x.js | 4 +- flow-typed/npm/install-peerdeps_vx.x.x.js | 4 +- flow-typed/npm/js-file-download_vx.x.x.js | 32 +++ flow-typed/npm/node-sass-chokidar_vx.x.x.js | 4 +- flow-typed/npm/npm-run-all_vx.x.x.js | 4 +- flow-typed/npm/prettier-eslint_vx.x.x.js | 4 +- flow-typed/npm/pretty-quick_vx.x.x.js | 4 +- .../npm/react-resize-detector_vx.x.x.js | 41 +++ flow-typed/npm/react-router-dom_v4.x.x.js | 21 +- flow-typed/npm/react-scripts_vx.x.x.js | 4 +- flow-typed/npm/typeface-roboto_vx.x.x.js | 4 +- src/containers/projects/EditProject.jsx | 3 - yarn.lock | 250 +++++++++++------- 34 files changed, 449 insertions(+), 165 deletions(-) create mode 100644 flow-typed/npm/heatmapjs_vx.x.x.js create mode 100644 flow-typed/npm/js-file-download_vx.x.x.js create mode 100644 flow-typed/npm/react-resize-detector_vx.x.x.js diff --git a/flow-typed/npm/@storybook/addon-actions_v3.x.x.js b/flow-typed/npm/@storybook/addon-actions_v3.x.x.js index ba7de4c..19268e4 100644 --- a/flow-typed/npm/@storybook/addon-actions_v3.x.x.js +++ b/flow-typed/npm/@storybook/addon-actions_v3.x.x.js @@ -1,8 +1,8 @@ -// flow-typed signature: 9f7284fc113607b916f1c64b0640c2a2 -// flow-typed version: 1709d3212d/@storybook/addon-actions_v3.x.x/flow_>=v0.25.x +// flow-typed signature: 64850c161373321ab9eabcceb1268d56 +// flow-typed version: 5edd39ab2e/@storybook/addon-actions_v3.x.x/flow_>=v0.25.x declare module "@storybook/addon-actions" { - declare type Action = (name: string) => Function; + declare type Action = (name: string) => (...args: Array) => void; declare type DecorateFn = (args: Array) => Array; declare module.exports: { diff --git a/flow-typed/npm/babel-core_vx.x.x.js b/flow-typed/npm/babel-core_vx.x.x.js index f25648a..ab696c6 100644 --- a/flow-typed/npm/babel-core_vx.x.x.js +++ b/flow-typed/npm/babel-core_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 640dcf7cdffdff8dddcaaf78dadb5f3c -// flow-typed version: <>/babel-core_v^6.26.0/flow_v0.69.0 +// flow-typed signature: 08d47bb8be6730195df8c8b1abc667ac +// flow-typed version: <>/babel-core_v^6.26.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: @@ -78,6 +78,10 @@ declare module "babel-core/lib/transformation/file/logger" { declare module.exports: any; } +declare module "babel-core/lib/transformation/file/merge-map" { + declare module.exports: any; +} + declare module "babel-core/lib/transformation/file/metadata" { declare module.exports: any; } @@ -191,6 +195,11 @@ declare module "babel-core/lib/transformation/file/index.js" { declare module "babel-core/lib/transformation/file/logger.js" { declare module.exports: $Exports<"babel-core/lib/transformation/file/logger">; } +declare module "babel-core/lib/transformation/file/merge-map.js" { + declare module.exports: $Exports< + "babel-core/lib/transformation/file/merge-map" + >; +} declare module "babel-core/lib/transformation/file/metadata.js" { declare module.exports: $Exports< "babel-core/lib/transformation/file/metadata" diff --git a/flow-typed/npm/babel-eslint_vx.x.x.js b/flow-typed/npm/babel-eslint_vx.x.x.js index ad738d2..deb409a 100644 --- a/flow-typed/npm/babel-eslint_vx.x.x.js +++ b/flow-typed/npm/babel-eslint_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 7d8a567071271aca71f1d7c450898abf -// flow-typed version: <>/babel-eslint_v^8.2.2/flow_v0.69.0 +// flow-typed signature: b30564aa0c8eb0c970eb7bbca2156d3a +// flow-typed version: <>/babel-eslint_v^8.2.2/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/babel-jest_vx.x.x.js b/flow-typed/npm/babel-jest_vx.x.x.js index 0ec56e2..c21acd2 100644 --- a/flow-typed/npm/babel-jest_vx.x.x.js +++ b/flow-typed/npm/babel-jest_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 75b3bccd57b6eba723a724ffb80ca92a -// flow-typed version: <>/babel-jest_v^23.0.0-alpha.6r/flow_v0.69.0 +// flow-typed signature: 9711bed7d1b82d61affb15cdf9a0579b +// flow-typed version: <>/babel-jest_v^23.0.0-alpha.6r/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/babel-preset-env_vx.x.x.js b/flow-typed/npm/babel-preset-env_vx.x.x.js index 7463d27..98b1768 100644 --- a/flow-typed/npm/babel-preset-env_vx.x.x.js +++ b/flow-typed/npm/babel-preset-env_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: bda3a77185ea3a353196e1409d969036 -// flow-typed version: <>/babel-preset-env_v^1.6.1/flow_v0.69.0 +// flow-typed signature: 68cb472180604a12c9a79a9e96af6843 +// flow-typed version: <>/babel-preset-env_v^1.6.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/babel-preset-react_vx.x.x.js b/flow-typed/npm/babel-preset-react_vx.x.x.js index 19a5301..1e326a3 100644 --- a/flow-typed/npm/babel-preset-react_vx.x.x.js +++ b/flow-typed/npm/babel-preset-react_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 46ec1259939954a65717a38374f317fb -// flow-typed version: <>/babel-preset-react_v^6.24.1/flow_v0.69.0 +// flow-typed signature: 00d4a4f57b8243f69204faddb7fd0ec9 +// flow-typed version: <>/babel-preset-react_v^6.24.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/concurrently_vx.x.x.js b/flow-typed/npm/concurrently_vx.x.x.js index 4a1359b..dac6b9d 100644 --- a/flow-typed/npm/concurrently_vx.x.x.js +++ b/flow-typed/npm/concurrently_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: abc8bd6e18ea696dacd822c5811ecf8c -// flow-typed version: <>/concurrently_v^3.5.1/flow_v0.69.0 +// flow-typed signature: c8756f7ab56d3b63c43353c0b00ab527 +// flow-typed version: <>/concurrently_v^3.5.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/cross-env_vx.x.x.js b/flow-typed/npm/cross-env_vx.x.x.js index f5123fd..f23b977 100644 --- a/flow-typed/npm/cross-env_vx.x.x.js +++ b/flow-typed/npm/cross-env_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: d3eaccdd0d0a86addedd10d3aec2d14c -// flow-typed version: <>/cross-env_v^5.1.4/flow_v0.69.0 +// flow-typed signature: f0e1373c33509ce2c1c682bd314907ef +// flow-typed version: <>/cross-env_v^5.1.4/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/enzyme-adapter-react-16_vx.x.x.js b/flow-typed/npm/enzyme-adapter-react-16_vx.x.x.js index 3e7b8a9..8142ea6 100644 --- a/flow-typed/npm/enzyme-adapter-react-16_vx.x.x.js +++ b/flow-typed/npm/enzyme-adapter-react-16_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: b55edbf3961daef0addd5d5576d8a0d3 -// flow-typed version: <>/enzyme-adapter-react-16_v^1.1.1/flow_v0.69.0 +// flow-typed signature: bf740df2f514a2c3c799c9c978be9475 +// flow-typed version: <>/enzyme-adapter-react-16_v^1.1.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-config-airbnb_vx.x.x.js b/flow-typed/npm/eslint-config-airbnb_vx.x.x.js index f209f57..8dac2ed 100644 --- a/flow-typed/npm/eslint-config-airbnb_vx.x.x.js +++ b/flow-typed/npm/eslint-config-airbnb_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 2233f4da2d8d37989c5fae04ca0d9a87 -// flow-typed version: <>/eslint-config-airbnb_v16.1.0/flow_v0.69.0 +// flow-typed signature: 8ffe25013da31aa58e37e37fa118d965 +// flow-typed version: <>/eslint-config-airbnb_v16.1.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-config-prettier_vx.x.x.js b/flow-typed/npm/eslint-config-prettier_vx.x.x.js index 11c7d70..e8bb1dd 100644 --- a/flow-typed/npm/eslint-config-prettier_vx.x.x.js +++ b/flow-typed/npm/eslint-config-prettier_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 3711665c8cab1c09358ae8b972d2e47d -// flow-typed version: <>/eslint-config-prettier_v^2.9.0/flow_v0.69.0 +// flow-typed signature: bb5a1119b3b91d0f07c1d0ad7cee3814 +// flow-typed version: <>/eslint-config-prettier_v^2.9.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-config-react-app_vx.x.x.js b/flow-typed/npm/eslint-config-react-app_vx.x.x.js index 370a6e6..acd0da4 100644 --- a/flow-typed/npm/eslint-config-react-app_vx.x.x.js +++ b/flow-typed/npm/eslint-config-react-app_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 9eb7773e0fb010dff004f3117373fa09 -// flow-typed version: <>/eslint-config-react-app_v^2.1.0/flow_v0.69.0 +// flow-typed signature: 0c6e10282d7cfb77bd879ff476f4b738 +// flow-typed version: <>/eslint-config-react-app_v^2.1.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-plugin-flowtype_vx.x.x.js b/flow-typed/npm/eslint-plugin-flowtype_vx.x.x.js index 5aeb53a..e6135eb 100644 --- a/flow-typed/npm/eslint-plugin-flowtype_vx.x.x.js +++ b/flow-typed/npm/eslint-plugin-flowtype_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: b6cee62d06ad86db0962aa2f6179c48f -// flow-typed version: <>/eslint-plugin-flowtype_v^2.46.1/flow_v0.69.0 +// flow-typed signature: 862e20636f5702c0d6085c877ff103b6 +// flow-typed version: <>/eslint-plugin-flowtype_v^2.46.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-plugin-import_vx.x.x.js b/flow-typed/npm/eslint-plugin-import_vx.x.x.js index 38f9cd4..fa08b88 100644 --- a/flow-typed/npm/eslint-plugin-import_vx.x.x.js +++ b/flow-typed/npm/eslint-plugin-import_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 48692da9159353db3136fe2fa07f4be0 -// flow-typed version: <>/eslint-plugin-import_v^2.11.0/flow_v0.69.0 +// flow-typed signature: 49929c2e6208e8fa48ffddbb6eeb9854 +// flow-typed version: <>/eslint-plugin-import_v^2.11.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-plugin-jsx-a11y_vx.x.x.js b/flow-typed/npm/eslint-plugin-jsx-a11y_vx.x.x.js index 5ba389c..fac10e9 100644 --- a/flow-typed/npm/eslint-plugin-jsx-a11y_vx.x.x.js +++ b/flow-typed/npm/eslint-plugin-jsx-a11y_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: d5452123075dd7edaed9dd600b1132a2 -// flow-typed version: <>/eslint-plugin-jsx-a11y_v6.0.3/flow_v0.69.0 +// flow-typed signature: e8e79788964ddd1c12370cffb16c074c +// flow-typed version: <>/eslint-plugin-jsx-a11y_v6.0.3/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-plugin-prettier_vx.x.x.js b/flow-typed/npm/eslint-plugin-prettier_vx.x.x.js index 50f2fdc..ddcea14 100644 --- a/flow-typed/npm/eslint-plugin-prettier_vx.x.x.js +++ b/flow-typed/npm/eslint-plugin-prettier_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 5ee51b1f6338b1d0ae6899264d7cfe9f -// flow-typed version: <>/eslint-plugin-prettier_v2.6.0/flow_v0.69.0 +// flow-typed signature: fbea8de079969f4aa0cbc984ad7d3173 +// flow-typed version: <>/eslint-plugin-prettier_v2.6.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint-plugin-react_vx.x.x.js b/flow-typed/npm/eslint-plugin-react_vx.x.x.js index 1d4810d..6b85cc5 100644 --- a/flow-typed/npm/eslint-plugin-react_vx.x.x.js +++ b/flow-typed/npm/eslint-plugin-react_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: d69461ea48e4f34c339a74ab9fb42d54 -// flow-typed version: <>/eslint-plugin-react_v7.7.0/flow_v0.69.0 +// flow-typed signature: 234d34357d5c546092367dd7ac9ba0d9 +// flow-typed version: <>/eslint-plugin-react_v^7.7.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/eslint_vx.x.x.js b/flow-typed/npm/eslint_vx.x.x.js index 8b39ab3..28911b5 100644 --- a/flow-typed/npm/eslint_vx.x.x.js +++ b/flow-typed/npm/eslint_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: f844f7003cd5706d223638d7977f6285 -// flow-typed version: <>/eslint_v^4.19.1/flow_v0.69.0 +// flow-typed signature: 6dfbdb84922c5551e53ff33efaeefafe +// flow-typed version: <>/eslint_v^4.19.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/flow-typed_vx.x.x.js b/flow-typed/npm/flow-typed_vx.x.x.js index 0061f00..87c090d 100644 --- a/flow-typed/npm/flow-typed_vx.x.x.js +++ b/flow-typed/npm/flow-typed_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 78a6d22874f3ad904d1ac98d2b3a7df3 -// flow-typed version: <>/flow-typed_v^2.4.0/flow_v0.69.0 +// flow-typed signature: 1291c62c38601583a9ec13e6bd24f7f9 +// flow-typed version: <>/flow-typed_v^2.4.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/grommet-addons_vx.x.x.js b/flow-typed/npm/grommet-addons_vx.x.x.js index af9918e..85554e9 100644 --- a/flow-typed/npm/grommet-addons_vx.x.x.js +++ b/flow-typed/npm/grommet-addons_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 2bd4a3eb4a6059c8f26f8b85fd8c3a31 -// flow-typed version: <>/grommet-addons_v^0.6.0/flow_v0.69.0 +// flow-typed signature: 3599b3342a7f6a0a60ba7798e625fa1a +// flow-typed version: <>/grommet-addons_v^0.6.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/heatmapjs_vx.x.x.js b/flow-typed/npm/heatmapjs_vx.x.x.js new file mode 100644 index 0000000..3521303 --- /dev/null +++ b/flow-typed/npm/heatmapjs_vx.x.x.js @@ -0,0 +1,144 @@ +// flow-typed signature: 16a92055faf349cbadc3884f21ad8cde +// flow-typed version: <>/heatmapjs_vgit+https://github.com/JonathanWi/heatmap.js.git/flow_v0.72.0 + +/** + * This is an autogenerated libdef stub for: + * + * 'heatmapjs' + * + * Fill this stub out by replacing all the `any` types. + * + * Once filled out, we encourage you to share your work with the + * community by sending a pull request to: + * https://github.com/flowtype/flow-typed + */ + +declare module "heatmapjs" { + declare module.exports: any; +} + +/** + * We include stubs for each file inside this npm package in case you need to + * require those files directly. Feel free to delete any files that aren't + * needed. + */ +declare module "heatmapjs/build/heatmap" { + declare module.exports: any; +} + +declare module "heatmapjs/build/heatmap.min" { + declare module.exports: any; +} + +declare module "heatmapjs/docs/assets/js/prism" { + declare module.exports: any; +} + +declare module "heatmapjs/Gruntfile" { + declare module.exports: any; +} + +declare module "heatmapjs/plugins/boilerplate" { + declare module.exports: any; +} + +declare module "heatmapjs/plugins/gmaps-heatmap" { + declare module.exports: any; +} + +declare module "heatmapjs/plugins/leaflet-heatmap" { + declare module.exports: any; +} + +declare module "heatmapjs/plugins/segment-heatmap" { + declare module.exports: any; +} + +declare module "heatmapjs/plugins/svg-area-heatmap" { + declare module.exports: any; +} + +declare module "heatmapjs/src/config" { + declare module.exports: any; +} + +declare module "heatmapjs/src/core" { + declare module.exports: any; +} + +declare module "heatmapjs/src/data" { + declare module.exports: any; +} + +declare module "heatmapjs/src/renderer" { + declare module.exports: any; +} + +declare module "heatmapjs/src/renderer/canvas-webgl" { + declare module.exports: any; +} + +declare module "heatmapjs/src/renderer/canvas2d" { + declare module.exports: any; +} + +declare module "heatmapjs/src/renderer/vml" { + declare module.exports: any; +} + +declare module "heatmapjs/src/util" { + declare module.exports: any; +} + +// Filename aliases +declare module "heatmapjs/build/heatmap.js" { + declare module.exports: $Exports<"heatmapjs/build/heatmap">; +} +declare module "heatmapjs/build/heatmap.min.js" { + declare module.exports: $Exports<"heatmapjs/build/heatmap.min">; +} +declare module "heatmapjs/docs/assets/js/prism.js" { + declare module.exports: $Exports<"heatmapjs/docs/assets/js/prism">; +} +declare module "heatmapjs/Gruntfile.js" { + declare module.exports: $Exports<"heatmapjs/Gruntfile">; +} +declare module "heatmapjs/plugins/boilerplate.js" { + declare module.exports: $Exports<"heatmapjs/plugins/boilerplate">; +} +declare module "heatmapjs/plugins/gmaps-heatmap.js" { + declare module.exports: $Exports<"heatmapjs/plugins/gmaps-heatmap">; +} +declare module "heatmapjs/plugins/leaflet-heatmap.js" { + declare module.exports: $Exports<"heatmapjs/plugins/leaflet-heatmap">; +} +declare module "heatmapjs/plugins/segment-heatmap.js" { + declare module.exports: $Exports<"heatmapjs/plugins/segment-heatmap">; +} +declare module "heatmapjs/plugins/svg-area-heatmap.js" { + declare module.exports: $Exports<"heatmapjs/plugins/svg-area-heatmap">; +} +declare module "heatmapjs/src/config.js" { + declare module.exports: $Exports<"heatmapjs/src/config">; +} +declare module "heatmapjs/src/core.js" { + declare module.exports: $Exports<"heatmapjs/src/core">; +} +declare module "heatmapjs/src/data.js" { + declare module.exports: $Exports<"heatmapjs/src/data">; +} +declare module "heatmapjs/src/renderer.js" { + declare module.exports: $Exports<"heatmapjs/src/renderer">; +} +declare module "heatmapjs/src/renderer/canvas-webgl.js" { + declare module.exports: $Exports<"heatmapjs/src/renderer/canvas-webgl">; +} +declare module "heatmapjs/src/renderer/canvas2d.js" { + declare module.exports: $Exports<"heatmapjs/src/renderer/canvas2d">; +} +declare module "heatmapjs/src/renderer/vml.js" { + declare module.exports: $Exports<"heatmapjs/src/renderer/vml">; +} +declare module "heatmapjs/src/util.js" { + declare module.exports: $Exports<"heatmapjs/src/util">; +} diff --git a/flow-typed/npm/husky_vx.x.x.js b/flow-typed/npm/husky_vx.x.x.js index 30c99b6..a91b2fb 100644 --- a/flow-typed/npm/husky_vx.x.x.js +++ b/flow-typed/npm/husky_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 7c33f627df4dbbf2be926d413ab2101a -// flow-typed version: <>/husky_v^0.15.0-rc.10/flow_v0.69.0 +// flow-typed signature: d714bc1e05a395171404f7fbfb86eb8a +// flow-typed version: <>/husky_v^0.15.0-rc.10/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/install-peerdeps_vx.x.x.js b/flow-typed/npm/install-peerdeps_vx.x.x.js index 0d2a205..4ae86e5 100644 --- a/flow-typed/npm/install-peerdeps_vx.x.x.js +++ b/flow-typed/npm/install-peerdeps_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: ee4094faaad50e716108d43ef8270a6d -// flow-typed version: <>/install-peerdeps_v^1.6.0/flow_v0.69.0 +// flow-typed signature: ebf35a4a0c7e5abfb5e635b8c5524554 +// flow-typed version: <>/install-peerdeps_v^1.6.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/js-file-download_vx.x.x.js b/flow-typed/npm/js-file-download_vx.x.x.js new file mode 100644 index 0000000..a9846a2 --- /dev/null +++ b/flow-typed/npm/js-file-download_vx.x.x.js @@ -0,0 +1,32 @@ +// flow-typed signature: 3b312235f4458d0beefdf1788774e5ad +// flow-typed version: <>/js-file-download_v^0.4.1/flow_v0.72.0 + +/** + * This is an autogenerated libdef stub for: + * + * 'js-file-download' + * + * Fill this stub out by replacing all the `any` types. + * + * Once filled out, we encourage you to share your work with the + * community by sending a pull request to: + * https://github.com/flowtype/flow-typed + */ + +declare module "js-file-download" { + declare module.exports: any; +} + +/** + * We include stubs for each file inside this npm package in case you need to + * require those files directly. Feel free to delete any files that aren't + * needed. + */ +declare module "js-file-download/file-download" { + declare module.exports: any; +} + +// Filename aliases +declare module "js-file-download/file-download.js" { + declare module.exports: $Exports<"js-file-download/file-download">; +} diff --git a/flow-typed/npm/node-sass-chokidar_vx.x.x.js b/flow-typed/npm/node-sass-chokidar_vx.x.x.js index 9c39a66..f499ace 100644 --- a/flow-typed/npm/node-sass-chokidar_vx.x.x.js +++ b/flow-typed/npm/node-sass-chokidar_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 8582bdf0a8388cf09ba86a406cfaac38 -// flow-typed version: <>/node-sass-chokidar_v^1.2.0/flow_v0.69.0 +// flow-typed signature: 29508d19b6b7dcc22e4fdc5b06298a16 +// flow-typed version: <>/node-sass-chokidar_v^1.2.0/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/npm-run-all_vx.x.x.js b/flow-typed/npm/npm-run-all_vx.x.x.js index 99bc3bd..7fa0563 100644 --- a/flow-typed/npm/npm-run-all_vx.x.x.js +++ b/flow-typed/npm/npm-run-all_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 2ad7e47afb294d364fb2aa6600b9dd3a -// flow-typed version: <>/npm-run-all_v^4.1.2/flow_v0.69.0 +// flow-typed signature: 34913a488a581125031c282d1de3990f +// flow-typed version: <>/npm-run-all_v^4.1.2/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/prettier-eslint_vx.x.x.js b/flow-typed/npm/prettier-eslint_vx.x.x.js index f0b360f..58b50c6 100644 --- a/flow-typed/npm/prettier-eslint_vx.x.x.js +++ b/flow-typed/npm/prettier-eslint_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 931d6789bccc37143afd85e8fd8a3923 -// flow-typed version: <>/prettier-eslint_v^8.8.1/flow_v0.69.0 +// flow-typed signature: 584e9db0555f3c5dea08429548fcb09d +// flow-typed version: <>/prettier-eslint_v^8.8.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/pretty-quick_vx.x.x.js b/flow-typed/npm/pretty-quick_vx.x.x.js index 64dba43..69811c9 100644 --- a/flow-typed/npm/pretty-quick_vx.x.x.js +++ b/flow-typed/npm/pretty-quick_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: de78cf1cf4e130abf572b5706e12c25e -// flow-typed version: <>/pretty-quick_v^1.4.1/flow_v0.69.0 +// flow-typed signature: eb46b71538b2261cf09187db70406fc1 +// flow-typed version: <>/pretty-quick_v^1.4.1/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/react-resize-detector_vx.x.x.js b/flow-typed/npm/react-resize-detector_vx.x.x.js new file mode 100644 index 0000000..bd71bad --- /dev/null +++ b/flow-typed/npm/react-resize-detector_vx.x.x.js @@ -0,0 +1,41 @@ +// flow-typed signature: 23401ca447be3b12e721b87fe133ce67 +// flow-typed version: <>/react-resize-detector_v^2.3.0/flow_v0.72.0 + +/** + * This is an autogenerated libdef stub for: + * + * 'react-resize-detector' + * + * Fill this stub out by replacing all the `any` types. + * + * Once filled out, we encourage you to share your work with the + * community by sending a pull request to: + * https://github.com/flowtype/flow-typed + */ + +declare module "react-resize-detector" { + declare module.exports: any; +} + +/** + * We include stubs for each file inside this npm package in case you need to + * require those files directly. Feel free to delete any files that aren't + * needed. + */ +declare module "react-resize-detector/lib/components/ResizeDetector" { + declare module.exports: any; +} + +declare module "react-resize-detector/lib/index" { + declare module.exports: any; +} + +// Filename aliases +declare module "react-resize-detector/lib/components/ResizeDetector.js" { + declare module.exports: $Exports< + "react-resize-detector/lib/components/ResizeDetector" + >; +} +declare module "react-resize-detector/lib/index.js" { + declare module.exports: $Exports<"react-resize-detector/lib/index">; +} diff --git a/flow-typed/npm/react-router-dom_v4.x.x.js b/flow-typed/npm/react-router-dom_v4.x.x.js index 12fd273..4c3a63b 100644 --- a/flow-typed/npm/react-router-dom_v4.x.x.js +++ b/flow-typed/npm/react-router-dom_v4.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 60904532a0b2eae42e097223d1999f8e -// flow-typed version: f821d89401/react-router-dom_v4.x.x/flow_>=v0.53.x +// flow-typed signature: e5a7aa81d9e40346b8b63c86c07c3005 +// flow-typed version: 83f1c5c51e/react-router-dom_v4.x.x/flow_>=v0.63.x declare module "react-router-dom" { declare export class BrowserRouter extends React$Component<{ @@ -90,12 +90,19 @@ declare module "react-router-dom" { staticContext?: StaticRouterContext |}; + declare type ContextRouterVoid = { + history: RouterHistory | void, + location: Location | void, + match: Match | void, + staticContext?: StaticRouterContext | void + }; + declare export type GetUserConfirmation = ( message: string, callback: (confirmed: boolean) => void ) => void; - declare type StaticRouterContext = { + declare export type StaticRouterContext = { url?: string }; @@ -142,9 +149,11 @@ declare module "react-router-dom" { children?: React$Node }> {} - declare export function withRouter

( - Component: React$ComponentType<{| ...ContextRouter, ...P |}> - ): React$ComponentType

; + declare export function withRouter>( + WrappedComponent: Component + ): React$ComponentType< + $Diff, ContextRouterVoid> + >; declare type MatchPathOptions = { path?: string, diff --git a/flow-typed/npm/react-scripts_vx.x.x.js b/flow-typed/npm/react-scripts_vx.x.x.js index b737052..37e3dad 100644 --- a/flow-typed/npm/react-scripts_vx.x.x.js +++ b/flow-typed/npm/react-scripts_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: 446244b07375c5b8f16ce8e466486414 -// flow-typed version: <>/react-scripts_v^1.1.4/flow_v0.69.0 +// flow-typed signature: ad9c88a083be1a474b617580ee24102d +// flow-typed version: <>/react-scripts_v^1.1.4/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/flow-typed/npm/typeface-roboto_vx.x.x.js b/flow-typed/npm/typeface-roboto_vx.x.x.js index 1218e8c..1cfe330 100644 --- a/flow-typed/npm/typeface-roboto_vx.x.x.js +++ b/flow-typed/npm/typeface-roboto_vx.x.x.js @@ -1,5 +1,5 @@ -// flow-typed signature: eaa6716ebb395eed79efe33fb55d6f29 -// flow-typed version: <>/typeface-roboto_v^0.0.54/flow_v0.69.0 +// flow-typed signature: 0e43f2f9fc4dca53adeae545caae039b +// flow-typed version: <>/typeface-roboto_v^0.0.54/flow_v0.72.0 /** * This is an autogenerated libdef stub for: diff --git a/src/containers/projects/EditProject.jsx b/src/containers/projects/EditProject.jsx index 38ba12d..7768ef3 100644 --- a/src/containers/projects/EditProject.jsx +++ b/src/containers/projects/EditProject.jsx @@ -22,9 +22,6 @@ type State = { shouldRedirect: boolean, toast?: ToastMetadata }; -type Test = { - t?: () => void -}; export default class EditProject extends React.Component { source: CancelTokenSource = CancelToken.source(); diff --git a/yarn.lock b/yarn.lock index 4e8726f..ea20167 100644 --- a/yarn.lock +++ b/yarn.lock @@ -78,11 +78,11 @@ lodash "^4.2.0" to-fast-properties "^2.0.0" -"@storybook/addon-actions@3.4.4", "@storybook/addon-actions@^3.4.1": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/addon-actions/-/addon-actions-3.4.4.tgz#03cc675977b6c6ce44a4dd7e2d36a910848af85f" +"@storybook/addon-actions@3.4.5", "@storybook/addon-actions@^3.4.1": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/addon-actions/-/addon-actions-3.4.5.tgz#ba0d0c0c74357c0852e0b890b404214975df40a8" dependencies: - "@storybook/components" "3.4.4" + "@storybook/components" "3.4.5" babel-runtime "^6.26.0" deep-equal "^1.0.1" glamor "^2.20.40" @@ -93,52 +93,52 @@ react-inspector "^2.2.2" uuid "^3.2.1" -"@storybook/addon-links@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/addon-links/-/addon-links-3.4.4.tgz#ff2a7c810c97fe465b25e417752eeebb5322ed9c" +"@storybook/addon-links@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/addon-links/-/addon-links-3.4.5.tgz#c885dae976f5084faa0ae026755f2d6068da034f" dependencies: - "@storybook/components" "3.4.4" + "@storybook/components" "3.4.5" babel-runtime "^6.26.0" global "^4.3.2" prop-types "^15.6.1" -"@storybook/addons@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/addons/-/addons-3.4.4.tgz#5f3203791df83499247a8bc4034788943500ff16" +"@storybook/addons@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/addons/-/addons-3.4.5.tgz#8dd6eb93ae26b4498a9b1e2b890316944efa41da" -"@storybook/channel-postmessage@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/channel-postmessage/-/channel-postmessage-3.4.4.tgz#96ead79c7752c747c355f297f4f344a44763600b" +"@storybook/channel-postmessage@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/channel-postmessage/-/channel-postmessage-3.4.5.tgz#8c7de674847dec2a154947e0b99e54a2618c79cb" dependencies: - "@storybook/channels" "3.4.4" + "@storybook/channels" "3.4.5" global "^4.3.2" json-stringify-safe "^5.0.1" -"@storybook/channels@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/channels/-/channels-3.4.4.tgz#a0492404d21231dcbe12716707472dd4549fb37a" +"@storybook/channels@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/channels/-/channels-3.4.5.tgz#cb8e3798cdcbed0b7037e634fb029cdd758c73a8" -"@storybook/client-logger@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/client-logger/-/client-logger-3.4.4.tgz#e76a457e7a19ba7a66fae9cce91bf52e6ece3f6e" +"@storybook/client-logger@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/client-logger/-/client-logger-3.4.5.tgz#aca45699b14d6663c694ab3253d46bc257f8783e" -"@storybook/components@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/components/-/components-3.4.4.tgz#272bcbdb2ac28583de049f75352f9eec76835641" +"@storybook/components@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/components/-/components-3.4.5.tgz#02653ba562e3678eab3adbc31b012eae4fbe61dc" dependencies: glamor "^2.20.40" glamorous "^4.12.1" prop-types "^15.6.1" -"@storybook/core@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/core/-/core-3.4.4.tgz#4335974772bcdf858b5ccbc7f89d9cd6090e7889" +"@storybook/core@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/core/-/core-3.4.5.tgz#a34a498eace85d29a12559a895c420f5ae54b0b7" dependencies: - "@storybook/addons" "3.4.4" - "@storybook/channel-postmessage" "3.4.4" - "@storybook/client-logger" "3.4.4" - "@storybook/node-logger" "3.4.4" - "@storybook/ui" "3.4.4" + "@storybook/addons" "3.4.5" + "@storybook/channel-postmessage" "3.4.5" + "@storybook/client-logger" "3.4.5" + "@storybook/node-logger" "3.4.5" + "@storybook/ui" "3.4.5" autoprefixer "^7.2.6" babel-runtime "^6.26.0" chalk "^2.3.2" @@ -170,9 +170,9 @@ "@storybook/react-simple-di" "^1.2.1" babel-runtime "6.x.x" -"@storybook/node-logger@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/node-logger/-/node-logger-3.4.4.tgz#f4378e63d3fb6addc76f9a8baaf5be4dae7811f4" +"@storybook/node-logger@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/node-logger/-/node-logger-3.4.5.tgz#d08c082b0d4a573736f25c2e0eea261b30183962" dependencies: npmlog "^4.1.2" @@ -209,17 +209,17 @@ babel-runtime "^6.5.0" "@storybook/react@^3.4.1": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/react/-/react-3.4.4.tgz#53c9c8f50283ee9bdc8bfcb882cbf74b0658a4f1" - dependencies: - "@storybook/addon-actions" "3.4.4" - "@storybook/addon-links" "3.4.4" - "@storybook/addons" "3.4.4" - "@storybook/channel-postmessage" "3.4.4" - "@storybook/client-logger" "3.4.4" - "@storybook/core" "3.4.4" - "@storybook/node-logger" "3.4.4" - "@storybook/ui" "3.4.4" + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/react/-/react-3.4.5.tgz#1979423f365252cf03a4508db26b676f239c1e80" + dependencies: + "@storybook/addon-actions" "3.4.5" + "@storybook/addon-links" "3.4.5" + "@storybook/addons" "3.4.5" + "@storybook/channel-postmessage" "3.4.5" + "@storybook/client-logger" "3.4.5" + "@storybook/core" "3.4.5" + "@storybook/node-logger" "3.4.5" + "@storybook/ui" "3.4.5" airbnb-js-shims "^1.4.1" babel-loader "^7.1.4" babel-plugin-macros "^2.2.0" @@ -252,11 +252,11 @@ webpack "^3.11.0" webpack-hot-middleware "^2.22.1" -"@storybook/ui@3.4.4": - version "3.4.4" - resolved "https://registry.yarnpkg.com/@storybook/ui/-/ui-3.4.4.tgz#2bb8ba4cdb7711695e018c2cc2db0a7e1c48a09a" +"@storybook/ui@3.4.5": + version "3.4.5" + resolved "https://registry.yarnpkg.com/@storybook/ui/-/ui-3.4.5.tgz#b11e97590b5e09b2d1452c0a4b84567780ec3390" dependencies: - "@storybook/components" "3.4.4" + "@storybook/components" "3.4.5" "@storybook/mantra-core" "^1.7.2" "@storybook/podda" "^1.2.3" "@storybook/react-komposer" "^2.0.3" @@ -332,12 +332,13 @@ address@1.0.3, address@^1.0.1: resolved "https://registry.yarnpkg.com/address/-/address-1.0.3.tgz#b5f50631f8d6cec8bd20c963963afb55e06cbce9" airbnb-js-shims@^1.4.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/airbnb-js-shims/-/airbnb-js-shims-1.4.1.tgz#cc3e8eb8d35877f9d0fdc6583e26b0ee75b98ad0" + version "1.5.1" + resolved "https://registry.yarnpkg.com/airbnb-js-shims/-/airbnb-js-shims-1.5.1.tgz#5d7614a76ca7bfdcfc3162eefe4011aff870aee8" dependencies: array-includes "^3.0.3" - array.prototype.flatmap "^1.2.0" - array.prototype.flatten "^1.2.0" + array.prototype.flat "^1.2.1" + array.prototype.flatmap "^1.2.1" + array.prototype.flatten "^1.2.1" es5-shim "^4.5.10" es6-shim "^0.35.3" function.prototype.name "^1.1.0" @@ -347,6 +348,7 @@ airbnb-js-shims@^1.4.1: promise.prototype.finally "^3.1.0" string.prototype.padend "^3.0.0" string.prototype.padstart "^3.0.0" + symbol.prototype.description "^1.0.0" ajv-keywords@^2.0.0, ajv-keywords@^2.1.0: version "2.1.1" @@ -553,7 +555,15 @@ array-unique@^0.3.2: version "0.3.2" resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428" -array.prototype.flatmap@^1.2.0: +array.prototype.flat@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.2.1.tgz#812db8f02cad24d3fab65dd67eabe3b8903494a4" + dependencies: + define-properties "^1.1.2" + es-abstract "^1.10.0" + function-bind "^1.1.1" + +array.prototype.flatmap@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.2.1.tgz#3103cd4826ef90019c9b0a4839b2535fa6faf4e9" dependencies: @@ -561,7 +571,7 @@ array.prototype.flatmap@^1.2.0: es-abstract "^1.10.0" function-bind "^1.1.1" -array.prototype.flatten@^1.2.0: +array.prototype.flatten@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/array.prototype.flatten/-/array.prototype.flatten-1.2.1.tgz#a77ae1b64524ce373b137fade324d12040d3c680" dependencies: @@ -631,7 +641,13 @@ async@^1.4.0, async@^1.5.2: version "1.5.2" resolved "https://registry.yarnpkg.com/async/-/async-1.5.2.tgz#ec6a61ae56480c0c3cb241c95618e20892f9672a" -async@^2.1.2, async@^2.1.4, async@^2.4.1: +async@^2.1.2, async@^2.1.4: + version "2.6.1" + resolved "https://registry.yarnpkg.com/async/-/async-2.6.1.tgz#b245a23ca71930044ec53fa46aa00a3e87c6a610" + dependencies: + lodash "^4.17.10" + +async@^2.4.1: version "2.6.0" resolved "https://registry.yarnpkg.com/async/-/async-2.6.0.tgz#61a29abb6fcc026fea77e56d1c6ec53a795951f4" dependencies: @@ -2157,13 +2173,17 @@ caniuse-api@^1.5.2: lodash.uniq "^4.5.0" caniuse-db@^1.0.30000529, caniuse-db@^1.0.30000634, caniuse-db@^1.0.30000639: - version "1.0.30000840" - resolved "https://registry.yarnpkg.com/caniuse-db/-/caniuse-db-1.0.30000840.tgz#68d5a0f0694c92180b0d82e720d70f8e61366604" + version "1.0.30000844" + resolved "https://registry.yarnpkg.com/caniuse-db/-/caniuse-db-1.0.30000844.tgz#bca5798cda2b6931d68100c2d69e55fb338cbb41" -caniuse-lite@^1.0.30000748, caniuse-lite@^1.0.30000792, caniuse-lite@^1.0.30000805, caniuse-lite@^1.0.30000835: +caniuse-lite@^1.0.30000748, caniuse-lite@^1.0.30000835: version "1.0.30000840" resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30000840.tgz#344513f8f843536cf99694964c09811277eee395" +caniuse-lite@^1.0.30000792, caniuse-lite@^1.0.30000805: + version "1.0.30000844" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30000844.tgz#de7c84cde0582143cf4f5abdf1b98e5a0539ad4a" + capture-stack-trace@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/capture-stack-trace/-/capture-stack-trace-1.0.0.tgz#4a6fa07399c26bba47f0b2496b4d0fb408c5550d" @@ -2667,8 +2687,8 @@ create-react-class@^15.5.1, create-react-class@^15.6.2: object-assign "^4.1.1" cross-env@^5.1.4: - version "5.1.5" - resolved "https://registry.yarnpkg.com/cross-env/-/cross-env-5.1.5.tgz#31daf7f3a52ef337c8ddda585f08175cce5d1fa5" + version "5.1.6" + resolved "https://registry.yarnpkg.com/cross-env/-/cross-env-5.1.6.tgz#0dc05caf945b24e4b9e3b12871fe0e858d08b38d" dependencies: cross-spawn "^5.1.0" is-windows "^1.0.0" @@ -2863,8 +2883,8 @@ cssom@0.3.x, "cssom@>= 0.3.2 < 0.4.0": cssom "0.3.x" csstype@^2.2.0: - version "2.5.1" - resolved "https://registry.yarnpkg.com/csstype/-/csstype-2.5.1.tgz#654231d1ddddfc3eb93da281a1144e7c14fc0bdc" + version "2.5.2" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-2.5.2.tgz#4534308476ceede8fbe148b9b99f9baf1c80fa06" currently-unhandled@^0.4.1: version "0.4.1" @@ -3229,7 +3249,11 @@ ee-first@1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" -electron-to-chromium@^1.2.7, electron-to-chromium@^1.3.30, electron-to-chromium@^1.3.45: +electron-to-chromium@^1.2.7, electron-to-chromium@^1.3.30: + version "1.3.48" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.48.tgz#d3b0d8593814044e092ece2108fc3ac9aea4b900" + +electron-to-chromium@^1.3.45: version "1.3.45" resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.45.tgz#458ac1b1c5c760ce8811a16d2bfbd97ec30bafb8" @@ -4273,13 +4297,20 @@ fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" -fsevents@^1.0.0, fsevents@^1.1.2, fsevents@^1.1.3: +fsevents@^1.0.0, fsevents@^1.1.3: version "1.2.3" resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.2.3.tgz#08292982e7059f6674c93d8b829c1e8604979ac0" dependencies: nan "^2.9.2" node-pre-gyp "^0.9.0" +fsevents@^1.1.2: + version "1.2.4" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.2.4.tgz#f41dcb1af2582af3692da36fc55cbd8e1041c426" + dependencies: + nan "^2.9.2" + node-pre-gyp "^0.10.0" + fstream@^1.0.0, fstream@^1.0.2, fstream@~1.0.10: version "1.0.11" resolved "https://registry.yarnpkg.com/fstream/-/fstream-1.0.11.tgz#5c1fb1f117477114f0632a0eb4b71b3cb0fd3171" @@ -4841,8 +4872,8 @@ html-loader@^0.5.5: object-assign "^4.1.1" html-minifier@^3.2.3, html-minifier@^3.5.8: - version "3.5.15" - resolved "https://registry.yarnpkg.com/html-minifier/-/html-minifier-3.5.15.tgz#f869848d4543cbfd84f26d5514a2a87cbf9a05e0" + version "3.5.16" + resolved "https://registry.yarnpkg.com/html-minifier/-/html-minifier-3.5.16.tgz#39f5aabaf78bdfc057fe67334226efd7f3851175" dependencies: camel-case "3.0.x" clean-css "4.1.x" @@ -4921,8 +4952,8 @@ http-errors@~1.6.2: statuses ">= 1.4.0 < 2" http-parser-js@>=0.4.0: - version "0.4.12" - resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.4.12.tgz#b9cfbf4a2cf26f0fc34b10ca1489a27771e3474f" + version "0.4.13" + resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.4.13.tgz#3bd6d6fde6e3172c9334c3b33b6c193d80fe1137" http-proxy-middleware@~0.17.4: version "0.17.4" @@ -5856,10 +5887,14 @@ jest@20.0.4: dependencies: jest-cli "^20.0.4" -js-base64@^2.1.8, js-base64@^2.1.9: +js-base64@^2.1.8: version "2.4.3" resolved "https://registry.yarnpkg.com/js-base64/-/js-base64-2.4.3.tgz#2e545ec2b0f2957f41356510205214e98fad6582" +js-base64@^2.1.9: + version "2.4.5" + resolved "https://registry.yarnpkg.com/js-base64/-/js-base64-2.4.5.tgz#e293cd3c7c82f070d700fc7a1ca0a2e69f101f92" + js-cookie@^2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/js-cookie/-/js-cookie-2.2.0.tgz#1b2c279a6eece380a12168b92485265b35b1effb" @@ -6250,7 +6285,7 @@ lodash.zip@^4.2.0: version "4.2.0" resolved "https://registry.yarnpkg.com/lodash.zip/-/lodash.zip-4.2.0.tgz#ec6662e4896408ed4ab6c542a3990b72cc080020" -"lodash@>=3.5 <5", lodash@^4.0.0, lodash@^4.13.1, lodash@^4.14.0, lodash@^4.15.0, lodash@^4.17.0, lodash@^4.17.2, lodash@^4.17.3, lodash@^4.17.4, lodash@^4.17.5, lodash@^4.2.0, lodash@^4.2.1, lodash@^4.3.0, lodash@^4.5.1, lodash@~4.17.4: +"lodash@>=3.5 <5", lodash@^4.0.0, lodash@^4.13.1, lodash@^4.14.0, lodash@^4.15.0, lodash@^4.17.0, lodash@^4.17.10, lodash@^4.17.2, lodash@^4.17.3, lodash@^4.17.4, lodash@^4.17.5, lodash@^4.2.0, lodash@^4.2.1, lodash@^4.3.0, lodash@^4.5.1, lodash@~4.17.4: version "4.17.10" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.10.tgz#1b7793cf7259ea38fb3661d4d38b3260af8ae4e7" @@ -6303,10 +6338,6 @@ lru-queue@0.1: dependencies: es5-ext "~0.10.2" -macaddress@^0.2.8: - version "0.2.8" - resolved "https://registry.yarnpkg.com/macaddress/-/macaddress-0.2.8.tgz#5904dc537c39ec6dbefeae902327135fa8511f12" - make-dir@^1.0.0: version "1.3.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-1.3.0.tgz#79c1033b80515bd6d24ec9933e860ca75ee27f0c" @@ -6551,10 +6582,10 @@ minimist@~0.0.1: resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.10.tgz#de3f98543dbf96082be48ad1a0c7cda836301dcf" minipass@^2.2.1, minipass@^2.2.4: - version "2.3.0" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-2.3.0.tgz#2e11b1c46df7fe7f1afbe9a490280add21ffe384" + version "2.3.3" + resolved "https://registry.yarnpkg.com/minipass/-/minipass-2.3.3.tgz#a7dcc8b7b833f5d368759cce544dccb55f50f233" dependencies: - safe-buffer "^5.1.1" + safe-buffer "^5.1.2" yallist "^3.0.0" minizlib@^1.1.0: @@ -6773,6 +6804,21 @@ node-notifier@^5.0.2: shellwords "^0.1.1" which "^1.3.0" +node-pre-gyp@^0.10.0: + version "0.10.0" + resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.10.0.tgz#6e4ef5bb5c5203c6552448828c852c40111aac46" + dependencies: + detect-libc "^1.0.2" + mkdirp "^0.5.1" + needle "^2.2.0" + nopt "^4.0.1" + npm-packlist "^1.1.6" + npmlog "^4.0.2" + rc "^1.1.7" + rimraf "^2.6.1" + semver "^5.3.0" + tar "^4" + node-pre-gyp@^0.9.0: version "0.9.1" resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.9.1.tgz#f11c07516dd92f87199dbc7e1838eab7cd56c9e0" @@ -7411,11 +7457,10 @@ postcss-discard-unused@^2.2.1: uniqs "^2.0.0" postcss-filter-plugins@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/postcss-filter-plugins/-/postcss-filter-plugins-2.0.2.tgz#6d85862534d735ac420e4a85806e1f5d4286d84c" + version "2.0.3" + resolved "https://registry.yarnpkg.com/postcss-filter-plugins/-/postcss-filter-plugins-2.0.3.tgz#82245fdf82337041645e477114d8e593aa18b8ec" dependencies: postcss "^5.0.4" - uniqid "^4.0.0" postcss-flexbugs-fixes@3.2.0: version "3.2.0" @@ -7720,8 +7765,8 @@ pretty-format@^22.0.3: ansi-styles "^3.2.0" pretty-quick@^1.4.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/pretty-quick/-/pretty-quick-1.4.1.tgz#9d41f778d2d4d940ec603d1293a0998e84c4722c" + version "1.6.0" + resolved "https://registry.yarnpkg.com/pretty-quick/-/pretty-quick-1.6.0.tgz#afc3591eb5c4cf37614a305d489a8a40e57c9258" dependencies: chalk "^2.3.0" execa "^0.8.0" @@ -7830,8 +7875,8 @@ pump@^2.0.0, pump@^2.0.1: once "^1.3.1" pumpify@^1.3.3: - version "1.5.0" - resolved "https://registry.yarnpkg.com/pumpify/-/pumpify-1.5.0.tgz#30c905a26c88fa0074927af07256672b474b1c15" + version "1.5.1" + resolved "https://registry.yarnpkg.com/pumpify/-/pumpify-1.5.1.tgz#36513be246ab27570b1a374a5ce278bfd74370ce" dependencies: duplexify "^3.6.0" inherits "^2.0.3" @@ -8006,8 +8051,8 @@ react-dom@^16.3.1: prop-types "^15.6.0" react-dropzone@^4.2.9: - version "4.2.9" - resolved "https://registry.yarnpkg.com/react-dropzone/-/react-dropzone-4.2.9.tgz#98156ce4d4cb018f7c5099eeb2eaff6dc21836fd" + version "4.2.10" + resolved "https://registry.yarnpkg.com/react-dropzone/-/react-dropzone-4.2.10.tgz#49de76346f5f56bc3e76aeab5604f4cddd0e87fb" dependencies: attr-accept "^1.0.3" prop-types "^15.5.7" @@ -9395,6 +9440,12 @@ symbol-tree@^3.2.1: version "3.2.2" resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.2.tgz#ae27db38f660a7ae2e1c3b7d1bc290819b8519e6" +symbol.prototype.description@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/symbol.prototype.description/-/symbol.prototype.description-1.0.0.tgz#6e355660eb1e44ca8ad53a68fdb72ef131ca4b12" + dependencies: + has-symbols "^1.0.0" + table@4.0.2: version "4.0.2" resolved "https://registry.yarnpkg.com/table/-/table-4.0.2.tgz#a33447375391e766ad34d3486e6e2aedc84d2e36" @@ -9642,9 +9693,9 @@ uglify-es@^3.3.4: commander "~2.13.0" source-map "~0.6.1" -uglify-js@3.3.x, uglify-js@^3.0.13: - version "3.3.25" - resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-3.3.25.tgz#3266ccb87c5bea229f69041a0296010d6477d539" +uglify-js@3.3.x: + version "3.3.27" + resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-3.3.27.tgz#eb8c3c9429969f86ff5b0a2422ffc78c3cea8cc0" dependencies: commander "~2.15.0" source-map "~0.6.1" @@ -9658,6 +9709,13 @@ uglify-js@^2.6, uglify-js@^2.8.29: optionalDependencies: uglify-to-browserify "~1.0.0" +uglify-js@^3.0.13: + version "3.3.25" + resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-3.3.25.tgz#3266ccb87c5bea229f69041a0296010d6477d539" + dependencies: + commander "~2.15.0" + source-map "~0.6.1" + uglify-to-browserify@~1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7" @@ -9700,12 +9758,6 @@ uniq@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/uniq/-/uniq-1.0.1.tgz#b31c5ae8254844a3a8281541ce2b04b865a734ff" -uniqid@^4.0.0: - version "4.1.1" - resolved "https://registry.yarnpkg.com/uniqid/-/uniqid-4.1.1.tgz#89220ddf6b751ae52b5f72484863528596bb84c1" - dependencies: - macaddress "^0.2.8" - uniqs@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/uniqs/-/uniqs-2.0.0.tgz#ffede4b36b25290696e6e165d4a59edb998e6b02" @@ -9766,8 +9818,8 @@ unzipper@^0.8.11: setimmediate "~1.0.4" upath@^1.0.0: - version "1.0.5" - resolved "https://registry.yarnpkg.com/upath/-/upath-1.0.5.tgz#02cab9ecebe95bbec6d5fc2566325725ab6d1a73" + version "1.1.0" + resolved "https://registry.yarnpkg.com/upath/-/upath-1.1.0.tgz#35256597e46a581db4793d0ce47fa9aebfc9fabd" update-notifier@^2.3.0: version "2.5.0" From deb8d46ddf823383e108b649f319c5c9cea2e836 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 10:49:02 +0200 Subject: [PATCH 009/160] Updated to fix bug with syntax highlighting in VSCode --- src/containers/projects/EditProject.jsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/containers/projects/EditProject.jsx b/src/containers/projects/EditProject.jsx index 7768ef3..d6ff366 100644 --- a/src/containers/projects/EditProject.jsx +++ b/src/containers/projects/EditProject.jsx @@ -109,10 +109,10 @@ export default class EditProject extends React.Component { } return ( - {showToast => ( + {(showToast: any) => (

this.onSubmit((showToast: any))} + onSubmit={() => this.onSubmit(showToast)} > Date: Wed, 23 May 2018 11:17:58 +0200 Subject: [PATCH 010/160] Updated Project CRUD form, type names and Project model --- .../heatmapConfigForm/HeatmapConfigForm.jsx | 4 +-- .../HeatmapConfigForm.test.jsx | 4 +-- .../heatmapModeForm/HeatmapModeForm.jsx | 4 +-- .../heatmapModeForm/HeatmapModeForm.test.jsx | 4 +-- .../measurements/MeasurementSummary.jsx | 8 ++--- src/components/projects/Project.test.jsx | 7 +++- .../transformationForm/TransformationForm.jsx | 4 +-- .../TransformationForm.test.jsx | 4 +-- src/containers/projects/EditProject.jsx | 32 +++++++++++++------ src/models/Project.jsx | 14 ++++++-- src/utils/DataGenerator.jsx | 7 +++- src/utils/InputHandler.jsx | 4 +-- 12 files changed, 63 insertions(+), 33 deletions(-) diff --git a/src/components/heatmapConfigForm/HeatmapConfigForm.jsx b/src/components/heatmapConfigForm/HeatmapConfigForm.jsx index afee44f..db31944 100644 --- a/src/components/heatmapConfigForm/HeatmapConfigForm.jsx +++ b/src/components/heatmapConfigForm/HeatmapConfigForm.jsx @@ -6,12 +6,12 @@ import FormFields from "grommet/components/FormFields"; import NumberInput from "grommet/components/NumberInput"; import type { ConfigObject } from "../../types/Heatmap"; import { inputHandler } from "../../utils/InputHandler"; -import type { allInputTypes } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; type Props = { configObject: ConfigObject, onSubmit: () => void, - onChange: (string, allInputTypes) => void + onChange: (string, AllInputTypes) => void }; export default function HeatmapConfigForm({ diff --git a/src/components/heatmapConfigForm/HeatmapConfigForm.test.jsx b/src/components/heatmapConfigForm/HeatmapConfigForm.test.jsx index 1a580bb..363a605 100644 --- a/src/components/heatmapConfigForm/HeatmapConfigForm.test.jsx +++ b/src/components/heatmapConfigForm/HeatmapConfigForm.test.jsx @@ -4,11 +4,11 @@ import { shallow } from "enzyme"; import HeatmapConfigForm from "./HeatmapConfigForm"; import type { ConfigObject } from "../../types/Heatmap"; -import type { allInputTypes } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; describe("", () => { const onSubmit = () => {}; - const onChange = (key: string, value: allInputTypes) => {}; + const onChange = (key: string, value: AllInputTypes) => {}; const configObject: ConfigObject = {}; it("should render", () => { diff --git a/src/components/heatmapModeForm/HeatmapModeForm.jsx b/src/components/heatmapModeForm/HeatmapModeForm.jsx index a657bbf..2650d7b 100644 --- a/src/components/heatmapModeForm/HeatmapModeForm.jsx +++ b/src/components/heatmapModeForm/HeatmapModeForm.jsx @@ -6,11 +6,11 @@ import FormFields from "grommet/components/FormFields"; import CheckBox from "grommet/components/CheckBox"; import type { HeatmapModes } from "../../types/Heatmap"; import { inputHandler } from "../../utils/InputHandler"; -import type { allInputTypes } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; type Props = { heatmapModes: HeatmapModes, - onChange: (string, allInputTypes) => void + onChange: (string, AllInputTypes) => void }; export default function HeatmapModeForm({ heatmapModes, onChange }: Props) { diff --git a/src/components/heatmapModeForm/HeatmapModeForm.test.jsx b/src/components/heatmapModeForm/HeatmapModeForm.test.jsx index f951c9f..a1d275b 100644 --- a/src/components/heatmapModeForm/HeatmapModeForm.test.jsx +++ b/src/components/heatmapModeForm/HeatmapModeForm.test.jsx @@ -4,10 +4,10 @@ import { shallow } from "enzyme"; import HeatmapModeForm from "./HeatmapModeForm"; import type { HeatmapModes } from "../../types/Heatmap"; -import type { allInputTypes } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; describe("", () => { - const onChange = (key: string, value: allInputTypes) => {}; + const onChange = (key: string, value: AllInputTypes) => {}; const heatmapModes: HeatmapModes = { showCoverage: false, showAnchors: false diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index feae7b5..9568c8f 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -19,7 +19,7 @@ import TransformationForm from "../transformationForm/TransformationForm"; import HeatmapConfigForm from "../heatmapConfigForm/HeatmapConfigForm"; import { EXAMPLE_IMAGE } from "../../images/ImagesBase64"; import HeatmapModeForm from "../heatmapModeForm/HeatmapModeForm"; -import type { allInputTypes } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; import Loading from "../loading/Loading"; type Props = { @@ -56,7 +56,7 @@ export default class MeasurementSummary extends React.Component { }); } - handleTransformationChange = (key: string, value: allInputTypes) => { + handleTransformationChange = (key: string, value: AllInputTypes) => { this.setState((prevState, props) => ({ transformation: Object.assign(prevState.transformation, { [key]: parseFloat(value) @@ -64,7 +64,7 @@ export default class MeasurementSummary extends React.Component { })); }; - handleModeChange = (key: string, value: allInputTypes) => { + handleModeChange = (key: string, value: AllInputTypes) => { this.setState((prevState, props) => ({ heatmapModes: Object.assign(prevState.heatmapModes, { [key]: value @@ -72,7 +72,7 @@ export default class MeasurementSummary extends React.Component { })); }; - handleHeatmapConfigChange = (key: string, value: allInputTypes) => { + handleHeatmapConfigChange = (key: string, value: AllInputTypes) => { this.setState((prevState, props) => ({ configObject: Object.assign(prevState.configObject, { [key]: parseFloat(value) diff --git a/src/components/projects/Project.test.jsx b/src/components/projects/Project.test.jsx index ae1cdfe..1f1a92f 100644 --- a/src/components/projects/Project.test.jsx +++ b/src/components/projects/Project.test.jsx @@ -8,7 +8,12 @@ import Project from "./Project"; describe("", () => { it("should render", () => { - const project = new ProjectModel("First Project", [], 5234); + const project = new ProjectModel( + "First Project", + "First Project", + [], + 5234 + ); shallow( } /> diff --git a/src/components/transformationForm/TransformationForm.jsx b/src/components/transformationForm/TransformationForm.jsx index 9105cfe..674c2aa 100644 --- a/src/components/transformationForm/TransformationForm.jsx +++ b/src/components/transformationForm/TransformationForm.jsx @@ -6,12 +6,12 @@ import FormFields from "grommet/components/FormFields"; import NumberInput from "grommet/components/NumberInput"; import Transformation from "../../models/Transformation"; import { inputHandler } from "../../utils/InputHandler"; -import type { allInputTypes } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; type Props = { transformation: Transformation, onSubmit: () => void, - onChange: (string, allInputTypes) => void + onChange: (string, AllInputTypes) => void }; export default function TransformationForm({ diff --git a/src/components/transformationForm/TransformationForm.test.jsx b/src/components/transformationForm/TransformationForm.test.jsx index a6db9bf..ca9d24d 100644 --- a/src/components/transformationForm/TransformationForm.test.jsx +++ b/src/components/transformationForm/TransformationForm.test.jsx @@ -4,11 +4,11 @@ import { shallow } from "enzyme"; import TransformationForm from "./TransformationForm"; import Transformation from "../../models/Transformation"; -import type { allInputTypes } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; describe("", () => { const onSubmit = () => {}; - const onChange = (key: string, value: allInputTypes) => {}; + const onChange = (key: string, value: AllInputTypes) => {}; it("should render", () => { const wrapper = shallow( diff --git a/src/containers/projects/EditProject.jsx b/src/containers/projects/EditProject.jsx index d6ff366..53ea060 100644 --- a/src/containers/projects/EditProject.jsx +++ b/src/containers/projects/EditProject.jsx @@ -9,7 +9,9 @@ import { Redirect } from "react-router-dom"; import Form from "./../../components/form/Form"; import Project from "../../models/Project"; import { ToastContext } from "./../../components/toast/ToastContext"; +import { inputHandler } from "../../utils/InputHandler"; +import type { AllInputTypes } from "../../utils/InputHandler"; import type { ToastMetadata } from "./../../components/toast/Toast"; type Props = { @@ -26,7 +28,11 @@ type State = { export default class EditProject extends React.Component { source: CancelTokenSource = CancelToken.source(); state = { - project: new Project("uninitialized project", []), + project: new Project( + "uninitialized project", + "This project is uninitialized. Probably an error!", + [] + ), loading: true, shouldRedirect: false }; @@ -43,12 +49,11 @@ export default class EditProject extends React.Component { }); }; - onTitleChanged = (event: SyntheticEvent) => { - const target = event.currentTarget; - const value = target.value; - - this.setState(prevState => { - prevState.project.name = value; + onProjectChanged = (key: string, value: AllInputTypes) => { + this.setState((prevState, props) => { + prevState.project = Object.assign(prevState.project, { + [key]: value + }); return prevState; }); }; @@ -80,12 +85,11 @@ export default class EditProject extends React.Component { componentDidMount() { const projectId = this.props.match.params.projectId; - let project: Project; if (typeof projectId === "undefined") { this.setState({ - project: new Project("", []), + project: new Project("", "", []), loading: false }); } else { @@ -119,7 +123,15 @@ export default class EditProject extends React.Component { name="name" placeholder="Projektname eingeben" value={this.state.project.name} - onDOMChange={this.onTitleChanged} + onDOMChange={inputHandler(this.onProjectChanged)} + /> + + + {this.state.shouldRedirect && } diff --git a/src/models/Project.jsx b/src/models/Project.jsx index a00404d..76f92c4 100644 --- a/src/models/Project.jsx +++ b/src/models/Project.jsx @@ -3,6 +3,7 @@ import Room from "./Room"; type ConstructorType = { name: string, + description: string, rooms: Room[], projectId: ?number }; @@ -10,19 +11,26 @@ type ConstructorType = { export default class Project { projectId: ?number; name: string; + description: string; rooms: Room[]; - constructor(name: string, rooms: Room[], projectId: ?number) { + constructor( + name: string, + description: string, + rooms: Room[], + projectId: ?number + ) { this.projectId = projectId; this.name = name; + this.description = description; this.rooms = rooms; } - static fromObject({ name, rooms, projectId }: ConstructorType) { + static fromObject({ name, description, rooms, projectId }: ConstructorType) { const typedRoomObjects: Room[] = []; rooms.forEach(r => { typedRoomObjects.push(Room.fromObject(r)); }); - return new Project(name, typedRoomObjects, projectId); + return new Project(name, description, typedRoomObjects, projectId); } } diff --git a/src/utils/DataGenerator.jsx b/src/utils/DataGenerator.jsx index 64b1586..5c5527f 100644 --- a/src/utils/DataGenerator.jsx +++ b/src/utils/DataGenerator.jsx @@ -41,7 +41,12 @@ export default class DataGenerator { rooms.push(DataGenerator.createRoom(amountOfMeasurementPerRoom)); } - return new Project("My First Project", rooms, DataGenerator.getRandomInt()); + return new Project( + "My First Project", + "Project description", + rooms, + DataGenerator.getRandomInt() + ); } static createProjects( diff --git a/src/utils/InputHandler.jsx b/src/utils/InputHandler.jsx index 9905702..2dda83a 100644 --- a/src/utils/InputHandler.jsx +++ b/src/utils/InputHandler.jsx @@ -1,7 +1,7 @@ // @flow -export type allInputTypes = string | number | boolean; +export type AllInputTypes = string | number | boolean; -export const inputHandler = (callback: (string, allInputTypes) => void) => ( +export const inputHandler = (callback: (string, AllInputTypes) => void) => ( event: SyntheticEvent ) => { if ( From daf7a364d589a25d6455b326b79767283c8615d5 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 13:02:06 +0200 Subject: [PATCH 011/160] Updated List Items --- public/index.html | 2 +- src/components/list/ItemsList.jsx | 2 +- .../AnchorMeasurementItemRenderer.jsx | 19 ++++++++++++++----- .../projects/AnchorProjectItemRenderer.jsx | 10 +++++++++- .../room/AnchorRoomItemRenderer.jsx | 9 +++++++-- src/index.scss | 6 ++++++ 6 files changed, 38 insertions(+), 10 deletions(-) diff --git a/public/index.html b/public/index.html index 3a6f697..59b967d 100644 --- a/public/index.html +++ b/public/index.html @@ -1,5 +1,5 @@ - + diff --git a/src/components/list/ItemsList.jsx b/src/components/list/ItemsList.jsx index e43c30d..d9f8108 100644 --- a/src/components/list/ItemsList.jsx +++ b/src/components/list/ItemsList.jsx @@ -57,7 +57,7 @@ export default function ItemsList({ {items && items.map(item => ( - + ))} diff --git a/src/components/measurements/AnchorMeasurementItemRenderer.jsx b/src/components/measurements/AnchorMeasurementItemRenderer.jsx index 10cc1cd..44c4b7d 100644 --- a/src/components/measurements/AnchorMeasurementItemRenderer.jsx +++ b/src/components/measurements/AnchorMeasurementItemRenderer.jsx @@ -1,6 +1,8 @@ // @flow import * as React from "react"; -import Anchor from "grommet/components/Anchor"; +import Box from "grommet/components/Box"; +import Button from "grommet/components/Button"; +import Timestamp from "grommet/components/Timestamp"; import Measurement from "../../models/Measurement"; @@ -12,10 +14,17 @@ type Props = { export default function AnchorMeasurementItemRenderer({ item, match }: Props) { if (item.measurementId) { return ( - - {item.description} - {item.startDate.toLocaleString()} - + ); } else { return null; diff --git a/src/components/projects/AnchorProjectItemRenderer.jsx b/src/components/projects/AnchorProjectItemRenderer.jsx index ae4435d..3cb7355 100644 --- a/src/components/projects/AnchorProjectItemRenderer.jsx +++ b/src/components/projects/AnchorProjectItemRenderer.jsx @@ -1,5 +1,6 @@ // @flow import * as React from "react"; +import Button from "grommet/components/Button"; import Anchor from "grommet/components/Anchor"; import Project from "../../models/Project"; @@ -10,7 +11,14 @@ type Props = { export default function AnchorProjectItemRenderer({ item }: Props) { if (item.projectId) { - return {item.name}; + return ( + + ); } else { return null; } diff --git a/src/components/room/AnchorRoomItemRenderer.jsx b/src/components/room/AnchorRoomItemRenderer.jsx index c31c25d..4c2b6f7 100644 --- a/src/components/room/AnchorRoomItemRenderer.jsx +++ b/src/components/room/AnchorRoomItemRenderer.jsx @@ -1,6 +1,6 @@ // @flow import * as React from "react"; -import Anchor from "grommet/components/Anchor"; +import Button from "grommet/components/Button"; import Room from "../../models/Room"; @@ -12,7 +12,12 @@ type Props = { export default function AnchorProjectItemRenderer({ item, match }: Props) { if (item.roomId) { return ( - {item.name} + ); } else { return null; diff --git a/src/index.scss b/src/index.scss index fd4f7e1..3e1917c 100644 --- a/src/index.scss +++ b/src/index.scss @@ -3,3 +3,9 @@ #sidebar-toggler { border: 0; } + +.custom-list-anchor { + width: 100%; + padding-bottom: 24px !important; + padding-top: 24px !important; +} From 5d8a1aef188aa4b2fc959482e5cd4b516e2e40aa Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 13:16:18 +0200 Subject: [PATCH 012/160] Updated item renderers for the export wizard --- src/components/projects/AnchorProjectItemRenderer.jsx | 1 - src/containers/importexport/wizard/SelectMeasurementsStep.jsx | 2 +- src/containers/importexport/wizard/SelectProjectsStep.jsx | 2 +- src/containers/importexport/wizard/SelectRoomsStep.jsx | 2 +- 4 files changed, 3 insertions(+), 4 deletions(-) diff --git a/src/components/projects/AnchorProjectItemRenderer.jsx b/src/components/projects/AnchorProjectItemRenderer.jsx index 3cb7355..582fb0d 100644 --- a/src/components/projects/AnchorProjectItemRenderer.jsx +++ b/src/components/projects/AnchorProjectItemRenderer.jsx @@ -1,7 +1,6 @@ // @flow import * as React from "react"; import Button from "grommet/components/Button"; -import Anchor from "grommet/components/Anchor"; import Project from "../../models/Project"; diff --git a/src/containers/importexport/wizard/SelectMeasurementsStep.jsx b/src/containers/importexport/wizard/SelectMeasurementsStep.jsx index f61899b..1282c0a 100644 --- a/src/containers/importexport/wizard/SelectMeasurementsStep.jsx +++ b/src/containers/importexport/wizard/SelectMeasurementsStep.jsx @@ -121,7 +121,7 @@ export default class SelectMeasurementsStep extends React.Component< } function MeasurementItemRenderer({ item }: { item: Measurement }) { - return item.description; + return
{item.description}
; } function getItemsFromArrayByIndex( diff --git a/src/containers/importexport/wizard/SelectProjectsStep.jsx b/src/containers/importexport/wizard/SelectProjectsStep.jsx index fbf43bf..88d1332 100644 --- a/src/containers/importexport/wizard/SelectProjectsStep.jsx +++ b/src/containers/importexport/wizard/SelectProjectsStep.jsx @@ -76,5 +76,5 @@ export default class SelectProjectsStep extends React.Component< } function ProjectItemRenderer({ item }: { item: Project }) { - return item.name; + return
{item.name}
; } diff --git a/src/containers/importexport/wizard/SelectRoomsStep.jsx b/src/containers/importexport/wizard/SelectRoomsStep.jsx index c17d33a..36189d7 100644 --- a/src/containers/importexport/wizard/SelectRoomsStep.jsx +++ b/src/containers/importexport/wizard/SelectRoomsStep.jsx @@ -109,5 +109,5 @@ export default class SelectRoomsStep extends React.Component { } function RoomItemRenderer({ item }: { item: Room }) { - return item.name; + return
{item.name}
; } From 03af08fa8b8c6efbb941fb28bed3f951ae093123 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 15:55:02 +0200 Subject: [PATCH 013/160] Added edit button for the projects, rooms and measurements --- src/components/list/ItemListAnchorButton.jsx | 17 ++++++++++++++ src/components/list/ItemListEditButton.jsx | 21 ++++++++++++++++++ src/components/list/ItemsList.jsx | 4 +++- .../AnchorMeasurementItemRenderer.jsx | 22 +++++++++---------- .../projects/AnchorProjectItemRenderer.jsx | 17 +++++++------- .../room/AnchorRoomItemRenderer.jsx | 15 +++++++------ 6 files changed, 68 insertions(+), 28 deletions(-) create mode 100644 src/components/list/ItemListAnchorButton.jsx create mode 100644 src/components/list/ItemListEditButton.jsx diff --git a/src/components/list/ItemListAnchorButton.jsx b/src/components/list/ItemListAnchorButton.jsx new file mode 100644 index 0000000..5728ab6 --- /dev/null +++ b/src/components/list/ItemListAnchorButton.jsx @@ -0,0 +1,17 @@ +// @flow +import * as React from "react"; +import Box from "grommet/components/Box"; +import Button from "grommet/components/Button"; + +type Props = { + path: string, + children: React.Node +}; + +export default function ItemListAnchoButton({ path, children }: Props) { + return ( + + ); +} diff --git a/src/components/list/ItemListEditButton.jsx b/src/components/list/ItemListEditButton.jsx new file mode 100644 index 0000000..c36a73b --- /dev/null +++ b/src/components/list/ItemListEditButton.jsx @@ -0,0 +1,21 @@ +// @flow +import * as React from "react"; +import Button from "grommet/components/Button"; +import EditIcon from "grommet/components/icons/base/Edit"; + +type Props = { + path: string +}; + +export default function ItemListAnchoButton({ path }: Props) { + return ( + + + + ); } else { return null; diff --git a/src/components/projects/AnchorProjectItemRenderer.jsx b/src/components/projects/AnchorProjectItemRenderer.jsx index 582fb0d..ef15256 100644 --- a/src/components/projects/AnchorProjectItemRenderer.jsx +++ b/src/components/projects/AnchorProjectItemRenderer.jsx @@ -1,22 +1,23 @@ // @flow import * as React from "react"; -import Button from "grommet/components/Button"; import Project from "../../models/Project"; +import ItemListAnchorButton from "../list/ItemListAnchorButton"; +import ItemListEditButton from "../list/ItemListEditButton"; type Props = { item: Project }; -export default function AnchorProjectItemRenderer({ item }: Props) { +export default function AnchorProjectItemRenderer({ item, onEdit }: Props) { if (item.projectId) { return ( - + + + {item.name} + + + ); } else { return null; diff --git a/src/components/room/AnchorRoomItemRenderer.jsx b/src/components/room/AnchorRoomItemRenderer.jsx index 4c2b6f7..55fa468 100644 --- a/src/components/room/AnchorRoomItemRenderer.jsx +++ b/src/components/room/AnchorRoomItemRenderer.jsx @@ -1,8 +1,9 @@ // @flow import * as React from "react"; -import Button from "grommet/components/Button"; import Room from "../../models/Room"; +import ItemListAnchorButton from "../list/ItemListAnchorButton"; +import ItemListEditButton from "../list/ItemListEditButton"; type Props = { item: Room, @@ -12,12 +13,12 @@ type Props = { export default function AnchorProjectItemRenderer({ item, match }: Props) { if (item.roomId) { return ( - + + + {item.name} + + + ); } else { return null; From efcf0f7e791b960ccf83636728986a56ef1479c8 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 16:06:33 +0200 Subject: [PATCH 014/160] FLUX-153 Add buttons for the lists --- src/components/list/ItemListHeader.jsx | 22 +++++++++++++++++++ src/components/projects/AddProjectButton.jsx | 8 ------- .../projects/AddProjectButton.test.jsx | 11 ---------- src/components/projects/Project.jsx | 5 ++--- src/components/projects/Projects.jsx | 11 +++++----- src/components/room/Room.jsx | 5 ++--- 6 files changed, 31 insertions(+), 31 deletions(-) create mode 100644 src/components/list/ItemListHeader.jsx delete mode 100644 src/components/projects/AddProjectButton.jsx delete mode 100644 src/components/projects/AddProjectButton.test.jsx diff --git a/src/components/list/ItemListHeader.jsx b/src/components/list/ItemListHeader.jsx new file mode 100644 index 0000000..c8be299 --- /dev/null +++ b/src/components/list/ItemListHeader.jsx @@ -0,0 +1,22 @@ +// @flow +import * as React from "react"; +import Header from "grommet/components/Header"; +import Heading from "grommet/components/Heading"; +import Button from "grommet/components/Button"; +import AddIcon from "grommet/components/icons/base/Add"; + +type Props = { + header: React.Node, + path: string +}; + +export default function ItemListHeader({ header, path }: Props) { + return ( +
+ + {header} + +
+ ); +} diff --git a/src/components/projects/AddProjectButton.jsx b/src/components/projects/AddProjectButton.jsx deleted file mode 100644 index feb0f6c..0000000 --- a/src/components/projects/AddProjectButton.jsx +++ /dev/null @@ -1,8 +0,0 @@ -// @flow -import * as React from "react"; -import Anchor from "grommet/components/Anchor"; -import AddIcon from "grommet/components/icons/base/Add"; - -export default function AddProjectButton() { - return } path="/editProject" />; -} diff --git a/src/components/projects/AddProjectButton.test.jsx b/src/components/projects/AddProjectButton.test.jsx deleted file mode 100644 index 77ddc92..0000000 --- a/src/components/projects/AddProjectButton.test.jsx +++ /dev/null @@ -1,11 +0,0 @@ -// @flow -import * as React from "react"; -import { shallow } from "enzyme"; - -import AddProjectButton from "./AddProjectButton"; - -describe("", () => { - it("should render", () => { - shallow(); - }); -}); diff --git a/src/components/projects/Project.jsx b/src/components/projects/Project.jsx index da839c6..1b825b7 100644 --- a/src/components/projects/Project.jsx +++ b/src/components/projects/Project.jsx @@ -8,6 +8,7 @@ import NotFound from "../../components/notfound/NotFound"; import ContentBox from "../contentBox/ContentBox"; import ProjectModel from "../../models/Project"; import ItemsList from "../list/ItemsList"; +import ItemListHeader from "./../list/ItemListHeader"; import AnchorRoomItemRenderer from "../room/AnchorRoomItemRenderer"; type Props = { @@ -31,9 +32,7 @@ export default function Project({ projects, match }: Props) { return ( -
- Räume -
+ item.roomId} diff --git a/src/components/projects/Projects.jsx b/src/components/projects/Projects.jsx index 6a9ea0a..a6f4d3f 100644 --- a/src/components/projects/Projects.jsx +++ b/src/components/projects/Projects.jsx @@ -1,16 +1,18 @@ // @flow import * as React from "react"; import Header from "grommet/components/Header"; +import Heading from "grommet/components/Heading"; +import Button from "grommet/components/Button"; import Title from "grommet/components/Title"; import Section from "grommet/components/Section"; import Box from "grommet/components/Box"; import Search from "grommet/components/Search"; -import Heading from "grommet/components/Heading"; +import AddIcon from "grommet/components/icons/base/Add"; import ContentBox from "../contentBox/ContentBox"; import ItemsList from "./../list/ItemsList"; +import ItemListHeader from "./../list/ItemListHeader"; import Project from "../../models/Project"; -import AddProjectButton from "./AddProjectButton"; import AnchorProjectItemRenderer from "./AnchorProjectItemRenderer"; import type { ToastMetadata } from "./../toast/Toast"; @@ -45,10 +47,7 @@ export default class Projects extends React.Component {
-
- Projekte - -
+ project.projectId} diff --git a/src/components/room/Room.jsx b/src/components/room/Room.jsx index 961a806..5f7accd 100644 --- a/src/components/room/Room.jsx +++ b/src/components/room/Room.jsx @@ -10,6 +10,7 @@ import { BrowserRouter as Router, Route, Switch } from "react-router-dom"; import Measurement from "../../models/Measurement"; import RoomModel from "../../models/Room"; import ItemsList from "../list/ItemsList"; +import ItemListHeader from "./../list/ItemListHeader"; import MeasurementContainer from "../../containers/measurements/MeasurementContainer"; import AnchorMeasurementItemRenderer from "../measurements/AnchorMeasurementItemRenderer"; @@ -34,9 +35,7 @@ export default function Room({ match, room }: Props) { }} />
-
- Messungen -
+ item.measurementId} From d9a46aa1d579ddd5a70efbb38b73247439cf2e33 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 23 May 2018 16:07:41 +0200 Subject: [PATCH 015/160] FLUX-153 Add optional path --- src/components/list/ItemListHeader.jsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/list/ItemListHeader.jsx b/src/components/list/ItemListHeader.jsx index c8be299..1a11564 100644 --- a/src/components/list/ItemListHeader.jsx +++ b/src/components/list/ItemListHeader.jsx @@ -7,7 +7,7 @@ import AddIcon from "grommet/components/icons/base/Add"; type Props = { header: React.Node, - path: string + path?: string }; export default function ItemListHeader({ header, path }: Props) { @@ -16,7 +16,7 @@ export default function ItemListHeader({ header, path }: Props) { {header} -
{ - return ShowMeasurement({ room, match }); - }} + component={({ match }) => ( + + )} />
- measurement.measurementId === parseInt(match.params.measurementId, 10) - ); - - if (currentMeasurement) { - return ( - - ); - } - } - return null; -} - Room.defaultProps = { currentMeasurement: null }; diff --git a/src/containers/measurements/MeasurementContainer.jsx b/src/containers/measurements/MeasurementContainer.jsx index 55ed379..68cc9c1 100644 --- a/src/containers/measurements/MeasurementContainer.jsx +++ b/src/containers/measurements/MeasurementContainer.jsx @@ -6,10 +6,10 @@ import MeasurementSummary from "../../components/measurements/MeasurementSummary import ReadingModel from "../../models/Reading"; import RoomModel from "../../models/Room"; import MeasurementModel from "../../models/Measurement"; +import { ToastContext } from "./../../components/toast/ToastContext"; type Props = { room: RoomModel, - measurement: MeasurementModel, match: any }; @@ -29,13 +29,13 @@ export default class MeasurementContainer extends React.Component< keepAliveTimer = null; state = { - loading: false, - currentMeasurement: this.props.measurement + loading: true, + currentMeasurement: new MeasurementModel(undefined, "", "", 0, 0) }; - getReadings = () => { + fetchMeasurement = () => { this.setState({ loading: true }); - const measurementId = this.props.measurement.measurementId; + const measurementId = this.props.match.params.measurementId; if (measurementId != null) { axios .get(`/measurements/${measurementId}`, { @@ -47,14 +47,13 @@ export default class MeasurementContainer extends React.Component< }) .catch(error => { if (!axios.isCancel(error)) { - this.setState( - ({ - currentMeasurement: this.props.measurement, - loading: false - }: State) - ); + this.setState({ + loading: false + }); } }); + } else { + alert("Konnte die Messung nicht laden."); } }; @@ -93,7 +92,7 @@ export default class MeasurementContainer extends React.Component< }); } else { alert( - "Es gab einen Fehler und die Messung konnte nicht gestartet werden (die Messungs ID ist unbekannt)" + "Es gab einen Fehler. Die Messung konnte nicht gestartet werden (die Messungs ID ist unbekannt)" ); } }; @@ -144,13 +143,33 @@ export default class MeasurementContainer extends React.Component< }); }; - saveMeasurement = (measurement: MeasurementModel) => { + saveMeasurement = (showToast?: (toast: ToastMetadata) => void) => { const roomId = this.props.room.roomId; - const exportMeasurement = measurement.toDto(); + const exportMeasurement = this.state.currentMeasurement.toDto(); + axios + .post(`/rooms/${roomId}/measurements`, exportMeasurement, { + cancelToken: this.source.token + }) + .then(result => { + if (showToast) { + showToast({ + status: "ok", + children: "Messung abgespeichert" + }); + } + }) + .catch(error => { + if (showToast) { + showToast({ + status: "critical", + children: "Messung konnte nicht gespeichert werden" + }); + } + }); }; componentDidMount() { - this.getReadings(); + this.fetchMeasurement(); let serverUri = process.env.REACT_APP_SERVICE_URI; if (serverUri) { @@ -163,10 +182,10 @@ export default class MeasurementContainer extends React.Component< if ( this && prevProps && - prevProps.measurement.measurementId !== - this.props.measurement.measurementId + prevState.currentMeasurement.measurementId !== + this.state.currentMeasurement.measurementId ) { - this.getReadings(); + this.fetchMeasurement(); } } @@ -177,13 +196,17 @@ export default class MeasurementContainer extends React.Component< render() { return ( - + + {(showToast: any) => ( + this.saveMeasurement(showToast)} + isLoading={this.state.loading} + /> + )} + ); } } diff --git a/src/containers/measurements/MeasurementContainer.test.jsx b/src/containers/measurements/MeasurementContainer.test.jsx index b6f06c5..6f730e6 100644 --- a/src/containers/measurements/MeasurementContainer.test.jsx +++ b/src/containers/measurements/MeasurementContainer.test.jsx @@ -1,6 +1,7 @@ // @flow import * as React from "react"; import { shallow } from "enzyme"; +import { MemoryRouter, Route } from "react-router"; import Measurement from "./../../models/Measurement"; import Room from "./../../models/Room"; @@ -22,7 +23,11 @@ describe("", () => { ([measurement]: Measurement[]) ); const wrapper = shallow( - + + } + /> + ); expect(wrapper).toHaveLength(1); }); From 3e82469a1fc6b713a84859d9ccfaf6cf3bde4c8a Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Tue, 29 May 2018 16:28:22 +0200 Subject: [PATCH 080/160] review changes --- .../HeatmapAnalysisForm.jsx | 38 +++++++++---------- src/containers/fluxHeatmap/FluxHeatmap.jsx | 10 ++--- 2 files changed, 23 insertions(+), 25 deletions(-) diff --git a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx index 67b9238..7f83691 100644 --- a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx +++ b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx @@ -7,8 +7,8 @@ import FormFields from "grommet/components/FormFields"; import NumberInput from "grommet/components/NumberInput"; import Value from "grommet/components/Value"; import { inputHandler } from "../../../utils/InputHandler"; -import type { AllInputTypes } from "../../../utils/InputHandler"; import HeatmapData from "../../../models/HeatmapData"; +import type { AllInputTypes } from "../../../utils/InputHandler"; import type { HeatmapMode } from "../../../types/Heatmap"; type Props = { @@ -93,50 +93,50 @@ export default class HeatmapAnalysisForm extends React.Component {
- +
diff --git a/src/containers/fluxHeatmap/FluxHeatmap.jsx b/src/containers/fluxHeatmap/FluxHeatmap.jsx index b1f1162..5680e6d 100644 --- a/src/containers/fluxHeatmap/FluxHeatmap.jsx +++ b/src/containers/fluxHeatmap/FluxHeatmap.jsx @@ -8,14 +8,14 @@ import HeatmapData from "../../models/HeatmapData"; import { Positionable } from "../../types/Positionable"; import ReactResizeDetector from "react-resize-detector"; import Transformation from "../../models/Transformation"; -import type { ConfigObject, Container, HeatmapMode } from "../../types/Heatmap"; import Box from "grommet/components/Box"; import { PLACEHOLDER_IMAGE } from "../../images/ImagesBase64"; import HeatmapLegend from "./HeatmapLegend"; import HeatmapTooltip from "./HeatmapTooltip"; import BrowserPosition from "../../models/BrowserPosition"; -import type { AllInputTypes } from "../../utils/InputHandler"; import HeatmapAnalysisForm from "../../components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm"; +import type { ConfigObject, Container, HeatmapMode } from "../../types/Heatmap"; +import type { AllInputTypes } from "../../utils/InputHandler"; const FIXED_HEATMAP_VALUE = 1; @@ -184,11 +184,9 @@ export default class FluxHeatmap extends React.Component { elements: Positionable[], fixedValue: boolean ): HeatmapDataPoint[] => { - const container = this.state.container; - const transformation = this.props.transformation; + const { container, maxLuxValue } = this.state; + const { transformation, heatmapMode } = this.props; const containerScaleFactor = container.width / container.originalWidth; - const heatmapMode = this.props.heatmapMode; - const maxLuxValue = this.state.maxLuxValue; return elements.reduce(function(transformedReadings, element) { const x = Math.round( (element.position.xposition * transformation.scaleFactor + From ac3257e2b0cc0dcbd8f8e57a5e0eb992c268d112 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Tue, 29 May 2018 16:31:44 +0200 Subject: [PATCH 081/160] remove unused brackets --- src/components/measurements/MeasurementSummary.jsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index b8ac4e0..1138470 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -110,7 +110,7 @@ export default class MeasurementSummary extends React.Component { configObject={this.state.configObject} heatmapMode={this.state.heatmapMode} /> - + Date: Tue, 29 May 2018 16:49:06 +0200 Subject: [PATCH 082/160] add tests for new components --- .../HeatmapAnalysisForm.test.jsx | 25 +++++++++++++++++++ .../fluxHeatmap/HeatmapTooltip.test.jsx | 22 ++++++++++++++++ 2 files changed, 47 insertions(+) create mode 100644 src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.test.jsx create mode 100644 src/containers/fluxHeatmap/HeatmapTooltip.test.jsx diff --git a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.test.jsx b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.test.jsx new file mode 100644 index 0000000..b2abdde --- /dev/null +++ b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.test.jsx @@ -0,0 +1,25 @@ +// @flow +import * as React from "react"; +import { shallow } from "enzyme"; +import HeatmapAnalysisForm from "./HeatmapAnalysisForm"; +import type { AllInputTypes } from "../../../utils/InputHandler"; +import HeatmapData from "../../../models/HeatmapData"; + +describe("", () => { + const onChange = (key: string, value: AllInputTypes) => {}; + const heatmapData = new HeatmapData(0, 1000, []); + const maxLuxValue = 0; + const heatmapMode = "DEFAULT"; + + it("should render", () => { + const wrapper = shallow( + + ); + expect(wrapper).toHaveLength(1); + }); +}); diff --git a/src/containers/fluxHeatmap/HeatmapTooltip.test.jsx b/src/containers/fluxHeatmap/HeatmapTooltip.test.jsx new file mode 100644 index 0000000..49287c8 --- /dev/null +++ b/src/containers/fluxHeatmap/HeatmapTooltip.test.jsx @@ -0,0 +1,22 @@ +// @flow +import * as React from "react"; +import { shallow } from "enzyme"; +import HeatmapTooltip from "./HeatmapTooltip"; +import BrowserPosition from "../../models/BrowserPosition"; + +describe("", () => { + const getValueCallback = (position: BrowserPosition) => position.xposition; + const heatmapMode = "DEFAULT"; + + it("should render", () => { + const wrapper = shallow( + +

Test

+
+ ); + expect(wrapper).toHaveLength(1); + }); +}); From a94e82f6c721986b9b364004339c6168f31af71e Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Tue, 29 May 2018 20:07:08 +0200 Subject: [PATCH 083/160] fix bug to not ignore new readings --- src/containers/fluxHeatmap/FluxHeatmap.jsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/containers/fluxHeatmap/FluxHeatmap.jsx b/src/containers/fluxHeatmap/FluxHeatmap.jsx index 5680e6d..47585e5 100644 --- a/src/containers/fluxHeatmap/FluxHeatmap.jsx +++ b/src/containers/fluxHeatmap/FluxHeatmap.jsx @@ -72,6 +72,7 @@ export default class FluxHeatmap extends React.Component { heatmap: Heatmap; heatmapContainer: ?HTMLDivElement; imgElement: ?HTMLImageElement; + numberOfReadings: number = 0; componentDidMount() { this.heatmap = this.createHeatmapInstance( @@ -111,9 +112,10 @@ export default class FluxHeatmap extends React.Component { this.setConfig(); } if ( - prevProps.readings.length !== this.props.readings.length || + this.props.readings.length !== this.numberOfReadings || prevState.maxLuxValue !== this.state.maxLuxValue ) { + this.numberOfReadings = this.props.readings.length; this.setData(); } } From 15fa61b6e69502a111ee03cf874bd3153af4bdbc Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 29 May 2018 21:48:13 +0200 Subject: [PATCH 084/160] FLUX-153 Added delete button for the project --- src/components/list/ItemListDeleteButton.jsx | 23 +++++++++++++++++++ .../list/ItemListDeleteButton.test.jsx | 11 +++++++++ .../list/ItemListEditButton.test.jsx | 11 +++++++++ .../projects/AnchorProjectItemRenderer.jsx | 7 ++++-- src/components/projects/Projects.jsx | 9 +++++--- src/containers/projects/ProjectsContainer.jsx | 12 ++++++++++ 6 files changed, 68 insertions(+), 5 deletions(-) create mode 100644 src/components/list/ItemListDeleteButton.jsx create mode 100644 src/components/list/ItemListDeleteButton.test.jsx create mode 100644 src/components/list/ItemListEditButton.test.jsx diff --git a/src/components/list/ItemListDeleteButton.jsx b/src/components/list/ItemListDeleteButton.jsx new file mode 100644 index 0000000..824437c --- /dev/null +++ b/src/components/list/ItemListDeleteButton.jsx @@ -0,0 +1,23 @@ +// @flow +import * as React from "react"; +import Button from "grommet/components/Button"; +import TrashIcon from "grommet/components/icons/base/Trash"; + +type Props = { + onClick: () => void +}; + +export default function ItemListDeleteButton({ onClick }: Props) { + return ( +
); } From bed6f4204466dfc762fea568b564cc5d513875c9 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 12:17:47 +0200 Subject: [PATCH 119/160] max lux value also works in coverage mode --- .../HeatmapAnalysisForm.jsx | 10 ++++-- src/containers/fluxHeatmap/FluxHeatmap.jsx | 32 +++++++++++++------ 2 files changed, 31 insertions(+), 11 deletions(-) diff --git a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx index 1f0cb72..b88d9ef 100644 --- a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx +++ b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx @@ -99,7 +99,10 @@ export default class HeatmapAnalysisForm extends React.Component { help="(0 = kein Limit)" > { help="(Zu hohe Werte werden auf den oben festgelegten Maximalwert herabgesetzt.)" > { return 0; } const maxLuxValue = this.state.maxLuxValue; - if (maxLuxValue > 0 && this.state.includeFilteredValues) { + if ( + maxLuxValue > 0 && + this.state.includeFilteredValues && + this.props.heatmapMode === "DEFAULT" + ) { return maxLuxValue; } return Math.max(...dataPoints.map(d => d.value)); @@ -214,19 +218,29 @@ export default class FluxHeatmap extends React.Component { transformation.yOffset) * containerScaleFactor ); - let value = FIXED_HEATMAP_VALUE; - if (!fixedValue && element.getValue != null) { - value = element.getValue(); - } if (x >= 0 && y >= 0 && x <= container.width && y <= container.height) { + let measuredValue = 0; + if (element.getValue != null) { + measuredValue = element.getValue(); + } + let transformedValue = measuredValue; + let transformedMaxLuxValue = maxLuxValue; + if (fixedValue) { + transformedValue = FIXED_HEATMAP_VALUE; + transformedMaxLuxValue = FIXED_HEATMAP_VALUE; + } if ( - heatmapMode !== "DEFAULT" || + (heatmapMode !== "DEFAULT" && heatmapMode !== "COVERAGE") || maxLuxValue === 0 || - value <= maxLuxValue + measuredValue <= maxLuxValue ) { - transformedReadings.push(new HeatmapDataPoint(x, y, value)); + transformedReadings.push( + new HeatmapDataPoint(x, y, transformedValue) + ); } else if (includeFilteredValues) { - transformedReadings.push(new HeatmapDataPoint(x, y, maxLuxValue)); + transformedReadings.push( + new HeatmapDataPoint(x, y, transformedMaxLuxValue) + ); } } return transformedReadings; From 2382467be9d0f12827be159c8798ed2c43976445 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Sun, 3 Jun 2018 13:06:08 +0200 Subject: [PATCH 120/160] Fixed typo --- src/containers/importexport/wizard/WizardStep.jsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/containers/importexport/wizard/WizardStep.jsx b/src/containers/importexport/wizard/WizardStep.jsx index fad698a..b68c3b6 100644 --- a/src/containers/importexport/wizard/WizardStep.jsx +++ b/src/containers/importexport/wizard/WizardStep.jsx @@ -53,7 +53,7 @@ export default function WizardStep({ {children} - {button} + {button}
); } From c9e9105d33a6b0e5e3eb98a83c7bc722b42f9f94 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 13:56:09 +0200 Subject: [PATCH 121/160] update transformation form only on initialization and submit --- .../transformationForm/TransformationForm.jsx | 76 +++++++++---------- 1 file changed, 38 insertions(+), 38 deletions(-) diff --git a/src/components/transformationForm/TransformationForm.jsx b/src/components/transformationForm/TransformationForm.jsx index 9c6b834..82c8759 100644 --- a/src/components/transformationForm/TransformationForm.jsx +++ b/src/components/transformationForm/TransformationForm.jsx @@ -14,42 +14,42 @@ type Props = { onChange: (key: string, value: AllInputTypes) => void }; -export default function TransformationForm({ - transformation, - onSubmit, - onChange -}: Props) { - const { scaleFactor, xOffset, yOffset } = transformation; - return ( - - -
- - - - - - - - - -
-
- - ); +export default class TransformationForm extends React.Component { + render() { + const { scaleFactor, xOffset, yOffset } = this.props.transformation; + const { onSubmit, onChange } = this.props; + + return ( +
+ +
+ + + + + + + + + +
+
+
+ ); + } } From 68f244700a298f7b5a65cce9fdda549c96d1dba3 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 14:13:35 +0200 Subject: [PATCH 122/160] fix padding between section elements in room --- src/components/measurements/MeasurementSummary.jsx | 2 +- src/components/room/Room.jsx | 6 ++++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index 8d43d75..d3f0d71 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -98,7 +98,7 @@ export default class MeasurementSummary extends React.Component { } return ( -
+
Aktuelle Messung ({this.props.currentMeasurement.name}) diff --git a/src/components/room/Room.jsx b/src/components/room/Room.jsx index ff7232f..d9ab482 100644 --- a/src/components/room/Room.jsx +++ b/src/components/room/Room.jsx @@ -21,7 +21,9 @@ type Props = { export default function Room({ match, room, onDeleteMeasurement }: Props) { return ( -
+
{room.name} @@ -34,7 +36,7 @@ export default function Room({ match, room, onDeleteMeasurement }: Props) { )} /> -
+
Date: Sun, 3 Jun 2018 14:18:47 +0200 Subject: [PATCH 123/160] fix padding between heatmap boxes --- src/containers/fluxHeatmap/FluxHeatmap.jsx | 60 ++++++++++++---------- 1 file changed, 32 insertions(+), 28 deletions(-) diff --git a/src/containers/fluxHeatmap/FluxHeatmap.jsx b/src/containers/fluxHeatmap/FluxHeatmap.jsx index 96adec5..48dbaac 100644 --- a/src/containers/fluxHeatmap/FluxHeatmap.jsx +++ b/src/containers/fluxHeatmap/FluxHeatmap.jsx @@ -315,35 +315,39 @@ export default class FluxHeatmap extends React.Component { } return ( - - -
(this.heatmapContainer = heatmapContainer)} + + + - (this.imgElement = imgElement)} - onLoad={this.setContainerState} - src={backgroundImage} - alt={"heatmap"} - /> - -
-
- {this.state.configObject.gradient && - this.props.heatmapMode !== "ANCHORS" && ( - - )} +
+ (this.heatmapContainer = heatmapContainer) + } + > + (this.imgElement = imgElement)} + onLoad={this.setContainerState} + src={backgroundImage} + alt={"heatmap"} + /> + +
+ + {this.state.configObject.gradient && + this.props.heatmapMode !== "ANCHORS" && ( + + )} +
Date: Sun, 3 Jun 2018 14:19:37 +0200 Subject: [PATCH 124/160] change heatmap analysis form heading to h3 --- .../HeatmapAnalysisForm.jsx | 148 +++++++++--------- 1 file changed, 76 insertions(+), 72 deletions(-) diff --git a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx index b88d9ef..b8c935d 100644 --- a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx +++ b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx @@ -1,6 +1,7 @@ // @flow import * as React from "react"; import Form from "../../form/Form"; +import Heading from "grommet/components/Heading"; import Box from "grommet/components/Box"; import FormField from "grommet/components/FormField"; import FormFields from "grommet/components/FormFields"; @@ -91,78 +92,81 @@ export default class HeatmapAnalysisForm extends React.Component { render() { return ( -
- -
- - - - - - - - - - - - - - -
-
-
+ + Auswertung +
+ +
+ + + + + + + + + + + + + + +
+
+
+
); } } From 08af457460794bbb787c1ba7cecb06b137643aa3 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Sun, 3 Jun 2018 14:52:56 +0200 Subject: [PATCH 125/160] Several UI Fixes and better UX --- src/containers/importexport/ExportWizard.jsx | 4 +-- .../wizard/SelectMeasurementsStep.jsx | 30 ++++++++++++------- .../wizard/SelectProjectsStep.jsx | 17 +++++++++-- .../importexport/wizard/SelectRoomsStep.jsx | 29 ++++++++++-------- .../importexport/wizard/WizardStep.jsx | 2 +- 5 files changed, 54 insertions(+), 28 deletions(-) diff --git a/src/containers/importexport/ExportWizard.jsx b/src/containers/importexport/ExportWizard.jsx index 8fbb011..ae53a34 100644 --- a/src/containers/importexport/ExportWizard.jsx +++ b/src/containers/importexport/ExportWizard.jsx @@ -43,7 +43,7 @@ export default class ExportWizard extends React.Component { }); } else { // If it's the last step -> Send the data! - const rooms = [].concat.apply([], data.map(p => p.rooms)); + const rooms = [].concat.apply([], data.map(p => (p.rooms: any))); const measurements = [].concat.apply([], rooms.map(r => r.measurements)); const exportBody = measurements.map(m => ({ measurementId: m.measurementId @@ -95,7 +95,7 @@ export default class ExportWizard extends React.Component { } render() { - let Step = this.state.steps[this.state.currentStep]; + const Step = this.state.steps[this.state.currentStep]; return ( { + RenderProjectRooms = (project: Project) => { return project.rooms.map(r => ( -
-
- - {r.name} - -
+
+ + {r.name} + p.rooms)); + const measurements = [].concat.apply([], rooms.map(r => r.measurements)); + + return measurements.length > 0; + } + render() { const projects = this.props.projects; + const onSubmit = this.isValidState + ? () => this.props.onNext(this.state.projects) + : null; + return ( this.props.onNext(this.state.projects)} + onSubmit={onSubmit} isLastStep > - {projects && projects.map(p => this.RenderProject(p))} + {projects && projects.map(p => this.RenderProjectRooms(p))} ); } diff --git a/src/containers/importexport/wizard/SelectProjectsStep.jsx b/src/containers/importexport/wizard/SelectProjectsStep.jsx index 60955f9..8c3f3c2 100644 --- a/src/containers/importexport/wizard/SelectProjectsStep.jsx +++ b/src/containers/importexport/wizard/SelectProjectsStep.jsx @@ -51,17 +51,28 @@ export default class SelectProjectsStep extends React.Component< static getDerivedStateFromProps(nextProps: StepProps, prevState: State) { return { - returnData: nextProps.projects, - selected: null + returnData: nextProps.projects }; } + get isValidState() { + const { selected } = this.state; + if (selected != null) { + if (!Array.isArray(selected)) { + return true; + } else { + return selected.length > 0; + } + } + return false; + } + render() { return ( { p => p.projectId === project.projectId ); let selectedRooms: Room[]; + const selectedConst = selected; if (foundProject) { - if (typeof selected === "number") { - selectedRooms = [foundProject.rooms[selected]]; + if (typeof selectedConst === "number") { + selectedRooms = [foundProject.rooms[selectedConst]]; } else { selectedRooms = foundProject.rooms.filter( - (r, index) => (selected ? (selected: any).includes(index) : false) + (r, index) => (selectedConst ? selectedConst.includes(index) : false) ); } @@ -68,6 +68,10 @@ export default class SelectRoomsStep extends React.Component { } }; + get isValidState() { + return this.state.selectedProjects.length > 0; + } + static getDerivedStateFromProps(nextProps: StepProps, prevState: State) { return { returnData: nextProps.projects, @@ -77,23 +81,24 @@ export default class SelectRoomsStep extends React.Component { render() { const projects = this.props.projects; + const onSubmit = this.isValidState + ? () => this.props.onNext(this.state.selectedProjects) + : null; + return ( this.props.onNext(this.state.selectedProjects)} + onSubmit={onSubmit} > {projects && projects.map(p => ( -
-
- - {p.name} - -
+
+ + {p.name} + item.roomId} selectable={"multiple"} diff --git a/src/containers/importexport/wizard/WizardStep.jsx b/src/containers/importexport/wizard/WizardStep.jsx index b68c3b6..5c796ea 100644 --- a/src/containers/importexport/wizard/WizardStep.jsx +++ b/src/containers/importexport/wizard/WizardStep.jsx @@ -11,7 +11,7 @@ type Props = { heading: React.Node, subheading?: React.Node, children: React.Node, - onSubmit: () => void, + onSubmit?: ?() => void, isLastStep?: boolean }; From 3a9d2e0d675a55f586437db0470700de9a6d5c06 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Sun, 3 Jun 2018 15:32:35 +0200 Subject: [PATCH 126/160] Update item list design to match other design --- .../importexport/wizard/SelectMeasurementsStep.jsx | 6 +++++- src/containers/importexport/wizard/SelectProjectsStep.jsx | 7 ++++++- src/containers/importexport/wizard/SelectRoomsStep.jsx | 6 +++++- 3 files changed, 16 insertions(+), 3 deletions(-) diff --git a/src/containers/importexport/wizard/SelectMeasurementsStep.jsx b/src/containers/importexport/wizard/SelectMeasurementsStep.jsx index c22d1ff..215e961 100644 --- a/src/containers/importexport/wizard/SelectMeasurementsStep.jsx +++ b/src/containers/importexport/wizard/SelectMeasurementsStep.jsx @@ -132,7 +132,11 @@ export default class SelectMeasurementsStep extends React.Component< } function MeasurementItemRenderer({ item }: { item: Measurement }) { - return
{item.description}
; + return ( + + {item.name} + + ); } function getItemsFromArrayByIndex( diff --git a/src/containers/importexport/wizard/SelectProjectsStep.jsx b/src/containers/importexport/wizard/SelectProjectsStep.jsx index 8c3f3c2..d8946ab 100644 --- a/src/containers/importexport/wizard/SelectProjectsStep.jsx +++ b/src/containers/importexport/wizard/SelectProjectsStep.jsx @@ -1,5 +1,6 @@ // @flow import * as React from "react"; +import Heading from "grommet/components/Heading"; import WizardStep from "./WizardStep"; import ItemsList from "./../../../components/list/ItemsList"; @@ -88,5 +89,9 @@ export default class SelectProjectsStep extends React.Component< } function ProjectItemRenderer({ item }: { item: Project }) { - return
{item.name}
; + return ( + + {item.name} + + ); } diff --git a/src/containers/importexport/wizard/SelectRoomsStep.jsx b/src/containers/importexport/wizard/SelectRoomsStep.jsx index 51830d7..3285d2c 100644 --- a/src/containers/importexport/wizard/SelectRoomsStep.jsx +++ b/src/containers/importexport/wizard/SelectRoomsStep.jsx @@ -114,5 +114,9 @@ export default class SelectRoomsStep extends React.Component { } function RoomItemRenderer({ item }: { item: Room }) { - return
{item.name}
; + return ( + + {item.name} + + ); } From 167f2f01cd5a2af2b7ad5824abece095c21bb4af Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 15:55:50 +0200 Subject: [PATCH 127/160] add missing fields to measurement view --- .../measurements/MeasurementSummary.jsx | 45 +++++++++++++++---- src/components/room/Room.jsx | 3 +- 2 files changed, 39 insertions(+), 9 deletions(-) diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index d3f0d71..98b41e0 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -2,6 +2,9 @@ import * as React from "react"; import Header from "grommet/components/Header"; import Heading from "grommet/components/Heading"; +import Paragraph from "grommet/components/Paragraph"; +import Timestamp from "grommet/components/Timestamp"; +import FormNextLink from "grommet/components/icons/base/FormNextLink"; import Box from "grommet/components/Box"; import Accordion from "grommet/components/Accordion"; import AccordionPanel from "grommet/components/AccordionPanel"; @@ -98,17 +101,43 @@ export default class MeasurementSummary extends React.Component { } return ( -
-
- - Aktuelle Messung ({this.props.currentMeasurement.name}) - -
+
- Grundriss + + Aktuelle Messung ({this.props.currentMeasurement.name}) + +
+ + + {this.props.currentMeasurement.description} + + + + Vermesser: + {this.props.currentMeasurement.creator} + + + Zeitraum: + + + + + + +
+ {this.props.currentMeasurement.readings && ( {room.name} - {room.description} + {room.description}
Date: Sun, 3 Jun 2018 16:22:01 +0200 Subject: [PATCH 128/160] add pozyx anchors to measurement view --- src/containers/fluxHeatmap/FluxHeatmap.jsx | 30 ++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/containers/fluxHeatmap/FluxHeatmap.jsx b/src/containers/fluxHeatmap/FluxHeatmap.jsx index 48dbaac..2673a67 100644 --- a/src/containers/fluxHeatmap/FluxHeatmap.jsx +++ b/src/containers/fluxHeatmap/FluxHeatmap.jsx @@ -9,6 +9,9 @@ import { Positionable } from "../../types/Positionable"; import ReactResizeDetector from "react-resize-detector"; import Transformation from "../../models/Transformation"; import Box from "grommet/components/Box"; +import Heading from "grommet/components/Heading"; +import Table from "grommet/components/Table"; +import TableRow from "grommet/components/TableRow"; import { PLACEHOLDER_IMAGE, EXAMPLE_IMAGE } from "../../images/ImagesBase64"; import HeatmapLegend from "./HeatmapLegend"; import HeatmapTooltip from "./HeatmapTooltip"; @@ -357,6 +360,33 @@ export default class FluxHeatmap extends React.Component { onChange={this.handleValueChange} /> + + Pozyx Anchors + {this.props.anchors.length > 0 ? ( + + + + + + + + + + + {this.props.anchors.map(anchor => ( + + + + + + + ))} + +
NameXYZ
{anchor.networkId}{anchor.position.xposition}{anchor.position.yposition}{anchor.position.zposition}
+ ) : ( + Es sind keine Anchors für diese Messung konfiguriert. + )} +
); } From c109370ccbe2fb47515880f875380f69c7b57e9d Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 16:47:30 +0200 Subject: [PATCH 129/160] add ratio to uniformity and irregularity --- .../HeatmapAnalysisForm.jsx | 26 ++++++++++++++----- 1 file changed, 20 insertions(+), 6 deletions(-) diff --git a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx index b8c935d..3f67671 100644 --- a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx +++ b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx @@ -27,7 +27,9 @@ type State = { min: number, max: number, uniformity: number, - irregularity: number + irregularity: number, + uniformityRatio: number, + irregularityRatio: number }; export default class HeatmapAnalysisForm extends React.Component { @@ -37,7 +39,9 @@ export default class HeatmapAnalysisForm extends React.Component { min: 0, max: 0, uniformity: 0, - irregularity: 0 + irregularity: 0, + uniformityRatio: 0, + irregularityRatio: 0 }; static getDerivedStateFromProps(nextProps: Props, prevState: State) { @@ -69,13 +73,17 @@ export default class HeatmapAnalysisForm extends React.Component { ).value; const uniformity = min / average; const irregularity = min / max; + const uniformityRatio = 1 / uniformity; + const irregularityRatio = 1 / irregularity; return { numberOfReadings: numberOfReadings, average: Math.round(average), min: Math.floor(min), max: Math.ceil(max), uniformity: Math.round(uniformity * 100) / 100, - irregularity: Math.round(irregularity * 100) / 100 + irregularity: Math.round(irregularity * 100) / 100, + uniformityRatio: Math.round(uniformityRatio * 100) / 100, + irregularityRatio: Math.round(irregularityRatio * 100) / 100 }; } @@ -86,7 +94,9 @@ export default class HeatmapAnalysisForm extends React.Component { min: 0, max: 0, uniformity: 0, - irregularity: 0 + irregularity: 0, + uniformityRatio: 0, + irregularityRatio: 0 }; } @@ -154,12 +164,16 @@ export default class HeatmapAnalysisForm extends React.Component { /> From f89e7f3a4f5a2ffd71f91572a2fd91e1c9eddac1 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 18:33:05 +0200 Subject: [PATCH 130/160] remove example image --- src/containers/fluxHeatmap/FluxHeatmap.jsx | 4 ++-- src/images/ImagesBase64.jsx | 3 --- 2 files changed, 2 insertions(+), 5 deletions(-) diff --git a/src/containers/fluxHeatmap/FluxHeatmap.jsx b/src/containers/fluxHeatmap/FluxHeatmap.jsx index 2673a67..4d6c058 100644 --- a/src/containers/fluxHeatmap/FluxHeatmap.jsx +++ b/src/containers/fluxHeatmap/FluxHeatmap.jsx @@ -12,7 +12,7 @@ import Box from "grommet/components/Box"; import Heading from "grommet/components/Heading"; import Table from "grommet/components/Table"; import TableRow from "grommet/components/TableRow"; -import { PLACEHOLDER_IMAGE, EXAMPLE_IMAGE } from "../../images/ImagesBase64"; +import { PLACEHOLDER_IMAGE } from "../../images/ImagesBase64"; import HeatmapLegend from "./HeatmapLegend"; import HeatmapTooltip from "./HeatmapTooltip"; import BrowserPosition from "../../models/BrowserPosition"; @@ -314,7 +314,7 @@ export default class FluxHeatmap extends React.Component { render() { let { backgroundImage } = this.props; if (!backgroundImage) { - backgroundImage = EXAMPLE_IMAGE; + backgroundImage = PLACEHOLDER_IMAGE; } return ( diff --git a/src/images/ImagesBase64.jsx b/src/images/ImagesBase64.jsx index 1b611fa..9860158 100644 --- a/src/images/ImagesBase64.jsx +++ b/src/images/ImagesBase64.jsx @@ -2,6 +2,3 @@ export const PLACEHOLDER_IMAGE: string = ""; - -export const EXAMPLE_IMAGE: string = - ""; From b8ba48aec61ce7099c29ca87b75c9d859c767fb5 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 20:46:19 +0200 Subject: [PATCH 131/160] handle division by zero --- .../heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx index 3f67671..7cb83cd 100644 --- a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx +++ b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx @@ -73,8 +73,8 @@ export default class HeatmapAnalysisForm extends React.Component { ).value; const uniformity = min / average; const irregularity = min / max; - const uniformityRatio = 1 / uniformity; - const irregularityRatio = 1 / irregularity; + const uniformityRatio = uniformity > 0 ? 1 / uniformity : 0; + const irregularityRatio = uniformity > 0 ? 1 / irregularity : 0; return { numberOfReadings: numberOfReadings, average: Math.round(average), From 6eaff93cc8c4be75c4e81c3c1f697f57055bc7dc Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 20:48:19 +0200 Subject: [PATCH 132/160] fix wrong grommet parameter types --- src/components/measurements/MeasurementSummary.jsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index 98b41e0..ca7881c 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -119,7 +119,7 @@ export default class MeasurementSummary extends React.Component { Vermesser: {this.props.currentMeasurement.creator} @@ -127,7 +127,7 @@ export default class MeasurementSummary extends React.Component { Zeitraum: From 78c2d1c0311bc7a173624063db6116f544f9db54 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sun, 3 Jun 2018 20:54:13 +0200 Subject: [PATCH 133/160] refactor value transformation and filter out zero lux values --- src/containers/fluxHeatmap/FluxHeatmap.jsx | 48 ++++++++++++---------- 1 file changed, 26 insertions(+), 22 deletions(-) diff --git a/src/containers/fluxHeatmap/FluxHeatmap.jsx b/src/containers/fluxHeatmap/FluxHeatmap.jsx index 4d6c058..f616512 100644 --- a/src/containers/fluxHeatmap/FluxHeatmap.jsx +++ b/src/containers/fluxHeatmap/FluxHeatmap.jsx @@ -222,28 +222,32 @@ export default class FluxHeatmap extends React.Component { containerScaleFactor ); if (x >= 0 && y >= 0 && x <= container.width && y <= container.height) { - let measuredValue = 0; + let value = 0; if (element.getValue != null) { - measuredValue = element.getValue(); + value = element.getValue(); } - let transformedValue = measuredValue; - let transformedMaxLuxValue = maxLuxValue; - if (fixedValue) { - transformedValue = FIXED_HEATMAP_VALUE; - transformedMaxLuxValue = FIXED_HEATMAP_VALUE; - } - if ( - (heatmapMode !== "DEFAULT" && heatmapMode !== "COVERAGE") || - maxLuxValue === 0 || - measuredValue <= maxLuxValue - ) { - transformedReadings.push( - new HeatmapDataPoint(x, y, transformedValue) - ); - } else if (includeFilteredValues) { - transformedReadings.push( - new HeatmapDataPoint(x, y, transformedMaxLuxValue) - ); + if (value > 0 || heatmapMode === "ANCHORS") { + if ( + (heatmapMode !== "DEFAULT" && heatmapMode !== "COVERAGE") || + maxLuxValue === 0 || + value <= maxLuxValue + ) { + transformedReadings.push( + new HeatmapDataPoint( + x, + y, + fixedValue ? FIXED_HEATMAP_VALUE : value + ) + ); + } else if (includeFilteredValues) { + transformedReadings.push( + new HeatmapDataPoint( + x, + y, + fixedValue ? FIXED_HEATMAP_VALUE : maxLuxValue + ) + ); + } } } return transformedReadings; @@ -373,8 +377,8 @@ export default class FluxHeatmap extends React.Component { - {this.props.anchors.map(anchor => ( - + {this.props.anchors.map((anchor, i) => ( + {anchor.networkId} {anchor.position.xposition} {anchor.position.yposition} From 821d2ebb191b2116049cf56d3a4b0f0af2988dd7 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Mon, 4 Jun 2018 09:53:26 +0200 Subject: [PATCH 134/160] fix alignment of measurement data and creator if description is smaller than maximum paragraph width --- src/components/measurements/MeasurementSummary.jsx | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index ca7881c..a4952c8 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -111,10 +111,12 @@ export default class MeasurementSummary extends React.Component {
- - - {this.props.currentMeasurement.description} - + + + + {this.props.currentMeasurement.description} + + Date: Mon, 4 Jun 2018 12:33:48 +0200 Subject: [PATCH 135/160] provide a fallback text for missing values --- .../measurements/MeasurementSummary.jsx | 29 ++++++++++++++++--- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index a4952c8..6732de7 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -124,7 +124,14 @@ export default class MeasurementSummary extends React.Component { responsive={false} > Vermesser: - {this.props.currentMeasurement.creator} + {this.props.currentMeasurement.creator != null && + this.props.currentMeasurement.creator !== "" ? ( + {this.props.currentMeasurement.creator} + ) : ( + + unbekannt + + )} { responsive={false} > Zeitraum: - - - + {this.props.currentMeasurement.startDate != null ? ( + + + + + + ) : ( + + nicht verfügbar + + )} From 442430668fe49d0c5732399c20e4517368b59f20 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Mon, 4 Jun 2018 12:40:04 +0200 Subject: [PATCH 136/160] remove search from projects list --- src/components/projects/Projects.jsx | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/src/components/projects/Projects.jsx b/src/components/projects/Projects.jsx index 1f4b159..3159e3c 100644 --- a/src/components/projects/Projects.jsx +++ b/src/components/projects/Projects.jsx @@ -3,8 +3,6 @@ import * as React from "react"; import Header from "grommet/components/Header"; import Title from "grommet/components/Title"; import Section from "grommet/components/Section"; -import Box from "grommet/components/Box"; -import Search from "grommet/components/Search"; import ContentBox from "../contentBox/ContentBox"; import ItemsList from "./../list/ItemsList"; @@ -33,15 +31,6 @@ export default class Projects extends React.Component {
Alle Projekte - - -
From d7c85e66f4512b75783725e807778f0bab347027 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Mon, 4 Jun 2018 16:43:19 +0200 Subject: [PATCH 137/160] change boolean flag to connection state type --- src/components/dashboard/Dashboard.jsx | 51 +++++++++++++------ .../dashboard/DashboardContainer.jsx | 3 ++ 2 files changed, 39 insertions(+), 15 deletions(-) diff --git a/src/components/dashboard/Dashboard.jsx b/src/components/dashboard/Dashboard.jsx index 86ce7ad..c064ab0 100644 --- a/src/components/dashboard/Dashboard.jsx +++ b/src/components/dashboard/Dashboard.jsx @@ -12,10 +12,11 @@ import Card from "grommet/components/Card"; import ContentBox from "./../contentBox/ContentBox"; import Measurement from "./../../models/Measurement"; -import type { ServerState } from "./../../types/ServerState"; +import type { ConnectionState, ServerState } from "./../../types/ServerState"; type Props = { serverState: ServerState, + sensorConnectionState: ConnectionState, activeMeasurement?: ?Measurement }; @@ -126,18 +127,34 @@ function ActiveMeasurement({ ); } -function SensorStatus({ sensorReachable }: { sensorReachable: boolean }) { - let description = ( - - Nicht verfügbar - - ); - if (sensorReachable) { - description = ( - - Bereit - - ); +function SensorStatus({ + sensorConnectionState +}: { + sensorConnectionState: ConnectionState +}) { + let description: React.Node; + switch (sensorConnectionState) { + case "CONNECTED": + description = ( + + Bereit + + ); + break; + case "DISCONNECTED": + description = ( + + Nicht verfügbar + + ); + break; + default: + description = ( + + Unbekannt + + ); + break; } return ( @@ -147,7 +164,11 @@ function SensorStatus({ sensorReachable }: { sensorReachable: boolean }) { ); } -export default function Dashboard({ serverState, activeMeasurement }: Props) { +export default function Dashboard({ + serverState, + sensorConnectionState, + activeMeasurement +}: Props) { return ( @@ -159,7 +180,7 @@ export default function Dashboard({ serverState, activeMeasurement }: Props) { - + diff --git a/src/containers/dashboard/DashboardContainer.jsx b/src/containers/dashboard/DashboardContainer.jsx index cab8570..4ed94b1 100644 --- a/src/containers/dashboard/DashboardContainer.jsx +++ b/src/containers/dashboard/DashboardContainer.jsx @@ -11,6 +11,7 @@ type Props = {}; type State = { serverState: ServerState, + sensorConnectionState: ConnectionState, activeMeasurement: ?Measurement }; @@ -24,6 +25,7 @@ export default class DashboardContainer extends React.Component { connectionState: "UNKNOWN", uri: axios.defaults.baseURL }, + sensorConnectionState: "UNKNOWN", activeMeasurement: undefined }; @@ -80,6 +82,7 @@ export default class DashboardContainer extends React.Component { return ( ); From b8950f321d4ecb4c73674b3ec8156d0d665363bc Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Mon, 4 Jun 2018 21:12:22 +0200 Subject: [PATCH 138/160] change timeout to interval and also get sensor activity --- .../dashboard/DashboardContainer.jsx | 34 ++++++++++++++----- 1 file changed, 26 insertions(+), 8 deletions(-) diff --git a/src/containers/dashboard/DashboardContainer.jsx b/src/containers/dashboard/DashboardContainer.jsx index 4ed94b1..bdfcc13 100644 --- a/src/containers/dashboard/DashboardContainer.jsx +++ b/src/containers/dashboard/DashboardContainer.jsx @@ -18,7 +18,7 @@ type State = { export default class DashboardContainer extends React.Component { isUnmounted = false; source: CancelTokenSource = CancelToken.source(); - timeout: TimeoutID; + interval: IntervalID; state = { serverState: { @@ -29,6 +29,11 @@ export default class DashboardContainer extends React.Component { activeMeasurement: undefined }; + onUpdate = () => { + this.fetchActiveMeasurement(); + this.getSensorActivity(); + }; + fetchActiveMeasurement = () => { axios .get("/measurements/active", { @@ -40,11 +45,24 @@ export default class DashboardContainer extends React.Component { activeMeasurement = Measurement.fromObject(result.data); } this.updateState("CONNECTED", activeMeasurement); - this.resetFetchTimeout(); }) .catch(error => { this.updateState("DISCONNECTED", undefined); - this.resetFetchTimeout(); + }); + }; + + getSensorActivity = () => { + axios + .get("/sensors", { + cancelToken: this.source.token + }) + .then(result => { + if (result.status === 200) { + this.setState({ sensorConnectionState: "CONNECTED" }); + } + }) + .catch(error => { + this.setState({ sensorConnectionState: "DISCONNECTED" }); }); }; @@ -60,20 +78,20 @@ export default class DashboardContainer extends React.Component { }); }; - resetFetchTimeout = (milliseconds: number = 3000) => { + setInterval = (timeoutMilliseconds: number = 3000) => { if (!this.isUnmounted) { - this.timeout = setTimeout(this.fetchActiveMeasurement, milliseconds); + this.interval = setInterval(this.onUpdate, timeoutMilliseconds); } }; componentDidMount() { - this.fetchActiveMeasurement(); + this.setInterval(); } componentWillUnmount() { this.isUnmounted = true; - if (this.timeout) { - clearTimeout(this.timeout); + if (this.interval) { + clearInterval(this.interval); } this.source.cancel(); } From 1e5ecbe30c32c15011d59ae876dc0a942a3ac875 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 00:21:47 +0200 Subject: [PATCH 139/160] FLUX-150 Refactored the import UI and added visual feedback --- src/components/importexport/Import.jsx | 33 +++++++++---- src/components/importexport/Import.test.jsx | 2 +- .../importexport/ImportExportContainer.jsx | 48 ++++++++++++++----- 3 files changed, 62 insertions(+), 21 deletions(-) diff --git a/src/components/importexport/Import.jsx b/src/components/importexport/Import.jsx index ffb51d3..7706ac6 100644 --- a/src/components/importexport/Import.jsx +++ b/src/components/importexport/Import.jsx @@ -1,14 +1,18 @@ // @flow import * as React from "react"; +import Box from "grommet/components/Box"; import Section from "grommet/components/Section"; import Header from "grommet/components/Header"; import Title from "grommet/components/Title"; import Button from "grommet/components/Button"; import Dropzone from "react-dropzone"; +import DocumentUploadIcon from "grommet/components/icons/base/DocumentUpload"; + import type { DZFile as File } from "../../types/File"; type Props = { - onUpload: (file: ?File) => void + onUpload: (file: ?File) => void, + isLoading: boolean }; type State = { @@ -37,6 +41,10 @@ export default class Import extends React.Component { }; render() { + let uploadHandler; + if (!this.props.isLoading) { + uploadHandler = () => this.props.onUpload(this.state.file); + } return (
@@ -47,16 +55,23 @@ export default class Import extends React.Component { multiple={false} accept="application/json" > -

- Ziehen Sie die Datei mit den Daten, die Sie importieren möchten in - dieses Feld. -

+ Ziehen Sie die Datei mit den Daten, die Sie importieren möchten in + dieses Feld. {this.state.file && ( -
); diff --git a/src/components/importexport/Import.test.jsx b/src/components/importexport/Import.test.jsx index 9545657..c67bb2c 100644 --- a/src/components/importexport/Import.test.jsx +++ b/src/components/importexport/Import.test.jsx @@ -6,7 +6,7 @@ import Import from "./Import"; describe("", () => { it("should render", () => { - const wrapper = shallow( {}} />); + const wrapper = shallow( {}} isLoading={false} />); expect(wrapper).toHaveLength(1); }); }); diff --git a/src/containers/importexport/ImportExportContainer.jsx b/src/containers/importexport/ImportExportContainer.jsx index fccea55..9955880 100644 --- a/src/containers/importexport/ImportExportContainer.jsx +++ b/src/containers/importexport/ImportExportContainer.jsx @@ -5,23 +5,29 @@ import ContentBox from "../../components/contentBox/ContentBox"; import ImportComponent from "../../components/importexport/Import"; import ExportComponent from "../../components/importexport/Export"; +import { ToastContext } from "./../../components/toast/ToastContext"; + +import type { ToastMetadata } from "./../../components/toast/Toast"; type Props = {}; -type Status = { - showWizard: boolean +type State = { + showWizard: boolean, + isLoading: boolean }; export default class ImportExportContainer extends React.Component< Props, - Status + State > { source: CancelTokenSource = CancelToken.source(); state = { - showWizard: false + showWizard: false, + isLoading: false }; - uploadFile = (file: ?File) => { + uploadFile = (file: ?File, showToast: ToastMetadata => void) => { if (file) { + this.setState({ isLoading: true }); const reader = new FileReader(); reader.onload = () => { const fileAsBinaryString = reader.result; @@ -30,10 +36,22 @@ export default class ImportExportContainer extends React.Component< headers: { "Content-Type": "application/json" } }) .then(response => { - console.log(response); + this.setState({ isLoading: false }); + if (showToast) { + showToast({ + status: "ok", + children: response.data + }); + } }) .catch(error => { - console.log(error); + this.setState({ isLoading: false }); + if (showToast) { + showToast({ + status: "critical", + children: error.data + }); + } }); }; reader.readAsText(file, "utf-8"); @@ -41,11 +59,19 @@ export default class ImportExportContainer extends React.Component< }; render() { + console.log(this.state.isLoading); return ( - - - - + + {(showToast: any) => ( + + this.uploadFile(file, showToast)} + isLoading={this.state.isLoading} + /> + + + )} + ); } } From 6a871d728c35767738893a2d6ea0b8d1aa0641d6 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 10:39:52 +0200 Subject: [PATCH 140/160] FLUX-167 Authorization Headers are sent now --- src/components/routing/ProtectedRoute.jsx | 2 +- src/containers/app/App.jsx | 1 + src/containers/login/LoginContainer.jsx | 2 ++ src/utils/AuthenticationService.jsx | 12 ++++++++---- 4 files changed, 12 insertions(+), 5 deletions(-) diff --git a/src/components/routing/ProtectedRoute.jsx b/src/components/routing/ProtectedRoute.jsx index a7cd7f6..a67f79d 100644 --- a/src/components/routing/ProtectedRoute.jsx +++ b/src/components/routing/ProtectedRoute.jsx @@ -9,7 +9,7 @@ export default function ProtectedRoute({ component: Component, ...rest }: any) { - AuthenticationService.isLoggedIn ? ( + AuthenticationService.token ? ( ) : ( diff --git a/src/containers/app/App.jsx b/src/containers/app/App.jsx index c5b132a..b2261c3 100644 --- a/src/containers/app/App.jsx +++ b/src/containers/app/App.jsx @@ -29,6 +29,7 @@ export default class App extends React.Component { constructor() { super(); (axios.defaults: Object).baseURL = process.env.REACT_APP_SERVICE_URI; // Sets the default URL for the rest of the applications lifetime. + // axios.defaults.headers.common['Authorization'] = AuthenticationService.token; } state = {}; diff --git a/src/containers/login/LoginContainer.jsx b/src/containers/login/LoginContainer.jsx index e467308..c8defe6 100644 --- a/src/containers/login/LoginContainer.jsx +++ b/src/containers/login/LoginContainer.jsx @@ -46,6 +46,8 @@ export default class LoginContainer extends React.Component { ) .then(result => { AuthenticationService.login(result.data, login.rememberMe); + axios.defaults.headers.common["Authorization"] = + AuthenticationService.token; this.setState({ shouldRedirect: true }); }) .catch(error => { diff --git a/src/utils/AuthenticationService.jsx b/src/utils/AuthenticationService.jsx index 2836230..8790938 100644 --- a/src/utils/AuthenticationService.jsx +++ b/src/utils/AuthenticationService.jsx @@ -1,3 +1,4 @@ +import axios from "axios"; const STORAGE_KEY = "LOGIN_TOKEN"; export default class AuthenticationService { @@ -12,6 +13,7 @@ export default class AuthenticationService { } else { sessionStorage.setItem(STORAGE_KEY, token); } + axios.defaults.headers.common["Authorization"] = token; }; /** @@ -21,15 +23,17 @@ export default class AuthenticationService { static logout = () => { localStorage.removeItem(STORAGE_KEY); sessionStorage.removeItem(STORAGE_KEY); + delete axios.defaults.headers.common["Authorization"]; }; /** * Returns true, if there is an authentication token stored. * It is still possible that the token was invalidated by the server. */ - static get isLoggedIn() { - return ( - localStorage.getItem(STORAGE_KEY) || sessionStorage.getItem(STORAGE_KEY) - ); + static get token() { + const token = + localStorage.getItem(STORAGE_KEY) || sessionStorage.getItem(STORAGE_KEY); + axios.defaults.headers.common["Authorization"] = token; + return token; } } From 328b382f1707ca1303759becd20ab8cecfec4cfd Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 10:55:41 +0200 Subject: [PATCH 141/160] FLUX-167 Removed commented code --- src/containers/app/App.jsx | 1 - 1 file changed, 1 deletion(-) diff --git a/src/containers/app/App.jsx b/src/containers/app/App.jsx index b2261c3..c5b132a 100644 --- a/src/containers/app/App.jsx +++ b/src/containers/app/App.jsx @@ -29,7 +29,6 @@ export default class App extends React.Component { constructor() { super(); (axios.defaults: Object).baseURL = process.env.REACT_APP_SERVICE_URI; // Sets the default URL for the rest of the applications lifetime. - // axios.defaults.headers.common['Authorization'] = AuthenticationService.token; } state = {}; From aba03dfab850285b1bd5c276585f873df6b1dd2f Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Tue, 5 Jun 2018 11:01:19 +0200 Subject: [PATCH 142/160] change interval back to timeout due to risk of overload when requests take too long --- .../dashboard/DashboardContainer.jsx | 38 +++++++++++++------ 1 file changed, 27 insertions(+), 11 deletions(-) diff --git a/src/containers/dashboard/DashboardContainer.jsx b/src/containers/dashboard/DashboardContainer.jsx index bdfcc13..9337d83 100644 --- a/src/containers/dashboard/DashboardContainer.jsx +++ b/src/containers/dashboard/DashboardContainer.jsx @@ -18,7 +18,8 @@ type State = { export default class DashboardContainer extends React.Component { isUnmounted = false; source: CancelTokenSource = CancelToken.source(); - interval: IntervalID; + fetchMeasurementTimeout: TimeoutID; + getSensorTimeout: TimeoutID; state = { serverState: { @@ -29,11 +30,6 @@ export default class DashboardContainer extends React.Component { activeMeasurement: undefined }; - onUpdate = () => { - this.fetchActiveMeasurement(); - this.getSensorActivity(); - }; - fetchActiveMeasurement = () => { axios .get("/measurements/active", { @@ -45,9 +41,11 @@ export default class DashboardContainer extends React.Component { activeMeasurement = Measurement.fromObject(result.data); } this.updateState("CONNECTED", activeMeasurement); + this.resetFetchMeasurementTimeout(); }) .catch(error => { this.updateState("DISCONNECTED", undefined); + this.resetFetchMeasurementTimeout(); }); }; @@ -60,9 +58,11 @@ export default class DashboardContainer extends React.Component { if (result.status === 200) { this.setState({ sensorConnectionState: "CONNECTED" }); } + this.resetGetSensorTimeout(); }) .catch(error => { this.setState({ sensorConnectionState: "DISCONNECTED" }); + this.resetGetSensorTimeout(); }); }; @@ -78,20 +78,36 @@ export default class DashboardContainer extends React.Component { }); }; - setInterval = (timeoutMilliseconds: number = 3000) => { + resetFetchMeasurementTimeout = (timeoutMilliseconds: number = 3000) => { if (!this.isUnmounted) { - this.interval = setInterval(this.onUpdate, timeoutMilliseconds); + this.fetchMeasurementTimeout = setTimeout( + this.fetchActiveMeasurement, + timeoutMilliseconds + ); + } + }; + + resetGetSensorTimeout = (timeoutMilliseconds: number = 3000) => { + if (!this.isUnmounted) { + this.getSensorTimeout = setTimeout( + this.getSensorActivity, + timeoutMilliseconds + ); } }; componentDidMount() { - this.setInterval(); + this.fetchActiveMeasurement(); + this.getSensorActivity(); } componentWillUnmount() { this.isUnmounted = true; - if (this.interval) { - clearInterval(this.interval); + if (this.fetchMeasurementTimeout) { + clearTimeout(this.fetchMeasurementTimeout); + } + if (this.getSensorTimeout) { + clearTimeout(this.getSensorTimeout); } this.source.cancel(); } From 65af6a54a8edcc829954d3f77331a2e55eded017 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Tue, 5 Jun 2018 11:09:19 +0200 Subject: [PATCH 143/160] replace placeholder image of floorplan with svg image --- src/images/ImagesBase64.jsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/images/ImagesBase64.jsx b/src/images/ImagesBase64.jsx index 9860158..093d278 100644 --- a/src/images/ImagesBase64.jsx +++ b/src/images/ImagesBase64.jsx @@ -1,4 +1,4 @@ // @flow export const PLACEHOLDER_IMAGE: string = - ""; + ""; From eb16b9405869d4076e2c34d47b67d60a94ecae35 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 12:38:50 +0200 Subject: [PATCH 144/160] Fixed double-fetch of measurement --- src/containers/measurements/MeasurementContainer.jsx | 1 + 1 file changed, 1 insertion(+) diff --git a/src/containers/measurements/MeasurementContainer.jsx b/src/containers/measurements/MeasurementContainer.jsx index 08cf036..a3e7524 100644 --- a/src/containers/measurements/MeasurementContainer.jsx +++ b/src/containers/measurements/MeasurementContainer.jsx @@ -192,6 +192,7 @@ export default class MeasurementContainer extends React.Component< if ( this && prevProps && + prevState.currentMeasurement.measurementId != null && prevState.currentMeasurement.measurementId !== this.state.currentMeasurement.measurementId ) { From fc933395354a1d3533f4979cd84cbc0becdab92d Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 12:39:22 +0200 Subject: [PATCH 145/160] Adjusted handling of return of sensor state XHR --- src/containers/dashboard/DashboardContainer.jsx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/containers/dashboard/DashboardContainer.jsx b/src/containers/dashboard/DashboardContainer.jsx index 9337d83..d3c1f6c 100644 --- a/src/containers/dashboard/DashboardContainer.jsx +++ b/src/containers/dashboard/DashboardContainer.jsx @@ -57,6 +57,8 @@ export default class DashboardContainer extends React.Component { .then(result => { if (result.status === 200) { this.setState({ sensorConnectionState: "CONNECTED" }); + } else if (result.status === 204) { + this.setState({ sensorConnectionState: "DISCONNECTED" }); } this.resetGetSensorTimeout(); }) From 283c2c61c2b802d4aed401b9393762e9a5f154a4 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 12:53:37 +0200 Subject: [PATCH 146/160] Fixed details --- src/containers/dashboard/DashboardContainer.jsx | 6 +++--- src/containers/importexport/ImportExportContainer.jsx | 1 - 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/src/containers/dashboard/DashboardContainer.jsx b/src/containers/dashboard/DashboardContainer.jsx index d3c1f6c..00c8bbc 100644 --- a/src/containers/dashboard/DashboardContainer.jsx +++ b/src/containers/dashboard/DashboardContainer.jsx @@ -40,11 +40,11 @@ export default class DashboardContainer extends React.Component { if (result.status === 200) { activeMeasurement = Measurement.fromObject(result.data); } - this.updateState("CONNECTED", activeMeasurement); + this.updateActiveMeasurement("CONNECTED", activeMeasurement); this.resetFetchMeasurementTimeout(); }) .catch(error => { - this.updateState("DISCONNECTED", undefined); + this.updateActiveMeasurement("DISCONNECTED", undefined); this.resetFetchMeasurementTimeout(); }); }; @@ -68,7 +68,7 @@ export default class DashboardContainer extends React.Component { }); }; - updateState = ( + updateActiveMeasurement = ( serverConnection: ConnectionState, activeMeasurement?: Measurement ) => { diff --git a/src/containers/importexport/ImportExportContainer.jsx b/src/containers/importexport/ImportExportContainer.jsx index 9955880..69833df 100644 --- a/src/containers/importexport/ImportExportContainer.jsx +++ b/src/containers/importexport/ImportExportContainer.jsx @@ -59,7 +59,6 @@ export default class ImportExportContainer extends React.Component< }; render() { - console.log(this.state.isLoading); return ( {(showToast: any) => ( From b8425d413e7421910f38d511150d3ccec59e4b56 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 14:27:02 +0200 Subject: [PATCH 147/160] FLUX-154 Fix CSRF exception --- src/containers/app/App.jsx | 1 + 1 file changed, 1 insertion(+) diff --git a/src/containers/app/App.jsx b/src/containers/app/App.jsx index c5b132a..78f8e1f 100644 --- a/src/containers/app/App.jsx +++ b/src/containers/app/App.jsx @@ -29,6 +29,7 @@ export default class App extends React.Component { constructor() { super(); (axios.defaults: Object).baseURL = process.env.REACT_APP_SERVICE_URI; // Sets the default URL for the rest of the applications lifetime. + axios.defaults.headers["X-Requested-With"] = "XMLHttpRequest"; } state = {}; From bd34ed510047b0f2a9524d342d0e6e2ace63910e Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 16:07:21 +0200 Subject: [PATCH 148/160] Fixed test --- src/components/dashboard/Dashboard.test.jsx | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/components/dashboard/Dashboard.test.jsx b/src/components/dashboard/Dashboard.test.jsx index f0d718c..9796dd3 100644 --- a/src/components/dashboard/Dashboard.test.jsx +++ b/src/components/dashboard/Dashboard.test.jsx @@ -5,12 +5,19 @@ import { shallow } from "enzyme"; import Dashboard from "./Dashboard"; import type { ServerState } from "./../../types/ServerState"; +import type { ConnectionState } from "./../../types/ServerState"; describe("", () => { it("should render", () => { const serverState: ServerState = { connectionState: "UNKNOWN" }; - shallow(); + const sensorState: ConnectionState = "UNKNOWN"; + shallow( + + ); }); }); From 11c6bdcf151578bfa8a31c9b7de0645e288ea4e0 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Tue, 5 Jun 2018 16:57:48 +0200 Subject: [PATCH 149/160] hide missing end date of measurement --- .../measurements/MeasurementSummary.jsx | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/src/components/measurements/MeasurementSummary.jsx b/src/components/measurements/MeasurementSummary.jsx index 6732de7..76711de 100644 --- a/src/components/measurements/MeasurementSummary.jsx +++ b/src/components/measurements/MeasurementSummary.jsx @@ -140,17 +140,19 @@ export default class MeasurementSummary extends React.Component { > Zeitraum: {this.props.currentMeasurement.startDate != null ? ( - + - - - + {this.props.currentMeasurement.endDate != null && ( + + + + + )} + ) : ( nicht verfügbar From ec43803d1588deaae6a851b82987924867f228d2 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 5 Jun 2018 18:08:13 +0200 Subject: [PATCH 150/160] Added swiss german locale for momentjs --- package.json | 1 + src/index.js | 1 + yarn.lock | 2 +- 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/package.json b/package.json index 3201c15..10123ba 100644 --- a/package.json +++ b/package.json @@ -10,6 +10,7 @@ "grommet": "^1.10.1", "grommet-addons": "^0.6.0", "js-file-download": "^0.4.1", + "moment": "^2.22.2", "node-sass-chokidar": "^1.2.0", "npm-run-all": "^4.1.2", "react": "^16.3.1", diff --git a/src/index.js b/src/index.js index 75f30a7..0c2dd4b 100644 --- a/src/index.js +++ b/src/index.js @@ -1,6 +1,7 @@ import React from "react"; import ReactDOM from "react-dom"; import registerServiceWorker from "./registerServiceWorker"; +import "moment/locale/de-ch"; import "./index.css"; import App from "./containers/app/App"; diff --git a/yarn.lock b/yarn.lock index 2c2dbd2..5f1a3d6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6566,7 +6566,7 @@ mkdirp@0.5.1, mkdirp@0.5.x, "mkdirp@>=0.5 0", mkdirp@^0.5.0, mkdirp@^0.5.1, mkdi dependencies: minimist "0.0.8" -moment@^2.20.1: +moment@^2.20.1, moment@^2.22.2: version "2.22.2" resolved "https://registry.yarnpkg.com/moment/-/moment-2.22.2.tgz#3c257f9839fc0e93ff53149632239eb90783ff66" From 3092658276ee20a9fb93d12a90ce7c7c7e4af1ee Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Wed, 6 Jun 2018 09:45:05 +0200 Subject: [PATCH 151/160] Update version to 1.0.0 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 10123ba..f625aae 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "flux-frontend", - "version": "0.1.0", + "version": "1.0.0", "private": true, "dependencies": { "@flux-coordinator/heatmapjs": "^2.1.4", From e1664ae39fc6cafdb7b8c345d41a36b08c6e59dc Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sat, 9 Jun 2018 09:35:15 +0200 Subject: [PATCH 152/160] remove unused settings menu --- src/components/navmenu/NavMenu.jsx | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/components/navmenu/NavMenu.jsx b/src/components/navmenu/NavMenu.jsx index 6bba34b..18b6487 100644 --- a/src/components/navmenu/NavMenu.jsx +++ b/src/components/navmenu/NavMenu.jsx @@ -21,9 +21,6 @@ export default function NavMenu({ onNavigate }: Props) { Import / Export - - Einstellungen - { From f427b4c9edfecc4ebe15648298ba5d45feac3486 Mon Sep 17 00:00:00 2001 From: Patrick Scherler Date: Sat, 9 Jun 2018 09:48:44 +0200 Subject: [PATCH 153/160] initialize missing date with null --- src/models/Measurement.jsx | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/models/Measurement.jsx b/src/models/Measurement.jsx index 2ca877b..ad6f65b 100644 --- a/src/models/Measurement.jsx +++ b/src/models/Measurement.jsx @@ -8,8 +8,8 @@ type ConstructorType = { measurementId: number, name: string, description: string, - startDate: Date, - endDate: Date, + startDate: ?Date, + endDate: ?Date, measurementState: MeasurementState, xOffset: number, yOffset: number, @@ -25,8 +25,8 @@ export default class Measurement { measurementId: ?number; name: string; description: string; - startDate: Date; - endDate: Date; + startDate: ?Date; + endDate: ?Date; measurementState: MeasurementState; transformation: Transformation; creator: string; @@ -42,8 +42,8 @@ export default class Measurement { xOffset: number, yOffset: number, scaleFactor: number = 1.0, - startDate?: Date = new Date(), - endDate?: Date = new Date(), + startDate?: ?Date = null, + endDate?: ?Date = null, measurementState?: MeasurementState = "READY", creator?: string = "", readings?: Reading[] = [], From 719cf9a45fd6e63ec1948a3f1f1940f3580f9cfb Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 12 Jun 2018 13:45:58 +0200 Subject: [PATCH 154/160] Unregister registered service workers --- src/index.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/index.js b/src/index.js index 0c2dd4b..aae3f36 100644 --- a/src/index.js +++ b/src/index.js @@ -1,10 +1,10 @@ import React from "react"; import ReactDOM from "react-dom"; -import registerServiceWorker from "./registerServiceWorker"; +import { unregister } from "./registerServiceWorker"; import "moment/locale/de-ch"; import "./index.css"; import App from "./containers/app/App"; ReactDOM.render(, document.getElementById("root")); -registerServiceWorker(); +unregister(); From fbf5fe2b8fa00bbc91f56165cbd73e7a1d9f79db Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 12 Jun 2018 14:16:39 +0200 Subject: [PATCH 155/160] Added nginx configuration --- .../heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx | 2 +- static.json | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) create mode 100644 static.json diff --git a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx index 7cb83cd..342fe1b 100644 --- a/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx +++ b/src/components/heatmap/heatmapAnalysisForm/HeatmapAnalysisForm.jsx @@ -140,7 +140,7 @@ export default class HeatmapAnalysisForm extends React.Component { diff --git a/static.json b/static.json new file mode 100644 index 0000000..d641fad --- /dev/null +++ b/static.json @@ -0,0 +1,6 @@ +{ + "root": "build/", + "routes": { + "/**": "index.html" + } +} From e481fbd78b13b28023ceaea33eb04c9d37a2ddbc Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Tue, 12 Jun 2018 19:54:16 +0200 Subject: [PATCH 156/160] Cleanup headers --- src/components/contentBox/ContentBox.jsx | 12 ++++----- src/components/projects/Project.jsx | 2 +- src/components/projects/Projects.jsx | 31 +++++++----------------- 3 files changed, 16 insertions(+), 29 deletions(-) diff --git a/src/components/contentBox/ContentBox.jsx b/src/components/contentBox/ContentBox.jsx index 7a6e842..36a9c8f 100644 --- a/src/components/contentBox/ContentBox.jsx +++ b/src/components/contentBox/ContentBox.jsx @@ -1,13 +1,14 @@ // @flow import * as React from "react"; -import Header from "grommet/components/Header"; import Heading from "grommet/components/Heading"; +import Paragraph from "grommet/components/Paragraph"; import Article from "grommet/components/Article"; import Box from "grommet/components/Box"; import { withRouter } from "react-router"; type Props = { heading: React.Node, + subheading?: React.Node, children: React.Node, location: any }; @@ -16,11 +17,10 @@ class ContentBox extends React.Component { render() { return (
-
- - {this.props.heading} - -
+ + {this.props.heading} + + {this.props.subheading} {this.props.children}
); diff --git a/src/components/projects/Project.jsx b/src/components/projects/Project.jsx index a874e99..ef1500b 100644 --- a/src/components/projects/Project.jsx +++ b/src/components/projects/Project.jsx @@ -30,7 +30,7 @@ export default function Project({ projects, match, onDeleteRoom }: Props) { } return ( - + { const { projects, loading, onDeleteProject } = this.props; return ( -
-
- Alle Projekte -
-
-
- - project.projectId} - loading={loading} - ItemRenderer={({ item }) => ( - - )} - /> -
+ + project.projectId} + loading={loading} + ItemRenderer={({ item }) => ( + + )} + />
); } From 4015f14ac80fe9af6901e8241136f548a538c412 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Thu, 14 Jun 2018 08:40:04 +0200 Subject: [PATCH 157/160] Simplified the layout of Project and Room views --- src/components/projects/Project.jsx | 33 +++++++++++++---------------- src/components/room/Room.jsx | 20 +++++------------ 2 files changed, 20 insertions(+), 33 deletions(-) diff --git a/src/components/projects/Project.jsx b/src/components/projects/Project.jsx index ef1500b..99d4ea9 100644 --- a/src/components/projects/Project.jsx +++ b/src/components/projects/Project.jsx @@ -1,6 +1,5 @@ // @flow import * as React from "react"; -import Box from "grommet/components/Box"; import NotFound from "../../components/notfound/NotFound"; import ContentBox from "../contentBox/ContentBox"; @@ -31,23 +30,21 @@ export default function Project({ projects, match, onDeleteRoom }: Props) { return ( - - - item.roomId} - ItemRenderer={({ item }) => ( - - )} - /> - + + item.roomId} + ItemRenderer={({ item }) => ( + + )} + /> ); } diff --git a/src/components/room/Room.jsx b/src/components/room/Room.jsx index cae68ce..1b51387 100644 --- a/src/components/room/Room.jsx +++ b/src/components/room/Room.jsx @@ -1,18 +1,16 @@ // @flow import * as React from "react"; -import Heading from "grommet/components/Heading"; import Section from "grommet/components/Section"; -import Article from "grommet/components/Article"; -import Paragraph from "grommet/components/Paragraph"; // eslint-disable-next-line import { BrowserRouter as Router, Route, Switch } from "react-router-dom"; -import Measurement from "../../models/Measurement"; -import RoomModel from "../../models/Room"; +import ContentBox from "../contentBox/ContentBox"; import ItemsList from "../list/ItemsList"; import ItemListHeader from "./../list/ItemListHeader"; import MeasurementContainer from "../../containers/measurements/MeasurementContainer"; import AnchorMeasurementItemRenderer from "../measurements/AnchorMeasurementItemRenderer"; +import RoomModel from "../../models/Room"; +import Measurement from "../../models/Measurement"; type Props = { match: any, @@ -22,15 +20,7 @@ type Props = { export default function Room({ match, room, onDeleteMeasurement }: Props) { return ( -
-
- - {room.name} - - {room.description} -
+ ( @@ -54,7 +44,7 @@ export default function Room({ match, room, onDeleteMeasurement }: Props) { )} />
-
+
); } From b614733b82bb742060c3d17ad9c56605d13761fb Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Thu, 14 Jun 2018 08:44:54 +0200 Subject: [PATCH 158/160] Added the help-text for Room and Measurement export steps --- .../importexport/wizard/SelectMeasurementsStep.jsx | 4 ++++ src/containers/importexport/wizard/SelectRoomsStep.jsx | 7 +++---- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/src/containers/importexport/wizard/SelectMeasurementsStep.jsx b/src/containers/importexport/wizard/SelectMeasurementsStep.jsx index 215e961..8f724da 100644 --- a/src/containers/importexport/wizard/SelectMeasurementsStep.jsx +++ b/src/containers/importexport/wizard/SelectMeasurementsStep.jsx @@ -30,6 +30,9 @@ export default class SelectMeasurementsStep extends React.Component< projects: [] }; + subheading: string = + "Sie können mit CTRL + Mausclick mehrere Projekte auswählen."; + getMeasurementsOfRoom = ( data: Project[], projectId: ?number, @@ -122,6 +125,7 @@ export default class SelectMeasurementsStep extends React.Component< return ( diff --git a/src/containers/importexport/wizard/SelectRoomsStep.jsx b/src/containers/importexport/wizard/SelectRoomsStep.jsx index 3285d2c..3a3db89 100644 --- a/src/containers/importexport/wizard/SelectRoomsStep.jsx +++ b/src/containers/importexport/wizard/SelectRoomsStep.jsx @@ -24,10 +24,8 @@ export default class SelectRoomsStep extends React.Component { selectedProjects: [] }; - listItemProperties = { - margin: "small", - pad: "small" - }; + subheading: string = + "Sie können mit CTRL + Mausclick mehrere Projekte auswählen."; onSelect = (selected: ?number | number[], project: Project) => { const foundProject = this.props.projects.find( @@ -88,6 +86,7 @@ export default class SelectRoomsStep extends React.Component { return ( {projects && From f959af5f36f9937cffb0a338fea4aae80d11a3c5 Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Thu, 14 Jun 2018 17:10:49 +0200 Subject: [PATCH 159/160] Update readme.md with instructions --- README.md | 38 ++++++++++++++++++++++++++------------ 1 file changed, 26 insertions(+), 12 deletions(-) diff --git a/README.md b/README.md index e7feae6..f31821f 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,7 @@ # Flux-Frontend
- + [![Tested with Jest](https://img.shields.io/badge/tested_with-jest-99424f.svg)](https://github.com/facebook/jest) [![GitHub license](https://img.shields.io/github/license/Flux-Coordinator/flux-frontend.svg)](https://github.com/Flux-Coordinator/flux-frontend) [![Sonar Cloud Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=reliability_rating)](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=reliability_rating) @@ -12,18 +12,32 @@ [![Dependencies](https://david-dm.org/Flux-Coordinator/flux-frontend.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend) [![DevDependencies](https://david-dm.org/Flux-Coordinator/flux-frontend/dev-status.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend?type=dev) [![peerDependency Status](https://david-dm.org/Flux-Coordinator/repo/peer-status.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend?type=peer) - +
-## Ordnerstruktur +## How to run this application in development mode + +Follow the below guide to run this application in development mode. +**Prerequisites:** [NodeJS 8](https://nodejs.org/en/download/) and [Yarn](https://yarnpkg.com/en/docs/install) (recommended) or NPM. + +1. Download the repository +2. Install the dependencies using `yarn` or `npm install` +3. Run the application using the `yarn start` or the `npm run start` command. + +The URI for the connection to the [flux-server](https://github.com/Flux-Coordinator/flux-server) instance needs to be set either as an environment variable REACT_APP_SERVICE_URI or using a `.env` file, in which you have the following content: + +``` +REACT_APP_SERVICE_URI = +``` + +## Run in Production Mode + +To run this application in production mode, you need to build it first, using the `yarn build` or `npm run build` command. After the command has run through, you will find the built application in the _/build_ folder. You can deploy that folder on your preferred static webserver or using [serve](https://github.com/zeit/serve). + +To install serve globally, you can use the `yarn global add serve` or `npm install -g serve`. After the installation is complete, you can use the command `serve -s build`, where build the _/build_ folder. + +If you use a webserver other than serve, you will need to make some changes. Follow the guide [here](https://github.com/facebook/create-react-app/blob/master/packages/react-scripts/template/README.md#serving-apps-with-client-side-routing). -Die Ordnerstruktur im **./src** Ordner sieht wie folgt aus: +## More informations -| Ordner | Beschreibung | -| -------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| src/api | Die JS Dateien in diesem Ordner stellen die Anfragen an das backend API. | -| src/components | In diesem Ordner befinden sich die Presentational Components. Merke, dass die CSS und Tests ebenfalls in diesem Ordner zusammen mit ihren Components befinden. | -| src/containers | In diesem Ordner befinden sich die Container Components. Diese machen die API Calls und besitzen einen State. Merke, dass die CSS und Tests ebenfalls in diesem Ordner zusammen mit ihren Components befinden. | -| src/images | Hier befinden sich die Bilder, die in der Anwendung verwendet werden. | -| src/index.jsx | In dieser Datei wird die App initialisiert. | -| src/utils | Alles, was sonst nicht eingeordnet werden kann und keinen eigenen Ordner verdient. | +For more information about running and deploying the application, you can consult the CRA documentation [here](https://github.com/facebook/create-react-app/blob/master/packages/react-scripts/template/README.md). From ad4b9edc73c1ed389f9ba2e9655d40bcd308224b Mon Sep 17 00:00:00 2001 From: Esteban Luchsinger Date: Thu, 14 Jun 2018 17:25:37 +0200 Subject: [PATCH 160/160] Updated readme --- README.md | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/README.md b/README.md index f31821f..576f88e 100644 --- a/README.md +++ b/README.md @@ -2,29 +2,29 @@
- [![Tested with Jest](https://img.shields.io/badge/tested_with-jest-99424f.svg)](https://github.com/facebook/jest) - [![GitHub license](https://img.shields.io/github/license/Flux-Coordinator/flux-frontend.svg)](https://github.com/Flux-Coordinator/flux-frontend) - [![Sonar Cloud Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=reliability_rating)](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=reliability_rating) - [![Sonar Cloud Coverage](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=coverage)](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=coverage) - [![Sonar Cloud Quality Gate](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=alert_status)](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=alert_status) - [![Build Status](https://travis-ci.org/Flux-Coordinator/flux-frontend.svg?branch=master)](https://travis-ci.org/Flux-Coordinator/flux-frontend) - [![Code Style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square)](https://github.com/prettier/prettier) - [![Dependencies](https://david-dm.org/Flux-Coordinator/flux-frontend.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend) - [![DevDependencies](https://david-dm.org/Flux-Coordinator/flux-frontend/dev-status.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend?type=dev) - [![peerDependency Status](https://david-dm.org/Flux-Coordinator/repo/peer-status.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend?type=peer) +[![Tested with Jest](https://img.shields.io/badge/tested_with-jest-99424f.svg)](https://github.com/facebook/jest) +[![GitHub license](https://img.shields.io/github/license/Flux-Coordinator/flux-frontend.svg)](https://github.com/Flux-Coordinator/flux-frontend) +[![Sonar Cloud Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=reliability_rating)](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=reliability_rating) +[![Sonar Cloud Coverage](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=coverage)](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=coverage) +[![Sonar Cloud Quality Gate](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=alert_status)](https://sonarcloud.io/api/project_badges/measure?project=flux-frontend&metric=alert_status) +[![Build Status](https://travis-ci.org/Flux-Coordinator/flux-frontend.svg?branch=master)](https://travis-ci.org/Flux-Coordinator/flux-frontend) +[![Code Style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square)](https://github.com/prettier/prettier) +[![Dependencies](https://david-dm.org/Flux-Coordinator/flux-frontend.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend) +[![DevDependencies](https://david-dm.org/Flux-Coordinator/flux-frontend/dev-status.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend?type=dev) +[![peerDependency Status](https://david-dm.org/Flux-Coordinator/repo/peer-status.svg)](https://david-dm.org/Flux-Coordinator/flux-frontend?type=peer)
## How to run this application in development mode -Follow the below guide to run this application in development mode. +Follow the guide below to run this application in development mode. **Prerequisites:** [NodeJS 8](https://nodejs.org/en/download/) and [Yarn](https://yarnpkg.com/en/docs/install) (recommended) or NPM. 1. Download the repository 2. Install the dependencies using `yarn` or `npm install` 3. Run the application using the `yarn start` or the `npm run start` command. -The URI for the connection to the [flux-server](https://github.com/Flux-Coordinator/flux-server) instance needs to be set either as an environment variable REACT_APP_SERVICE_URI or using a `.env` file, in which you have the following content: +The URI for the connection to the [flux-server](https://github.com/Flux-Coordinator/flux-server) instance needs to be set either as an environment variable named `REACT_APP_SERVICE_URI` or using a [_.env_](https://github.com/motdotla/dotenv) file, in which you have the following content: ``` REACT_APP_SERVICE_URI =