38 lines
1.1 KiB
TypeScript
38 lines
1.1 KiB
TypeScript
import { View, type ViewProps } from 'react-native';
|
|
|
|
import { useThemeColor } from '@/hooks/use-theme-color';
|
|
|
|
export type ThemedViewProps = ViewProps & {
|
|
lightColor?: string;
|
|
darkColor?: string;
|
|
lvl?:number;
|
|
border?:number;
|
|
};
|
|
|
|
export function ThemedView({ style, lightColor, darkColor,lvl=1,border=-1, ...otherProps }: ThemedViewProps) {
|
|
var lvlStr:string = "background";
|
|
var borderColor ="";
|
|
if(lvl>=0 && lvl<6){
|
|
lvlStr+=lvl;
|
|
}
|
|
else lvlStr+='5';
|
|
|
|
const backgroundColor = useThemeColor({ light: lightColor, dark: darkColor },lvlStr as 'background0'|'background1'|'background2'|'background3'|'background4'|'background5');
|
|
|
|
|
|
if(border!=-1){
|
|
var borderStr = "";
|
|
if(border>=0 && border<6){
|
|
borderStr="background"+border;
|
|
borderColor = useThemeColor({ light: lightColor, dark: darkColor },borderStr as 'background0'|'background1'|'background2'|'background3'|'background4'|'background5');
|
|
}
|
|
else{
|
|
borderColor = backgroundColor
|
|
}
|
|
}
|
|
|
|
|
|
|
|
return <View style={[{ backgroundColor, borderColor }, style]} {...otherProps} />;
|
|
}
|