managarten/manadeck/apps/mobile/components/ui/Switch.tsx
Till-JS e7f5f942f3 chore: initial commit - consolidate 4 projects into monorepo
Projects included:
- maerchenzauber (NestJS backend + Expo mobile + SvelteKit web + Astro landing)
- manacore (Expo mobile + SvelteKit web + Astro landing)
- manadeck (NestJS backend + Expo mobile + SvelteKit web)
- memoro (Expo mobile + SvelteKit web + Astro landing)

This commit preserves the current state before monorepo restructuring.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-22 23:38:24 +01:00

26 lines
718 B
TypeScript

import React from 'react';
import { Switch as RNSwitch, SwitchProps } from 'react-native';
import { useTheme } from '../ThemeProvider';
export interface CustomSwitchProps extends Omit<SwitchProps, 'trackColor' | 'thumbColor'> {
value: boolean;
onValueChange: (value: boolean) => void;
}
export function Switch({ value, onValueChange, ...props }: CustomSwitchProps) {
const { colors } = useTheme();
return (
<RNSwitch
value={value}
onValueChange={onValueChange}
trackColor={{
false: colors.muted,
true: colors.primary,
}}
thumbColor={value ? colors.background : colors.mutedForeground}
ios_backgroundColor={colors.muted}
{...props}
/>
);
}