Skip to content

Commit

Permalink
FOUR-17488: Back redirection on element destination with external URL…
Browse files Browse the repository at this point in the history
… is not correct
  • Loading branch information
Rodrigo Quelca committed Aug 1, 2024
1 parent fe5c579 commit d02582e
Showing 1 changed file with 28 additions and 1 deletion.
29 changes: 28 additions & 1 deletion src/components/task.vue
Original file line number Diff line number Diff line change
Expand Up @@ -455,6 +455,7 @@ export default {
const elementDestinationUrl = elementDestination.value;
if (elementDestinationUrl) {
sessionStorage.setItem('sessionUrlActionBlocker', document.referrer);
return elementDestinationUrl;
}
Expand Down Expand Up @@ -797,6 +798,30 @@ export default {
requestIdNode.setAttribute('content', this.requestId);
}
},
/**
* Checks for the presence of a URL action blocker in sessionStorage and handles it.
*
* This method retrieves the 'sessionUrlActionBlocker' value from sessionStorage,
* and if present, removes it and emits a 'closed' event with the task id and
* the source of the redirection. It returns false if the blocker was handled,
* and true otherwise.
*
* @returns {boolean} Returns false if the 'sessionUrlActionBlocker' was found and handled, true otherwise.
*/
hasUrlActionBloker() {
// Retrieve the 'sessionUrlActionBlocker' value from sessionStorage
const redirectedFrom = sessionStorage.getItem("sessionUrlActionBlocker");
if (redirectedFrom) {
// Remove 'sessionUrlActionBlocker' from sessionStorage after retrieving its value
sessionStorage.removeItem("sessionUrlActionBlocker");
// Emit a 'closed' event with the task id and the source of the redirection
this.$emit("closed", this.task?.id, redirectedFrom);
return true;
}
return false;
},
},
mounted() {
Expand All @@ -807,7 +832,9 @@ export default {
this.nodeId = this.initialNodeId;
this.requestData = this.value;
this.loopContext = this.initialLoopContext;
this.loadTask();
if (!this.hasUrlActionBloker()) {
this.loadTask();
}
},
destroyed() {
this.unsubscribeSocketListeners();
Expand Down

0 comments on commit d02582e

Please sign in to comment.