mirror of
https://github.com/hay-kot/homebox.git
synced 2024-12-31 19:07:15 +00:00
b77c9be36f
* bump prettier/eslint-plugin * bump nuxt pwa * use typed imports * set vue version to fix layout errors * disable import
52 lines
1.1 KiB
TypeScript
52 lines
1.1 KiB
TypeScript
import type { Ref } from "vue";
|
|
import type { TreeItem } from "~~/lib/api/types/data-contracts";
|
|
|
|
export interface FlatTreeItem {
|
|
id: string;
|
|
name: string;
|
|
treeString: string;
|
|
}
|
|
|
|
function flatTree(tree: TreeItem[]): FlatTreeItem[] {
|
|
const v = [] as FlatTreeItem[];
|
|
|
|
// turns the nested items into a flat items array where
|
|
// the display is a string of the tree hierarchy separated by breadcrumbs
|
|
|
|
function flatten(items: TreeItem[], display: string) {
|
|
if (!items) {
|
|
return;
|
|
}
|
|
|
|
for (const item of items) {
|
|
v.push({
|
|
id: item.id,
|
|
name: item.name,
|
|
treeString: display + item.name,
|
|
});
|
|
if (item.children) {
|
|
flatten(item.children, display + item.name + " > ");
|
|
}
|
|
}
|
|
}
|
|
|
|
flatten(tree, "");
|
|
|
|
return v;
|
|
}
|
|
|
|
export function useFlatLocations(): Ref<FlatTreeItem[]> {
|
|
const locations = useLocationStore();
|
|
|
|
if (locations.tree === null) {
|
|
locations.refreshTree();
|
|
}
|
|
|
|
return computed(() => {
|
|
if (locations.tree === null) {
|
|
return [];
|
|
}
|
|
|
|
return flatTree(locations.tree);
|
|
});
|
|
}
|