From 99a93f79ba64d2404cfc0937f6c6673735cc2223 Mon Sep 17 00:00:00 2001 From: John Chilton Date: Thu, 1 Mar 2018 13:19:21 -0500 Subject: [PATCH] Update rule based collection builder for pre-built outputs. As soon the initial fetch request is complete there should be collections and datasets in the history so do a refresh of the history so Galaxy polls on those items. When jobs fail - you will now see red collections/datasets. Also fixes a bug where the modal polling wouldn't actually display an error message when the fetch job fails. --- .../galaxy/scripts/components/RuleCollectionBuilder.vue | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/client/galaxy/scripts/components/RuleCollectionBuilder.vue b/client/galaxy/scripts/components/RuleCollectionBuilder.vue index 8256634dff51..e9285ad1fe79 100644 --- a/client/galaxy/scripts/components/RuleCollectionBuilder.vue +++ b/client/galaxy/scripts/components/RuleCollectionBuilder.vue @@ -1770,6 +1770,12 @@ export default { removeMapping(index) { this.mapping.splice(index, 1); }, + refreshAndWait(response) { + if (Galaxy && Galaxy.currHistoryPanel) { + Galaxy.currHistoryPanel.refreshContents(); + } + this.waitOnJob(response); + }, waitOnJob(response) { const jobId = response.data.jobs[0].id; const handleJobShow = (jobResponse) => { @@ -1778,6 +1784,7 @@ export default { if (JobStatesModel.NON_TERMINAL_STATES.indexOf(state) !== -1) { setTimeout(doJobCheck, 1000); } else if (JobStatesModel.ERROR_STATES.indexOf(state) !== -1) { + this.state = 'error'; this.errorMessage = "Unknown error encountered while running your upload job, this could be a server issue or a problem with the upload definition."; } else { const history = parent.Galaxy && parent.Galaxy.currHistoryPanel && parent.Galaxy.currHistoryPanel.model; @@ -1862,7 +1869,7 @@ export default { "history_id": historyId, "targets": targets, }) - .then(this.waitOnJob) + .then(this.refreshAndWait) .catch(this.renderFetchError); } },