mirror of
https://github.com/GraphiteEditor/Graphite.git
synced 2025-12-23 10:11:54 +00:00
79 lines
1.7 KiB
TypeScript
79 lines
1.7 KiB
TypeScript
export type Widgets = IconButtonWidget | SeparatorWidget | PopoverButtonWidget | NumberInputWidget;
|
|
export type WidgetRow = Array<Widgets>;
|
|
export type WidgetLayout = Array<WidgetRow>;
|
|
|
|
// Icon Button
|
|
export interface IconButtonWidget {
|
|
kind: "IconButton";
|
|
tooltip?: string;
|
|
message?: string | object;
|
|
callback?: Function;
|
|
props: IconButtonProps;
|
|
}
|
|
|
|
export interface IconButtonProps {
|
|
// `action` is used via `IconButtonWidget.callback`
|
|
icon: string;
|
|
size: number;
|
|
gapAfter?: boolean;
|
|
}
|
|
|
|
// Popover Button
|
|
export interface PopoverButtonWidget {
|
|
kind: "PopoverButton";
|
|
tooltip?: string;
|
|
callback?: Function;
|
|
// popover: WidgetLayout;
|
|
popover: { title: string; text: string }; // TODO: Replace this with a `WidgetLayout` like above for arbitrary layouts
|
|
props: PopoverButtonProps;
|
|
}
|
|
|
|
export interface PopoverButtonProps {
|
|
// `action` is used via `PopoverButtonWidget.callback`
|
|
icon?: string;
|
|
}
|
|
|
|
// Number Input
|
|
export interface NumberInputWidget {
|
|
kind: "NumberInput";
|
|
tooltip?: string;
|
|
callback?: Function;
|
|
props: NumberInputProps;
|
|
}
|
|
|
|
export interface NumberInputProps {
|
|
value: number;
|
|
min?: number;
|
|
max?: number;
|
|
step?: number;
|
|
stepIsMultiplier?: boolean;
|
|
isInteger?: boolean;
|
|
unit?: string;
|
|
unitIsHiddenWhenEditing?: boolean;
|
|
displayDecimalPlaces?: number;
|
|
label?: string;
|
|
disabled?: boolean;
|
|
}
|
|
|
|
// Separator
|
|
export interface SeparatorWidget {
|
|
kind: "Separator";
|
|
props: SeparatorProps;
|
|
}
|
|
|
|
export interface SeparatorProps {
|
|
direction?: SeparatorDirection;
|
|
type?: SeparatorType;
|
|
}
|
|
|
|
export enum SeparatorDirection {
|
|
"Horizontal" = "Horizontal",
|
|
"Vertical" = "Vertical",
|
|
}
|
|
|
|
export enum SeparatorType {
|
|
"Related" = "Related",
|
|
"Unrelated" = "Unrelated",
|
|
"Section" = "Section",
|
|
"List" = "List",
|
|
}
|