UNPKG

sb-element

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 12.0.1. It is a component library constructed around the SCSS library [Sb-Theming](https://github.com/SeverinBuchser/SbTheming) and supports [Angular Schematics]

177 lines 23.8 kB
import { Component, EventEmitter, Input, Output } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { Color, mixinClassName, mixinColor, mixinDisable, mixinFocus, mixinSize, Size } from '../../../core'; import * as i0 from "@angular/core"; import * as i1 from "../../../core"; import * as i2 from "../../../icon/icon/icon.component"; import * as i3 from "@angular/forms"; import * as i4 from "@angular/common"; const SbNumberInputCoreCore = mixinDisable(mixinFocus(mixinSize(mixinColor(mixinClassName(class { constructor(_elementRef, _themeService) { this._elementRef = _elementRef; this._themeService = _themeService; } }, 'sb-input-core'), Color.PRIMARY), Size.MEDIUM))); export class SbNumberInputCoreComponent extends SbNumberInputCoreCore { constructor(elementRef, themeService) { super(elementRef, themeService); this.placeholder = ''; this.min = Number.MIN_SAFE_INTEGER; this.max = Number.MAX_SAFE_INTEGER; this.prefixIcon = ''; this.suffixIcon = ''; this.overflow = new EventEmitter(); this.underflow = new EventEmitter(); this.intervals = new Array(); this.isMouseDown = false; this.steps = 0; this.speed = 0; this.delta = 1; this.innerValue = undefined; this.onChange = () => { }; this.onTouch = () => { }; this.increase = () => { let newValue; if (this.value != undefined) { newValue = this.value + this.delta; } else if (this.max >= 0) { newValue = 0; } else { newValue = this.max; } if (newValue > this.max) { newValue = this.min; this.steps = 0; this.speed = 0; this.delta = 1; this.overflow.emit(); } this.steps++; this.value = newValue; }; this.decrease = () => { let newValue; if (this.value != undefined) { newValue = this.value - this.delta; } else if (this.min <= 0) { newValue = 0; } else { newValue = this.min; } if (newValue < this.min) { newValue = this.max; this.steps = 0; this.speed = 0; this.delta = 1; this.underflow.emit(); } this.steps++; this.value = newValue; }; } set value(value) { this.writeValue(value); this.onChange(value); } get value() { return this.innerValue; } handleMouseDownIncrease() { this.handleMouseDown(this.increase); } handleMouseDownDecrease() { this.handleMouseDown(this.decrease); } handleMouseDown(stepFunction) { this.isMouseDown = true; stepFunction(); this.wait(400).then(() => { if (this.isMouseDown) { this.intervals.push(setInterval(() => { stepFunction(); this.updateSpeed(); }, 30)); } }); } updateSpeed() { if (this.speed < SbNumberInputCoreComponent.MAX_SPEED && this.steps == SbNumberInputCoreComponent.MAX_STEP) { this.speed += 1; this.delta = Math.pow(SbNumberInputCoreComponent.SPEED_FACTOR, this.speed); this.steps = 0; } } handleMouseUp() { this.isMouseDown = false; this.intervals.forEach((interval) => clearInterval(interval)); this.steps = 0; this.speed = 0; this.delta = 1; } async wait(time) { return new Promise(resolve => { let timeout = setTimeout(() => { resolve(); clearTimeout(timeout); }, time); }); } getPlaceholderClasses() { let classes = new Array(); classes.push(this.className + '__placeholder'); classes.push(this.value || this.value == 0 || this.focused ? 'top' : ''); return classes; } writeValue(value) { if (value !== this.innerValue && !this.disabled) { this.innerValue = value; } } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouch = fn; } onBlur() { this.onTouch(); } } SbNumberInputCoreComponent.SPEED_FACTOR = 2; SbNumberInputCoreComponent.MAX_SPEED = 10; SbNumberInputCoreComponent.MAX_STEP = Math.pow(SbNumberInputCoreComponent.SPEED_FACTOR, 7); SbNumberInputCoreComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbNumberInputCoreComponent, deps: [{ token: i0.ElementRef }, { token: i1.SbThemeService }], target: i0.ɵɵFactoryTarget.Component }); SbNumberInputCoreComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: SbNumberInputCoreComponent, selector: "sb-input-core[type=number]", inputs: { size: "size", color: "color", disabled: "disabled", placeholder: "placeholder", min: "min", max: "max", prefixIcon: "prefixIcon", suffixIcon: "suffixIcon" }, outputs: { focus: "focus", blur: "blur", overflow: "overflow", underflow: "underflow" }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: SbNumberInputCoreComponent, multi: true }], usesInheritance: true, ngImport: i0, template: "<input\n type=\"number\"\n [(ngModel)]=\"value\"\n [spellcheck]=\"false\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n<div [ngClass]=\"getPlaceholderClasses()\">\n {{ placeholder }}\n</div>\n<div [ngClass]=\"className + '__spinner-controls'\">\n <sb-icon\n [ngClass]=\"className + '__spinner-control'\"\n (mousedown)=\"handleMouseDownIncrease()\"\n (mouseup)=\"handleMouseUp()\">&#xe5e1;</sb-icon>\n <sb-icon\n [ngClass]=\"className + '__spinner-control'\"\n (mousedown)=\"handleMouseDownDecrease()\"\n (mouseup)=\"handleMouseUp()\">&#xe2ea;</sb-icon>\n</div>\n", components: [{ type: i2.SbIconComponent, selector: "sb-icon", inputs: ["size", "color", "icon", "isOutline"] }], directives: [{ type: i3.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbNumberInputCoreComponent, decorators: [{ type: Component, args: [{ selector: 'sb-input-core[type=number]', inputs: [ 'size', 'color', 'disabled' ], outputs: [ 'focus', 'blur' ], providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: SbNumberInputCoreComponent, multi: true }], template: "<input\n type=\"number\"\n [(ngModel)]=\"value\"\n [spellcheck]=\"false\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n<div [ngClass]=\"getPlaceholderClasses()\">\n {{ placeholder }}\n</div>\n<div [ngClass]=\"className + '__spinner-controls'\">\n <sb-icon\n [ngClass]=\"className + '__spinner-control'\"\n (mousedown)=\"handleMouseDownIncrease()\"\n (mouseup)=\"handleMouseUp()\">&#xe5e1;</sb-icon>\n <sb-icon\n [ngClass]=\"className + '__spinner-control'\"\n (mousedown)=\"handleMouseDownDecrease()\"\n (mouseup)=\"handleMouseUp()\">&#xe2ea;</sb-icon>\n</div>\n" }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.SbThemeService }]; }, propDecorators: { placeholder: [{ type: Input }], min: [{ type: Input }], max: [{ type: Input }], prefixIcon: [{ type: Input }], suffixIcon: [{ type: Input }], overflow: [{ type: Output }], underflow: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input-core.component.js","sourceRoot":"","sources":["../../../../../../../sb-element/src/lib/forms/number-input/number-input-core/number-input-core.component.ts","../../../../../../../sb-element/src/lib/forms/number-input/number-input-core/number-input-core.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Color, mixinClassName, mixinColor, mixinDisable, mixinFocus, mixinSize, Size, SbThemeService } from '../../../core';\n\nconst SbNumberInputCoreCore = mixinDisable(\n  mixinFocus(\n    mixinSize(\n      mixinColor(\n        mixinClassName(\n          class {\n            constructor(\n              public _elementRef: ElementRef,\n              public _themeService: SbThemeService) {}\n          }, 'sb-input-core'\n        ), Color.PRIMARY\n      ), Size.MEDIUM\n    )\n  )\n);\n\n@Component({\n  selector: 'sb-input-core[type=number]',\n  templateUrl: './number-input-core.component.html',\n  inputs: [\n    'size',\n    'color',\n    'disabled'\n  ],\n  outputs: [\n    'focus',\n    'blur'\n  ],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: SbNumberInputCoreComponent,\n    multi: true\n  }]\n})\nexport class SbNumberInputCoreComponent extends SbNumberInputCoreCore implements ControlValueAccessor {\n\n  @Input()\n  public placeholder: string = '';\n\n  @Input()\n  public min: number = Number.MIN_SAFE_INTEGER;\n  @Input()\n  public max: number = Number.MAX_SAFE_INTEGER;\n\n  @Input()\n  public prefixIcon: string = '';\n  @Input()\n  public suffixIcon: string = '';\n\n  @Output()\n  public overflow: EventEmitter<void> = new EventEmitter<void>();\n  @Output()\n  public underflow: EventEmitter<void> = new EventEmitter<void>();\n\n  private intervals: Array<number> = new Array<number>();\n  private isMouseDown: boolean = false;\n  private static SPEED_FACTOR: number = 2;\n  private static MAX_SPEED: number = 10;\n  private static MAX_STEP: number =  Math.pow(SbNumberInputCoreComponent.SPEED_FACTOR, 7);\n  private steps: number = 0;\n  private speed: number = 0;\n  private delta: number = 1;\n\n  private innerValue: number | undefined = undefined;\n\n  set value(value: number | undefined) {\n    this.writeValue(value);\n    this.onChange(value);\n  }\n\n  get value(): number | undefined {\n    return this.innerValue;\n  }\n\n  private onChange: any = () => {};\n  private onTouch: () => void = () => {};\n\n  constructor(\n    elementRef: ElementRef,\n    themeService: SbThemeService\n  ) {\n    super(elementRef, themeService);\n  }\n\n  public handleMouseDownIncrease(): void {\n    this.handleMouseDown(this.increase)\n  }\n\n  public handleMouseDownDecrease(): void {\n    this.handleMouseDown(this.decrease)\n  }\n\n  private handleMouseDown(stepFunction: () => void): void {\n    this.isMouseDown = true;\n    stepFunction();\n    this.wait(400).then(() => {\n      if (this.isMouseDown) {\n        this.intervals.push(setInterval(() => {\n          stepFunction();\n          this.updateSpeed();\n        }, 30));\n      }\n    })\n  }\n\n  private updateSpeed(): void {\n    if (this.speed < SbNumberInputCoreComponent.MAX_SPEED &&\n      this.steps == SbNumberInputCoreComponent.MAX_STEP) {\n      this.speed += 1;\n      this.delta = Math.pow(SbNumberInputCoreComponent.SPEED_FACTOR, this.speed)\n      this.steps = 0;\n    }\n  }\n\n  private increase = () => {\n    let newValue: number;\n    if (this.value != undefined) {\n      newValue = this.value + this.delta;\n    } else if (this.max >= 0) {\n      newValue = 0;\n    } else {\n      newValue = this.max;\n    }\n    if (newValue > this.max) {\n      newValue = this.min;\n      this.steps = 0;\n      this.speed = 0;\n      this.delta = 1;\n      this.overflow.emit();\n    }\n    this.steps++;\n    this.value = newValue;\n  }\n\n  private decrease = () => {\n    let newValue: number;\n    if (this.value != undefined) {\n      newValue = this.value - this.delta;\n    } else if (this.min <= 0) {\n      newValue = 0;\n    } else {\n      newValue = this.min;\n    }\n    if (newValue < this.min) {\n      newValue = this.max;\n      this.steps = 0;\n      this.speed = 0;\n      this.delta = 1;\n      this.underflow.emit();\n    }\n    this.steps++;\n    this.value = newValue;\n  }\n\n  public handleMouseUp(): void {\n    this.isMouseDown = false;\n    this.intervals.forEach((interval: number) => clearInterval(interval));\n    this.steps = 0;\n    this.speed = 0;\n    this.delta = 1;\n  }\n\n  private async wait(time: number): Promise<void> {\n    return new Promise<void>(resolve => {\n      let timeout = setTimeout(() => {\n        resolve();\n        clearTimeout(timeout);\n      }, time);\n    });\n  }\n\n  public getPlaceholderClasses(): Array<string> {\n    let classes = new Array<string>();\n    classes.push(this.className + '__placeholder')\n    classes.push(this.value || this.value == 0 || this.focused ? 'top' : '')\n    return classes;\n  }\n\n  public writeValue(value: number | undefined): void {\n    if (value !== this.innerValue && !this.disabled) {\n      this.innerValue = value;\n    }\n  }\n\n  public registerOnChange(fn: (value: string) => void): void { this.onChange = fn }\n  public registerOnTouched(fn: any): void { this.onTouch = fn }\n  public onBlur(): void { this.onTouch() }\n\n}\n","<input\n  type=\"number\"\n  [(ngModel)]=\"value\"\n  [spellcheck]=\"false\"\n  (blur)=\"setFocusedState(false)\"\n  (focus)=\"setFocusedState(true)\"\n  [disabled]=\"disabled\">\n<div [ngClass]=\"getPlaceholderClasses()\">\n  {{ placeholder }}\n</div>\n<div [ngClass]=\"className + '__spinner-controls'\">\n  <sb-icon\n    [ngClass]=\"className + '__spinner-control'\"\n    (mousedown)=\"handleMouseDownIncrease()\"\n    (mouseup)=\"handleMouseUp()\">&#xe5e1;</sb-icon>\n  <sb-icon\n    [ngClass]=\"className + '__spinner-control'\"\n    (mousedown)=\"handleMouseDownDecrease()\"\n    (mouseup)=\"handleMouseUp()\">&#xe2ea;</sb-icon>\n</div>\n"]}