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

70 lines
2.3 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';
declare type ReachMinScaleStrategy = 'reset' | 'none';
2018-11-09 20:40:51 +00:00
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;
2019-01-16 13:18:09 +00:00
static readonly observedAttributes: string[];
2018-11-09 20:40:51 +00:00
constructor();
2019-01-16 13:18:09 +00:00
attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
minScale: number;
reachMinScaleStrategy: ReachMinScaleStrategy;
allowPanMinScale: number;
resetToMinScaleLimit: number;
stopPropagateHandled: boolean;
2018-11-09 20:40:51 +00:00
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;
private _maybeResetScale;
private _onPointerEnd;
private _resetToMinScale;
2018-11-09 20:40:51 +00:00
/** Transform the view & fire a change event */
private _applyChange;
private _maybeStopPropagate;
private _allowPan;
private _maybeEmitCancel;
private _onClick;
2018-11-09 20:40:51 +00:00
}
export {};