37 lines
1016 B
TypeScript
37 lines
1016 B
TypeScript
import type { Project } from "~/server/api/project.get";
|
|
|
|
export default function useProject()
|
|
{
|
|
const id = useState<number>("projectId", () => 1);
|
|
const name = useState<string>("projectName", undefined);
|
|
const owner = useState<number>("projectOwner", undefined);
|
|
const home = useState<string | null>("projectHomepage", () => null);
|
|
|
|
return {
|
|
id, name, owner, home, get, set
|
|
}
|
|
}
|
|
|
|
async function get(): Promise<void> {
|
|
const id = useState<number>("projectId");
|
|
|
|
if (!id.value)
|
|
return;
|
|
|
|
try {
|
|
const result = await $fetch(`/api/project/${id}`) as Project;
|
|
|
|
const name = useState<string>("projectName");
|
|
const owner = useState<number>("projectOwner");
|
|
const home = useState<string | null>("projectHomepage");
|
|
|
|
name.value = result.name;
|
|
owner.value = result.owner;
|
|
home.value = result.home;
|
|
} catch(e) {}
|
|
}
|
|
function set(id: number): void {
|
|
const _id = useState<number>("projectId");
|
|
|
|
_id.value = id;
|
|
} |