Files
task-team/apps/tasks/app/layout.tsx
Admin 4ace4d5f7d PWA widgets dashboard, lock screen, screensaver with active category
- Dashboard (/dashboard): configurable widget system with 6 widget types
  (current_tasks, category_time, today_progress, next_task, motivace, calendar_mini)
  stored in localStorage widget_config
- Lock screen (/lockscreen): fullscreen with clock, active group badge,
  up to 4 current tasks, gradient from group color, swipe/tap to unlock
- InactivityMonitor: auto-redirect to lockscreen after configurable timeout
  (only in PWA standalone/fullscreen mode)
- Settings: widget toggle switches, inactivity timeout slider, lockscreen preview
- manifest.json: added display_override ["fullscreen","standalone"] + orientation portrait

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-30 11:32:08 +00:00

56 lines
1.5 KiB
TypeScript

import type { Metadata, Viewport } from "next";
import "./globals.css";
import ThemeProvider from "@/components/ThemeProvider";
import AuthProvider from "@/components/AuthProvider";
import Header from "@/components/Header";
import BottomNav from "@/components/BottomNav";
import InactivityMonitor from "@/components/InactivityMonitor";
import { I18nProvider } from "@/lib/i18n";
export const metadata: Metadata = {
title: "Task Team",
description: "Sprava ukolu pro tym",
manifest: "/manifest.json",
appleWebApp: {
capable: true,
statusBarStyle: "black-translucent",
title: "Task Team",
},
other: { "mobile-web-app-capable": "yes" },
};
export const viewport: Viewport = {
width: "device-width",
initialScale: 1,
maximumScale: 1,
themeColor: [
{ media: "(prefers-color-scheme: light)", color: "#ffffff" },
{ media: "(prefers-color-scheme: dark)", color: "#0a0a0a" },
],
};
export default function RootLayout({
children,
}: {
children: React.ReactNode;
}) {
return (
<html lang="cs" suppressHydrationWarning>
<body className="antialiased min-h-screen">
<I18nProvider>
<ThemeProvider>
<AuthProvider>
<Header />
<main className="w-full max-w-4xl mx-auto py-4 sm:px-4">
{children}
</main>
<BottomNav />
<InactivityMonitor />
</AuthProvider>
</ThemeProvider>
</I18nProvider>
</body>
</html>
);
}