feat(navigation): add Header entity + use-case + mock/payload repos + DI container

This commit is contained in:
2026-05-05 08:34:14 +02:00
parent f71025b14a
commit 19f32ec94d
10 changed files with 164 additions and 0 deletions

View File

@@ -0,0 +1,5 @@
import type { Header } from "../../entities/header";
export interface IHeaderRepository {
getHeader(): Promise<Header>;
}

View File

@@ -0,0 +1,23 @@
import { beforeEach, describe, expect, it } from "vitest";
import { navigationContainer } from "@/di/container";
import { NAVIGATION_SYMBOLS } from "@/di/symbols";
import { MockHeaderRepository } from "@/infrastructure/repositories/mock-header.repository";
import type { IHeaderRepository } from "@/application/repositories/header-repository.interface";
import { getHeaderUseCase } from "./get-header.use-case";
describe("getHeaderUseCase", () => {
beforeEach(() => {
if (navigationContainer.isBound(NAVIGATION_SYMBOLS.IHeaderRepository)) {
navigationContainer.unbind(NAVIGATION_SYMBOLS.IHeaderRepository);
}
navigationContainer
.bind<IHeaderRepository>(NAVIGATION_SYMBOLS.IHeaderRepository)
.toConstantValue(new MockHeaderRepository());
});
it("returns the seeded header items", async () => {
const result = await getHeaderUseCase();
expect(result.items.length).toBeGreaterThan(0);
expect(result.items[0]?.label).toBe("Home");
});
});

View File

@@ -0,0 +1,11 @@
import type { Header } from "../../entities/header";
import { navigationContainer } from "../../di/container";
import { NAVIGATION_SYMBOLS } from "../../di/symbols";
import type { IHeaderRepository } from "../repositories/header-repository.interface";
export async function getHeaderUseCase(): Promise<Header> {
const repo = navigationContainer.get<IHeaderRepository>(
NAVIGATION_SYMBOLS.IHeaderRepository,
);
return repo.getHeader();
}