fix: fixed the language thing and handling of project settings

This commit is contained in:
2026-02-17 20:11:28 +01:00
parent 80bc164917
commit 406568c78c
4 changed files with 52 additions and 0 deletions

View File

@@ -25,6 +25,8 @@ interface PostEngineContract {
interface MetaEngineContract {
getProjectMetadata: () => Promise<ProjectMetadata | null>;
setProjectContext: (projectId: string, dataDir?: string) => void;
isInitialized?: () => boolean;
syncOnStartup?: () => Promise<void>;
}
interface PreviewServerDependencies {
@@ -421,6 +423,10 @@ export class PreviewServer {
this.mediaEngine.setProjectContext?.(context.projectId, context.dataDir, context.dataDir);
this.settingsEngine.setProjectContext(context.projectId, context.dataDir);
if (this.settingsEngine.isInitialized && this.settingsEngine.syncOnStartup && !this.settingsEngine.isInitialized()) {
await this.settingsEngine.syncOnStartup();
}
const metadata = await this.settingsEngine.getProjectMetadata();
const maxPostsPerPage = clampMaxPostsPerPage(metadata?.maxPostsPerPage);
const htmlRewriteContext = await this.buildHtmlRewriteContext();

View File

@@ -810,6 +810,9 @@ export function registerIpcHandlers(): void {
safeHandle('meta:getProjectMetadata', async () => {
const engine = getMetaEngine();
if (!engine.isInitialized()) {
await engine.syncOnStartup();
}
return engine.getProjectMetadata();
});

View File

@@ -359,6 +359,34 @@ describe('PreviewServer', () => {
expect(html).toContain('<html lang="de">');
});
it('initializes metadata before reading language when supported by settings engine', async () => {
let initialized = false;
server = new PreviewServer({
postEngine: makeEngine([makePost()]),
settingsEngine: {
setProjectContext: vi.fn(),
isInitialized: vi.fn(() => initialized),
syncOnStartup: vi.fn(async () => {
initialized = true;
}),
async getProjectMetadata() {
return initialized
? { name: 'My Great Blog', mainLanguage: 'fr', maxPostsPerPage: 50 }
: null;
},
} as any,
getActiveProjectContext: async () => ({ projectId: 'default' }),
});
await server.start(0);
const response = await fetch(`${server.getBaseUrl()}/`);
expect(response.status).toBe(200);
const html = await response.text();
expect(html).toContain('<html lang="fr">');
});
it('falls back to active project name in page title when metadata is unavailable', async () => {
server = new PreviewServer({
postEngine: makeEngine([makePost()]),

View File

@@ -106,6 +106,7 @@ const mockProjectEngine = {
const mockMetaEngine = {
on: vi.fn(),
setProjectContext: vi.fn(),
isInitialized: vi.fn(),
syncOnStartup: vi.fn(),
getTags: vi.fn(),
getCategories: vi.fn(),
@@ -1166,6 +1167,7 @@ describe('IPC Handlers', () => {
describe('meta:getProjectMetadata', () => {
it('should return project metadata', async () => {
const metadata = { name: 'Test Blog', description: 'A test blog', mainLanguage: 'de' };
mockMetaEngine.isInitialized.mockReturnValue(true);
mockMetaEngine.getProjectMetadata.mockResolvedValue(metadata);
const result = await invokeHandler('meta:getProjectMetadata');
@@ -1173,6 +1175,19 @@ describe('IPC Handlers', () => {
expect(mockMetaEngine.getProjectMetadata).toHaveBeenCalled();
expect(result).toEqual(metadata);
});
it('should sync metadata before reading when engine is not initialized', async () => {
const metadata = { name: 'Test Blog', mainLanguage: 'de', defaultAuthor: 'Max' };
mockMetaEngine.isInitialized.mockReturnValue(false);
mockMetaEngine.syncOnStartup.mockResolvedValue(undefined);
mockMetaEngine.getProjectMetadata.mockResolvedValue(metadata);
const result = await invokeHandler('meta:getProjectMetadata');
expect(mockMetaEngine.syncOnStartup).toHaveBeenCalled();
expect(mockMetaEngine.getProjectMetadata).toHaveBeenCalled();
expect(result).toEqual(metadata);
});
});
describe('meta:setProjectMetadata', () => {