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 , and * that's the element we pan/scale. */ private _stageElChange; private _onWheel; private _onPointerMove; /** Transform the view & fire a change event */ private _applyChange; } export {};