Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 30 additions & 6 deletions core/frontend/src/components/version-chooser/VersionChooser.vue
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,8 @@
id="file"
show-size
accept=".tar"
:rules="[isFileInputNotEmpty]"
:error-messages="file_input_error"
label="File input"
/>
<v-progress-linear
Expand All @@ -157,8 +159,8 @@
<v-btn
v-if="!disable_upload_controls"
color="primary"
class="mr-2 mb-4"
@click="upload()"
class="mr-2 mb-4 mt-1"
@click="validateInputFileForm() && upload()"
v-text="'Upload'"
/>

Expand Down Expand Up @@ -253,6 +255,7 @@ export default Vue.extend({
default_repository,
selected_image: default_repository,
deleting: '', // image currently being deleted, if any
file_input_error: '',
}
},
computed: {
Expand All @@ -262,6 +265,9 @@ export default Vue.extend({
totalPages(): number {
return Math.ceil(this.available_versions.remote.length / 10)
},
inputFileRequiredMessage(): string {
return 'File is required'
},
},
mounted() {
this.loadCurrentVersion()
Expand Down Expand Up @@ -430,14 +436,14 @@ export default Vue.extend({
return remote_counterpart.sha !== image.sha && remote_counterpart.sha !== null
},
async upload() {
this.disable_upload_controls = true
const { files } = document.getElementById('file') as HTMLInputElement
if (files !== null) {
const file = this.getInputFile()
if (file) {
this.disable_upload_controls = true
await back_axios({
method: 'POST',
url: '/version-chooser/v1.0/version/load/',
timeout: 15 * 60 * 1000, // Wait for 15min
data: files[0],
data: file,
headers: { 'Content-Type': 'undefined' },
onUploadProgress: (event) => {
this.upload_percentage = Math.round(100 * (event.loaded / event.total))
Expand Down Expand Up @@ -596,6 +602,24 @@ export default Vue.extend({
}
return this.available_versions.local.some((image) => image.sha === sha)
},
getInputFile(): File | undefined {
const { files } = document.getElementById('file') as HTMLInputElement

return files?.[0]
},
isFileInputNotEmpty(v: File | null): true | string {
this.file_input_error = ''
return !!v || this.inputFileRequiredMessage
},
validateInputFileForm(): boolean {
const valid = this.getInputFile() != null

if (!valid) {
this.file_input_error = this.inputFileRequiredMessage
}

return valid
},
},
})
</script>