Skip to content

Commit

Permalink
🎨: improve the loading alert and show error when there is an error wh…
Browse files Browse the repository at this point in the history
…ile redirecting to the file source provider in `FileSources/CreateInstance`
  • Loading branch information
itisAliRH authored and mvdbeek committed Oct 11, 2024
1 parent bea8589 commit 905c9c2
Showing 1 changed file with 29 additions and 9 deletions.
38 changes: 29 additions & 9 deletions client/src/components/FileSources/Instances/CreateInstance.vue
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
<script setup lang="ts">
import { computed, watch } from "vue";
import { BAlert } from "bootstrap-vue";
import { computed, ref, watch } from "vue";
import { GalaxyApi } from "@/api";
import type { UserFileSourceModel } from "@/api/fileSources";
import { useFileSourceTemplatesStore } from "@/stores/fileSourceTemplatesStore";
import { errorMessageAsString } from "@/utils/simple-error";
import { useInstanceRouting } from "./routing";
Expand All @@ -23,22 +25,34 @@ fileSourceTemplatesStore.fetchTemplates();
const { goToIndex } = useInstanceRouting();
const props = defineProps<Props>();
const loading = ref(false);
const errorMessage = ref("");
const template = computed(() => fileSourceTemplatesStore.getLatestTemplate(props.templateId));
const redirectMessage = computed(
() =>
`You will redirected to ${template.value?.name} to authorize Galaxy to access this resource remotely. Please wait`
);
const requiresOAuth2AuthorizeRedirect = computed(() => {
const templateValue = template.value;
return props.uuid == undefined && templateValue && OAUTH2_TYPES.indexOf(templateValue.type) >= 0;
});
async function onCreated(objectStore: UserFileSourceModel) {
function onCreated(objectStore: UserFileSourceModel) {
const message = `Created file source ${objectStore.name}`;
goToIndex({ message });
}
watch(
requiresOAuth2AuthorizeRedirect,
async (requiresAuth) => {
const templateValue = template.value;
if (templateValue && requiresAuth) {
loading.value = true;
const { data, error: testRequestError } = await GalaxyApi().GET(
"/api/file_source_templates/{template_id}/{template_version}/oauth2",
{
Expand All @@ -50,9 +64,11 @@ watch(
},
}
);
if (testRequestError) {
console.log("Error getting OAuth2 URL");
console.log(testRequestError);
errorMessage.value = errorMessageAsString(testRequestError, "Error getting OAuth2 URL");
loading.value = false;
} else {
window.location.href = data.authorize_url;
}
Expand All @@ -64,10 +80,14 @@ watch(

<template>
<div>
<LoadingSpan v-if="!template" message="Loading file source templates" />
<LoadingSpan
v-else-if="requiresOAuth2AuthorizeRedirect"
message="Fetching redirect information, you will need to authorize Galaxy to have access to this resource remotely" />
<CreateForm v-else :uuid="uuid" :template="template" @created="onCreated"></CreateForm>
<BAlert v-if="loading" show variant="info">
<LoadingSpan v-if="!template" message="Loading file source templates" />
<LoadingSpan v-else-if="requiresOAuth2AuthorizeRedirect && !errorMessage" :message="redirectMessage" />
</BAlert>

<BAlert v-if="errorMessage" show variant="danger">
{{ errorMessage }}
</BAlert>
<CreateForm v-if="!loading && template" :uuid="uuid" :template="template" @created="onCreated" />
</div>
</template>

0 comments on commit 905c9c2

Please sign in to comment.