summaryrefslogtreecommitdiff
path: root/frontend/src/containers/simulations
diff options
context:
space:
mode:
Diffstat (limited to 'frontend/src/containers/simulations')
-rw-r--r--frontend/src/containers/simulations/FilterLink.js19
-rw-r--r--frontend/src/containers/simulations/NewSimulationButtonContainer.js15
-rw-r--r--frontend/src/containers/simulations/SimulationActions.js22
-rw-r--r--frontend/src/containers/simulations/VisibleSimulationAuthList.js42
4 files changed, 98 insertions, 0 deletions
diff --git a/frontend/src/containers/simulations/FilterLink.js b/frontend/src/containers/simulations/FilterLink.js
new file mode 100644
index 00000000..2c5f4ed5
--- /dev/null
+++ b/frontend/src/containers/simulations/FilterLink.js
@@ -0,0 +1,19 @@
+import { connect } from "react-redux";
+import { setAuthVisibilityFilter } from "../../actions/simulations";
+import FilterButton from "../../components/simulations/FilterButton";
+
+const mapStateToProps = (state, ownProps) => {
+ return {
+ active: state.simulationList.authVisibilityFilter === ownProps.filter
+ };
+};
+
+const mapDispatchToProps = (dispatch, ownProps) => {
+ return {
+ onClick: () => dispatch(setAuthVisibilityFilter(ownProps.filter))
+ };
+};
+
+const FilterLink = connect(mapStateToProps, mapDispatchToProps)(FilterButton);
+
+export default FilterLink;
diff --git a/frontend/src/containers/simulations/NewSimulationButtonContainer.js b/frontend/src/containers/simulations/NewSimulationButtonContainer.js
new file mode 100644
index 00000000..3ea04d24
--- /dev/null
+++ b/frontend/src/containers/simulations/NewSimulationButtonContainer.js
@@ -0,0 +1,15 @@
+import { connect } from "react-redux";
+import { openNewSimulationModal } from "../../actions/modals/simulations";
+import NewSimulationButtonComponent from "../../components/simulations/NewSimulationButtonComponent";
+
+const mapDispatchToProps = dispatch => {
+ return {
+ onClick: () => dispatch(openNewSimulationModal())
+ };
+};
+
+const NewSimulationButtonContainer = connect(undefined, mapDispatchToProps)(
+ NewSimulationButtonComponent
+);
+
+export default NewSimulationButtonContainer;
diff --git a/frontend/src/containers/simulations/SimulationActions.js b/frontend/src/containers/simulations/SimulationActions.js
new file mode 100644
index 00000000..32243eff
--- /dev/null
+++ b/frontend/src/containers/simulations/SimulationActions.js
@@ -0,0 +1,22 @@
+import { connect } from "react-redux";
+import { deleteSimulation } from "../../actions/simulations";
+import SimulationActionButtons from "../../components/simulations/SimulationActionButtons";
+
+const mapStateToProps = (state, ownProps) => {
+ return {
+ simulationId: ownProps.simulationId
+ };
+};
+
+const mapDispatchToProps = dispatch => {
+ return {
+ onViewUsers: id => {}, // TODO implement user viewing
+ onDelete: id => dispatch(deleteSimulation(id))
+ };
+};
+
+const SimulationActions = connect(mapStateToProps, mapDispatchToProps)(
+ SimulationActionButtons
+);
+
+export default SimulationActions;
diff --git a/frontend/src/containers/simulations/VisibleSimulationAuthList.js b/frontend/src/containers/simulations/VisibleSimulationAuthList.js
new file mode 100644
index 00000000..ffc74d9e
--- /dev/null
+++ b/frontend/src/containers/simulations/VisibleSimulationAuthList.js
@@ -0,0 +1,42 @@
+import { connect } from "react-redux";
+import SimulationList from "../../components/simulations/SimulationAuthList";
+
+const getVisibleSimulationAuths = (simulationAuths, filter) => {
+ switch (filter) {
+ case "SHOW_ALL":
+ return simulationAuths;
+ case "SHOW_OWN":
+ return simulationAuths.filter(
+ simulationAuth => simulationAuth.authorizationLevel === "OWN"
+ );
+ case "SHOW_SHARED":
+ return simulationAuths.filter(
+ simulationAuth => simulationAuth.authorizationLevel !== "OWN"
+ );
+ default:
+ return simulationAuths;
+ }
+};
+
+const mapStateToProps = state => {
+ const denormalizedAuthorizations = state.simulationList.authorizationsOfCurrentUser.map(
+ authorizationIds => {
+ const authorization = state.objects.authorization[authorizationIds];
+ authorization.user = state.objects.user[authorization.userId];
+ authorization.simulation =
+ state.objects.simulation[authorization.simulationId];
+ return authorization;
+ }
+ );
+
+ return {
+ authorizations: getVisibleSimulationAuths(
+ denormalizedAuthorizations,
+ state.simulationList.authVisibilityFilter
+ )
+ };
+};
+
+const VisibleSimulationAuthList = connect(mapStateToProps)(SimulationList);
+
+export default VisibleSimulationAuthList;