You've already forked joplin
mirror of
https://github.com/laurent22/joplin.git
synced 2025-11-26 22:41:17 +02:00
139 lines
4.1 KiB
TypeScript
139 lines
4.1 KiB
TypeScript
import * as React from 'react';
|
|
|
|
import { UpdateSettingValueCallback } from './types';
|
|
import { View, Text } from 'react-native';
|
|
import Setting, { AppType } from '@joplin/lib/models/Setting';
|
|
import Dropdown from '../../Dropdown';
|
|
import { ConfigScreenStyles } from './configScreenStyles';
|
|
import SettingsToggle from './SettingsToggle';
|
|
import FileSystemPathSelector from './FileSystemPathSelector';
|
|
import ValidatedIntegerInput from './ValidatedIntegerInput';
|
|
import SettingTextInput from './SettingTextInput';
|
|
import shim from '@joplin/lib/shim';
|
|
import { themeStyle } from '../../global-style';
|
|
|
|
interface Props {
|
|
settingId: string;
|
|
|
|
// The value associated with the given settings key
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
|
value: any;
|
|
|
|
styles: ConfigScreenStyles;
|
|
themeId: number;
|
|
|
|
updateSettingValue: UpdateSettingValueCallback;
|
|
}
|
|
|
|
|
|
const SettingComponent: React.FunctionComponent<Props> = props => {
|
|
const themeId = props.themeId;
|
|
const theme = themeStyle(themeId);
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
|
const output: any = null;
|
|
|
|
const md = Setting.settingMetadata(props.settingId);
|
|
const settingDescription = md.description ? md.description(AppType.Mobile) : '';
|
|
|
|
const styleSheet = props.styles.styleSheet;
|
|
|
|
const descriptionComp = !settingDescription ? null : <Text style={styleSheet.settingDescriptionText}>{settingDescription}</Text>;
|
|
const containerStyles = props.styles.getContainerStyle(!!settingDescription);
|
|
|
|
if (md.isEnum) {
|
|
const value = props.value?.toString();
|
|
|
|
const items = Setting.enumOptionsToValueLabels(md.options(), md.optionsOrder ? md.optionsOrder() : []);
|
|
const label = md.label();
|
|
|
|
return (
|
|
<View key={props.settingId} style={containerStyles.outerContainer}>
|
|
<View style={containerStyles.innerContainer}>
|
|
<Text key="label" style={styleSheet.settingText}>
|
|
{label}
|
|
</Text>
|
|
<Dropdown
|
|
key="control"
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
|
items={items as any}
|
|
selectedValue={value}
|
|
itemListStyle={{
|
|
backgroundColor: theme.backgroundColor,
|
|
}}
|
|
headerStyle={{
|
|
color: theme.color,
|
|
fontSize: theme.fontSize,
|
|
}}
|
|
itemStyle={{
|
|
color: theme.color,
|
|
fontSize: theme.fontSize,
|
|
}}
|
|
onValueChange={(itemValue: string) => {
|
|
void props.updateSettingValue(props.settingId, itemValue);
|
|
}}
|
|
accessibilityHint={label}
|
|
/>
|
|
</View>
|
|
{descriptionComp}
|
|
</View>
|
|
);
|
|
} else if (md.type === Setting.TYPE_BOOL) {
|
|
return (
|
|
<SettingsToggle
|
|
settingId={props.settingId}
|
|
value={props.value}
|
|
themeId={props.themeId}
|
|
styles={props.styles}
|
|
label={md.label()}
|
|
updateSettingValue={props.updateSettingValue}
|
|
description={descriptionComp}
|
|
/>
|
|
);
|
|
} else if (md.type === Setting.TYPE_INT) {
|
|
return (
|
|
<ValidatedIntegerInput
|
|
settingId={props.settingId}
|
|
value={props.value}
|
|
themeId={props.themeId}
|
|
styles={props.styles}
|
|
label={md.label()}
|
|
updateSettingValue={props.updateSettingValue}
|
|
description={descriptionComp}
|
|
/>
|
|
);
|
|
} else if (md.type === Setting.TYPE_STRING) {
|
|
if (['sync.2.path', 'plugins.devPluginPaths'].includes(md.key) && (shim.fsDriver().isUsingAndroidSAF() || shim.mobilePlatform() === 'web')) {
|
|
return (
|
|
<FileSystemPathSelector
|
|
themeId={props.themeId}
|
|
mode={md.key === 'sync.2.path' ? 'readwrite' : 'read'}
|
|
styles={props.styles}
|
|
settingMetadata={md}
|
|
updateSettingValue={props.updateSettingValue}
|
|
description={descriptionComp}
|
|
/>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<SettingTextInput
|
|
settingId={props.settingId}
|
|
value={props.value}
|
|
themeId={props.themeId}
|
|
styles={props.styles}
|
|
label={md.label()}
|
|
updateSettingValue={props.updateSettingValue}
|
|
description={descriptionComp}
|
|
/>
|
|
);
|
|
} else if (md.type === Setting.TYPE_BUTTON) {
|
|
// TODO: Not yet supported
|
|
} else if (Setting.value('env') === 'dev') {
|
|
throw new Error(`Unsupported setting type: ${md.type}`);
|
|
}
|
|
|
|
return output;
|
|
};
|
|
|
|
export default SettingComponent;
|