mirror of
https://github.com/grafana/grafana.git
synced 2025-09-19 22:52:51 +08:00

* remove metadata for single folder listing * extendTests * remove ac metadata from dash and folder search results * remove test * remove one more test * put ac metadata back for single folder API responses * extend tests * remove ac metadata from folder frontend object * undo unneeded change * PR feedback Co-authored-by: Gabriel MABILLE <gamab@users.noreply.github.com> --------- Co-authored-by: Gabriel MABILLE <gamab@users.noreply.github.com>
79 lines
2.3 KiB
TypeScript
79 lines
2.3 KiB
TypeScript
import { css } from '@emotion/css';
|
|
import React from 'react';
|
|
|
|
import { GrafanaTheme2 } from '@grafana/data';
|
|
import { Stack } from '@grafana/experimental';
|
|
import { Icon, Tooltip, useStyles2 } from '@grafana/ui';
|
|
import { FolderPicker, Props as FolderPickerProps } from 'app/core/components/Select/FolderPicker';
|
|
import { PermissionLevelString, SearchQueryType } from 'app/types';
|
|
|
|
import { FolderWarning, CustomAdd } from '../../../../../core/components/Select/FolderPicker';
|
|
|
|
export interface Folder {
|
|
title: string;
|
|
uid: string;
|
|
}
|
|
|
|
export interface RuleFolderPickerProps extends Omit<FolderPickerProps, 'initialTitle' | 'initialFolderId'> {
|
|
value?: Folder;
|
|
}
|
|
|
|
const SlashesWarning = () => {
|
|
const styles = useStyles2(getStyles);
|
|
const onClick = () => window.open('https://github.com/grafana/grafana/issues/42947', '_blank');
|
|
return (
|
|
<Stack gap={0.5}>
|
|
<div className={styles.slashNotAllowed}>Folders with '/' character are not allowed.</div>
|
|
<Tooltip placement="top" content={'Link to the Github issue'} theme="info">
|
|
<Icon name="info-circle" size="xs" className={styles.infoIcon} onClick={onClick} />
|
|
</Tooltip>
|
|
</Stack>
|
|
);
|
|
};
|
|
|
|
export const containsSlashes = (str: string): boolean => str.indexOf('/') !== -1;
|
|
|
|
export function RuleFolderPicker(props: RuleFolderPickerProps) {
|
|
const { value } = props;
|
|
const warningCondition = (folderName: string) => containsSlashes(folderName);
|
|
|
|
const folderWarning: FolderWarning = {
|
|
warningCondition: warningCondition,
|
|
warningComponent: SlashesWarning,
|
|
};
|
|
|
|
const customAdd: CustomAdd = {
|
|
disallowValues: true,
|
|
isAllowedValue: (value) => !containsSlashes(value),
|
|
};
|
|
|
|
return (
|
|
<FolderPicker
|
|
showRoot={false}
|
|
rootName=""
|
|
allowEmpty={true}
|
|
initialTitle={value?.title}
|
|
initialFolderUid={value?.uid}
|
|
searchQueryType={SearchQueryType.AlertFolder}
|
|
{...props}
|
|
permissionLevel={PermissionLevelString.Edit}
|
|
customAdd={customAdd}
|
|
folderWarning={folderWarning}
|
|
/>
|
|
);
|
|
}
|
|
|
|
const getStyles = (theme: GrafanaTheme2) => ({
|
|
slashNotAllowed: css`
|
|
color: ${theme.colors.warning.main};
|
|
font-size: 12px;
|
|
margin-bottom: 2px;
|
|
`,
|
|
infoIcon: css`
|
|
color: ${theme.colors.warning.main};
|
|
font-size: 12px;
|
|
margin-bottom: 2px;
|
|
cursor: pointer;
|
|
`,
|
|
});
|