mirror of
https://github.com/prymitive/karma
synced 2026-05-09 03:36:44 +00:00
57 lines
1.5 KiB
TypeScript
57 lines
1.5 KiB
TypeScript
import React, { FC } from "react";
|
|
|
|
import Creatable from "react-select/creatable";
|
|
|
|
import { useFetchGet } from "Hooks/useFetchGet";
|
|
import { FormatBackendURI } from "Stores/AlertStore";
|
|
import { Settings } from "Stores/Settings";
|
|
import { ThemeContext } from "Components/Theme";
|
|
import { NewLabelName, StringToOption } from "Common/Select";
|
|
|
|
const disabledLabel = "Disable multi-grid";
|
|
|
|
const valueToOption = (v: string) => ({
|
|
label: v ? v : disabledLabel,
|
|
value: v,
|
|
});
|
|
|
|
const staticValues = [
|
|
{ label: disabledLabel, value: "" },
|
|
{ label: "@alertmanager", value: "@alertmanager" },
|
|
{ label: "@cluster", value: "@cluster" },
|
|
{ label: "@receiver", value: "@receiver" },
|
|
];
|
|
|
|
const GridLabelName: FC<{
|
|
settingsStore: Settings;
|
|
}> = ({ settingsStore }) => {
|
|
const { response } = useFetchGet(FormatBackendURI(`labelNames.json`));
|
|
|
|
const context = React.useContext(ThemeContext);
|
|
|
|
return (
|
|
<Creatable
|
|
styles={context.reactSelectStyles}
|
|
classNamePrefix="react-select"
|
|
instanceId="configuration-grid-label"
|
|
formatCreateLabel={NewLabelName}
|
|
defaultValue={valueToOption(
|
|
settingsStore.multiGridConfig.config.gridLabel
|
|
)}
|
|
options={
|
|
response
|
|
? [
|
|
...staticValues,
|
|
...response.map((value: string) => StringToOption(value)),
|
|
]
|
|
: staticValues
|
|
}
|
|
onChange={({ value }) => {
|
|
settingsStore.multiGridConfig.config.gridLabel = value;
|
|
}}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export { GridLabelName };
|