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]

125 lines 17.9 kB
import { Component, Input } 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 "../input-core/input-core.component"; import * as i4 from "@angular/common"; import * as i5 from "@angular/forms"; const SbDoubleInputCore = mixinDisable(mixinFocus(mixinSize(mixinColor(mixinClassName(class { constructor(_elementRef, _themeService) { this._elementRef = _elementRef; this._themeService = _themeService; } }, 'sb-input'), Color.PRIMARY), Size.MEDIUM))); export class SbDoubleInput { constructor(first, second) { if (first) { this.first = first; } if (second) { this.second = second; } } static equals(inputOne, inputTwo) { return inputOne.first == inputTwo.first && inputOne.second == inputTwo.second; } } export class SbDoubleInputComponent extends SbDoubleInputCore { constructor(elementRef, themeService) { super(elementRef, themeService); this.firstPlaceholder = ''; this.secondPlaceholder = ''; this.delimiter = ':'; this._type = 'text'; this.spellcheck = false; this.prefixIcon = ''; this.suffixIcon = ''; this.onChange = () => { }; this.onTouch = () => { }; this.innerFirstValue = undefined; this.innerSecondValue = undefined; } set type(type) { if (type != 'double') { this._type = type; } } get type() { return this._type; } set firstValue(firstValue) { let value = new SbDoubleInput(firstValue, this.innerSecondValue); this.writeValue(value); this.onChange(value); } get firstValue() { if (this.innerFirstValue) { return this.innerFirstValue; } else return ''; } set secondValue(secondValue) { let value = new SbDoubleInput(this.innerFirstValue, secondValue); this.writeValue(value); this.onChange(value); } get secondValue() { if (this.innerSecondValue) { return this.innerSecondValue; } else return ''; } writeValue(value) { if (value && !this.disabled) { if (value.first) { this.innerFirstValue = value.first; } if (value.second) { this.innerSecondValue = value.second; } } } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouch = fn; } onBlur() { this.onTouch(); } } SbDoubleInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbDoubleInputComponent, deps: [{ token: i0.ElementRef }, { token: i1.SbThemeService }], target: i0.ɵɵFactoryTarget.Component }); SbDoubleInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: SbDoubleInputComponent, selector: "sb-input[type=double]", inputs: { size: "size", color: "color", disabled: "disabled", firstPlaceholder: "firstPlaceholder", secondPlaceholder: "secondPlaceholder", delimiter: "delimiter", type: "type", spellcheck: "spellcheck", prefixIcon: "prefixIcon", suffixIcon: "suffixIcon" }, outputs: { focus: "focus", blur: "blur" }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: SbDoubleInputComponent, multi: true }], usesInheritance: true, ngImport: i0, template: "<div [ngClass]=\"className + '__border'\"></div>\n<sb-icon\n *ngIf=\"prefixIcon\"\n [ngClass]=\"className + '__prefix'\"\n [icon]=\"prefixIcon\"\n size=\"s\">\n</sb-icon>\n<sb-input-core\n [size]=\"size\"\n [color]=\"color\"\n [placeholder]=\"firstPlaceholder\"\n [type]=\"type\"\n [(ngModel)]=\"firstValue\"\n [spellcheck]=\"spellcheck\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n</sb-input-core>\n<div [ngClass]=\"className + '__delimiter'\">\n {{ delimiter }}\n</div>\n<sb-input-core\n [size]=\"size\"\n [color]=\"color\"\n [placeholder]=\"secondPlaceholder\"\n [type]=\"type\"\n [(ngModel)]=\"secondValue\"\n [spellcheck]=\"spellcheck\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n</sb-input-core>\n<sb-icon\n *ngIf=\"suffixIcon\"\n [ngClass]=\"className + '__suffix'\"\n [icon]=\"suffixIcon\"\n size=\"s\">\n</sb-icon>\n", components: [{ type: i2.SbIconComponent, selector: "sb-icon", inputs: ["size", "color", "icon", "isOutline"] }, { type: i3.SbInputCoreComponent, selector: "sb-input-core", inputs: ["size", "color", "disabled", "placeholder", "type", "spellcheck"], outputs: ["focus", "blur"] }], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbDoubleInputComponent, decorators: [{ type: Component, args: [{ selector: 'sb-input[type=double]', inputs: [ 'size', 'color', 'disabled' ], outputs: [ 'focus', 'blur' ], providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: SbDoubleInputComponent, multi: true }], template: "<div [ngClass]=\"className + '__border'\"></div>\n<sb-icon\n *ngIf=\"prefixIcon\"\n [ngClass]=\"className + '__prefix'\"\n [icon]=\"prefixIcon\"\n size=\"s\">\n</sb-icon>\n<sb-input-core\n [size]=\"size\"\n [color]=\"color\"\n [placeholder]=\"firstPlaceholder\"\n [type]=\"type\"\n [(ngModel)]=\"firstValue\"\n [spellcheck]=\"spellcheck\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n</sb-input-core>\n<div [ngClass]=\"className + '__delimiter'\">\n {{ delimiter }}\n</div>\n<sb-input-core\n [size]=\"size\"\n [color]=\"color\"\n [placeholder]=\"secondPlaceholder\"\n [type]=\"type\"\n [(ngModel)]=\"secondValue\"\n [spellcheck]=\"spellcheck\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n</sb-input-core>\n<sb-icon\n *ngIf=\"suffixIcon\"\n [ngClass]=\"className + '__suffix'\"\n [icon]=\"suffixIcon\"\n size=\"s\">\n</sb-icon>\n" }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.SbThemeService }]; }, propDecorators: { firstPlaceholder: [{ type: Input }], secondPlaceholder: [{ type: Input }], delimiter: [{ type: Input }], type: [{ type: Input }], spellcheck: [{ type: Input }], prefixIcon: [{ type: Input }], suffixIcon: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"double-input.component.js","sourceRoot":"","sources":["../../../../../../../sb-element/src/lib/forms/input/double-input/double-input.component.ts","../../../../../../../sb-element/src/lib/forms/input/double-input/double-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Color, mixinClassName, mixinColor, mixinDisable, mixinFocus, mixinSize, Size, SbThemeService } from '../../../core';\n\nconst SbDoubleInputCore = mixinDisable(\n  mixinFocus(\n    mixinSize(\n      mixinColor(\n        mixinClassName(\n          class {\n            constructor(\n              public _elementRef: ElementRef,\n              public _themeService: SbThemeService) {}\n          }, 'sb-input'\n        ), Color.PRIMARY\n      ), Size.MEDIUM\n    )\n  )\n);\n\nexport class SbDoubleInput<T> {\n  public first?: T;\n  public second?: T;\n\n  constructor();\n  constructor(first: T | undefined, second: T | undefined);\n  constructor(first?: T, second?: T) {\n    if (first) {\n      this.first = first;\n    }\n    if (second) {\n      this.second = second;\n    }\n  }\n\n  public static equals<T>(inputOne: SbDoubleInput<T>, inputTwo: SbDoubleInput<T>): boolean {\n    return inputOne.first == inputTwo.first && inputOne.second == inputTwo.second;\n  }\n}\n\n@Component({\n  selector: 'sb-input[type=double]',\n  templateUrl: './double-input.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: SbDoubleInputComponent,\n    multi: true\n  }]\n})\nexport class SbDoubleInputComponent extends SbDoubleInputCore implements ControlValueAccessor {\n\n  @Input()\n  public firstPlaceholder: string = '';\n\n  @Input()\n  public secondPlaceholder: string = '';\n\n  @Input()\n  public delimiter: string = ':';\n\n  public _type: string = 'text';\n  @Input()\n  set type(type: string) {\n    if (type != 'double') {\n      this._type = type;\n    }\n  }\n  get type(): string {\n    return this._type;\n  }\n\n  @Input()\n  public spellcheck: boolean = false;\n\n  @Input()\n  public prefixIcon: string = '';\n  @Input()\n  public suffixIcon: string = '';\n\n  private onChange: any = () => {};\n  private onTouch: any = () => {};\n\n  private innerFirstValue: string | undefined = undefined;\n  private innerSecondValue: string | undefined = undefined;\n\n  set firstValue(firstValue: string) {\n    let value = new SbDoubleInput(firstValue, this.innerSecondValue);\n    this.writeValue(value);\n    this.onChange(value);\n  }\n  get firstValue(): string {\n    if (this.innerFirstValue) {\n      return this.innerFirstValue;\n    } else return '';\n  }\n\n  set secondValue(secondValue: string) {\n    let value = new SbDoubleInput(this.innerFirstValue, secondValue);\n    this.writeValue(value);\n    this.onChange(value);\n  }\n\n  get secondValue(): string {\n    if (this.innerSecondValue) {\n      return this.innerSecondValue;\n    } else return '';\n  }\n\n  constructor(\n    elementRef: ElementRef,\n    themeService: SbThemeService\n  ) {\n    super(elementRef, themeService);\n  }\n\n  public writeValue(value: SbDoubleInput<string>): void {\n    if (value && !this.disabled) {\n      if (value.first) {\n        this.innerFirstValue = value.first;\n      }\n      if (value.second) {\n        this.innerSecondValue = value.second;\n      }\n    }\n  }\n\n  public registerOnChange(fn: any): void { this.onChange = fn }\n  public registerOnTouched(fn: any): void { this.onTouch = fn }\n  protected onBlur(): void { this.onTouch() }\n\n}\n","<div [ngClass]=\"className + '__border'\"></div>\n<sb-icon\n  *ngIf=\"prefixIcon\"\n  [ngClass]=\"className + '__prefix'\"\n  [icon]=\"prefixIcon\"\n  size=\"s\">\n</sb-icon>\n<sb-input-core\n  [size]=\"size\"\n  [color]=\"color\"\n  [placeholder]=\"firstPlaceholder\"\n  [type]=\"type\"\n  [(ngModel)]=\"firstValue\"\n  [spellcheck]=\"spellcheck\"\n  (blur)=\"setFocusedState(false)\"\n  (focus)=\"setFocusedState(true)\"\n  [disabled]=\"disabled\">\n</sb-input-core>\n<div [ngClass]=\"className + '__delimiter'\">\n  {{ delimiter }}\n</div>\n<sb-input-core\n  [size]=\"size\"\n  [color]=\"color\"\n  [placeholder]=\"secondPlaceholder\"\n  [type]=\"type\"\n  [(ngModel)]=\"secondValue\"\n  [spellcheck]=\"spellcheck\"\n  (blur)=\"setFocusedState(false)\"\n  (focus)=\"setFocusedState(true)\"\n  [disabled]=\"disabled\">\n</sb-input-core>\n<sb-icon\n  *ngIf=\"suffixIcon\"\n  [ngClass]=\"className + '__suffix'\"\n  [icon]=\"suffixIcon\"\n  size=\"s\">\n</sb-icon>\n"]}