managarten/apps-archived/mukke/apps/mobile/components/SegmentedControl.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

57 lines
1.2 KiB
TypeScript

import { Pressable, View, Text } from 'react-native';
import { useTheme } from '~/utils/themeContext';
interface SegmentedControlProps<T extends string> {
segments: { key: T; label: string }[];
selected: T;
onSelect: (key: T) => void;
}
export function SegmentedControl<T extends string>({
segments,
selected,
onSelect,
}: SegmentedControlProps<T>) {
const { colors } = useTheme();
return (
<View
style={{
flexDirection: 'row',
backgroundColor: colors.backgroundTertiary,
borderRadius: 8,
padding: 2,
marginHorizontal: 16,
marginVertical: 8,
}}
>
{segments.map((seg) => {
const isActive = seg.key === selected;
return (
<Pressable
key={seg.key}
onPress={() => onSelect(seg.key)}
style={{
flex: 1,
paddingVertical: 8,
borderRadius: 6,
backgroundColor: isActive ? colors.card : 'transparent',
alignItems: 'center',
}}
>
<Text
style={{
fontSize: 13,
fontWeight: isActive ? '600' : '400',
color: isActive ? colors.text : colors.textSecondary,
}}
>
{seg.label}
</Text>
</Pressable>
);
})}
</View>
);
}