UNPKG

ngx-moveable

Version:

An Angular Component that create Moveable, Draggable, Resizable, Scalable, Rotatable, Warpable, Pinchable, Groupable, Snappable.

370 lines 27.7 kB
/** * @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"]}