mirror of
https://github.com/ajnart/homarr.git
synced 2025-11-10 23:45:48 +01:00
🔀 Merge pull request #280 from ajnart/ajnart/issue279
✨ Add support for lists in module option
This commit is contained in:
@@ -23,7 +23,7 @@ export default function DateComponent(props: any) {
|
|||||||
const [date, setDate] = useState(new Date());
|
const [date, setDate] = useState(new Date());
|
||||||
const setSafeInterval = useSetSafeInterval();
|
const setSafeInterval = useSetSafeInterval();
|
||||||
const { config } = useConfig();
|
const { config } = useConfig();
|
||||||
const isFullTime = config?.modules?.[DateModule.title]?.options?.full?.value ?? false;
|
const isFullTime = config?.modules?.[DateModule.title]?.options?.full?.value ?? true;
|
||||||
const formatString = isFullTime ? 'HH:mm' : 'h:mm A';
|
const formatString = isFullTime ? 'HH:mm' : 'h:mm A';
|
||||||
// Change date on minute change
|
// Change date on minute change
|
||||||
// Note: Using 10 000ms instead of 1000ms to chill a little :)
|
// Note: Using 10 000ms instead of 1000ms to chill a little :)
|
||||||
|
|||||||
@@ -1,10 +1,18 @@
|
|||||||
import { Button, Card, Group, Menu, Switch, TextInput, useMantineColorScheme } from '@mantine/core';
|
import {
|
||||||
|
Button,
|
||||||
|
Card,
|
||||||
|
Group,
|
||||||
|
Menu,
|
||||||
|
MultiSelect,
|
||||||
|
Switch,
|
||||||
|
TextInput,
|
||||||
|
useMantineColorScheme,
|
||||||
|
} from '@mantine/core';
|
||||||
import { useConfig } from '../../tools/state';
|
import { useConfig } from '../../tools/state';
|
||||||
import { IModule } from './modules';
|
import { IModule } from './modules';
|
||||||
|
|
||||||
function getItems(module: IModule) {
|
function getItems(module: IModule) {
|
||||||
const { config, setConfig } = useConfig();
|
const { config, setConfig } = useConfig();
|
||||||
const enabledModules = config.modules ?? {};
|
|
||||||
const items: JSX.Element[] = [];
|
const items: JSX.Element[] = [];
|
||||||
if (module.options) {
|
if (module.options) {
|
||||||
const keys = Object.keys(module.options);
|
const keys = Object.keys(module.options);
|
||||||
@@ -15,6 +23,38 @@ function getItems(module: IModule) {
|
|||||||
types.forEach((type, index) => {
|
types.forEach((type, index) => {
|
||||||
const optionName = `${module.title}.${keys[index]}`;
|
const optionName = `${module.title}.${keys[index]}`;
|
||||||
const moduleInConfig = config.modules?.[module.title];
|
const moduleInConfig = config.modules?.[module.title];
|
||||||
|
if (type === 'object') {
|
||||||
|
items.push(
|
||||||
|
<MultiSelect
|
||||||
|
label={module.options?.[keys[index]].name}
|
||||||
|
data={module.options?.[keys[index]].options ?? []}
|
||||||
|
defaultValue={
|
||||||
|
(moduleInConfig?.options?.[keys[index]]?.value as string[]) ??
|
||||||
|
(values[index].value as string[]) ??
|
||||||
|
[]
|
||||||
|
}
|
||||||
|
searchable
|
||||||
|
onChange={(value) => {
|
||||||
|
setConfig({
|
||||||
|
...config,
|
||||||
|
modules: {
|
||||||
|
...config.modules,
|
||||||
|
[module.title]: {
|
||||||
|
...moduleInConfig,
|
||||||
|
options: {
|
||||||
|
...moduleInConfig?.options,
|
||||||
|
[keys[index]]: {
|
||||||
|
...moduleInConfig?.options?.[keys[index]],
|
||||||
|
value,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
if (type === 'string') {
|
if (type === 'string') {
|
||||||
items.push(
|
items.push(
|
||||||
<form
|
<form
|
||||||
@@ -44,7 +84,11 @@ function getItems(module: IModule) {
|
|||||||
id={optionName}
|
id={optionName}
|
||||||
name={optionName}
|
name={optionName}
|
||||||
label={values[index].name}
|
label={values[index].name}
|
||||||
defaultValue={(moduleInConfig?.options?.[keys[index]]?.value as string) ?? ''}
|
defaultValue={
|
||||||
|
(moduleInConfig?.options?.[keys[index]]?.value as string) ??
|
||||||
|
(values[index].value as string) ??
|
||||||
|
''
|
||||||
|
}
|
||||||
onChange={(e) => {}}
|
onChange={(e) => {}}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
@@ -59,7 +103,9 @@ function getItems(module: IModule) {
|
|||||||
<Switch
|
<Switch
|
||||||
defaultChecked={
|
defaultChecked={
|
||||||
// Set default checked to the value of the option if it exists
|
// Set default checked to the value of the option if it exists
|
||||||
(moduleInConfig?.options?.[keys[index]]?.value as boolean) ?? false
|
(moduleInConfig?.options?.[keys[index]]?.value as boolean) ??
|
||||||
|
(values[index].value as boolean) ??
|
||||||
|
false
|
||||||
}
|
}
|
||||||
key={keys[index]}
|
key={keys[index]}
|
||||||
onClick={(e) => {
|
onClick={(e) => {
|
||||||
|
|||||||
@@ -16,5 +16,6 @@ interface Option {
|
|||||||
|
|
||||||
export interface OptionValues {
|
export interface OptionValues {
|
||||||
name: string;
|
name: string;
|
||||||
value: boolean | string;
|
value: boolean | string | string[];
|
||||||
|
options?: string[];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ export const WeatherModule: IModule = {
|
|||||||
},
|
},
|
||||||
location: {
|
location: {
|
||||||
name: 'Current location',
|
name: 'Current location',
|
||||||
value: '',
|
value: 'Paris',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@@ -135,7 +135,7 @@ export default function WeatherComponent(props: any) {
|
|||||||
const { config } = useConfig();
|
const { config } = useConfig();
|
||||||
const [weather, setWeather] = useState({} as WeatherResponse);
|
const [weather, setWeather] = useState({} as WeatherResponse);
|
||||||
const cityInput: string =
|
const cityInput: string =
|
||||||
(config?.modules?.[WeatherModule.title]?.options?.location?.value as string) ?? '';
|
(config?.modules?.[WeatherModule.title]?.options?.location?.value as string) ?? 'Paris';
|
||||||
const isFahrenheit: boolean =
|
const isFahrenheit: boolean =
|
||||||
(config?.modules?.[WeatherModule.title]?.options?.freedomunit?.value as boolean) ?? false;
|
(config?.modules?.[WeatherModule.title]?.options?.freedomunit?.value as boolean) ?? false;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user