angular-color-picker-fixed
Version:
Radial Color Picker - Angular
155 lines • 20.5 kB
JavaScript
import { __decorate } from "tslib";
import { coerceBooleanProperty } from '@angular/cdk/coercion';
import { Platform } from '@angular/cdk/platform';
import { AfterViewInit, Directive, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, Renderer2, SimpleChanges } from '@angular/core';
import { fromEvent, merge } from 'rxjs';
import { filter, takeUntil, tap } from 'rxjs/operators';
import { calculateQuadrant, determineCSSRotationAngle } from '../helpers/helpers';
let RotatableDirective = class RotatableDirective {
constructor(el, renderer, platform) {
this.el = el;
this.renderer = renderer;
this.platform = platform;
this.dragging = false;
this.rotateStart = new EventEmitter();
this.rotating = new EventEmitter();
this.rotateStop = new EventEmitter();
if (this.platform.IOS || this.platform.ANDROID) {
this.mouseDownEv = 'touchstart';
this.mouseUpEv = 'touchend';
this.mouseMoveEv = 'touchmove';
this.cancelEv = 'touchcancel';
}
else {
this.mouseDownEv = 'mousedown';
this.mouseUpEv = 'mouseup';
this.mouseMoveEv = 'mousemove';
this.cancelEv = 'mouseout';
}
}
get isDisabled() {
return this.disable ? coerceBooleanProperty(this.disable) : false;
}
ngOnInit() {
}
ngOnChanges(changes) {
if (changes.angle && changes.angle.currentValue) {
// console.log(changes.angle.currentValue);
const angle = changes.angle.currentValue + 90;
this.renderer.setStyle(this.el.nativeElement, 'transform', `rotate(${angle}deg)`);
}
}
ngAfterViewInit() {
// console.log(this.isDisabled);
requestAnimationFrame(this.initialRender.bind(this));
this.rect = this.el.nativeElement.getBoundingClientRect();
this.mouseUp$ = fromEvent(this.el.nativeElement, this.mouseUpEv, { passive: true });
this.mouseOut$ = fromEvent(this.el.nativeElement, this.cancelEv, { passive: true });
this.mouseDownSub = fromEvent(this.el.nativeElement, this.mouseDownEv, { passive: true })
.pipe(filter((val) => {
return this.active && !this.isDisabled;
}))
.subscribe((downEvent) => {
this.dragging = true;
this.rect = this.el.nativeElement.getBoundingClientRect();
// console.log('mouse down', downEvent, this.rect);
this.point = this.createPoint(downEvent);
this.rotateStart.emit(this.point);
this.applyRotation();
this.mouseMoveSub = fromEvent(this.el.nativeElement, this.mouseMoveEv).pipe(takeUntil(merge(this.mouseOut$, this.mouseUp$).pipe(tap((upEvent) => {
this.rect = this.el.nativeElement.getBoundingClientRect();
// console.log('mouse up', upEvent, this.rect);
this.dragging = false;
this.mouseMoveSub.unsubscribe();
this.rotateStop.emit(this.point);
})))).subscribe((moveEvent) => {
this.rect = this.el.nativeElement.getBoundingClientRect();
// console.log('mouse move', moveEvent, this.rect);
this.point = this.createPoint(moveEvent);
// console.log(this.point);
this.applyRotation();
});
});
}
initialRender() {
const angle = this.angle + 90;
this.renderer.setStyle(this.el.nativeElement, 'transform', `rotate(${angle}deg)`);
}
rotationRender() {
// console.log(this.rotation);
this.renderer.setStyle(this.el.nativeElement, 'transform', `rotate(${this.rotation}deg)`);
}
ngOnDestroy() {
if (this.mouseDownSub) {
this.mouseDownSub.unsubscribe();
}
if (this.mouseMoveSub) {
this.mouseMoveSub.unsubscribe();
}
if (this.mouseUpSub) {
this.mouseUpSub.unsubscribe();
}
// console.log('directive destroy');
}
applyRotation() {
const quadrant = calculateQuadrant(this.point);
const rotation = determineCSSRotationAngle(this.point, quadrant);
// console.log(rotation);
this.rotating.emit(rotation);
this.rotation = rotation;
requestAnimationFrame(this.rotationRender.bind(this));
}
createPoint(mouseEvent) {
let point;
if (mouseEvent.targetTouches) {
point = {
x: this._normalizeX(mouseEvent.targetTouches[0].clientX),
y: this._normalizeY(mouseEvent.targetTouches[0].clientY)
};
}
else {
point = {
x: this._normalizeX(mouseEvent.clientX),
y: this._normalizeY(mouseEvent.clientY)
};
}
// console.log('point', point);
return point;
}
_normalizeX(coordX) {
return coordX - this.rect.left - this.rect.width / 2;
}
_normalizeY(coordY) {
return ((coordY - this.rect.top) * -1) + this.rect.height / 2;
}
};
RotatableDirective.ctorParameters = () => [
{ type: ElementRef },
{ type: Renderer2 },
{ type: Platform }
];
__decorate([
Input()
], RotatableDirective.prototype, "angle", void 0);
__decorate([
Input()
], RotatableDirective.prototype, "disable", void 0);
__decorate([
Input()
], RotatableDirective.prototype, "active", void 0);
__decorate([
Output()
], RotatableDirective.prototype, "rotateStart", void 0);
__decorate([
Output()
], RotatableDirective.prototype, "rotating", void 0);
__decorate([
Output()
], RotatableDirective.prototype, "rotateStop", void 0);
RotatableDirective = __decorate([
Directive({
selector: '[rcpRotatable]'
})
], RotatableDirective);
export { RotatableDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rotatable.directive.js","sourceRoot":"ng://@radial-color-picker/angular-color-picker/","sources":["lib/directives/rotatable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { Platform } from '@angular/cdk/platform';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  SimpleChanges\n} from '@angular/core';\nimport { fromEvent, Observable, Subscription, merge } from 'rxjs';\nimport { filter, takeUntil, tap } from 'rxjs/operators';\nimport { calculateQuadrant, determineCSSRotationAngle } from '../helpers/helpers';\n\n@Directive({\n  selector: '[rcpRotatable]'\n})\nexport class RotatableDirective implements OnInit, OnChanges, OnDestroy, AfterViewInit {\n  public rotation: any;\n  public dragging = false;\n  public mouseDownSub: Subscription;\n  public mouseMoveSub: Subscription;\n  public mouseUpSub: Subscription;\n  public rect: any;\n\n  public cancelEv: string;\n  public mouseDownEv: string;\n  public mouseMoveEv: string;\n  public mouseUpEv: string;\n\n  @Input() angle: number;\n  @Input() disable: boolean;\n  @Input() active: boolean;\n\n  get isDisabled() {\n    return this.disable ? coerceBooleanProperty(this.disable) : false;\n  }\n\n  @Output() public rotateStart = new EventEmitter<any>();\n  @Output() public rotating = new EventEmitter<any>();\n  @Output() public rotateStop = new EventEmitter<any>();\n\n  private point: any;\n  private mouseUp$: Observable<any>;\n  private mouseOut$: Observable<any>;\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private platform: Platform\n  ) {\n    if (this.platform.IOS || this.platform.ANDROID) {\n      this.mouseDownEv = 'touchstart';\n      this.mouseUpEv = 'touchend';\n      this.mouseMoveEv = 'touchmove';\n      this.cancelEv = 'touchcancel';\n    } else {\n      this.mouseDownEv = 'mousedown';\n      this.mouseUpEv = 'mouseup';\n      this.mouseMoveEv = 'mousemove';\n      this.cancelEv = 'mouseout';\n    }\n\n  }\n\n  ngOnInit() {\n\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.angle && changes.angle.currentValue) {\n      // console.log(changes.angle.currentValue);\n      const angle = changes.angle.currentValue + 90;\n      this.renderer.setStyle(this.el.nativeElement, 'transform', `rotate(${angle}deg)`);\n    }\n  }\n\n  ngAfterViewInit() {\n    // console.log(this.isDisabled);\n    requestAnimationFrame(this.initialRender.bind(this));\n    this.rect = this.el.nativeElement.getBoundingClientRect();\n    this.mouseUp$ = fromEvent(this.el.nativeElement, this.mouseUpEv, { passive: true });\n    this.mouseOut$ = fromEvent(this.el.nativeElement, this.cancelEv, { passive: true });\n\n    this.mouseDownSub = fromEvent(this.el.nativeElement, this.mouseDownEv, { passive: true })\n      .pipe(\n        filter((val) => {\n          return this.active && !this.isDisabled;\n        })\n      )\n      .subscribe((downEvent) => {\n        this.dragging = true;\n        this.rect = this.el.nativeElement.getBoundingClientRect();\n        // console.log('mouse down', downEvent, this.rect);\n        this.point = this.createPoint(downEvent);\n        this.rotateStart.emit(this.point);\n        this.applyRotation();\n\n\n        this.mouseMoveSub = fromEvent(this.el.nativeElement, this.mouseMoveEv).pipe(\n          takeUntil(merge(this.mouseOut$, this.mouseUp$).pipe(\n            tap((upEvent) => {\n              this.rect = this.el.nativeElement.getBoundingClientRect();\n              // console.log('mouse up', upEvent, this.rect);\n              this.dragging = false;\n              this.mouseMoveSub.unsubscribe();\n              this.rotateStop.emit(this.point);\n            })\n          ))\n        ).subscribe((moveEvent: MouseEvent) => {\n          this.rect = this.el.nativeElement.getBoundingClientRect();\n          // console.log('mouse move', moveEvent, this.rect);\n\n          this.point = this.createPoint(moveEvent);\n          // console.log(this.point);\n          this.applyRotation();\n        });\n      });\n  }\n\n  public initialRender() {\n    const angle = this.angle + 90;\n    this.renderer.setStyle(this.el.nativeElement, 'transform', `rotate(${angle}deg)`);\n  }\n\n  public rotationRender() {\n    // console.log(this.rotation);\n    this.renderer.setStyle(this.el.nativeElement, 'transform', `rotate(${this.rotation}deg)`);\n  }\n\n  ngOnDestroy() {\n    if (this.mouseDownSub) {\n      this.mouseDownSub.unsubscribe();\n    }\n    if (this.mouseMoveSub) {\n      this.mouseMoveSub.unsubscribe();\n    }\n    if (this.mouseUpSub) {\n      this.mouseUpSub.unsubscribe();\n    }\n    // console.log('directive destroy');\n  }\n\n\n\n  private applyRotation() {\n    const quadrant = calculateQuadrant(this.point);\n    const rotation = determineCSSRotationAngle(this.point, quadrant);\n    // console.log(rotation);\n    this.rotating.emit(rotation);\n    this.rotation = rotation;\n    requestAnimationFrame(this.rotationRender.bind(this));\n\n  }\n\n  private createPoint(mouseEvent) {\n    let point;\n    if (mouseEvent.targetTouches) {\n      point = {\n        x: this._normalizeX(mouseEvent.targetTouches[0].clientX),\n        y: this._normalizeY(mouseEvent.targetTouches[0].clientY)\n      };\n    } else {\n      point = {\n        x: this._normalizeX(mouseEvent.clientX),\n        y: this._normalizeY(mouseEvent.clientY)\n      };\n    }\n    // console.log('point', point);\n    return point;\n  }\n\n  private _normalizeX(coordX) {\n    return coordX - this.rect.left - this.rect.width / 2;\n  }\n\n  private _normalizeY(coordY) {\n    return ((coordY - this.rect.top) * -1) + this.rect.height / 2;\n  }\n\n}\n"]}