From 7260b974fd7095614970dc7189781e1e039d0107 Mon Sep 17 00:00:00 2001 From: Mateusz Rybczonek Date: Wed, 15 Nov 2023 11:13:14 +0100 Subject: [PATCH] feat(happ-unhosting): hook up API --- src/components/StopHostingModal.vue | 58 +++++++++---------- .../hAppDetails/HAppDetailsContent.vue | 15 +++-- .../hAppDetails/HAppDetailsStopHosting.vue | 7 +++ src/interfaces/HposInterface.ts | 38 ++++++++++++ src/locales/en.ts | 2 + src/pages/HappDetails.vue | 22 ++++--- 6 files changed, 102 insertions(+), 40 deletions(-) diff --git a/src/components/StopHostingModal.vue b/src/components/StopHostingModal.vue index 08728337..0b910df3 100644 --- a/src/components/StopHostingModal.vue +++ b/src/components/StopHostingModal.vue @@ -7,9 +7,11 @@ import { EButtonType } from '@uicommon/types/ui' import { ref } from 'vue' import { useI18n } from 'vue-i18n' import { EModal } from '@/constants/ui' -import { HAppDetails } from '@/interfaces/HposInterface' +import { HAppDetails, useHposInterface } from '@/interfaces/HposInterface' +import { isError as isErrorPredicate } from '@/types/predicates' const { t } = useI18n() +const { stopHostingHApp, startHostingHApp } = useHposInterface() // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-assignment const { showModal } = useModals() @@ -18,34 +20,40 @@ const props = defineProps<{ hApp: HAppDetails }>() -const emit = defineEmits(['close']) +const emit = defineEmits(['close', 'update:hosting']) const isConfirmed = ref(false) const isBusy = ref(false) const isError = ref(false) -function confirm(): void { +async function confirm(): Promise { isBusy.value = true + let result = null + + if (props.hApp.enabled) { + result = await stopHostingHApp(props.hApp.id) + } else { + result = await startHostingHApp(props.hApp.id) + } + + // If failed + if (isErrorPredicate(result)) { + emit('close') - setTimeout(() => { - if (props.hApp.enabled) { - stopHostingHApp() - } else { - startHostingHApp() - } - - // If failed - // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-assignment - // showModal(EModal.error_modal) - // emit('close') - // - // isBusy.value = false - // isConfirmed.value = false - - // If success isBusy.value = false - isConfirmed.value = true - }, 2000) + isConfirmed.value = false + + setTimeout(() => { + showModal(EModal.error_modal) + }, 300) + + return + } + + // If success + isBusy.value = false + isConfirmed.value = true + emit('update:hosting', !props.hApp.enabled) } function close(): void { @@ -54,14 +62,6 @@ function close(): void { isError.value = false emit('close') } - -function startHostingHApp(): void { - console.log('NOT YET IMPLEMENTED: Starting hosting happ', props.hApp.name) -} - -function stopHostingHApp(): void { - console.log('NOT YET IMPLEMENTED: Stopping hosting happ', props.hApp.name) -}