managarten/apps-archived/mukke/apps/mobile/app/(tabs)/_layout.tsx
Till JS 7a56699d45 feat(mukke): rename LightWrite to Mukke and add music library, player, playlists
Combines LightWrite (beat/lyrics editor) and Mukke (iOS music player) into
a single web-based music workspace app. Archives the old Mukke mobile app.

- Rename: @lightwrite/* → @mukke/*, all branding, configs, Dockerfiles
- New DB schemas: songs, playlists, playlist_songs + songId FK on projects
- New backend modules: SongModule, PlaylistModule, LibraryModule
- New web: app shell with sidebar, library (songs/albums/artists/genres),
  web player (queue/shuffle/repeat/MediaSession), playlists, search,
  upload, dashboard, album/artist/genre detail pages
- Auth: add forgot-password + reset-password pages, extend auth store
- Tests: 40 backend unit tests (song, playlist, library services)
- Config: env generation, MinIO bucket, docker-compose prod, cloudflare
- Docs: update CLAUDE.md, auth guidelines with SvelteKit checklist

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-19 09:55:56 +01:00

33 lines
836 B
TypeScript

import { NativeTabs, Icon, Label } from 'expo-router/unstable-native-tabs';
import { View } from 'react-native';
import { MiniPlayer } from '~/components/MiniPlayer';
export default function TabLayout() {
return (
<View style={{ flex: 1 }}>
<NativeTabs>
<NativeTabs.Trigger name="index">
<Icon sf="music.note.list" />
<Label>Bibliothek</Label>
</NativeTabs.Trigger>
<NativeTabs.Trigger name="playlists">
<Icon sf="list.bullet" />
<Label>Playlists</Label>
</NativeTabs.Trigger>
<NativeTabs.Trigger name="search">
<Icon sf="magnifyingglass" />
<Label>Suche</Label>
</NativeTabs.Trigger>
<NativeTabs.Trigger name="settings">
<Icon sf="gearshape.fill" />
<Label>Einstellungen</Label>
</NativeTabs.Trigger>
</NativeTabs>
<MiniPlayer />
</View>
);
}