O que mudou
Infra (por app):
i18n/locales.ts — lista de locales (pt, en), default pt, labels para o seletor
i18n/request.ts — lê o cookie NEXT_LOCALE, carrega as mensagens
messages/pt.json + messages/en.json — todas as strings extraídas
next.config.ts — envolvido com withNextIntl (operator-pwa: withPWA(withNextIntl(...)))
app/layout.tsx — <html lang={locale}> dinâmico, NextIntlClientProvider
app/language-switcher.tsx — seletor PT | EN (cookie + router.refresh())
23 ficheiros de UI atualizados — todos os textos visíveis agora usam t('...') ou getTranslations.
Datas no relatório passaram de toLocaleString('pt-PT') fixo para useFormatter() do next-intl — localizam-se automaticamente.
Plurais em ICU no sync-chip: {count, plural, one {# pedido...} other {# pedidos...}}.
Resultado dos testes:
pnpm test:e2e — 3/3 ✓
pnpm test:e2e:auth — 4/4 ✓
tsc --noEmit em ambas as apps — limpo ✓
Para adicionar uma língua futura: criar messages/<locale>.json + adicionar o locale a i18n/locales.ts em cada app. O seletor aparece automaticamente.
26 lines
928 B
TypeScript
26 lines
928 B
TypeScript
export type ShiftKey = 'manha' | 'tarde' | 'noite';
|
|
|
|
export const SHIFTS: Record<ShiftKey, { startHour: number; endHour: number }> = {
|
|
manha: { startHour: 6, endHour: 14 },
|
|
tarde: { startHour: 14, endHour: 22 },
|
|
noite: { startHour: 22, endHour: 6 },
|
|
};
|
|
|
|
/** Given a shift and a day (Date at local midnight), returns [from, to). */
|
|
export function shiftWindow(shift: ShiftKey, day: Date): { from: Date; to: Date } {
|
|
const s = SHIFTS[shift];
|
|
const from = new Date(day);
|
|
from.setHours(s.startHour, 0, 0, 0);
|
|
const to = new Date(day);
|
|
if (s.endHour <= s.startHour) to.setDate(to.getDate() + 1); // noite crosses midnight
|
|
to.setHours(s.endHour, 0, 0, 0);
|
|
return { from, to };
|
|
}
|
|
|
|
/** "Hoje" = start of local day up to now. `now` injected for testability. */
|
|
export function todayWindow(now: Date): { from: Date; to: Date } {
|
|
const from = new Date(now);
|
|
from.setHours(0, 0, 0, 0);
|
|
return { from, to: now };
|
|
}
|