pinch-zoom-element/dist/pinch-zoom.d.ts

55 lines
1.8 KiB
TypeScript
Raw Normal View History

2018-11-09 20:40:51 +00:00
import './styles.css';
interface ChangeOptions {
/**
* Fire a 'change' event if values are different to current values
*/
allowChangeEvent?: boolean;
}
interface SetTransformOpts extends ChangeOptions {
scale?: number;
x?: number;
y?: number;
}
declare type ScaleRelativeToValues = 'container' | 'content';
export interface ScaleToOpts extends ChangeOptions {
/** Transform origin. Can be a number, or string percent, eg "50%" */
originX?: number | string;
/** Transform origin. Can be a number, or string percent, eg "50%" */
originY?: number | string;
/** Should the transform origin be relative to the container, or content? */
relativeTo?: ScaleRelativeToValues;
}
export default class PinchZoom extends HTMLElement {
private _positioningEl?;
private _transform;
constructor();
connectedCallback(): void;
readonly x: number;
readonly y: number;
readonly scale: number;
/**
* Change the scale, adjusting x/y by a given transform origin.
*/
scaleTo(scale: number, opts?: ScaleToOpts): void;
/**
* Update the stage with a given scale/x/y.
*/
setTransform(opts?: SetTransformOpts): void;
/**
* Update transform values without checking bounds. This is only called in setTransform.
*/
private _updateTransform;
/**
* Called when the direct children of this element change.
* Until we have have shadow dom support across the board, we
* require a single element to be the child of <pinch-zoom>, and
* that's the element we pan/scale.
*/
private _stageElChange;
private _onWheel;
private _onPointerMove;
/** Transform the view & fire a change event */
private _applyChange;
}
export {};