bigbluebutton-html-plugin-sdk
Version:
This repository contains the SDK for developing BigBlueButton plugins. Plugins are React components that can be loaded from external sources by the BigBlueButton HTML5 client to extend its functionalities.
59 lines (58 loc) • 1.74 kB
TypeScript
import { ChangeEvent, MouseEvent } from 'react';
import { PluginProvidedUiItemDescriptor } from '../base';
import { ActionsBarItemType, ActionsBarPosition } from './enums';
import { PluginIconType } from '../common/icon';
/**
* Interface for the generic Actions bar item. (`position` is mandatory)
*/
export interface ActionsBarInterface extends PluginProvidedUiItemDescriptor {
position: ActionsBarPosition;
}
export interface ActionsBarItemProps {
id?: string;
position: ActionsBarPosition;
type: ActionsBarItemType;
dataTest?: string;
}
export interface ActionsBarButtonProps {
id?: string;
icon: PluginIconType;
tooltip: string;
position: ActionsBarPosition;
dataTest?: string;
onClick: () => void;
color?: string;
}
export interface ActionsBarSeparatorProps {
position: ActionsBarPosition;
icon?: PluginIconType;
dataTest?: string;
}
export interface SelectOption {
value: string | number;
label: string;
dataTest?: string;
}
export interface ToggleGroupOption extends SelectOption {
dataTest?: string;
}
export interface ActionsBarSelectorProps {
id?: string;
title: string;
options: SelectOption[];
defaultOption?: SelectOption;
onChange: (value: string | number, event: ChangeEvent<HTMLInputElement>) => void;
position: ActionsBarPosition;
width?: number;
dataTest?: string;
}
export interface ActionsBarToggleGroupProps {
id?: string;
title: string;
options: ToggleGroupOption[];
defaultOption?: ToggleGroupOption;
exclusive?: boolean;
onChange: (values: string | number | string[] | number[], event: MouseEvent<HTMLElement>) => void;
position: ActionsBarPosition;
dataTest?: string;
}