1
0
Fork 0
mirror of https://github.com/portainer/portainer.git synced 2025-07-21 06:19:41 +02:00
portainer/app/react/components/form-components/Input/Select.tsx
Ali d38085a560
Some checks are pending
ci / build_images (map[arch:amd64 platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:amd64 platform:windows version:1809]) (push) Waiting to run
ci / build_images (map[arch:amd64 platform:windows version:ltsc2022]) (push) Waiting to run
ci / build_images (map[arch:arm platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:arm64 platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:ppc64le platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:s390x platform:linux version:]) (push) Waiting to run
ci / build_manifests (push) Blocked by required conditions
/ triage (push) Waiting to run
Lint / Run linters (push) Waiting to run
Test / test-client (push) Waiting to run
Test / test-server (map[arch:amd64 platform:linux]) (push) Waiting to run
Test / test-server (map[arch:amd64 platform:windows version:1809]) (push) Waiting to run
Test / test-server (map[arch:amd64 platform:windows version:ltsc2022]) (push) Waiting to run
Test / test-server (map[arch:arm64 platform:linux]) (push) Waiting to run
chore(data-cy): require data-cy attributes [EE-6880] (#11453)
2024-04-11 12:11:38 +12:00

42 lines
988 B
TypeScript

import clsx from 'clsx';
import { SelectHTMLAttributes } from 'react';
import { AutomationTestingProps } from '@/types';
export interface Option<T extends string | number>
extends Partial<AutomationTestingProps> {
value: T;
label: string;
disabled?: boolean;
}
interface Props<T extends string | number> extends AutomationTestingProps {
options: Option<T>[];
}
export function Select<T extends number | string>({
options,
className,
'data-cy': dataCy,
...props
}: Props<T> & SelectHTMLAttributes<HTMLSelectElement>) {
return (
<select
// eslint-disable-next-line react/jsx-props-no-spreading
{...props}
className={clsx('form-control', className)}
data-cy={dataCy}
>
{options.map((item) => (
<option
value={item.value}
key={item.value}
disabled={item.disabled}
data-cy={`${dataCy}-${item.value}`}
>
{item.label}
</option>
))}
</select>
);
}