ngx-moveable
Version:
An Angular Component that create Moveable, Draggable, Resizable, Scalable, Rotatable, Warpable, Pinchable, Groupable, Snappable.
370 lines • 27.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, EventEmitter, Output } from '@angular/core';
import Moveable, { PROPERTIES, EVENTS, } from 'moveable';
import { NgxMoveableInterface } from './ngx-moveable.interface';
// @dynamic
export class NgxMoveableComponent extends NgxMoveableInterface {
constructor() {
super();
EVENTS.forEach((/**
* @param {?} name
* @return {?}
*/
name => {
this[name] = new EventEmitter();
}));
}
/**
* @return {?}
*/
ngOnInit() {
/** @type {?} */
const options = {};
/** @type {?} */
const events = {};
PROPERTIES.forEach((/**
* @param {?} name
* @return {?}
*/
name => {
((/** @type {?} */ (options)))[name] = this[name];
}));
EVENTS.forEach((/**
* @param {?} name
* @return {?}
*/
name => {
events[name] = (/**
* @param {?} e
* @return {?}
*/
e => {
this[name].emit(e);
});
}));
this.moveable = new Moveable(this.container || document.body, options);
this.moveable.on(events);
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
/** @type {?} */
const moveable = this.moveable;
if (!moveable) {
return;
}
for (const name in changes) {
const { previousValue, currentValue } = changes[name];
if (previousValue === currentValue) {
continue;
}
moveable[name] = currentValue;
}
}
/**
* @return {?}
*/
ngOnDestroy() {
this.moveable.destroy();
}
}
NgxMoveableComponent.decorators = [
{ type: Component, args: [{
selector: 'ngx-moveable',
template: ''
}] }
];
/** @nocollapse */
NgxMoveableComponent.ctorParameters = () => [];
NgxMoveableComponent.propDecorators = {
draggable: [{ type: Input }],
resizable: [{ type: Input }],
scalable: [{ type: Input }],
rotatable: [{ type: Input }],
warpable: [{ type: Input }],
pinchable: [{ type: Input }],
snappable: [{ type: Input }],
origin: [{ type: Input }],
target: [{ type: Input }],
container: [{ type: Input }],
throttleDrag: [{ type: Input }],
throttleDragRotate: [{ type: Input }],
throttleResize: [{ type: Input }],
throttleScale: [{ type: Input }],
throttleRotate: [{ type: Input }],
keepRatio: [{ type: Input }],
edge: [{ type: Input }],
pinchThreshold: [{ type: Input }],
snapCenter: [{ type: Input }],
snapVertical: [{ type: Input }],
snapElement: [{ type: Input }],
snapHorizontal: [{ type: Input }],
snapThreshold: [{ type: Input }],
horizontalGuidelines: [{ type: Input }],
verticalGuidelines: [{ type: Input }],
elementGuidelines: [{ type: Input }],
bounds: [{ type: Input }],
dragArea: [{ type: Input }],
rotationPosition: [{ type: Input }],
baseDirection: [{ type: Input }],
defaultGroupRotate: [{ type: Input }],
ables: [{ type: Input }],
className: [{ type: Input }],
renderDirections: [{ type: Input }],
scrollable: [{ type: Input }],
scrollContainer: [{ type: Input }],
scrollThreshold: [{ type: Input }],
getScrollPosition: [{ type: Input }],
rootContainer: [{ type: Input }],
zoom: [{ type: Input }],
transformOrigin: [{ type: Input }],
snapDigit: [{ type: Input }],
isDisplaySnapDigit: [{ type: Input }],
innerBounds: [{ type: Input }],
triggerAblesSimultaneously: [{ type: Input }],
snapGap: [{ type: Input }],
pinchOutside: [{ type: Input }],
padding: [{ type: Input }],
snapDistFormat: [{ type: Input }],
dragTarget: [{ type: Input }],
dragStart: [{ type: Output }],
drag: [{ type: Output }],
dragEnd: [{ type: Output }],
dragGroupStart: [{ type: Output }],
dragGroup: [{ type: Output }],
dragGroupEnd: [{ type: Output }],
resizeStart: [{ type: Output }],
resize: [{ type: Output }],
resizeEnd: [{ type: Output }],
resizeGroupStart: [{ type: Output }],
resizeGroup: [{ type: Output }],
resizeGroupEnd: [{ type: Output }],
scaleStart: [{ type: Output }],
scale: [{ type: Output }],
scaleEnd: [{ type: Output }],
scaleGroupStart: [{ type: Output }],
scaleGroup: [{ type: Output }],
scaleGroupEnd: [{ type: Output }],
rotateStart: [{ type: Output }],
rotate: [{ type: Output }],
rotateEnd: [{ type: Output }],
rotateGroupStart: [{ type: Output }],
rotateGroup: [{ type: Output }],
rotateGroupEnd: [{ type: Output }],
warpStart: [{ type: Output }],
warp: [{ type: Output }],
warpEnd: [{ type: Output }],
pinchStart: [{ type: Output }],
pinch: [{ type: Output }],
pinchEnd: [{ type: Output }],
pinchGroupStart: [{ type: Output }],
pinchGroup: [{ type: Output }],
pinchGroupEnd: [{ type: Output }],
click: [{ type: Output }],
clickGroup: [{ type: Output }],
renderStart: [{ type: Output }],
render: [{ type: Output }],
renderEnd: [{ type: Output }],
renderGroupStart: [{ type: Output }],
renderGroup: [{ type: Output }],
renderGroupEnd: [{ type: Output }],
scroll: [{ type: Output }],
scrollGroup: [{ type: Output }],
snap: [{ type: Output }]
};
if (false) {
/** @type {?} */
NgxMoveableComponent.prototype.draggable;
/** @type {?} */
NgxMoveableComponent.prototype.resizable;
/** @type {?} */
NgxMoveableComponent.prototype.scalable;
/** @type {?} */
NgxMoveableComponent.prototype.rotatable;
/** @type {?} */
NgxMoveableComponent.prototype.warpable;
/** @type {?} */
NgxMoveableComponent.prototype.pinchable;
/** @type {?} */
NgxMoveableComponent.prototype.snappable;
/** @type {?} */
NgxMoveableComponent.prototype.origin;
/** @type {?} */
NgxMoveableComponent.prototype.target;
/** @type {?} */
NgxMoveableComponent.prototype.container;
/** @type {?} */
NgxMoveableComponent.prototype.throttleDrag;
/** @type {?} */
NgxMoveableComponent.prototype.throttleDragRotate;
/** @type {?} */
NgxMoveableComponent.prototype.throttleResize;
/** @type {?} */
NgxMoveableComponent.prototype.throttleScale;
/** @type {?} */
NgxMoveableComponent.prototype.throttleRotate;
/** @type {?} */
NgxMoveableComponent.prototype.keepRatio;
/** @type {?} */
NgxMoveableComponent.prototype.edge;
/** @type {?} */
NgxMoveableComponent.prototype.pinchThreshold;
/** @type {?} */
NgxMoveableComponent.prototype.snapCenter;
/** @type {?} */
NgxMoveableComponent.prototype.snapVertical;
/** @type {?} */
NgxMoveableComponent.prototype.snapElement;
/** @type {?} */
NgxMoveableComponent.prototype.snapHorizontal;
/** @type {?} */
NgxMoveableComponent.prototype.snapThreshold;
/** @type {?} */
NgxMoveableComponent.prototype.horizontalGuidelines;
/** @type {?} */
NgxMoveableComponent.prototype.verticalGuidelines;
/** @type {?} */
NgxMoveableComponent.prototype.elementGuidelines;
/** @type {?} */
NgxMoveableComponent.prototype.bounds;
/** @type {?} */
NgxMoveableComponent.prototype.dragArea;
/** @type {?} */
NgxMoveableComponent.prototype.rotationPosition;
/** @type {?} */
NgxMoveableComponent.prototype.baseDirection;
/** @type {?} */
NgxMoveableComponent.prototype.defaultGroupRotate;
/** @type {?} */
NgxMoveableComponent.prototype.ables;
/** @type {?} */
NgxMoveableComponent.prototype.className;
/** @type {?} */
NgxMoveableComponent.prototype.renderDirections;
/** @type {?} */
NgxMoveableComponent.prototype.scrollable;
/** @type {?} */
NgxMoveableComponent.prototype.scrollContainer;
/** @type {?} */
NgxMoveableComponent.prototype.scrollThreshold;
/** @type {?} */
NgxMoveableComponent.prototype.getScrollPosition;
/** @type {?} */
NgxMoveableComponent.prototype.rootContainer;
/** @type {?} */
NgxMoveableComponent.prototype.zoom;
/** @type {?} */
NgxMoveableComponent.prototype.transformOrigin;
/** @type {?} */
NgxMoveableComponent.prototype.snapDigit;
/** @type {?} */
NgxMoveableComponent.prototype.isDisplaySnapDigit;
/** @type {?} */
NgxMoveableComponent.prototype.innerBounds;
/** @type {?} */
NgxMoveableComponent.prototype.triggerAblesSimultaneously;
/** @type {?} */
NgxMoveableComponent.prototype.snapGap;
/** @type {?} */
NgxMoveableComponent.prototype.pinchOutside;
/** @type {?} */
NgxMoveableComponent.prototype.padding;
/** @type {?} */
NgxMoveableComponent.prototype.snapDistFormat;
/** @type {?} */
NgxMoveableComponent.prototype.dragTarget;
/** @type {?} */
NgxMoveableComponent.prototype.dragStart;
/** @type {?} */
NgxMoveableComponent.prototype.drag;
/** @type {?} */
NgxMoveableComponent.prototype.dragEnd;
/** @type {?} */
NgxMoveableComponent.prototype.dragGroupStart;
/** @type {?} */
NgxMoveableComponent.prototype.dragGroup;
/** @type {?} */
NgxMoveableComponent.prototype.dragGroupEnd;
/** @type {?} */
NgxMoveableComponent.prototype.resizeStart;
/** @type {?} */
NgxMoveableComponent.prototype.resize;
/** @type {?} */
NgxMoveableComponent.prototype.resizeEnd;
/** @type {?} */
NgxMoveableComponent.prototype.resizeGroupStart;
/** @type {?} */
NgxMoveableComponent.prototype.resizeGroup;
/** @type {?} */
NgxMoveableComponent.prototype.resizeGroupEnd;
/** @type {?} */
NgxMoveableComponent.prototype.scaleStart;
/** @type {?} */
NgxMoveableComponent.prototype.scale;
/** @type {?} */
NgxMoveableComponent.prototype.scaleEnd;
/** @type {?} */
NgxMoveableComponent.prototype.scaleGroupStart;
/** @type {?} */
NgxMoveableComponent.prototype.scaleGroup;
/** @type {?} */
NgxMoveableComponent.prototype.scaleGroupEnd;
/** @type {?} */
NgxMoveableComponent.prototype.rotateStart;
/** @type {?} */
NgxMoveableComponent.prototype.rotate;
/** @type {?} */
NgxMoveableComponent.prototype.rotateEnd;
/** @type {?} */
NgxMoveableComponent.prototype.rotateGroupStart;
/** @type {?} */
NgxMoveableComponent.prototype.rotateGroup;
/** @type {?} */
NgxMoveableComponent.prototype.rotateGroupEnd;
/** @type {?} */
NgxMoveableComponent.prototype.warpStart;
/** @type {?} */
NgxMoveableComponent.prototype.warp;
/** @type {?} */
NgxMoveableComponent.prototype.warpEnd;
/** @type {?} */
NgxMoveableComponent.prototype.pinchStart;
/** @type {?} */
NgxMoveableComponent.prototype.pinch;
/** @type {?} */
NgxMoveableComponent.prototype.pinchEnd;
/** @type {?} */
NgxMoveableComponent.prototype.pinchGroupStart;
/** @type {?} */
NgxMoveableComponent.prototype.pinchGroup;
/** @type {?} */
NgxMoveableComponent.prototype.pinchGroupEnd;
/** @type {?} */
NgxMoveableComponent.prototype.click;
/** @type {?} */
NgxMoveableComponent.prototype.clickGroup;
/** @type {?} */
NgxMoveableComponent.prototype.renderStart;
/** @type {?} */
NgxMoveableComponent.prototype.render;
/** @type {?} */
NgxMoveableComponent.prototype.renderEnd;
/** @type {?} */
NgxMoveableComponent.prototype.renderGroupStart;
/** @type {?} */
NgxMoveableComponent.prototype.renderGroup;
/** @type {?} */
NgxMoveableComponent.prototype.renderGroupEnd;
/** @type {?} */
NgxMoveableComponent.prototype.scroll;
/** @type {?} */
NgxMoveableComponent.prototype.scrollGroup;
/** @type {?} */
NgxMoveableComponent.prototype.snap;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-moveable.component.js","sourceRoot":"ng://ngx-moveable/","sources":["ngx-moveable.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Input, OnDestroy,\n  OnInit, OnChanges, SimpleChanges, EventEmitter, Output\n} from '@angular/core';\nimport Moveable, {\n  PROPERTIES, EVENTS, MoveableOptions,\n  OnScrollGroup, OnScroll, MoveableEvents, OnSnap,\n} from 'moveable';\nimport { IObject } from '@daybrush/utils';\nimport { NgxMoveableEvents } from './types';\nimport { Able } from 'moveable';\nimport { NgxMoveableInterface } from './ngx-moveable.interface';\n\n\n// @dynamic\n@Component({\n  selector: 'ngx-moveable',\n  template: '',\n})\nexport class NgxMoveableComponent\n  extends NgxMoveableInterface\n  implements OnDestroy, OnInit, OnChanges, Required<MoveableOptions>, NgxMoveableEvents {\n  @Input() public draggable!: MoveableOptions['draggable'];\n  @Input() public resizable!: MoveableOptions['resizable'];\n  @Input() public scalable!: MoveableOptions['scalable'];\n  @Input() public rotatable!: MoveableOptions['rotatable'];\n  @Input() public warpable!: MoveableOptions['warpable'];\n  @Input() public pinchable!: boolean | Array<'rotatable' | 'resizable' | 'scalable'>;\n  @Input() public snappable!: boolean | string[];\n  @Input() public origin!: boolean;\n  @Input() public target!: SVGElement | HTMLElement | Array<SVGElement | HTMLElement>;\n  @Input() public container!: SVGElement | HTMLElement | null;\n  @Input() public throttleDrag!: number;\n  @Input() public throttleDragRotate!: number;\n  @Input() public throttleResize!: number;\n  @Input() public throttleScale!: number;\n  @Input() public throttleRotate!: number;\n  @Input() public keepRatio!: boolean;\n  @Input() public edge!: boolean;\n  @Input() public pinchThreshold!: number;\n  @Input() public snapCenter!: boolean;\n  @Input() public snapVertical!: boolean;\n  @Input() public snapElement!: boolean;\n  @Input() public snapHorizontal!: boolean;\n  @Input() public snapThreshold!: number;\n  @Input() public horizontalGuidelines!: number[];\n  @Input() public verticalGuidelines!: number[];\n  @Input() public elementGuidelines!: Element[];\n  @Input() public bounds!: { left?: number, top?: number, right?: number, bottom?: number };\n  @Input() public dragArea!: boolean;\n  @Input() public rotationPosition!: 'top' | 'bottom' | 'left' | 'right';\n  @Input() public baseDirection!: number[];\n  @Input() public defaultGroupRotate!: number;\n  @Input() public ables!: Able[];\n\n  @Input() public className!: string;\n  @Input() public renderDirections!: string[];\n  @Input() public scrollable!: boolean;\n  @Input() public scrollContainer!: HTMLElement;\n  @Input() public scrollThreshold!: number;\n  @Input() public getScrollPosition!: MoveableOptions['getScrollPosition'];\n\n  @Input() public rootContainer!: MoveableOptions['rootContainer'];\n  @Input() public zoom!: MoveableOptions['zoom'];\n  @Input() public transformOrigin!: MoveableOptions['transformOrigin'];\n  @Input() public snapDigit!: MoveableOptions['snapDigit'];\n  @Input() public isDisplaySnapDigit!: MoveableOptions['isDisplaySnapDigit'];\n  @Input() public innerBounds!: MoveableOptions['innerBounds'];\n\n  @Input() public triggerAblesSimultaneously!: MoveableOptions['triggerAblesSimultaneously'];\n  @Input() public snapGap!: MoveableOptions['snapGap'];\n\n  @Input() public pinchOutside!: MoveableOptions['pinchOutside'];\n  @Input() public padding!: MoveableOptions['padding'];\n  @Input() public snapDistFormat!: MoveableOptions['snapDistFormat'];\n  @Input() public dragTarget!: MoveableOptions['dragTarget'];\n\n  @Output() public dragStart!: EventEmitter<MoveableEvents['dragStart']>;\n  @Output() public drag!: EventEmitter<MoveableEvents['drag']>;\n  @Output() public dragEnd!: EventEmitter<MoveableEvents['dragEnd']>;\n  @Output() public dragGroupStart!: EventEmitter<MoveableEvents['dragGroupStart']>;\n  @Output() public dragGroup!: EventEmitter<MoveableEvents['dragGroup']>;\n  @Output() public dragGroupEnd!: EventEmitter<MoveableEvents['dragGroupEnd']>;\n\n  @Output() public resizeStart!: EventEmitter<MoveableEvents['resizeStart']>;\n  @Output() public resize!: EventEmitter<MoveableEvents['resize']>;\n  @Output() public resizeEnd!: EventEmitter<MoveableEvents['resizeEnd']>;\n  @Output() public resizeGroupStart!: EventEmitter<MoveableEvents['resizeGroupStart']>;\n  @Output() public resizeGroup!: EventEmitter<MoveableEvents['resizeGroup']>;\n  @Output() public resizeGroupEnd!: EventEmitter<MoveableEvents['resizeGroupEnd']>;\n\n  @Output() public scaleStart!: EventEmitter<MoveableEvents['scaleStart']>;\n  @Output() public scale!: EventEmitter<MoveableEvents['scale']>;\n  @Output() public scaleEnd!: EventEmitter<MoveableEvents['scaleEnd']>;\n  @Output() public scaleGroupStart!: EventEmitter<MoveableEvents['scaleGroupStart']>;\n  @Output() public scaleGroup!: EventEmitter<MoveableEvents['scaleGroup']>;\n  @Output() public scaleGroupEnd!: EventEmitter<MoveableEvents['scaleGroupEnd']>;\n\n  @Output() public rotateStart!: EventEmitter<MoveableEvents['rotateStart']>;\n  @Output() public rotate!: EventEmitter<MoveableEvents['rotate']>;\n  @Output() public rotateEnd!: EventEmitter<MoveableEvents['rotateEnd']>;\n  @Output() public rotateGroupStart!: EventEmitter<MoveableEvents['rotateGroupStart']>;\n  @Output() public rotateGroup!: EventEmitter<MoveableEvents['rotateGroup']>;\n  @Output() public rotateGroupEnd!: EventEmitter<MoveableEvents['rotateGroupEnd']>;\n\n  @Output() public warpStart!: EventEmitter<MoveableEvents['warpStart']>;\n  @Output() public warp!: EventEmitter<MoveableEvents['warp']>;\n  @Output() public warpEnd!: EventEmitter<MoveableEvents['warpEnd']>;\n\n  @Output() public pinchStart!: EventEmitter<MoveableEvents['pinchStart']>;\n  @Output() public pinch!: EventEmitter<MoveableEvents['pinch']>;\n  @Output() public pinchEnd!: EventEmitter<MoveableEvents['pinchEnd']>;\n  @Output() public pinchGroupStart!: EventEmitter<MoveableEvents['pinchGroupStart']>;\n  @Output() public pinchGroup!: EventEmitter<MoveableEvents['pinchGroup']>;\n  @Output() public pinchGroupEnd!: EventEmitter<MoveableEvents['pinchGroupEnd']>;\n\n  @Output() public click!: EventEmitter<MoveableEvents['click']>;\n  @Output() public clickGroup!: EventEmitter<MoveableEvents['clickGroup']>;\n\n  @Output() public renderStart!: EventEmitter<MoveableEvents['renderStart']>;\n  @Output() public render!: EventEmitter<MoveableEvents['render']>;\n  @Output() public renderEnd!: EventEmitter<MoveableEvents['renderEnd']>;\n  @Output() public renderGroupStart!: EventEmitter<MoveableEvents['renderGroupStart']>;\n  @Output() public renderGroup!: EventEmitter<MoveableEvents['renderGroup']>;\n  @Output() public renderGroupEnd!: EventEmitter<MoveableEvents['renderGroupEnd']>;\n\n  @Output() public scroll!: EventEmitter<OnScroll>;\n  @Output() public scrollGroup!: EventEmitter<OnScrollGroup>;\n\n  @Output() public snap!: EventEmitter<OnSnap>;\n\n  constructor() {\n    super();\n    EVENTS.forEach(name => {\n      this[name] = new EventEmitter<any>();\n    });\n  }\n  ngOnInit(): void {\n    const options: MoveableOptions = {};\n    const events: IObject<any> = {};\n\n    PROPERTIES.forEach(name => {\n      (options as any)[name] = this[name];\n    });\n    EVENTS.forEach(name => {\n      events[name] = e => {\n        this[name].emit(e);\n      };\n    });\n\n    this.moveable = new Moveable(this.container || document.body, options);\n    this.moveable.on(events);\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    const moveable = this.moveable;\n\n    if (!moveable) {\n      return;\n    }\n    for (const name in changes) {\n      const { previousValue, currentValue } = changes[name];\n\n      if (previousValue === currentValue) {\n        continue;\n      }\n      moveable[name] = currentValue;\n    }\n  }\n  ngOnDestroy() {\n    this.moveable.destroy();\n  }\n}\n"]}