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]
106 lines • 14.7 kB
JavaScript
import { Attribute, Component, Input, Optional, ViewEncapsulation } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { mixinDisable, mixinFocus, mixinSize, mixinColor, mixinClassName, Color, Size } from '../../core';
import * as i0 from "@angular/core";
import * as i1 from "../../core";
import * as i2 from "../button/button.component";
import * as i3 from "../../icon/icon/icon.component";
import * as i4 from "@angular/common";
const SbSelectButtonCore = mixinDisable(mixinFocus(mixinSize(mixinColor(mixinClassName(class {
constructor(_elementRef, _themeService) {
this._elementRef = _elementRef;
this._themeService = _themeService;
}
}, 'sb-select-button'), Color.PRIMARY), Size.MEDIUM)));
export class SbSelectButtonComponent extends SbSelectButtonCore {
constructor(elementRef, themeService, pill, plain) {
super(elementRef, themeService);
this.plain = false;
this.pill = false;
this.open = false;
this.options = new Array();
this.onChange = () => { };
this.onTouch = () => { };
this.innerValue = undefined;
if (pill == '')
this.pill = true;
if (plain == '')
this.plain = true;
}
set isPill(isPill) {
this.pill = isPill;
}
set isPlain(isPlain) {
this.plain = isPlain;
}
set value(value) {
if (value !== this.innerValue && !this.disabled) {
this.innerValue = value;
this.onChange(value);
}
}
get value() {
if (this.innerValue) {
return this.innerValue;
}
else
return '';
}
toggle() {
this.open = !this.open;
}
select(newOption) {
this.toggle();
this.value = newOption;
}
writeValue(value) {
if (value !== this.innerValue && !this.disabled) {
this.innerValue = value;
}
}
registerOnChange(fn) { this.onChange = fn; }
registerOnTouched(fn) { this.onTouch = fn; }
onBlur() { this.onTouch(); }
}
SbSelectButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbSelectButtonComponent, deps: [{ token: i0.ElementRef }, { token: i1.SbThemeService }, { token: 'pill', attribute: true, optional: true }, { token: 'plain', attribute: true, optional: true }], target: i0.ɵɵFactoryTarget.Component });
SbSelectButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: SbSelectButtonComponent, selector: "sb-select-button", inputs: { size: "size", color: "color", disabled: "disabled", isPill: "isPill", isPlain: "isPlain", options: "options" }, outputs: { focus: "focus", blur: "blur" }, host: { properties: { "class.pill": "pill", "class.plain": "plain", "class.open": "open" } }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SbSelectButtonComponent,
multi: true
}], usesInheritance: true, ngImport: i0, template: "<button\n type=\"button\"\n [color]=\"color\"\n [size]=\"size\"\n [isPlain]=\"plain\"\n [isPill]=\"pill\"\n (focus)=\"setFocusedState(true)\"\n (blur)=\"setFocusedState(false)\"\n [disabled]=\"disabled\"\n (click)=\"toggle()\">\n {{ value }}\n <ng-content *ngIf=\"!value\"></ng-content>\n <sb-icon></sb-icon>\n</button>\n<div [ngClass]=\"className + '__options-wrapper'\">\n <div [ngClass]=\"className + '__options'\">\n <div\n [ngClass]=\"className + '__option'\"\n *ngFor=\"let option of options\"\n (click)=\"select(option)\">\n {{ option }}\n </div>\n </div>\n</div>\n", components: [{ type: i2.SbButtonComponent, selector: "button, [sb-button]", inputs: ["size", "color", "isRound", "isPill", "isPlain", "type"] }, { type: i3.SbIconComponent, selector: "sb-icon", inputs: ["size", "color", "icon", "isOutline"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbSelectButtonComponent, decorators: [{
type: Component,
args: [{ selector: 'sb-select-button', encapsulation: ViewEncapsulation.None, host: {
'[class.pill]': 'pill',
'[class.plain]': 'plain',
'[class.open]': 'open'
}, inputs: [
'size',
'color',
'disabled'
], outputs: [
'focus',
'blur'
], providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SbSelectButtonComponent,
multi: true
}], template: "<button\n type=\"button\"\n [color]=\"color\"\n [size]=\"size\"\n [isPlain]=\"plain\"\n [isPill]=\"pill\"\n (focus)=\"setFocusedState(true)\"\n (blur)=\"setFocusedState(false)\"\n [disabled]=\"disabled\"\n (click)=\"toggle()\">\n {{ value }}\n <ng-content *ngIf=\"!value\"></ng-content>\n <sb-icon></sb-icon>\n</button>\n<div [ngClass]=\"className + '__options-wrapper'\">\n <div [ngClass]=\"className + '__options'\">\n <div\n [ngClass]=\"className + '__option'\"\n *ngFor=\"let option of options\"\n (click)=\"select(option)\">\n {{ option }}\n </div>\n </div>\n</div>\n" }]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.SbThemeService }, { type: undefined, decorators: [{
type: Optional
}, {
type: Attribute,
args: ['pill']
}] }, { type: undefined, decorators: [{
type: Optional
}, {
type: Attribute,
args: ['plain']
}] }]; }, propDecorators: { isPill: [{
type: Input
}], isPlain: [{
type: Input
}], options: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-button.component.js","sourceRoot":"","sources":["../../../../../../sb-element/src/lib/forms/select-button/select-button.component.ts","../../../../../../sb-element/src/lib/forms/select-button/select-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAc,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACrG,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAkB,YAAY,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,cAAc,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;;;;;;AAE1H,MAAM,kBAAkB,GAAG,YAAY,CACrC,UAAU,CACR,SAAS,CACP,UAAU,CACR,cAAc,CACZ;IACE,YACS,WAAuB,EACvB,aAA6B;QAD7B,gBAAW,GAAX,WAAW,CAAY;QACvB,kBAAa,GAAb,aAAa,CAAgB;IAAG,CAAC;CAC3C,EAAE,kBAAkB,CACtB,EAAE,KAAK,CAAC,OAAO,CACjB,EAAE,IAAI,CAAC,MAAM,CACf,CACF,CACF,CAAC;AA0BF,MAAM,OAAO,uBAAwB,SAAQ,kBAAkB;IAqC7D,YACE,UAAsB,EACtB,YAA4B,EACG,IAAS,EACR,KAAU;QAE1C,KAAK,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QA/B3B,UAAK,GAAY,KAAK,CAAC;QACvB,SAAI,GAAY,KAAK,CAAC;QACtB,SAAI,GAAY,KAAK,CAAC;QAGtB,YAAO,GAAkB,IAAI,KAAK,EAAU,CAAC;QAE5C,aAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QACzB,YAAO,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QAExB,eAAU,GAAuB,SAAS,CAAC;QAsBjD,IAAI,IAAI,IAAI,EAAE;YAAE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjC,IAAI,KAAK,IAAI,EAAE;YAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACrC,CAAC;IA5CD,IACI,MAAM,CAAC,MAAe;QACxB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;IACrB,CAAC;IAED,IACI,OAAO,CAAC,OAAgB;QAC1B,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC;IACvB,CAAC;IAcD,IAAI,KAAK,CAAC,KAAa;QACrB,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC/C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACtB;IACH,CAAC;IAED,IAAI,KAAK;QACP,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC;SACxB;;YAAM,OAAO,EAAE,CAAC;IACnB,CAAC;IAaM,MAAM;QACX,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;IACzB,CAAC;IAEM,MAAM,CAAC,SAAiB;QAC7B,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACzB,CAAC;IAEM,UAAU,CAAC,KAAa;QAC7B,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC/C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;SACzB;IACH,CAAC;IAEM,gBAAgB,CAAC,EAAO,IAAU,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA,CAAC,CAAC;IACtD,iBAAiB,CAAC,EAAO,IAAU,IAAI,CAAC,OAAO,GAAG,EAAE,CAAA,CAAC,CAAC;IACtD,MAAM,KAAW,IAAI,CAAC,OAAO,EAAE,CAAA,CAAC,CAAC;;oHAjE7B,uBAAuB,0EAwCT,MAAM,8CACN,OAAO;wGAzCrB,uBAAuB,8SANvB,CAAC;YACV,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,uBAAuB;YACpC,KAAK,EAAE,IAAI;SACZ,CAAC,iDC1CJ,gnBAwBA;2FDoBa,uBAAuB;kBAxBnC,SAAS;+BACE,kBAAkB,iBAEb,iBAAiB,CAAC,IAAI,QAC/B;wBACJ,cAAc,EAAE,MAAM;wBACtB,eAAe,EAAE,OAAO;wBACxB,cAAc,EAAE,MAAM;qBACvB,UACO;wBACN,MAAM;wBACN,OAAO;wBACP,UAAU;qBACX,WACQ;wBACP,OAAO;wBACP,MAAM;qBACP,aACU,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,yBAAyB;4BACpC,KAAK,EAAE,IAAI;yBACZ,CAAC;;0BA0CC,QAAQ;;0BAAI,SAAS;2BAAC,MAAM;;0BAC5B,QAAQ;;0BAAI,SAAS;2BAAC,OAAO;4CAtC5B,MAAM;sBADT,KAAK;gBAMF,OAAO;sBADV,KAAK;gBAUC,OAAO;sBADb,KAAK","sourcesContent":["import { Attribute, Component, ElementRef, Input, Optional, ViewEncapsulation } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { SbThemeService, mixinDisable, mixinFocus, mixinSize, mixinColor, mixinClassName, Color, Size } from '../../core';\n\nconst SbSelectButtonCore = mixinDisable(\n  mixinFocus(\n    mixinSize(\n      mixinColor(\n        mixinClassName(\n          class {\n            constructor(\n              public _elementRef: ElementRef,\n              public _themeService: SbThemeService) {}\n          }, 'sb-select-button'\n        ), Color.PRIMARY\n      ), Size.MEDIUM\n    )\n  )\n);\n\n@Component({\n  selector: 'sb-select-button',\n  templateUrl: './select-button.component.html',\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[class.pill]': 'pill',\n    '[class.plain]': 'plain',\n    '[class.open]': 'open'\n  },\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: SbSelectButtonComponent,\n    multi: true\n  }]\n})\nexport class SbSelectButtonComponent extends SbSelectButtonCore implements ControlValueAccessor {\n\n  @Input()\n  set isPill(isPill: boolean) {\n    this.pill = isPill;\n  }\n\n  @Input()\n  set isPlain(isPlain: boolean) {\n    this.plain = isPlain;\n  }\n\n  public plain: boolean = false;\n  public pill: boolean = false;\n  public open: boolean = false;\n\n  @Input()\n  public options: Array<string> = new Array<string>();\n\n  private onChange: any = () => {};\n  private onTouch: any = () => {};\n\n  private innerValue: string | undefined = undefined;\n\n  set value(value: string) {\n    if (value !== this.innerValue && !this.disabled) {\n      this.innerValue = value;\n      this.onChange(value);\n    }\n  }\n\n  get value(): string {\n    if (this.innerValue) {\n      return this.innerValue;\n    } else return '';\n  }\n\n  constructor(\n    elementRef: ElementRef,\n    themeService: SbThemeService,\n    @Optional() @Attribute('pill') pill: any,\n    @Optional() @Attribute('plain') plain: any\n  ) {\n    super(elementRef, themeService);\n    if (pill == '') this.pill = true;\n    if (plain == '') this.plain = true;\n  }\n\n  public toggle(): void {\n    this.open = !this.open;\n  }\n\n  public select(newOption: string) {\n    this.toggle();\n    this.value = newOption;\n  }\n\n  public writeValue(value: string): void {\n    if (value !== this.innerValue && !this.disabled) {\n      this.innerValue = value;\n    }\n  }\n\n  public registerOnChange(fn: any): void { this.onChange = fn }\n  public registerOnTouched(fn: any): void { this.onTouch = fn }\n  public onBlur(): void { this.onTouch() }\n}\n","<button\n  type=\"button\"\n  [color]=\"color\"\n  [size]=\"size\"\n  [isPlain]=\"plain\"\n  [isPill]=\"pill\"\n  (focus)=\"setFocusedState(true)\"\n  (blur)=\"setFocusedState(false)\"\n  [disabled]=\"disabled\"\n  (click)=\"toggle()\">\n  {{ value }}\n  <ng-content *ngIf=\"!value\"></ng-content>\n  <sb-icon>&#xe5cf;</sb-icon>\n</button>\n<div [ngClass]=\"className + '__options-wrapper'\">\n  <div [ngClass]=\"className + '__options'\">\n    <div\n      [ngClass]=\"className + '__option'\"\n      *ngFor=\"let option of options\"\n      (click)=\"select(option)\">\n        {{ option }}\n    </div>\n  </div>\n</div>\n"]}