Skip to content

Commit

Permalink
App: Startup dialogs: Implement changes to run under dialog queue
Browse files Browse the repository at this point in the history
Signed-off-by: Arturo Manzoli <[email protected]>
  • Loading branch information
ArturoManzoli committed Jan 17, 2025
1 parent 2855924 commit f6e9ea4
Show file tree
Hide file tree
Showing 4 changed files with 53 additions and 29 deletions.
14 changes: 13 additions & 1 deletion src/components/InteractionDialog.vue
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
<template>
<v-dialog v-model="internalShowDialog" :persistent="persistent" :width="maxWidth || 'auto'">
<v-dialog
v-model="internalShowDialog"
:persistent="persistent"
:width="maxWidth || 'auto'"
@click:outside="handleClose"
@close="handleClose"
>
<v-card
:width="maxWidth || 'auto'"
class="main-dialog px-2 rounded-lg"
Expand Down Expand Up @@ -200,6 +206,12 @@ const iconColor = computed(() => {
const hasActionsSlot = computed(() => !!slots.actions)
const handleClose = (): void => {
if (interfaceStore.dialogQueue.length > 0) {
interfaceStore.openNextDialogOnQueue()
}
}
watch(
() => props.showDialog,
(newVal) => {
Expand Down
19 changes: 4 additions & 15 deletions src/components/Tutorial.vue
Original file line number Diff line number Diff line change
Expand Up @@ -91,20 +91,11 @@ const { showSnackbar } = useSnackbar()
const interfaceStore = useAppInterfaceStore()
const vehicleStore = useMainVehicleStore()
const props = defineProps<{
/**
*
*/
showTutorial?: boolean
}>()
const emits = defineEmits(['update:showTutorial'])
const showTutorial = ref(props.showTutorial || false)
const userHasSeenTutorial = useBlueOsStorage('cockpit-has-seen-tutorial', false)
const showTutorial = ref((interfaceStore.activeDialog?.id === 'Tutorial' && !userHasSeenTutorial.value) || false)
const currentTutorialStep = ref(1)
const isVehicleConnectedVisible = ref(false)
const tallContent = ref(false)
const userHasSeenTutorial = useBlueOsStorage('cockpit-has-seen-tutorial', false)
const steps = [
{
Expand Down Expand Up @@ -345,7 +336,7 @@ const handleStepChangeDown = (newStep: number): void => {
const dontShowTutorialAgain = (): void => {
userHasSeenTutorial.value = true
showTutorial.value = false
emits('update:showTutorial', false)
interfaceStore.openNextDialogOnQueue()
showSnackbar({
message: 'This guide can be reopened via the Settings > General menu',
variant: 'info',
Expand All @@ -356,8 +347,6 @@ const dontShowTutorialAgain = (): void => {
const alwaysShowTutorialOnStartup = (): void => {
userHasSeenTutorial.value = false
showTutorial.value = true
emits('update:showTutorial', true)
}
const nextTutorialStep = (): void => {
Expand All @@ -379,7 +368,7 @@ const closeTutorial = (): void => {
showTutorial.value = false
interfaceStore.componentToHighlight = 'none'
currentTutorialStep.value = 1
emits('update:showTutorial', false)
interfaceStore.openNextDialogOnQueue()
}
const setVehicleConnectedVisible = (): void => {
Expand Down
35 changes: 25 additions & 10 deletions src/components/UpdateNotification.vue
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
</template>
</v-progress-linear>
</template>
<template #actions> <v-btn variant="text" size="small" @click="handleClose">Close</v-btn> </template>
</InteractionDialog>
</template>

Expand All @@ -37,6 +38,9 @@ import { onBeforeMount, ref } from 'vue'
import InteractionDialog, { type Action } from '@/components/InteractionDialog.vue'
import { app_version } from '@/libs/cosmos'
import { isElectron } from '@/libs/utils'
import { useAppInterfaceStore } from '@/stores/appInterface'
const interfaceStore = useAppInterfaceStore()
const showUpdateDialog = ref(false)
const dialogTitle = ref('')
Expand All @@ -52,6 +56,11 @@ const updateInfo = ref({
})
const ignoredUpdateVersions = useStorage<string[]>('cockpit-ignored-update-versions', [])
const handleClose = (): void => {
interfaceStore.openNextDialogOnQueue()
showUpdateDialog.value = false
}
const formatDate = (date: string): string => {
return new Date(date).toLocaleDateString('en-US', { year: 'numeric', month: 'long', day: 'numeric' })
}
Expand All @@ -75,7 +84,9 @@ onBeforeMount(() => {
dialogVariant.value = 'info'
dialogActions.value = []
showProgress.value = false
showUpdateDialog.value = true
if (interfaceStore.activeDialog?.id === 'UpdateNotification' || interfaceStore.activeDialog === undefined) {
showUpdateDialog.value = true
}
})
window.electronAPI.onUpdateNotAvailable(() => {
Expand All @@ -87,7 +98,7 @@ onBeforeMount(() => {
{
text: 'OK',
action: () => {
showUpdateDialog.value = false
interfaceStore.openNextDialogOnQueue()
},
},
]
Expand All @@ -107,7 +118,7 @@ onBeforeMount(() => {
console.log(`User chose to ignore version ${updateInfo.value.version}`)
ignoredUpdateVersions.value.push(updateInfo.value.version)
window.electronAPI!.cancelUpdate()
showUpdateDialog.value = false
interfaceStore.openNextDialogOnQueue()
},
},
{
Expand All @@ -121,7 +132,7 @@ onBeforeMount(() => {
action: () => {
console.log('User chose to cancel the update for the Electron app.')
window.electronAPI!.cancelUpdate()
showUpdateDialog.value = false
interfaceStore.openNextDialogOnQueue()
dialogMessage.value = 'Downloading update...'
},
},
Expand All @@ -132,19 +143,21 @@ onBeforeMount(() => {
text: 'Not Now',
action: () => {
window.electronAPI!.cancelUpdate()
showUpdateDialog.value = false
interfaceStore.openNextDialogOnQueue()
},
},
]
// Check if this version is in the ignored list
if (ignoredUpdateVersions.value.includes(info.version)) {
console.log(`Skipping ignored version ${info.version}.`)
showUpdateDialog.value = false
interfaceStore.openNextDialogOnQueue()
return
}
showUpdateDialog.value = true
if (interfaceStore.activeDialog?.id === 'UpdateNotification' || interfaceStore.activeDialog === undefined) {
showUpdateDialog.value = true
}
})
window.electronAPI.onDownloadProgress((progressInfo) => {
Expand All @@ -164,18 +177,20 @@ onBeforeMount(() => {
action: () => {
console.log('User chose to install the update for the Electron app now.')
window.electronAPI!.installUpdate()
showUpdateDialog.value = false
interfaceStore.openNextDialogOnQueue()
},
},
{
text: 'Later',
action: () => {
console.log('User chose to install the update for the Electron app later.')
showUpdateDialog.value = false
interfaceStore.openNextDialogOnQueue()
},
},
]
showUpdateDialog.value = true
if (interfaceStore.activeDialog?.id === 'UpdateNotification' || interfaceStore.activeDialog === undefined) {
showUpdateDialog.value = true
}
})
})
</script>
14 changes: 11 additions & 3 deletions src/components/VehicleDiscoveryDialog.vue
Original file line number Diff line number Diff line change
Expand Up @@ -47,15 +47,18 @@

<script setup lang="ts">
import { useStorage } from '@vueuse/core'
import { ref, watch } from 'vue'
import { computed, ref, watch } from 'vue'
import { useSnackbar } from '@/composables/snackbar'
import vehicleDiscover, { NetworkVehicle } from '@/libs/electron/vehicle-discovery'
import { reloadCockpit } from '@/libs/utils'
import { useAppInterfaceStore } from '@/stores/appInterface'
import { useMainVehicleStore } from '@/stores/mainVehicle'
import InteractionDialog, { Action } from './InteractionDialog.vue'
const interfaceStore = useAppInterfaceStore()
const props = defineProps<{
/**
*
Expand All @@ -75,7 +78,8 @@ const { showSnackbar } = useSnackbar()
const mainVehicleStore = useMainVehicleStore()
const discoveryService = vehicleDiscover
const isOpen = ref(props.modelValue)
const isDialogOpen = computed(() => interfaceStore.activeDialog?.id === 'VehicleDiscoveryDialog' || props.modelValue)
const isOpen = ref(isDialogOpen.value || false)
const searching = ref(false)
const searched = ref(false)
const vehicles = ref<NetworkVehicle[]>([])
Expand All @@ -85,6 +89,7 @@ const originalActions = [
{
text: 'Close',
action: () => {
interfaceStore.openNextDialogOnQueue()
isOpen.value = false
},
},
Expand All @@ -105,7 +110,6 @@ watch(
isOpen.value = value
}
)
watch(isOpen, (value) => {
emit('update:modelValue', value)
})
Expand All @@ -114,6 +118,8 @@ const searchVehicles = async (): Promise<void> => {
searching.value = true
disableButtons()
vehicles.value = await discoveryService.findVehicles()
interfaceStore.openNextDialogOnQueue()
isOpen.value = false
searching.value = false
enableButtons()
searched.value = true
Expand All @@ -122,6 +128,7 @@ const searchVehicles = async (): Promise<void> => {
const selectVehicle = async (address: string): Promise<void> => {
mainVehicleStore.globalAddress = address
isOpen.value = false
interfaceStore.openNextDialogOnQueue()
await reloadCockpit()
showSnackbar({ message: 'Vehicle address updated', variant: 'success', duration: 5000 })
}
Expand All @@ -131,6 +138,7 @@ const preventFutureAutoSearchs = (): void => {
disableButtons()
setTimeout(() => {
isOpen.value = false
interfaceStore.openNextDialogOnQueue()
}, 5000)
}
Expand Down

0 comments on commit f6e9ea4

Please sign in to comment.