Skip to content

Commit

Permalink
chore: release 4.6.0
Browse files Browse the repository at this point in the history
  • Loading branch information
timmywil committed Jan 14, 2025
1 parent c05ae3d commit f93c480
Show file tree
Hide file tree
Showing 15 changed files with 2,186 additions and 64 deletions.
122 changes: 61 additions & 61 deletions README.md

Large diffs are not rendered by default.

792 changes: 792 additions & 0 deletions dist/panzoom.es.js

Large diffs are not rendered by default.

800 changes: 800 additions & 0 deletions dist/panzoom.js

Large diffs are not rendered by default.

6 changes: 6 additions & 0 deletions dist/panzoom.min.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

81 changes: 81 additions & 0 deletions dist/src/css.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
import type { CurrentValues, PanzoomOptions } from './types.js';
/**
* Gets a style value expected to be a number
*/
export declare function getCSSNum(name: string, style: CSSStyleDeclaration): number;
/**
* Set a style using the properly prefixed name
*/
export declare function setStyle(elem: HTMLElement | SVGElement, name: string, value: string): void;
/**
* Constructs the transition from panzoom options
* and takes care of prefixing the transition and transform
*/
export declare function setTransition(elem: HTMLElement | SVGElement, options: PanzoomOptions): void;
/**
* Set the transform using the proper prefix
*
* Override the transform setter.
* This is exposed mostly so the user could
* set other parts of a transform
* aside from scale and translate.
* Default is defined in src/css.ts.
*
* ```js
* // This example always sets a rotation
* // when setting the scale and translation
* const panzoom = Panzoom(elem, {
* setTransform: (elem, { scale, x, y }) => {
* panzoom.setStyle('transform', `rotate(0.5turn) scale(${scale}) translate(${x}px, ${y}px)`)
* }
* })
* ```
*/
export declare function setTransform(elem: HTMLElement | SVGElement, { x, y, scale, isSVG }: CurrentValues, _options?: PanzoomOptions): void;
/**
* Dimensions used in containment and focal point zooming
*/
export declare function getDimensions(elem: HTMLElement | SVGElement): {
elem: {
style: CSSStyleDeclaration;
width: number;
height: number;
top: number;
bottom: number;
left: number;
right: number;
margin: {
left: number;
right: number;
top: number;
bottom: number;
};
border: {
left: number;
right: number;
top: number;
bottom: number;
};
};
parent: {
style: CSSStyleDeclaration;
width: number;
height: number;
top: number;
bottom: number;
left: number;
right: number;
padding: {
left: number;
right: number;
top: number;
bottom: number;
};
border: {
left: number;
right: number;
top: number;
bottom: number;
};
};
};
8 changes: 8 additions & 0 deletions dist/src/events.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
declare let events: {
down: string;
move: string;
up: string;
};
export { events as eventNames };
export declare function onPointer(event: 'down' | 'move' | 'up', elem: HTMLElement | SVGElement | Document, handler: (event: PointerEvent) => void, eventOpts?: boolean | AddEventListenerOptions): void;
export declare function destroyPointer(event: 'down' | 'move' | 'up', elem: HTMLElement | SVGElement | Document, handler: (event: PointerEvent) => void): void;
5 changes: 5 additions & 0 deletions dist/src/isAttached.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
/**
* Determine if an element is attached to the DOM
* Panzoom requires this so events work properly
*/
export default function isAttached(node: Node): boolean;
2 changes: 2 additions & 0 deletions dist/src/isExcluded.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
import type { PanzoomOptions } from './types.js';
export default function isExcluded(elem: Element, options: PanzoomOptions): boolean;
1 change: 1 addition & 0 deletions dist/src/isSVGElement.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export default function isSVGElement(elem: HTMLElement | SVGElement): boolean;
17 changes: 17 additions & 0 deletions dist/src/panzoom.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
/**
* Panzoom for panning and zooming elements using CSS transforms
* https://github.com/timmywil/panzoom
*
* Copyright Timmy Willison and other contributors
* Released under the MIT license
* https://github.com/timmywil/panzoom/blob/main/MIT-License.txt
*
*/
import './polyfills.js';
import type { PanzoomObject, PanzoomOptions } from './types.js';
declare function Panzoom(elem: HTMLElement | SVGElement, options?: Omit<PanzoomOptions, 'force'>): PanzoomObject;
declare namespace Panzoom {
var defaultOptions: PanzoomOptions;
}
export * from './types.js';
export default Panzoom;
17 changes: 17 additions & 0 deletions dist/src/pointers.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
/**
* Utilites for working with multiple pointer events
*/
export declare function addPointer(pointers: PointerEvent[], event: PointerEvent): void;
export declare function removePointer(pointers: PointerEvent[], event: PointerEvent): void;
/**
* Calculates a center point between
* the given pointer events, for panning
* with multiple pointers.
*/
export declare function getMiddle(pointers: PointerEvent[]): Pick<PointerEvent, "clientX" | "clientY">;
/**
* Calculates the distance between two points
* for pinch zooming.
* Limits to the first 2
*/
export declare function getDistance(pointers: PointerEvent[]): number;
1 change: 1 addition & 0 deletions dist/src/shallowClone.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export default function shallowClone(obj: any): any;
Loading

0 comments on commit f93c480

Please sign in to comment.