0
Fork 0
mirror of https://github.com/penpot/penpot-plugins.git synced 2025-01-22 14:49:27 -05:00

feat(plugin-types): add connect libraries and generate code

This commit is contained in:
alonso.torres 2024-06-24 14:31:53 +02:00 committed by Alonso Torres
parent 00772613eb
commit ffa5156fac
2 changed files with 92 additions and 6 deletions

View file

@ -1868,6 +1868,33 @@ export interface PenpotLibraryComponent extends PenpotLibraryElement {
mainInstance: PenpotShape; mainInstance: PenpotShape;
} }
export interface PenpotLibrarySummary {
/**
* TODO id
*/
readonly id: string;
/**
* TODO name
*/
readonly name: string;
/**
* TODO numColors
*/
readonly numColors: number;
/**
* TODO numComponents
*/
readonly numComponents: number;
/**
* TODO numTypographies
*/
readonly numTypographies: number;
}
/** /**
* Represents a library in Penpot, containing colors, typographies, and components. * Represents a library in Penpot, containing colors, typographies, and components.
* This type provides methods to create new color, typography, and component elements within the library. * This type provides methods to create new color, typography, and component elements within the library.
@ -1942,7 +1969,7 @@ export type PenpotLibraryContext = {
* const localLibrary = libraryContext.local; * const localLibrary = libraryContext.local;
* ``` * ```
*/ */
local: PenpotLibrary; readonly local: PenpotLibrary;
/** /**
* An array of connected libraries in the Penpot context. * An array of connected libraries in the Penpot context.
@ -1951,7 +1978,17 @@ export type PenpotLibraryContext = {
* const connectedLibraries = libraryContext.connected; * const connectedLibraries = libraryContext.connected;
* ``` * ```
*/ */
connected: PenpotLibrary[]; readonly connected: PenpotLibrary[];
/**
* TODO: availableLibraries
*/
availableLibraries(): Promise<PenpotLibrarySummary[]>;
/**
* TODO: linkToFile
*/
connectLibrary(libraryId: string): Promise<PenpotLibrary>;
}; };
/** /**
@ -2335,6 +2372,32 @@ export interface PenpotContext {
*/ */
createText(text: string): PenpotText | null; createText(text: string): PenpotText | null;
/**
*
* @param shapes
* @param markupType will default to 'html'
*/
generateMarkup(
shapes: PenpotShape[],
options?: { type?: 'html' | 'svg' }
): string;
/**
*
* @param shapes
* @param styleType will default to 'css'
* @param withPrelude will default to `false`
* @param includeChildren will default to `true`
*/
generateStyle(
shapes: PenpotShape[],
options?: {
type?: 'css';
withPrelude?: boolean;
includeChildren?: boolean;
}
): string;
// Event listeners // Event listeners
addListener<T extends keyof EventsMap>( addListener<T extends keyof EventsMap>(
type: T, type: T,

View file

@ -275,7 +275,7 @@ export function createApi(context: PenpotContext, manifest: Manifest): Penpot {
return context.createEllipse(); return context.createEllipse();
}, },
createText(text: string): PenpotText { createText(text: string): PenpotText | null {
// checkPermission('page:write'); // checkPermission('page:write');
return context.createText(text); return context.createText(text);
}, },
@ -285,17 +285,20 @@ export function createApi(context: PenpotContext, manifest: Manifest): Penpot {
return context.createPath(); return context.createPath();
}, },
createBoolean(boolType: PenpotBoolType, shapes: PenpotShape[]): PenpotBool { createBoolean(
boolType: PenpotBoolType,
shapes: PenpotShape[]
): PenpotBool | null {
// checkPermission('page:write'); // checkPermission('page:write');
return context.createBoolean(boolType, shapes); return context.createBoolean(boolType, shapes);
}, },
createShapeFromSvg(svgString: string): PenpotGroup { createShapeFromSvg(svgString: string): PenpotGroup | null {
// checkPermission('page:write'); // checkPermission('page:write');
return context.createShapeFromSvg(svgString); return context.createShapeFromSvg(svgString);
}, },
group(shapes: PenpotShape[]): PenpotGroup { group(shapes: PenpotShape[]): PenpotGroup | null {
// checkPermission('page:write'); // checkPermission('page:write');
return context.group(shapes); return context.group(shapes);
}, },
@ -312,6 +315,26 @@ export function createApi(context: PenpotContext, manifest: Manifest): Penpot {
uploadMediaData(name: string, data: Uint8Array, mimeType: string) { uploadMediaData(name: string, data: Uint8Array, mimeType: string) {
return context.uploadMediaData(name, data, mimeType); return context.uploadMediaData(name, data, mimeType);
}, },
generateMarkup(
shapes: PenpotShape[],
options?: { type?: 'html' | 'svg' }
): string {
// checkPermission('page:write');
return context.generateMarkup(shapes, options);
},
generateStyle(
shapes: PenpotShape[],
options?: {
type?: 'css';
withPrelude?: boolean;
includeChildren?: boolean;
}
): string {
// checkPermission('page:write');
return context.generateStyle(shapes, options);
},
}; };
return penpot; return penpot;