@allurereport/web-awesome
Version:
The static files for Allure Awesome Report
89 lines (74 loc) • 2.29 kB
text/typescript
import { type TestEnvGroup } from "@allurereport/core-api";
import { fetchReportJsonData } from "@allurereport/web-commons";
import { effect, signal } from "@preact/signals";
import type { StoreSignalState } from "@/stores/types";
import { loadFromLocalStorage } from "@/utils/loadFromLocalStorage";
export const environmentsStore = signal<StoreSignalState<string[]>>({
loading: false,
error: undefined,
data: [],
});
export const testEnvGroupsStore = signal<StoreSignalState<Record<string, TestEnvGroup>>>({
loading: false,
error: undefined,
data: {},
});
export const collapsedEnvironments = signal<string[]>(loadFromLocalStorage<string[]>("collapsedEnvironments", []));
export const currentEnvironment = signal<string>(loadFromLocalStorage<string>("currentEnvironment", ""));
export const setCurrentEnvironment = (env: string) => {
currentEnvironment.value = env;
};
export const fetchEnvironments = async () => {
environmentsStore.value = {
...environmentsStore.value,
loading: true,
error: undefined,
};
try {
const res = await fetchReportJsonData<string[]>("widgets/environments.json", { bustCache: true });
environmentsStore.value = {
data: res,
error: undefined,
loading: false,
};
} catch (e) {
environmentsStore.value = {
...environmentsStore.value,
error: e.message,
loading: false,
};
}
};
export const fetchTestEnvGroup = async (id: string) => {
if (testEnvGroupsStore.value.data[id]) {
return;
}
testEnvGroupsStore.value = {
...testEnvGroupsStore.value,
loading: true,
error: undefined,
};
try {
const res = await fetchReportJsonData<TestEnvGroup | undefined>(`data/test-env-groups/${id}.json`);
testEnvGroupsStore.value = {
data: {
...testEnvGroupsStore.value.data,
[id]: res,
},
error: undefined,
loading: false,
};
} catch (e) {
testEnvGroupsStore.value = {
...testEnvGroupsStore.value,
error: e.message,
loading: false,
};
}
};
effect(() => {
localStorage.setItem("currentEnvironment", JSON.stringify(currentEnvironment.value));
});
effect(() => {
localStorage.setItem("collapsedEnvironments", JSON.stringify([...collapsedEnvironments.value]));
});