UNPKG

@kushki/ng-suka

Version:

<p align="center"> <h1 align="center">Suka Components Angular</h1> <p align="center"> An Angular implementation of the Suka Design System </p> </p>

186 lines 15.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, HostBinding, ViewChild, ElementRef, HostListener, Output, EventEmitter, Input } from '@angular/core'; import { hexToRgb, rgbToHsv, rgbToHex } from './color-utils'; export class ColorSlider { constructor() { this.baseClass = true; this.mousedown = false; this.hueChange = new EventEmitter(); } /** * @param {?} evt * @return {?} */ onMouseUp(evt) { this.mousedown = false; } /** * @return {?} */ draw() { if (!this.ctx) { this.ctx = this.canvas.nativeElement.getContext('2d'); } /** @type {?} */ const width = this.canvas.nativeElement.width; /** @type {?} */ const height = this.canvas.nativeElement.height; this.ctx.clearRect(0, 0, width, height); /** @type {?} */ const gradient = this.ctx.createLinearGradient(0, 0, 0, height); gradient.addColorStop(0, 'rgba(255, 0, 0, 1)'); gradient.addColorStop(0.17, 'rgba(255, 255, 0, 1)'); gradient.addColorStop(0.34, 'rgba(0, 255, 0, 1)'); gradient.addColorStop(0.51, 'rgba(0, 255, 255, 1)'); gradient.addColorStop(0.68, 'rgba(0, 0, 255, 1)'); gradient.addColorStop(0.85, 'rgba(255, 0, 255, 1)'); gradient.addColorStop(1, 'rgba(255, 0, 0, 1)'); this.ctx.beginPath(); this.ctx.rect(0, 0, width, height); this.ctx.fillStyle = gradient; this.ctx.fill(); this.ctx.closePath(); if (this.selectedHeight) { this.ctx.beginPath(); this.ctx.strokeStyle = 'white'; this.ctx.lineWidth = 4; this.ctx.rect(0, this.selectedHeight - 5, width, 10); this.ctx.stroke(); this.ctx.closePath(); } } /** * @param {?} evt * @return {?} */ onMouseDown(evt) { this.mousedown = true; this.selectedHeight = evt.offsetY; this.draw(); this.emitHue(evt.offsetY); } /** * @param {?} evt * @return {?} */ onMouseMove(evt) { if (this.mousedown) { this.selectedHeight = evt.offsetY; this.draw(); this.emitHue(evt.offsetY); } } /** * @param {?} y * @return {?} */ emitHue(y) { if (y < 0) { y = 0; } else if (y >= 250) { y = 249; } /** @type {?} */ const color = this.getColorAtPosition(y); this.hueChange.emit(rgbToHex(color.r, color.g, color.b)); } /** * @param {?} y * @return {?} */ getColorAtPosition(y) { /** @type {?} */ const imageData = this.ctx.getImageData(5, y, 1, 1).data; return { r: imageData[0], g: imageData[1], b: imageData[2], }; } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (changes.hue && !changes.hue.isFirstChange()) { /** @type {?} */ const rgbColor = hexToRgb(this.hue); if (rgbColor) { /** @type {?} */ const hsvColor = rgbToHsv(rgbColor.r, rgbColor.g, rgbColor.b); /** @type {?} */ const hueFactor = hsvColor.h / 360; this.selectedHeight = hueFactor * 250; this.draw(); } } } /** * @return {?} */ ngAfterViewInit() { if (this.hue) { /** @type {?} */ const rgbColor = hexToRgb(this.hue); /** @type {?} */ const hsvColor = rgbToHsv(rgbColor.r, rgbColor.g, rgbColor.b); /** @type {?} */ const hueFactor = hsvColor.h / 360; this.selectedHeight = hueFactor * 250; } this.draw(); } } ColorSlider.decorators = [ { type: Component, args: [{ selector: 'suka-color-slider', template: ` <canvas #canvas class="color-slider" width="20" height="250" (mousedown)="onMouseDown($event)" (mousemove)="onMouseMove($event)" > </canvas> ` }] } ]; ColorSlider.propDecorators = { baseClass: [{ type: HostBinding, args: ['class.color-slider-wrapper',] }], hue: [{ type: Input }], hueChange: [{ type: Output }], canvas: [{ type: ViewChild, args: ['canvas', { static: false },] }], onMouseUp: [{ type: HostListener, args: ['window:mouseup', ['$event'],] }] }; if (false) { /** @type {?} */ ColorSlider.prototype.baseClass; /** * @type {?} * @private */ ColorSlider.prototype.ctx; /** * @type {?} * @private */ ColorSlider.prototype.mousedown; /** * @type {?} * @private */ ColorSlider.prototype.selectedHeight; /** @type {?} */ ColorSlider.prototype.hue; /** @type {?} */ ColorSlider.prototype.hueChange; /** @type {?} */ ColorSlider.prototype.canvas; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-slider.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/color-picker/color-slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  HostBinding,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  HostListener,\n  Output,\n  EventEmitter,\n  Input,\n  OnChanges,\n  SimpleChanges\n} from '@angular/core';\n\nimport { hexToRgb, rgbToHsv, rgbToHex } from './color-utils';\n\n@Component({\n  selector: 'suka-color-slider',\n  template: `\n    <canvas\n      #canvas\n      class=\"color-slider\"\n      width=\"20\"\n      height=\"250\"\n      (mousedown)=\"onMouseDown($event)\"\n      (mousemove)=\"onMouseMove($event)\"\n    >\n    </canvas>\n  `\n})\nexport class ColorSlider implements OnChanges, AfterViewInit {\n  @HostBinding('class.color-slider-wrapper') baseClass = true;\n  private ctx: CanvasRenderingContext2D;\n  private mousedown = false;\n  private selectedHeight: number;\n\n  @Input() hue: string;\n  @Output() hueChange: EventEmitter<string> = new EventEmitter();\n\n  @ViewChild('canvas', {static: false}) canvas: ElementRef<HTMLCanvasElement>;\n\n  @HostListener('window:mouseup', ['$event'])\n  onMouseUp(evt: MouseEvent) {\n    this.mousedown = false;\n  }\n\n  draw() {\n    if (!this.ctx) {\n      this.ctx = this.canvas.nativeElement.getContext('2d');\n    }\n\n    const width = this.canvas.nativeElement.width;\n    const height = this.canvas.nativeElement.height;\n    this.ctx.clearRect(0, 0, width, height);\n\n    const gradient = this.ctx.createLinearGradient(0, 0, 0, height);\n    gradient.addColorStop(0, 'rgba(255, 0, 0, 1)');\n    gradient.addColorStop(0.17, 'rgba(255, 255, 0, 1)');\n    gradient.addColorStop(0.34, 'rgba(0, 255, 0, 1)');\n    gradient.addColorStop(0.51, 'rgba(0, 255, 255, 1)');\n    gradient.addColorStop(0.68, 'rgba(0, 0, 255, 1)');\n    gradient.addColorStop(0.85, 'rgba(255, 0, 255, 1)');\n    gradient.addColorStop(1, 'rgba(255, 0, 0, 1)');\n\n    this.ctx.beginPath();\n    this.ctx.rect(0, 0, width, height);\n    this.ctx.fillStyle = gradient;\n    this.ctx.fill();\n    this.ctx.closePath();\n\n    if (this.selectedHeight) {\n      this.ctx.beginPath();\n      this.ctx.strokeStyle = 'white';\n      this.ctx.lineWidth = 4;\n      this.ctx.rect(0, this.selectedHeight - 5, width, 10);\n      this.ctx.stroke();\n      this.ctx.closePath();\n    }\n  }\n\n  onMouseDown(evt: MouseEvent) {\n    this.mousedown = true;\n    this.selectedHeight = evt.offsetY;\n    this.draw();\n    this.emitHue(evt.offsetY);\n  }\n\n  onMouseMove(evt: MouseEvent) {\n    if (this.mousedown) {\n      this.selectedHeight = evt.offsetY;\n      this.draw();\n      this.emitHue(evt.offsetY);\n    }\n  }\n\n  emitHue(y: number) {\n    if (y < 0) {\n      y = 0;\n    } else if (y >= 250) {\n      y = 249;\n    }\n    const color = this.getColorAtPosition(y);\n    this.hueChange.emit(rgbToHex(color.r, color.g, color.b));\n  }\n\n  getColorAtPosition(y: number) {\n    const imageData = this.ctx.getImageData(5, y, 1, 1).data;\n    return {\n      r: imageData[0],\n      g: imageData[1],\n      b: imageData[2],\n    };\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.hue && !changes.hue.isFirstChange()) {\n      const rgbColor = hexToRgb(this.hue);\n      if (rgbColor) {\n        const hsvColor = rgbToHsv(rgbColor.r, rgbColor.g, rgbColor.b);\n        const hueFactor = hsvColor.h / 360;\n        this.selectedHeight = hueFactor * 250;\n        this.draw();\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.hue) {\n      const rgbColor = hexToRgb(this.hue);\n      const hsvColor = rgbToHsv(rgbColor.r, rgbColor.g, rgbColor.b);\n      const hueFactor = hsvColor.h / 360;\n      this.selectedHeight = hueFactor * 250;\n    }\n\n    this.draw();\n  }\n}\n"]}