Initial commit: SIBU 2.0 MISSION
This commit is contained in:
78
frontend/src/stores/route.ts
Normal file
78
frontend/src/stores/route.ts
Normal file
@ -0,0 +1,78 @@
|
||||
/** Pinia store for route management */
|
||||
import { defineStore } from 'pinia'
|
||||
import { ref, computed } from 'vue'
|
||||
import type { Route, BusStop } from '@/types'
|
||||
import { routesService } from '@/services/routesService'
|
||||
|
||||
export const useRouteStore = defineStore('route', () => {
|
||||
const selectedRouteId = ref<string | null>(null)
|
||||
const selectedRouteName = ref<string | null>(null)
|
||||
const selectedRouteStops = ref<BusStop[]>([])
|
||||
const allRoutes = ref<Route[]>([])
|
||||
const isLoadingRoutes = ref(false)
|
||||
const isLoadingStops = ref(false)
|
||||
const error = ref<string | null>(null)
|
||||
|
||||
const hasSelectedRoute = computed(() => selectedRouteId.value !== null && selectedRouteName.value !== null)
|
||||
|
||||
async function loadRoutes(filters?: { originCity?: string, destinationCity?: string }, force = false) {
|
||||
if (!force && !filters && allRoutes.value.length > 0) {
|
||||
return
|
||||
}
|
||||
|
||||
isLoadingRoutes.value = true
|
||||
error.value = null
|
||||
try {
|
||||
allRoutes.value = await routesService.getAllRoutes(filters)
|
||||
} catch (e) {
|
||||
error.value = e instanceof Error ? e.message : 'Failed to load routes'
|
||||
console.error('Error loading routes:', e)
|
||||
} finally {
|
||||
isLoadingRoutes.value = false
|
||||
}
|
||||
}
|
||||
|
||||
async function loadRouteStops(routeId: string) {
|
||||
isLoadingStops.value = true
|
||||
error.value = null
|
||||
try {
|
||||
selectedRouteStops.value = await routesService.getRouteStops(routeId)
|
||||
} catch (e) {
|
||||
error.value = e instanceof Error ? e.message : 'Failed to load route stops'
|
||||
console.error('Error loading route stops:', e)
|
||||
selectedRouteStops.value = []
|
||||
} finally {
|
||||
isLoadingStops.value = false
|
||||
}
|
||||
}
|
||||
|
||||
async function selectRoute(routeId: string, routeName: string) {
|
||||
if (selectedRouteId.value === routeId) return
|
||||
selectedRouteId.value = routeId
|
||||
selectedRouteName.value = routeName
|
||||
selectedRouteStops.value = [] // Clear old stops immediately
|
||||
await loadRouteStops(routeId)
|
||||
}
|
||||
|
||||
function clearSelection() {
|
||||
selectedRouteId.value = null
|
||||
selectedRouteName.value = null
|
||||
selectedRouteStops.value = []
|
||||
}
|
||||
|
||||
return {
|
||||
selectedRouteId,
|
||||
selectedRouteName,
|
||||
selectedRouteStops,
|
||||
allRoutes,
|
||||
isLoadingRoutes,
|
||||
isLoadingStops,
|
||||
error,
|
||||
hasSelectedRoute,
|
||||
loadRoutes,
|
||||
loadRouteStops,
|
||||
selectRoute,
|
||||
clearSelection,
|
||||
}
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user