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
JavaScript
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"]}