mirror of
https://github.com/SteamDeckHomebrew/decky-frontend-lib.git
synced 2026-05-20 10:00:08 +02:00
48 lines
1.4 KiB
TypeScript
48 lines
1.4 KiB
TypeScript
import { ReactNode, FC } from 'react';
|
|
|
|
import { CommonUIModule } from '../webpack';
|
|
import { ItemProps } from './Item';
|
|
import { createPropListRegex } from '../utils';
|
|
import type { ContextMenuPositionOptions } from './Menu';
|
|
|
|
export interface SingleDropdownOption {
|
|
data: any;
|
|
label: ReactNode;
|
|
|
|
options?: never;
|
|
}
|
|
|
|
export interface MultiDropdownOption {
|
|
label: ReactNode;
|
|
options: DropdownOption[];
|
|
|
|
data?: never;
|
|
}
|
|
|
|
export type DropdownOption = SingleDropdownOption | MultiDropdownOption;
|
|
|
|
export interface DropdownProps {
|
|
rgOptions: DropdownOption[];
|
|
selectedOption: any;
|
|
disabled?: boolean;
|
|
onMenuWillOpen?(showMenu: () => void): void;
|
|
onMenuOpened?(): void;
|
|
onChange?(data: SingleDropdownOption): void;
|
|
contextMenuPositionOptions?: ContextMenuPositionOptions;
|
|
menuLabel?: string;
|
|
strDefaultLabel?: string;
|
|
renderButtonValue?(element: ReactNode): ReactNode;
|
|
focusable?: boolean;
|
|
}
|
|
|
|
export const Dropdown = Object.values(CommonUIModule).find(
|
|
(mod: any) => mod?.prototype?.SetSelectedOption && mod?.prototype?.BuildMenu,
|
|
) as FC<DropdownProps>;
|
|
|
|
export interface DropdownItemProps extends DropdownProps, ItemProps {}
|
|
|
|
const dropdownItemRegex = createPropListRegex(["dropDownControlRef", "description"], false);
|
|
export const DropdownItem = Object.values(CommonUIModule).find((mod: any) =>
|
|
mod?.toString && dropdownItemRegex.test(mod.toString()),
|
|
) as FC<DropdownItemProps>;
|