From 737ce62470a13ae153788207719396e107252955 Mon Sep 17 00:00:00 2001 From: Georgios Andreadis Date: Thu, 10 Aug 2017 12:40:36 +0300 Subject: Suppress duplicate modal close actions --- src/components/modals/Modal.js | 31 +++++++++++++++++++------ src/components/projects/ProjectActionButtons.js | 16 +++++++------ src/components/projects/ProjectAuth.js | 2 +- src/components/projects/ProjectAuthList.js | 1 - 4 files changed, 34 insertions(+), 16 deletions(-) (limited to 'src/components') diff --git a/src/components/modals/Modal.js b/src/components/modals/Modal.js index bb8fa00f..e7054fec 100644 --- a/src/components/modals/Modal.js +++ b/src/components/modals/Modal.js @@ -10,29 +10,46 @@ class Modal extends React.Component { }; static idCounter = 0; + // Local, up-to-date copy of modal visibility for time between close and props update (to prevent duplicate close + // triggers) + visible = false; + constructor() { super(); - this.id = "modal-" + Modal.idCounter; + this.id = "modal-" + Modal.idCounter++; } componentDidMount() { + this.visible = this.props.show; this.openOrCloseModal(); - window["$"]("#" + this.id).on("hide.bs.modal", this.props.onCancel.bind(this)); + window["$"]("#" + this.id).on("hide.bs.modal", () => { + if (this.visible) { + this.props.onCancel(); + console.log("TEST"); + } + }); } componentDidUpdate() { + this.visible = this.props.show; this.openOrCloseModal(); } onSubmit() { - this.props.onSubmit(); - this.closeModal(); + if (this.visible) { + this.props.onSubmit(); + this.visible = false; + this.closeModal(); + } } onCancel() { - this.props.onCancel(); - this.closeModal(); + if (this.visible) { + this.props.onCancel(); + this.visible = false; + this.closeModal(); + } } openModal() { @@ -44,7 +61,7 @@ class Modal extends React.Component { } openOrCloseModal() { - if (this.props.show) { + if (this.visible) { this.openModal(); } else { this.closeModal(); diff --git a/src/components/projects/ProjectActionButtons.js b/src/components/projects/ProjectActionButtons.js index 085438d8..66eb8bfa 100644 --- a/src/components/projects/ProjectActionButtons.js +++ b/src/components/projects/ProjectActionButtons.js @@ -1,24 +1,26 @@ import PropTypes from "prop-types"; import React from 'react'; -const ProjectActionButtons = ({onOpen, onViewUsers, onDelete}) => ( +const ProjectActionButtons = ({projectId, onOpen, onViewUsers, onDelete}) => (
-
+
onOpen(projectId)}>
-
+
onViewUsers(projectId)}>
-
+
onDelete(projectId)}>
); ProjectActionButtons.propTypes = { - onOpen: PropTypes.func.isRequired, - onViewUsers: PropTypes.func.isRequired, - onDelete: PropTypes.func.isRequired, + projectId: PropTypes.number.isRequired, + onOpen: PropTypes.func, + onViewUsers: PropTypes.func, + onDelete: PropTypes.func, }; export default ProjectActionButtons; diff --git a/src/components/projects/ProjectAuth.js b/src/components/projects/ProjectAuth.js index e58ac92b..10cfd252 100644 --- a/src/components/projects/ProjectAuth.js +++ b/src/components/projects/ProjectAuth.js @@ -13,7 +13,7 @@ const ProjectAuth = ({projectAuth}) => ( {AUTH_DESCRIPTION_MAP[projectAuth.authorizationLevel]}
- +
); diff --git a/src/components/projects/ProjectAuthList.js b/src/components/projects/ProjectAuthList.js index 217a8375..94e7abad 100644 --- a/src/components/projects/ProjectAuthList.js +++ b/src/components/projects/ProjectAuthList.js @@ -28,7 +28,6 @@ const ProjectAuthList = ({authorizations}) => { ProjectAuthList.propTypes = { authorizations: PropTypes.arrayOf(Shapes.Authorization).isRequired, - onProjectClick: PropTypes.func.isRequired, }; export default ProjectAuthList; -- cgit v1.2.3