export interface PenpotFile { id: string; name: string; revn: number; } export interface PenpotPage { id: string; name: string; getShapeById(id: string): PenpotShape | null; findShapes(): PenpotShape[]; } export type PenpotGradient = { type: 'linear' | 'radial'; startX: number; startY: number; endX: number; endY: number; width: number; stops: Array<{ color: string; opacity?: number; offset: number }>; }; export type PenpotImageData = { name?: string; width: number; height: number; mtype?: string; id: string; keepApectRatio?: boolean; }; export interface PenpotFill { fillColor?: string; fillOpacity?: number; fillColorGradient?: PenpotGradient; fillColorRefFile?: string; fillColorRefId?: string; fillImage?: PenpotImageData; } export type PenpotStrokeCap = | 'round' | 'square' | 'line-arrow' | 'triangle-arrow' | 'square-marker' | 'circle-marker' | 'diamond-marker'; export interface PenpotStroke { strokeColor?: string; strokeColorRefFile?: string; strokeColorRefId?: string; strokeOpacity?: number; strokeStyle?: 'solid' | 'dotted' | 'dashed' | 'mixed' | 'none' | 'svg'; strokeWidth?: number; strokeAlignment?: 'center' | 'inner' | 'outer'; strokeCapStart?: PenpotStrokeCap; strokeCapEnd?: PenpotStrokeCap; strokeColorGradient: PenpotGradient; } export interface PenpotColor { id: string; name?: string; path?: string; color?: string; opacity?: number; refId?: string; refFile?: string; gradient?: PenpotGradient; image?: PenpotImageData; } export interface PenpotShadow { id: string; style: 'drop-shadow' | 'inner-shadow'; offsetX: number; offsetY: number; blur: number; spread: number; hidden: boolean; color: PenpotColor; } export interface PenpotBlur { id: string; type: 'layer-blur'; value: number; hidden: boolean; } export interface PenpotFrameGuideColumnParams { color: { color: string; opacity: number }; type?: 'stretch' | 'left' | 'center' | 'right'; size?: number; margin?: number; itemLength?: number; gutter?: number; } export interface PenpotFrameGuideSquareParams { color: { color: string; opacity: number }; size?: number; } export interface PenpotFrameGuideColumn { type: 'column'; display: boolean; params: PenpotFrameGuideColumnParams; } export interface PenpotFrameGuideRow { type: 'row'; display: boolean; params: PenpotFrameGuideColumnParams; } export interface PenpotFrameGuideSquare { type: 'column'; display: boolean; params: PenpotFrameGuideSquareParams; } export type PenpotFrameGuide = | PenpotFrameGuideColumn | PenpotFrameGuideRow | PenpotFrameGuideSquare; export interface PenpotExport {} export type PenpotTrackType = 'flex' | 'fixed' | 'percent' | 'auto'; export interface PenpotTrack { type: PenpotTrackType; value: number | null; } export interface PenpotCommonLayout { alignItems?: 'start' | 'end' | 'center' | 'stretch'; alignContent?: | 'start' | 'end' | 'center' | 'space-between' | 'space-around' | 'space-evenly' | 'stretch'; justifyItems?: 'start' | 'end' | 'center' | 'stretch'; justifyContent?: | 'start' | 'center' | 'end' | 'space-between' | 'space-around' | 'space-evenly' | 'stretch'; rowGap: number; columnGap: number; verticalPadding: number; horizontalPadding: number; topPadding: number; rightPadding: number; bottomPadding: number; leftPadding: number; horizontalSizing: 'fit-content' | 'fill' | 'auto'; verticalSizing: 'fit-content' | 'fill' | 'auto'; remove(): void; } export interface PenpotGridLayout extends PenpotCommonLayout { dir: 'column' | 'row'; readonly rows: PenpotTrack[]; readonly columns: PenpotTrack[]; addRow(type: PenpotTrackType, value?: number): void; addRowAtIndex(index: number, type: PenpotTrackType, value?: number): void; addColumn(type: PenpotTrackType, value?: number): void; addColumnAtIndex(index: number, type: PenpotTrackType, value: number): void; removeRow(index: number): void; removeColumn(index: number): void; setColumn(index: number, type: PenpotTrackType, value?: number): void; setRow(index: number, type: PenpotTrackType, value?: number): void; appendChild(child: PenpotShape, row: number, column: number): void; } export interface PenpotFlexLayout extends PenpotCommonLayout { dir: 'row' | 'row-reverse' | 'column' | 'column-reverse'; wrap?: 'wrap' | 'nowrap'; appendChild(child: PenpotShape): void; } export interface PenpotShapeBase { id: string; name: string; x: number; y: number; width: number; height: number; blocked: boolean; hidden: boolean; proportionLock: boolean; constraintsHorizontal: 'left' | 'right' | 'leftright' | 'center' | 'scale'; constraintsVertical: 'top' | 'bottom' | 'topbottom' | 'center' | 'scale'; borderRadius: number; borderRadiusTopLeft: number; borderRadiusTopRight: number; borderRadiusBottomRight: number; borderRadiusBottomLeft: number; opacity: number; blendMode: | 'normal' | 'darken' | 'multiply' | 'color-burn' | 'lighten' | 'screen' | 'color-dodge' | 'overlay' | 'soft-light' | 'hard-light' | 'difference' | 'exclusion' | 'hue' | 'saturation' | 'color' | 'luminosity'; shadows: PenpotShadow[]; blur: PenpotBlur; exports: PenpotExport; // Relative positions frameX: number; frameY: number; parentX: number; parentY: number; flipX: boolean; flipY: boolean; fills: PenpotFill[]; strokes: PenpotStroke[]; readonly layoutChild?: { absolute: boolean; zIndex: number; horizontalSizing: 'auto' | 'fill' | 'fix'; verticalSizing: 'auto' | 'fill' | 'fix'; alignSelf: 'auto' | 'start' | 'center' | 'end' | 'stretch'; horizontalMargin: number; verticalMargin: number; topMargin: number; rightMargin: number; bottomMargin: number; leftMargin: number; maxWidth: number | null; maxHeight: number | null; minWidth: number | null; minHeight: number | null; }; readonly layoutCell?: { row?: number; rowSpan?: number; column?: number; columnSpan?: number; areaName?: string; position?: 'auto' | 'manual' | 'area'; }; resize(width: number, height: number): void; clone(): PenpotShape; remove(): void; } export interface PenpotFrame extends PenpotShapeBase { readonly type: 'frame'; readonly grid?: PenpotGridLayout; readonly flex?: PenpotFlexLayout; guides: PenpotFrameGuide; horizontalSizing?: 'auto' | 'fix'; verticalSizing?: 'auto' | 'fix'; // Container Properties readonly children: PenpotShape[]; appendChild(child: PenpotShape): void; insertChild(index: number, child: PenpotShape): void; // Grid layout addFlexLayout(): PenpotFlexLayout; addGridLayout(): PenpotGridLayout; } export interface PenpotGroup extends PenpotShapeBase { readonly type: 'group'; // Container Properties readonly children: PenpotShape[]; appendChild(child: PenpotShape): void; insertChild(index: number, child: PenpotShape): void; } export interface PenpotBool extends PenpotShapeBase { readonly type: 'bool'; // Container Properties readonly children: PenpotShape[]; appendChild(child: PenpotShape): void; insertChild(index: number, child: PenpotShape): void; } export interface PenpotRectangle extends PenpotShapeBase { readonly type: 'rect'; } export interface PenpotPath extends PenpotShapeBase { readonly type: 'rect'; } export interface PenpotText extends PenpotShapeBase { readonly type: 'text'; characters: string; growType: 'fixed' | 'auto-width' | 'auto-height'; } export interface PepotFrame extends PenpotShapeBase { readonly type: 'frame'; readonly children: PenpotShape[]; } export interface PenpotCircle extends PenpotShapeBase { type: 'circle'; } export interface PenpotSvgRaw extends PenpotShapeBase { type: 'svg-raw'; } export interface PenpotImage extends PenpotShapeBase { type: 'image'; } export type PenpotPoint = { x: number; y: number }; export type PenpotBounds = { x: number; y: number; width: number; height: number; }; export interface PenpotViewport { center: PenpotPoint; zoom: number; readonly bounds: PenpotBounds; } export type PenpotShape = | PenpotFrame | PenpotGroup | PenpotBool | PenpotRectangle | PenpotPath | PenpotText | PenpotCircle | PenpotSvgRaw | PenpotImage; export interface EventsMap { pagechange: PenpotPage; filechange: PenpotFile; selectionchange: string[]; themechange: PenpotTheme; } export type PenpotTheme = 'light' | 'dark'; export type PenpotLibraryColor = { name: string; color?: string; opacity?: number; asFill(): PenpotFill; asStroke(): PenpotStroke; }; export type PenpotLibraryTypography = { name: string; }; export type PenpotLibraryComponent = { name: string; }; export type PenpotLibrary = { colors: PenpotLibraryColor[]; typographies: PenpotLibraryTypography[]; components: PenpotLibraryComponent[]; }; export type PenpotLibraryContext = { local: PenpotLibrary; connected: PenpotLibrary[]; }; export interface PenpotContext { root: PenpotShape; currentPage: PenpotPage; selection: PenpotShape[]; viewport: PenpotViewport; library: PenpotLibraryContext; getFile(): PenpotFile | null; getPage(): PenpotPage | null; getSelected(): string[]; getSelectedShapes(): PenpotShape[]; getTheme(): PenpotTheme; uploadMediaUrl(name: string, url: string): Promise; group(first: PenpotShape, ...rest: PenpotShape[]): PenpotGroup; ungroup(first: PenpotShape, ...rest: PenpotShape[]): void; createRectangle(): PenpotRectangle; createFrame(): PenpotFrame; createShapeFromSvg(svgString: string): PenpotGroup; createText(text: string): PenpotText; addListener( type: T, callback: (event: EventsMap[T]) => void ): void; } /** * These are methods and properties available on the `penpot` global object. * */ export interface Penpot extends Omit { ui: { /** * Description of open * */ open: ( name: string, url: string, options?: { width: number; height: number } ) => void; /** * Description of sendMessage * */ sendMessage: (message: unknown) => void; /** * Description of onMessage * */ onMessage: (callback: (message: T) => void) => void; }; utils: { types: { isText(shape: PenpotShape): shape is PenpotText; isRectangle(shape: PenpotShape): shape is PenpotRectangle; isFrame(shape: PenpotShape): shape is PenpotFrame; }; }; /** * Description of setTimeout * */ setTimeout: (callback: () => void, time: number) => void; closePlugin: () => void; on: ( type: T, callback: (event: EventsMap[T]) => void ) => void; off: ( type: T, callback: (event: EventsMap[T]) => void ) => void; } declare global { const penpot: Penpot; }