Skip to content

Commit

Permalink
feat(plugin-types): add ruler guides and new zoom methods
Browse files Browse the repository at this point in the history
  • Loading branch information
Alotor committed Sep 4, 2024
1 parent 08508bf commit a305f99
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 25 deletions.
16 changes: 8 additions & 8 deletions libs/plugin-types/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -354,7 +354,7 @@ export interface Page extends PluginData {
/**
* Removes the `guide` from the current page.
*/
removeRulerGuide(guide: RulerGuide);
removeRulerGuide(guide: RulerGuide): void;
}

/**
Expand Down Expand Up @@ -1845,7 +1845,7 @@ export interface Board extends ShapeBase {
/**
* Removes the `guide` from the current page.
*/
removeRulerGuide(guide: RulerGuide);
removeRulerGuide(guide: RulerGuide): void;
}

/**
Expand Down Expand Up @@ -2312,18 +2312,18 @@ export interface Viewport {
/**
* Resets the zoom level.
*/
zoomReset();
zoomReset(): void;

/**
* 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
* visible.
*/
zoomToShapes(shapes: Shape[]);
zoomToShapes(shapes: Shape[]): void;
}

/**
Expand All @@ -2341,7 +2341,7 @@ export interface Viewport {
export type Shape =
| Board
| Group
| Bool
| Boolean
| Rectangle
| Path
| Text
Expand Down Expand Up @@ -3363,7 +3363,7 @@ export interface Context {
* 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.
* @param svgString The SVG string representing the shapes to be converted into a group.
Expand Down Expand Up @@ -3861,7 +3861,7 @@ export interface ContextTypesUtils {
* @param shape - The shape to check.
* @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.
Expand Down
6 changes: 3 additions & 3 deletions libs/plugins-runtime/src/lib/create-plugin.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { describe, it, vi, expect, beforeEach, afterEach } from 'vitest';
import { createPlugin } from './create-plugin';
import { createPluginManager } from './plugin-manager.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';

vi.mock('./plugin-manager.js', () => ({
Expand All @@ -14,7 +14,7 @@ vi.mock('./create-sandbox.js', () => ({
}));

describe('createPlugin', () => {
let mockContext: PenpotContext;
let mockContext: Context;
let manifest: Manifest;
let onCloseCallback: ReturnType<typeof vi.fn>;
let mockPluginManager: Awaited<ReturnType<typeof createPluginManager>>;
Expand Down Expand Up @@ -59,7 +59,7 @@ describe('createPlugin', () => {
addListener: vi.fn(),
removeListener: vi.fn(),
getTheme: vi.fn().mockReturnValue('light'),
} as unknown as PenpotContext;
} as unknown as Context;

onCloseCallback = vi.fn();

Expand Down
4 changes: 2 additions & 2 deletions libs/plugins-runtime/src/lib/create-plugin.ts
Original file line number Diff line number Diff line change
@@ -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 { createPluginManager } from './plugin-manager.js';
import { createSandbox } from './create-sandbox.js';

export async function createPlugin(
context: PenpotContext,
context: Context,
manifest: Manifest,
onCloseCallback: () => void
) {
Expand Down
8 changes: 4 additions & 4 deletions libs/plugins-runtime/src/lib/plugin-manager.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { createPluginManager } from './plugin-manager';
import { loadManifestCode, getValidUrl } from './parse-manifest.js';
import { PluginModalElement } from './modal/plugin-modal.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';

vi.mock('./parse-manifest.js', () => ({
Expand All @@ -16,7 +16,7 @@ vi.mock('./api/openUI.api.js', () => ({
}));

describe('createPluginManager', () => {
let mockContext: PenpotContext;
let mockContext: Context;
let manifest: Manifest;
let onCloseCallback: ReturnType<typeof vi.fn>;
let onReloadModal: ReturnType<typeof vi.fn>;
Expand Down Expand Up @@ -59,7 +59,7 @@ describe('createPluginManager', () => {
addListener: vi.fn().mockReturnValue(Symbol()),
removeListener: vi.fn(),
getTheme: vi.fn().mockReturnValue('light'),
} as unknown as PenpotContext;
} as unknown as Context;

onCloseCallback = vi.fn();
onReloadModal = vi.fn();
Expand Down Expand Up @@ -159,7 +159,7 @@ describe('createPluginManager', () => {
throw new Error('Theme change callback not found');
}

themeChangeCallback('dark' as PenpotTheme);
themeChangeCallback('dark' as Theme);

expect(mockModal.setTheme).toHaveBeenCalledWith('dark');
});
Expand Down
13 changes: 5 additions & 8 deletions libs/plugins-runtime/src/lib/plugin-manager.ts
Original file line number Diff line number Diff line change
@@ -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 { Manifest } from './models/manifest.model.js';
Expand All @@ -8,7 +8,7 @@ import { OpenUIOptions } from './models/open-ui-options.model.js';
import { RegisterListener, DestroyListener } from './models/plugin.model.js';

export async function createPluginManager(
context: PenpotContext,
context: Context,
manifest: Manifest,
onCloseCallback: () => void,
onReloadModal: (code: string) => void
Expand All @@ -21,12 +21,9 @@ export async function createPluginManager(
let uiMessagesCallbacks: ((message: unknown) => void)[] = [];
const timeouts = new Set<ReturnType<typeof setTimeout>>();

const themeChangeId = context.addListener(
'themechange',
(theme: PenpotTheme) => {
modal?.setTheme(theme);
}
);
const themeChangeId = context.addListener('themechange', (theme: Theme) => {
modal?.setTheme(theme);
});

const listenerId: symbol = context.addListener('finish', () => {
closePlugin();
Expand Down

0 comments on commit a305f99

Please sign in to comment.