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 ruler guides and new zoom methods

This commit is contained in:
alonso.torres 2024-09-04 09:16:15 +02:00 committed by Alonso Torres
parent 3bfa2a5c22
commit c8066becca
5 changed files with 22 additions and 25 deletions

View file

@ -354,7 +354,7 @@ export interface Page extends PluginData {
/** /**
* Removes the `guide` from the current page. * Removes the `guide` from the current page.
*/ */
removeRulerGuide(guide: RulerGuide); removeRulerGuide(guide: RulerGuide): void;
} }
/** /**
@ -1845,7 +1845,7 @@ export interface Board extends ShapeBase {
/** /**
* Removes the `guide` from the current page. * Removes the `guide` from the current page.
*/ */
removeRulerGuide(guide: RulerGuide); removeRulerGuide(guide: RulerGuide): void;
} }
/** /**
@ -2312,18 +2312,18 @@ export interface Viewport {
/** /**
* Resets the zoom level. * Resets the zoom level.
*/ */
zoomReset(); zoomReset(): void;
/** /**
* Changes the viewport and zoom so can fit all the current shapes in the page. * Changes the viewport and zoom so can fit all the current shapes in the page.
*/ */
zoomToFitAll(); zoomToFitAll(): void;
/** /**
* Changes the viewport and zoom so all the `shapes` in the argument are * Changes the viewport and zoom so all the `shapes` in the argument are
* visible. * visible.
*/ */
zoomToShapes(shapes: Shape[]); zoomToShapes(shapes: Shape[]): void;
} }
/** /**
@ -2341,7 +2341,7 @@ export interface Viewport {
export type Shape = export type Shape =
| Board | Board
| Group | Group
| Bool | Boolean
| Rectangle | Rectangle
| Path | Path
| Text | Text
@ -3363,7 +3363,7 @@ export interface Context {
* const booleanShape = context.createBoolean('union', [shape1, shape2]); * const booleanShape = context.createBoolean('union', [shape1, shape2]);
* ``` * ```
*/ */
createBoolean(boolType: BooleanType, shapes: Shape[]): Bool | null; createBoolean(boolType: BooleanType, shapes: Shape[]): Boolean | null;
/** /**
* Creates a Group from an SVG string. Requires `content:write` permission. * Creates a Group from an SVG string. Requires `content:write` permission.
* @param svgString The SVG string representing the shapes to be converted into a group. * @param svgString The SVG string representing the shapes to be converted into a group.
@ -3861,7 +3861,7 @@ export interface ContextTypesUtils {
* @param shape - The shape to check. * @param shape - The shape to check.
* @return Returns true if the shape is a Bool, otherwise false. * @return Returns true if the shape is a Bool, otherwise false.
*/ */
isBool(shape: Shape): shape is Bool; isBool(shape: Shape): shape is Boolean;
/** /**
* Checks if the given shape is a rectangle. * Checks if the given shape is a rectangle.

View file

@ -2,7 +2,7 @@ import { describe, it, vi, expect, beforeEach, afterEach } from 'vitest';
import { createPlugin } from './create-plugin'; import { createPlugin } from './create-plugin';
import { createPluginManager } from './plugin-manager.js'; import { createPluginManager } from './plugin-manager.js';
import { createSandbox } from './create-sandbox.js'; import { createSandbox } from './create-sandbox.js';
import type { PenpotContext } from '@penpot/plugin-types'; import type { Context } from '@penpot/plugin-types';
import type { Manifest } from './models/manifest.model.js'; import type { Manifest } from './models/manifest.model.js';
vi.mock('./plugin-manager.js', () => ({ vi.mock('./plugin-manager.js', () => ({
@ -14,7 +14,7 @@ vi.mock('./create-sandbox.js', () => ({
})); }));
describe('createPlugin', () => { describe('createPlugin', () => {
let mockContext: PenpotContext; let mockContext: Context;
let manifest: Manifest; let manifest: Manifest;
let onCloseCallback: ReturnType<typeof vi.fn>; let onCloseCallback: ReturnType<typeof vi.fn>;
let mockPluginManager: Awaited<ReturnType<typeof createPluginManager>>; let mockPluginManager: Awaited<ReturnType<typeof createPluginManager>>;
@ -59,7 +59,7 @@ describe('createPlugin', () => {
addListener: vi.fn(), addListener: vi.fn(),
removeListener: vi.fn(), removeListener: vi.fn(),
getTheme: vi.fn().mockReturnValue('light'), getTheme: vi.fn().mockReturnValue('light'),
} as unknown as PenpotContext; } as unknown as Context;
onCloseCallback = vi.fn(); onCloseCallback = vi.fn();

View file

@ -1,10 +1,10 @@
import type { PenpotContext } from '@penpot/plugin-types'; import type { Context } from '@penpot/plugin-types';
import type { Manifest } from './models/manifest.model.js'; import type { Manifest } from './models/manifest.model.js';
import { createPluginManager } from './plugin-manager.js'; import { createPluginManager } from './plugin-manager.js';
import { createSandbox } from './create-sandbox.js'; import { createSandbox } from './create-sandbox.js';
export async function createPlugin( export async function createPlugin(
context: PenpotContext, context: Context,
manifest: Manifest, manifest: Manifest,
onCloseCallback: () => void onCloseCallback: () => void
) { ) {

View file

@ -3,7 +3,7 @@ import { createPluginManager } from './plugin-manager';
import { loadManifestCode, getValidUrl } from './parse-manifest.js'; import { loadManifestCode, getValidUrl } from './parse-manifest.js';
import { PluginModalElement } from './modal/plugin-modal.js'; import { PluginModalElement } from './modal/plugin-modal.js';
import { openUIApi } from './api/openUI.api.js'; import { openUIApi } from './api/openUI.api.js';
import type { PenpotContext, PenpotTheme } from '@penpot/plugin-types'; import type { Context, Theme } from '@penpot/plugin-types';
import type { Manifest } from './models/manifest.model.js'; import type { Manifest } from './models/manifest.model.js';
vi.mock('./parse-manifest.js', () => ({ vi.mock('./parse-manifest.js', () => ({
@ -16,7 +16,7 @@ vi.mock('./api/openUI.api.js', () => ({
})); }));
describe('createPluginManager', () => { describe('createPluginManager', () => {
let mockContext: PenpotContext; let mockContext: Context;
let manifest: Manifest; let manifest: Manifest;
let onCloseCallback: ReturnType<typeof vi.fn>; let onCloseCallback: ReturnType<typeof vi.fn>;
let onReloadModal: ReturnType<typeof vi.fn>; let onReloadModal: ReturnType<typeof vi.fn>;
@ -59,7 +59,7 @@ describe('createPluginManager', () => {
addListener: vi.fn().mockReturnValue(Symbol()), addListener: vi.fn().mockReturnValue(Symbol()),
removeListener: vi.fn(), removeListener: vi.fn(),
getTheme: vi.fn().mockReturnValue('light'), getTheme: vi.fn().mockReturnValue('light'),
} as unknown as PenpotContext; } as unknown as Context;
onCloseCallback = vi.fn(); onCloseCallback = vi.fn();
onReloadModal = vi.fn(); onReloadModal = vi.fn();
@ -159,7 +159,7 @@ describe('createPluginManager', () => {
throw new Error('Theme change callback not found'); throw new Error('Theme change callback not found');
} }
themeChangeCallback('dark' as PenpotTheme); themeChangeCallback('dark' as Theme);
expect(mockModal.setTheme).toHaveBeenCalledWith('dark'); expect(mockModal.setTheme).toHaveBeenCalledWith('dark');
}); });

View file

@ -1,4 +1,4 @@
import type { PenpotContext, PenpotTheme } from '@penpot/plugin-types'; import type { Context, Theme } from '@penpot/plugin-types';
import { getValidUrl, loadManifestCode } from './parse-manifest.js'; import { getValidUrl, loadManifestCode } from './parse-manifest.js';
import { Manifest } from './models/manifest.model.js'; import { Manifest } from './models/manifest.model.js';
@ -8,7 +8,7 @@ import { OpenUIOptions } from './models/open-ui-options.model.js';
import { RegisterListener, DestroyListener } from './models/plugin.model.js'; import { RegisterListener, DestroyListener } from './models/plugin.model.js';
export async function createPluginManager( export async function createPluginManager(
context: PenpotContext, context: Context,
manifest: Manifest, manifest: Manifest,
onCloseCallback: () => void, onCloseCallback: () => void,
onReloadModal: (code: string) => void onReloadModal: (code: string) => void
@ -21,12 +21,9 @@ export async function createPluginManager(
let uiMessagesCallbacks: ((message: unknown) => void)[] = []; let uiMessagesCallbacks: ((message: unknown) => void)[] = [];
const timeouts = new Set<ReturnType<typeof setTimeout>>(); const timeouts = new Set<ReturnType<typeof setTimeout>>();
const themeChangeId = context.addListener( const themeChangeId = context.addListener('themechange', (theme: Theme) => {
'themechange',
(theme: PenpotTheme) => {
modal?.setTheme(theme); modal?.setTheme(theme);
} });
);
const listenerId: symbol = context.addListener('finish', () => { const listenerId: symbol = context.addListener('finish', () => {
closePlugin(); closePlugin();