// Navigation helpers import { ipcRenderer } from "electron"; import { compile } from "path-to-regexp" import { createBrowserHistory, createMemoryHistory, LocationDescriptor } from "history"; import { createObservableHistory } from "mobx-observable-history"; import logger from "../main/logger"; export const history = typeof window !== "undefined" ? createBrowserHistory() : createMemoryHistory(); export const navigation = createObservableHistory(history); // handle navigation from other process (e.g. system menus in main, common->cluster view interactions) if (ipcRenderer) { ipcRenderer.on("menu:navigate", (event, location: LocationDescriptor) => { logger.info(`Navigation via IPC to location: ${JSON.stringify(location)}`, event); navigate(location); }) } export function navigate(location: LocationDescriptor) { navigation.push(location); } export interface IURLParams
{ params?: P; query?: IQueryParams & Q; } export function buildURL
(path: string | string[]) { const pathBuilder = compile(path.toString()); return function ({ params, query }: IURLParams
= {}) {
return pathBuilder(params) + (query ? getQueryString(query, false) : "")
}
}
// common params for all pages
export interface IQueryParams {
namespaces?: string[]; // selected context namespaces
details?: string; // serialized resource details
selected?: string; // mark resource as selected
search?: string; // search-input value
sortBy?: string; // sorting params for table-list
orderBy?: string;
}
export function getQueryString(params?: Partial