2024-04-15 16:13:29 +02:00
|
|
|
export interface PenpotFile {
|
2024-02-28 12:54:37 +01:00
|
|
|
id: string;
|
2024-04-15 16:13:29 +02:00
|
|
|
name: string;
|
|
|
|
revn: number;
|
|
|
|
}
|
2024-04-12 10:45:39 +02:00
|
|
|
|
2024-04-15 16:13:29 +02:00
|
|
|
export interface PenpotPage {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
2024-04-18 17:11:48 +02:00
|
|
|
getShapeById(id: string): PenpotShape | null;
|
2024-04-12 10:45:39 +02:00
|
|
|
findShapes(): PenpotShape[];
|
2024-02-28 12:54:37 +01:00
|
|
|
}
|
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
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;
|
|
|
|
};
|
|
|
|
|
2024-04-15 16:13:29 +02:00
|
|
|
export interface PenpotFill {
|
2024-04-22 16:02:06 +02:00
|
|
|
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;
|
2024-04-15 16:13:29 +02:00
|
|
|
}
|
|
|
|
|
2024-05-08 16:56:34 +02:00
|
|
|
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 PenpotGridLayout {
|
|
|
|
dir: 'column' | 'row';
|
|
|
|
readonly rows: PenpotTrack[];
|
|
|
|
readonly columns: PenpotTrack[];
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
addRow(type: PenpotTrackType, value?: number);
|
|
|
|
addRowAtIndex(index: number, type: PenpotTrackType, value?: number);
|
|
|
|
addColumn(type: PenpotTrackType, value?: number);
|
|
|
|
addColumnAtIndex(index: number, type: PenpotTrackType, value: number);
|
|
|
|
removeRow(index: number);
|
|
|
|
removeColumn(index: number);
|
|
|
|
setColumn(index: number, type: PenpotTrackType, value?: number);
|
|
|
|
setRow(index: number, type: PenpotTrackType, value?: number);
|
|
|
|
|
|
|
|
appendChild(child: PenpotShape, row: number, column: number);
|
|
|
|
remove();
|
|
|
|
}
|
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
export interface PenpotShapeBase {
|
2024-02-28 12:54:37 +01:00
|
|
|
id: string;
|
2024-04-15 16:13:29 +02:00
|
|
|
name: string;
|
2024-04-22 16:02:06 +02:00
|
|
|
x: number;
|
|
|
|
y: number;
|
|
|
|
width: number;
|
|
|
|
height: number;
|
2024-04-22 16:02:06 +02:00
|
|
|
|
2024-05-08 16:56:34 +02:00
|
|
|
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;
|
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
fills: PenpotFill[];
|
|
|
|
strokes: PenpotStroke[];
|
2024-04-22 16:02:06 +02:00
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
resize(width: number, height: number);
|
2024-05-08 16:56:34 +02:00
|
|
|
clone(): PenpotShape;
|
|
|
|
remove();
|
2024-04-22 16:02:06 +02:00
|
|
|
}
|
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
export interface PenpotFrame extends PenpotShapeBase {
|
|
|
|
readonly type: 'frame';
|
|
|
|
readonly children: PenpotShape[];
|
2024-05-08 16:56:34 +02:00
|
|
|
readonly grid?: PenpotGridLayout;
|
|
|
|
guides: PenpotFrameGuide;
|
|
|
|
|
|
|
|
addGridLayout(): PenpotGridLayout;
|
2024-04-22 16:02:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface PenpotGroup extends PenpotShapeBase {
|
|
|
|
readonly type: 'group';
|
|
|
|
readonly children: PenpotShape[];
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface PenpotBool extends PenpotShapeBase {
|
|
|
|
readonly type: 'bool';
|
|
|
|
readonly children: PenpotShape[];
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
2024-05-08 16:56:34 +02:00
|
|
|
growType: 'fixed' | 'auto-width' | 'auto-height';
|
2024-04-22 16:02:06 +02:00
|
|
|
}
|
|
|
|
|
2024-05-07 10:28:40 +02:00
|
|
|
export interface PepotFrame extends PenpotShapeBase {
|
|
|
|
readonly type: 'frame';
|
|
|
|
readonly children: PenpotShape[];
|
|
|
|
}
|
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
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;
|
|
|
|
|
2024-03-27 13:57:02 +01:00
|
|
|
export interface EventsMap {
|
2024-04-12 10:45:39 +02:00
|
|
|
pagechange: PenpotPage;
|
|
|
|
filechange: PenpotFile;
|
2024-03-07 10:34:06 +01:00
|
|
|
selectionchange: string[];
|
2024-04-12 10:45:39 +02:00
|
|
|
themechange: PenpotTheme;
|
2024-02-27 14:50:38 +01:00
|
|
|
}
|
|
|
|
|
2024-04-12 10:45:39 +02:00
|
|
|
export type PenpotTheme = 'light' | 'dark';
|
2024-03-08 12:27:58 +01:00
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
export interface PenpotContext {
|
|
|
|
root: PenpotShape;
|
|
|
|
currentPage: PenpotPage;
|
|
|
|
selection: PenpotShape[];
|
2024-04-22 16:02:06 +02:00
|
|
|
viewport: PenpotViewport;
|
2024-04-22 16:02:06 +02:00
|
|
|
|
|
|
|
getFile(): PenpotFile | null;
|
|
|
|
getPage(): PenpotPage | null;
|
|
|
|
getSelected(): string[];
|
|
|
|
getSelectedShapes(): PenpotShape[];
|
|
|
|
getTheme(): PenpotTheme;
|
|
|
|
|
2024-04-29 12:24:38 +02:00
|
|
|
uploadMediaUrl(name: string, url: string): Promise<PenpotImageData>;
|
|
|
|
|
|
|
|
group(first: PenpotShape, ...rest: PenpotShape): PenpotGroup;
|
|
|
|
ungroup(first: PenpotShape, ...rest: PenpotShape);
|
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
createRectangle(): PenpotRectangle;
|
2024-05-08 16:56:34 +02:00
|
|
|
createFrame(): PenpotFrame;
|
2024-04-29 15:44:22 +02:00
|
|
|
createShapeFromSvg(svgString): PenpotGroup;
|
2024-05-08 16:56:34 +02:00
|
|
|
createText(text: string): PenpotText;
|
2024-04-22 16:02:06 +02:00
|
|
|
}
|
|
|
|
|
2024-04-22 16:02:06 +02:00
|
|
|
export interface Penpot extends PenpotContext {
|
2024-02-27 14:50:38 +01:00
|
|
|
ui: {
|
|
|
|
open: (
|
|
|
|
name: string,
|
|
|
|
url: string,
|
|
|
|
options: { width: number; height: number }
|
|
|
|
) => void;
|
|
|
|
sendMessage: (message: unknown) => void;
|
|
|
|
onMessage: <T>(callback: (message: T) => void) => void;
|
|
|
|
};
|
2024-04-22 16:02:06 +02:00
|
|
|
utils: {
|
|
|
|
types: {
|
|
|
|
isText(shape: PenpotShape): shape is PenpotText;
|
2024-04-29 12:24:38 +02:00
|
|
|
isRectangle(shape: PenpotShape): shape is PenpotRectangle;
|
|
|
|
isFrame(shape: PenpotShape): shape is PenpotFrame;
|
2024-04-22 16:02:06 +02:00
|
|
|
};
|
|
|
|
};
|
2024-02-27 14:50:38 +01:00
|
|
|
setTimeout: (callback: () => void, time: number) => void;
|
|
|
|
closePlugin: () => void;
|
|
|
|
on: <T extends keyof EventsMap>(
|
|
|
|
type: T,
|
|
|
|
callback: (event: EventsMap[T]) => void
|
|
|
|
) => void;
|
2024-02-28 12:54:37 +01:00
|
|
|
off: <T extends keyof EventsMap>(
|
|
|
|
type: T,
|
|
|
|
callback: (event: EventsMap[T]) => void
|
|
|
|
) => void;
|
2024-02-27 14:50:38 +01:00
|
|
|
}
|
|
|
|
|
2024-03-27 13:57:02 +01:00
|
|
|
declare global {
|
2024-02-27 14:50:38 +01:00
|
|
|
const penpot: Penpot;
|
|
|
|
}
|