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
JavaScript
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()\"></sb-icon>\n <sb-icon\n [ngClass]=\"className + '__spinner-control'\"\n (mousedown)=\"handleMouseDownDecrease()\"\n (mouseup)=\"handleMouseUp()\"></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()\"></sb-icon>\n <sb-icon\n [ngClass]=\"className + '__spinner-control'\"\n (mousedown)=\"handleMouseDownDecrease()\"\n (mouseup)=\"handleMouseUp()\"></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"]}