budibase/packages/client/src/store/routes.js

58 lines
1.4 KiB
JavaScript
Raw Normal View History

import { writable } from "svelte/store"
import { push } from "svelte-spa-router"
import * as API from "../api"
const createRouteStore = () => {
const initialState = {
routes: [],
routeParams: {},
activeRoute: null,
routeSessionId: Math.random(),
}
const store = writable(initialState)
const fetchRoutes = async () => {
const routeConfig = await API.fetchRoutes()
let routes = []
2021-05-03 09:31:09 +02:00
Object.values(routeConfig.routes).forEach((route) => {
Object.entries(route.subpaths).forEach(([path, config]) => {
routes.push({
path,
screenId: config.screenId,
})
})
})
// Sort route by paths so that the router matches correctly
routes.sort((a, b) => {
return a.path > b.path ? -1 : 1
})
2021-05-03 09:31:09 +02:00
store.update((state) => {
state.routes = routes
state.routeSessionId = Math.random()
return state
})
}
2021-05-03 09:31:09 +02:00
const setRouteParams = (routeParams) => {
store.update((state) => {
state.routeParams = routeParams
return state
})
}
2021-05-03 09:31:09 +02:00
const setActiveRoute = (route) => {
store.update((state) => {
state.activeRoute = state.routes.find((x) => x.path === route)
return state
})
}
const navigate = push
return {
subscribe: store.subscribe,
actions: { fetchRoutes, navigate, setRouteParams, setActiveRoute },
}
}
export const routeStore = createRouteStore()