-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[NM-82] download results state refactor #1036
Changes from 3 commits
493c0ab
60bd6c5
849b876
c1a6b7c
d54e89e
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,47 +2,17 @@ | |
<div class="container"> | ||
<div class="row"> | ||
<div class="col-sm"> | ||
<div id="spectrum-download"> | ||
<download :translate-key="translation.spectrum" | ||
@trigger-download="downloadSpectrumOutput" | ||
:disabled="!spectrum.downloadId || spectrum.preparing" | ||
:file="spectrum"/> | ||
<div class="pb-2"> | ||
<error-alert v-if="spectrum.downloadError" :error="spectrum.downloadError"></error-alert> | ||
<template v-for="type in Object.values(DownloadType)" :key="type"> | ||
<div :id="`${type}-download`" v-if="switches[type]"> | ||
<download :translate-key="`${type}Download`" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I wonder if we should put this into the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. hmmm do you mean because theres duplication between this and the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. No, only that when you're adding a new file type you have to look here to see what the key is. It is There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done extracted |
||
@trigger-download="() => downloadOutput(type)" | ||
:disabled="!state[type].downloadId || state[type].preparing" | ||
:file="state[type]"/> | ||
<div class="pb-2"> | ||
<error-alert v-if="state[type].downloadError" :error="state[type].downloadError"></error-alert> | ||
</div> | ||
</div> | ||
</div> | ||
<div id="coarse-output-download"> | ||
<download :translate-key="translation.coarse" | ||
@trigger-download="downloadCoarseOutput" | ||
:disabled="!coarseOutput.downloadId || coarseOutput.preparing" | ||
:file="coarseOutput"/> | ||
<div class="pb-2"> | ||
<error-alert v-if="coarseOutput.downloadError" :error="coarseOutput.downloadError"></error-alert> | ||
</div> | ||
</div> | ||
<div id="summary-download"> | ||
<download :translate-key="translation.summary" | ||
@trigger-download="downloadSummaryReport" | ||
:disabled="!summary.downloadId || summary.preparing" | ||
:file="summary"/> | ||
<div class="pb-2"> | ||
<error-alert v-if="summary.downloadError" :error="summary.downloadError"></error-alert> | ||
</div> | ||
</div> | ||
<div id="comparison-download" v-if="comparisonSwitch"> | ||
<download :translate-key="translation.comparison" | ||
@trigger-download="downloadComparisonReport" | ||
:disabled="!comparison.downloadId || comparison.preparing" | ||
:file="comparison"/> | ||
<error-alert v-if="comparison.downloadError" :error="comparison.downloadError"></error-alert> | ||
</div> | ||
<div id="agyw-download" v-if="agywSwitch"> | ||
<download :translate-key="translation.agyw" | ||
@trigger-download="downloadAgywTool" | ||
:disabled="!agyw.downloadId || agyw.preparing" | ||
:file="agyw"/> | ||
<error-alert v-if="agyw.downloadError" :error="agyw.downloadError"></error-alert> | ||
</div> | ||
</template> | ||
</div> | ||
<div id="upload" v-if="hasUploadPermission" class="col-sm"> | ||
<h4 v-translate="'uploadFileToAdr'"></h4> | ||
|
@@ -96,34 +66,31 @@ | |
import ErrorAlert from "../ErrorAlert.vue"; | ||
import i18next from "i18next"; | ||
import {ADRUploadState} from "../../store/adrUpload/adrUpload"; | ||
import {DownloadResultsState} from "../../store/downloadResults/downloadResults"; | ||
import Download from "./Download.vue"; | ||
import {switches} from "../../featureSwitches"; | ||
import { defineComponent } from "vue"; | ||
import { downloadSwitches, DownloadType } from "../../store/downloadResults/downloadConfig"; | ||
|
||
interface Data { | ||
uploadModalOpen: boolean, | ||
comparisonSwitch: boolean, | ||
agywSwitch: boolean, | ||
DownloadType: typeof DownloadType, | ||
switches: { | ||
[K in DownloadType]: boolean | ||
} | ||
} | ||
|
||
export default defineComponent({ | ||
name: "downloadResults", | ||
data(): Data { | ||
return { | ||
uploadModalOpen: false, | ||
comparisonSwitch: switches.comparisonOutput, | ||
agywSwitch: switches.agywDownload, | ||
switches: downloadSwitches, | ||
DownloadType | ||
} | ||
}, | ||
computed: { | ||
hasUploadPermission: mapStateProp<ADRState, boolean>("adr", (state: ADRState) => state.userCanUpload), | ||
...mapStateProps("downloadResults", { | ||
spectrum: ((state: DownloadResultsState) => state.spectrum), | ||
summary: ((state: DownloadResultsState) => state.summary), | ||
coarseOutput: ((state: DownloadResultsState) => state.coarseOutput), | ||
comparison: ((state: DownloadResultsState) => state.comparison), | ||
agyw: ((state: DownloadResultsState) => state.agyw), | ||
state: (state) => state | ||
}), | ||
...mapStateProps("adrUpload", { | ||
uploading: ((state: ADRUploadState) => state.uploading), | ||
|
@@ -145,18 +112,8 @@ | |
null, | ||
(state: RootState) => state.language | ||
), | ||
translation(): Record<string, any> { | ||
return { | ||
spectrum: {header: 'exportOutputs', button: 'download'}, | ||
coarse: {header: 'downloadCoarseOutput', button: 'download'}, | ||
summary: {header: 'downloadSummaryReport', button: 'download'}, | ||
comparison: {header: 'downloadComparisonReport', button: 'download'}, | ||
agyw: {header: 'downloadAgywTool', button: 'download'}, | ||
} | ||
}, | ||
isPreparing(): boolean { | ||
return this.summary.preparing || this.spectrum.preparing || this.coarseOutput.preparing || | ||
this.comparison.preparing || this.agyw.preparing | ||
return Object.values(DownloadType).some(type => this.state[type].preparing); | ||
} | ||
}, | ||
methods: { | ||
|
@@ -166,17 +123,13 @@ | |
clearStatus: mapMutationByName("adrUpload", "ClearStatus"), | ||
getUserCanUpload: mapActionByName("adr", "getUserCanUpload"), | ||
getUploadFiles: mapActionByName("adrUpload", "getUploadFiles"), | ||
prepareOutputs: mapActionByName("downloadResults", "prepareOutputs"), | ||
downloadComparisonReport: mapActionByName("downloadResults", "downloadComparisonReport"), | ||
downloadSpectrumOutput: mapActionByName("downloadResults", "downloadSpectrumOutput"), | ||
downloadSummaryReport: mapActionByName("downloadResults", "downloadSummaryReport"), | ||
downloadCoarseOutput: mapActionByName("downloadResults", "downloadCoarseOutput"), | ||
downloadAgywTool: mapActionByName("downloadResults", "downloadAgywTool"), | ||
prepareAllOutputs: mapActionByName("downloadResults", "prepareAllOutputs"), | ||
downloadOutput: mapActionByName("downloadResults", "downloadOutput"), | ||
}, | ||
mounted() { | ||
this.getUserCanUpload(); | ||
this.getUploadFiles(); | ||
this.prepareOutputs(); | ||
this.prepareAllOutputs(); | ||
}, | ||
beforeMount() { | ||
this.clearStatus(); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -89,6 +89,7 @@ | |
import {RootState} from "../../root"; | ||
import {DownloadResultsState} from "../../store/downloadResults/downloadResults"; | ||
import {defineComponent} from "vue"; | ||
import { DownloadType } from "../../store/downloadResults/downloadConfig"; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Bit of weird indenting There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ahhh my auto import extension is trippin, fixed |
||
|
||
interface Data { | ||
uploadFilesToAdr: string[] | ||
|
@@ -158,18 +159,16 @@ | |
}, | ||
computed: { | ||
...mapStateProps("downloadResults", { | ||
summary: ((state: DownloadResultsState) => state.summary), | ||
spectrum: ((state: DownloadResultsState) => state.spectrum), | ||
comparison: ((state: DownloadResultsState) => state.comparison) | ||
summary: (state: DownloadResultsState) => state[DownloadType.SUMMARY], | ||
spectrum: (state: DownloadResultsState) => state[DownloadType.SPECTRUM], | ||
comparison: (state: DownloadResultsState) => state[DownloadType.COMPARISON] | ||
}), | ||
outputFileError(): string | null { | ||
if ((this.summary.error || this.summary.metadataError) && | ||
(this.spectrum.error || this.spectrum.metadataError)) { | ||
return "downloadSpectrumAndSummaryError" | ||
|
||
} else if (this.summary.error || this.summary.metadataError) { | ||
return this.translatedOutputFileError("downloadSummary") | ||
|
||
} else if (this.spectrum.error || this.spectrum.metadataError) { | ||
return this.translatedOutputFileError("downloadSpectrum") | ||
} else if (this.comparison.error || this.comparison.metadataError) { | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,6 +7,7 @@ import {ADRUploadMutation} from "./mutations"; | |
import {constructUploadFile, constructUploadFileWithResourceName} from "../../utils"; | ||
import {Dict, UploadFile} from "../../types"; | ||
import {ValidateInputResponse} from "../../generated"; | ||
import { DownloadType } from "../downloadResults/downloadConfig"; | ||
|
||
export interface ADRUploadActions { | ||
getUploadFiles: (store: ActionContext<ADRUploadState, RootState>) => void; | ||
|
@@ -111,23 +112,23 @@ export const actions: ActionTree<ADRUploadState, RootState> & ADRUploadActions = | |
requestParams["resourceId"] = resourceId | ||
} | ||
if (resourceType === rootState.adr.schemas?.outputSummary) { | ||
downloadId = rootState.downloadResults.summary.downloadId | ||
downloadId = rootState.downloadResults[DownloadType.SUMMARY].downloadId | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What do you also think about handling this through the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Could use it above in There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. the reason i didnt do this here is because this requires me to refactor the ADR upload stuff because we need some way of matching up if "outputSummary" exists, then include in the i can create a ticket for these two if you agree! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yep sounds great doing that separately, yes please create the tickets. |
||
|
||
requestParams["description"] = | ||
uploadMetadata?.find(meta => meta.type === "summary")?.description | ||
|| "Naomi summary report uploaded from Naomi web app" | ||
} | ||
|
||
if (resourceType === rootState.adr.schemas?.outputZip) { | ||
downloadId = rootState.downloadResults.spectrum.downloadId | ||
downloadId = rootState.downloadResults[DownloadType.SPECTRUM].downloadId | ||
|
||
requestParams["description"] = | ||
uploadMetadata?.find(meta => meta.type === "spectrum")?.description | ||
|| "Naomi output uploaded from Naomi web app" | ||
} | ||
|
||
if (resourceType === rootState.adr.schemas?.outputComparison) { | ||
downloadId = rootState.downloadResults.comparison.downloadId | ||
downloadId = rootState.downloadResults[DownloadType.COMPARISON].downloadId | ||
|
||
requestParams["description"] = | ||
uploadMetadata?.find(meta => meta.type === "comparison")?.description | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So this is what I had previously added
withErrorCallback
for. But I think what you've done is better. Could you remove thewithErrorCallback
helper and tidy up uses of that to use this instead?But actually, I wonder if we should have 2 functions
withError
andwithErrorHandler
? Or some better name? Whatever you think!There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ohhhh damn sorry i didnt even see that, i was looking for that type of functionality, yh im happy to remove it, i think its nice to declare the mutation you want and all that, i personally think its nicer if we just have one function with an optional arg, it feels like exactly the same responsibility, just with pre commit step or not
im basically not sure what we gain by having 2 separate functions XD
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nope that's fine, happy with 1 function if you want.