UNPKG

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
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; }