@festo-ui/angular 5.1.0-dev.180 → 5.1.0-dev.186
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/forms/select/select.component.mjs +3 -1
- package/fesm2015/festo-ui-angular.mjs +2 -0
- package/fesm2015/festo-ui-angular.mjs.map +1 -1
- package/fesm2020/festo-ui-angular.mjs +2 -0
- package/fesm2020/festo-ui-angular.mjs.map +1 -1
- package/lib/forms/select/select.component.d.ts +5 -4
- package/package.json +1 -1
|
@@ -111,6 +111,8 @@ export class FngSelectComponent {
|
|
|
111
111
|
}
|
|
112
112
|
if (this.multiple === true) {
|
|
113
113
|
this._value = value;
|
|
114
|
+
// clear any previous state of overlay panel
|
|
115
|
+
this.checked.clear();
|
|
114
116
|
// set checkmarks in overlay panel, so that it is displayed correctly when user opens it
|
|
115
117
|
value?.forEach((v) => {
|
|
116
118
|
this.checked.set(v, 'checked');
|
|
@@ -270,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImpor
|
|
|
270
272
|
}], fngChange: [{
|
|
271
273
|
type: Output
|
|
272
274
|
}] } });
|
|
273
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/select/select.component.ts","../../../../../../projects/angular/src/lib/forms/select/select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EACL,SAAS,EACT,KAAK,EACL,WAAW,EAEX,iBAAiB,EAEjB,MAAM,EACN,UAAU,EACV,SAAS,EAIT,eAAe,EACf,MAAM,EACN,YAAY,EAGb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,wBAAwB,EAAE,MAAM,yCAAyC,CAAC;AACnF,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;AAsB/B,MAAM,OAAO,kBAAkB;IAQ7B,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,KAAK,CAAC,KAAU;QAClB,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;YAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;gBAChB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;aACpC;iBAAM;gBACL,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;gBAC7B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;aAC/B;SACF;aAAM;YACL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACrB;QAED,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;YACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC3B;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAkCD,YAAwC,QAAa,EAAY,QAAmB,EAAY,EAAqB;QAA7E,aAAQ,GAAR,QAAQ,CAAK;QAAY,aAAQ,GAAR,QAAQ,CAAW;QAAY,OAAE,GAAF,EAAE,CAAmB;QA7E3G,cAAS,GAAG,KAAK,CAAC;QAClB,cAAS,GAAG,KAAK,CAAC;QA+C5B,YAAO,GAAG,KAAK,CAAC;QAGhB,OAAE,GAAG,iBAAiB,EAAE,kBAAkB,CAAC,MAAM,EAAE,CAAC;QAE3C,aAAQ,GAAY,KAAK,CAAC;QAC1B,SAAI,GAAW,CAAC,CAAC;QACjB,YAAO,GAAU,EAAE,CAAC;QAKpB,UAAK,GAAG,EAAE,CAAC;QACX,cAAS,GAAG,KAAK,CAAC;QAClB,SAAI,GAAG,EAAE,CAAC;QAIT,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;QAE9C,uBAAkB,GAAa,CAAC,kBAAkB,CAAC,CAAC;QACpD,gBAAW,GAAG,KAAK,CAAC;QACpB,UAAK,GAAY,KAAK,CAAC;QAEvB,YAAO,GAAG,IAAI,GAAG,EAAE,CAAC;QACpB,wBAAmB,GAAG,KAAK,CAAC;QAC5B,kBAAa,GAAU,EAAE,CAAC;QAClB,aAAQ,GAAqB,IAAI,OAAO,EAAE,CAAC;QAGjD,IAAI,CAAC,IAAI,GAAI,IAAI,CAAC,QAAqB,CAAC,IAAI,CAAC;IAC/C,CAAC;IACD,kBAAkB;QAChB,sEAAsE;QACtE,IAAI,CAAC,gBAAgB,EAAE,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC1E,gCAAgC;YAChC,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,EAAE;YACrB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;SACvE;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;YAC1B,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;SAC3D;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,aAAa,EAAE,qBAAqB,EAAE,EAAE,KAAK,CAAC;QACnF,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,aAAsB;QACrC,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,KAAiB;QAC1B,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,OAAO;SACR;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;YAC1B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,wFAAwF;YACxF,KAAK,EAAE,OAAO,CAAC,CAAC,CAAM,EAAE,EAAE;gBACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACrB;IACH,CAAC;IAED,aAAa,CAAC,KAAa;QACzB,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,IAAI,EAAE;YAClG,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACjD;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,cAAc,CAAC,KAAa;QAC1B,iEAAiE;QACjE,IAAI,IAAI,CAAC,mBAAmB,KAAK,IAAI,EAAE;YACrC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SAC5B;QAED,0CAA0C;QAC1C,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC;QAEvC,IAAI,CAAC,KAAK,SAAS,EAAE;YACnB,OAAO,CAAC,CAAC;SACV;QAED,gEAAgE;QAChE,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,IAAI,EAAE;YACpG,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAClD;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,UAAU,CAAC,KAAU,EAAE,IAAY;QACjC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;IACH,CAAC;IAED,cAAc,CAAC,MAAe;QAC5B,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC;SAC5D;aAAM;YACL,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC;SAC/D;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,MAAM;QACJ,IAAI,KAAK,KAAK,IAAI,CAAC,QAAQ,EAAE;YAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,aAAa,EAAE,qBAAqB,EAAE,EAAE,KAAK,CAAC;YACnF,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;YACrC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC;SAChB;IACH,CAAC;IAED,MAAM,CAAC,KAAU,EAAE,KAAY;QAC7B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YAEnB,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC1B,uBAAuB;gBACvB,IAAI,CAAC,MAAM,EAAE,CAAC;aACf;SACF;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE;gBAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;aAClB;YACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;IACH,CAAC;IAES,oBAAoB;QAC5B,IAAI,IAAI,CAAC,gBAAgB,EAAE,MAAM,EAAE;YACjC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;YAChC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBACxC,SAAS,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;oBAC3B,IAAI,EAAE,EAAE;wBACN,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,WAAW,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;wBAC5E,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;wBACtC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;qBACzB;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IAES,OAAO;QACf,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,EAAE;YAC7D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;SACpB;IACH,CAAC;;AAlPM,yBAAM,GAAG,CAAC,CAAC;+GADP,kBAAkB,kBAgFT,QAAQ;mGAhFjB,kBAAkB,6cARlB;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;YACjD,KAAK,EAAE,IAAI;SACZ;KACF,2DAqEgB,wBAAwB,gICnH3C,s4FAyEA,gmKDtCY,YAAY,yVAAE,eAAe,mDAA4B,aAAa;2FAarE,kBAAkB;kBAf9B,SAAS;iCACI,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,EAAE,wBAAwB,EAAE,aAAa,CAAC,YACvE,YAAY,iBAGP,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACZ;qBACF;;0BAkFY,MAAM;2BAAC,QAAQ;oGAvExB,QAAQ;sBADX,KAAK;gBASF,QAAQ;sBADX,KAAK;gBAsCN,EAAE;sBADD,WAAW;gBAGH,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACqC,gBAAgB;sBAA1D,eAAe;uBAAC,wBAAwB;gBACvB,UAAU;sBAA3B,SAAS;uBAAC,KAAK;gBACN,SAAS;sBAAlB,MAAM","sourcesContent":["import { takeUntil } from 'rxjs/operators';\nimport {\n  Component,\n  Input,\n  HostBinding,\n  OnInit,\n  ViewEncapsulation,\n  Renderer2,\n  Inject,\n  forwardRef,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  QueryList,\n  ContentChildren,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n  AfterContentInit\n} from '@angular/core';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FngSelectOptionComponent } from './select-option/select-option.component';\nimport { FngChipTextPipe } from './chip-text.pipe';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { Subject } from 'rxjs';\n\nexport interface FngSelectOption {\n  value: any;\n  text: string;\n}\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, FngChipTextPipe, FngSelectOptionComponent, OverlayModule],\n  selector: 'fng-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class FngSelectComponent implements ControlValueAccessor, OnInit, AfterViewInit, AfterContentInit {\n  static nextId = 0;\n\n  protected _disabled = false;\n  protected _required = false;\n  protected _value: any;\n  protected body: HTMLElement;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  set value(value: any) {\n    if (this.multiple === true) {\n      const index = this._value.indexOf(value);\n      if (index === -1) {\n        this._value.push(value);\n        this.checked.set(value, 'checked');\n      } else {\n        this._value.splice(index, 1);\n        this.checked.set(value, null);\n      }\n    } else {\n      this._value = value;\n    }\n\n    if (this.onChange != null) {\n      this.onChange(this.value);\n    }\n    this.fngChange.emit(this.value);\n  }\n\n  onChange: ((_: any) => void) | undefined;\n  onTouched: (() => void) | undefined;\n\n  touched = false;\n\n  @HostBinding()\n  id = `input-control-${++FngSelectComponent.nextId}`;\n\n  @Input() multiple: boolean = false;\n  @Input() size: number = 0;\n  @Input() options: any[] = [];\n  @Input() optionsValueKey: string | undefined;\n  @Input() optionsTextKey: string | undefined;\n  @Input() optionObjectAsValue: boolean | undefined;\n  @Input() error: string | undefined;\n  @Input() label = '';\n  @Input() hideLabel = false;\n  @Input() hint = '';\n  @Input() resetOption: string | undefined;\n  @ContentChildren(FngSelectOptionComponent) fngSelectOptions: QueryList<FngSelectOptionComponent> | undefined;\n  @ViewChild('div') elementRef: ElementRef | undefined;\n  @Output() fngChange = new EventEmitter<any>();\n\n  selectPanelClasses: string[] = ['fng-select-panel'];\n  showOptions = false;\n  empty: boolean = false;\n  triggerWidth: any;\n  checked = new Map();\n  hasProjectedOptions = false;\n  projectedHtml: any[] = [];\n  private complete: Subject<boolean> = new Subject();\n\n  constructor(@Inject(DOCUMENT) protected document: any, protected renderer: Renderer2, protected cd: ChangeDetectorRef) {\n    this.body = (this.document as Document).body;\n  }\n  ngAfterContentInit(): void {\n    // observe if any of the projected content (fng-select-option) changes\n    this.fngSelectOptions?.changes.pipe(takeUntil(this.complete)).subscribe(_ => {\n      // if content changes init again\n      this.options = [];\n      this.projectedHtml = [];\n      this.initProjectedOptions();\n    });\n  }\n\n  ngOnInit(): void {\n    if (this.size != null) {\n      this.selectPanelClasses.push('fng-select-panel-options-' + this.size);\n    }\n\n    if (this.multiple === true) {\n      this._value = [];\n      this.selectPanelClasses.push('fng-select-panel-multiple');\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n    this.initProjectedOptions();\n  }\n\n  ngOnDestroy(): void {\n    this.complete.next(true);\n    this.complete.unsubscribe();\n  }\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(shouldDisable: boolean): void {\n    this.disabled = shouldDisable;\n  }\n\n  writeValue(value: any | null): void {\n    if (value === undefined) {\n      return;\n    }\n\n    if (this.multiple === true) {\n      this._value = value;\n      // set checkmarks in overlay panel, so that it is displayed correctly when user opens it\n      value?.forEach((v: any) => {\n        this.checked.set(v, 'checked');\n      });\n    } else {\n      this._value = value;\n    }\n  }\n\n  getOptionText(index: number) {\n    if (this.options[index] && this.optionsTextKey && this.options[index][this.optionsTextKey] != null) {\n      return this.options[index][this.optionsTextKey];\n    }\n    return undefined;\n  }\n\n  getOptionValue(index: number) {\n    // if set to true the complete option object is returned as value\n    if (this.optionObjectAsValue === true) {\n      return this.options[index];\n    }\n\n    // try to access standard property 'value'\n    const v = this.options[index]['value'];\n\n    if (v !== undefined) {\n      return v;\n    }\n\n    // try to map the value to a property of the option by given key\n    if (this.options[index] && this.optionsValueKey && this.options[index][this.optionsValueKey] != null) {\n      return this.options[index][this.optionsValueKey];\n    }\n    return undefined;\n  }\n\n  removeChip(event: any, chip: string) {\n    event.stopPropagation();\n    if (!this._disabled) {\n      this.markAsTouched();\n      this.value = chip;\n    }\n  }\n\n  onOpenedChange(isOpen: boolean) {\n    if (isOpen) {\n      this.renderer.addClass(this.body, 'fng-select-panel-open');\n    } else {\n      this.renderer.removeClass(this.body, 'fng-select-panel-open');\n    }\n  }\n\n  close() {\n    this.showOptions = false;\n    this.isEmpty();\n  }\n\n  toggle() {\n    if (false === this.disabled) {\n      this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n      this.showOptions = !this.showOptions;\n      this.onOpenedChange(this.showOptions);\n      this.isEmpty();\n    }\n  }\n\n  select(value: any, event: Event) {\n    if (!this._disabled) {\n      this.markAsTouched();\n      event.stopPropagation();\n      this.value = value;\n\n      if (this.multiple !== true) {\n        // closes overlay panel\n        this.toggle();\n      }\n    }\n  }\n\n  markAsTouched() {\n    if (!this.touched) {\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n      this.touched = true;\n    }\n  }\n\n  protected initProjectedOptions() {\n    if (this.fngSelectOptions?.length) {\n      this.hasProjectedOptions = true;\n      this.fngSelectOptions.forEach(component => {\n        component.update().then(el => {\n          if (el) {\n            this.options.push({ value: component.value, text: el.textContent?.trim() });\n            this.projectedHtml.push(el.innerHTML);\n            this.cd.detectChanges();\n          }\n        });\n      });\n    }\n    this.cd.detectChanges();\n  }\n\n  protected isEmpty() {\n    if (!this.showOptions && (!this._value || '' === this._value)) {\n      this.empty = true;\n    } else {\n      this.empty = false;\n    }\n  }\n}\n","<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n  <div\n    class=\"fwe-select\"\n    (click)=\"toggle()\"\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    [class.fwe-focus]=\"showOptions\"\n    [class.fwe-required]=\"required\"\n    [class.fwe-disabled]=\"disabled\"\n    [class.fwe-pty]=\"empty\"\n  >\n    <div class=\"fwe-select-content\">\n      <ng-container *ngIf=\"!multiple; else chips\">\n        {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n      </ng-container>\n      <ng-template #chips>\n        <div class=\"fwe-chip-container\">\n          <div\n            *ngFor=\"let v of value\"\n            class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n            [style.max-width.px]=\"triggerWidth\"\n            [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n          >\n            {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n            <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n          </div>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n  <ng-template\n    cdkConnectedOverlay\n    cdkConnectedOverlayHasBackdrop\n    cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n    [cdkConnectedOverlayOrigin]=\"trigger\"\n    [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n    [cdkConnectedOverlayOpen]=\"showOptions\"\n    [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n    (backdropClick)=\"close()\"\n  >\n    <div class=\"fng-select-panel-wrap\">\n      <ul class=\"fwe-select-options-container\">\n        <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n        <li\n          class=\"fwe-select-option\"\n          *ngFor=\"let option of options; let i = index\"\n          (click)=\"select(getOptionValue(i), $event)\"\n          [title]=\"getOptionText(i) || option?.text\"\n        >\n          <span class=\"fwe-select-option-content\">\n            <span\n              *ngIf=\"multiple\"\n              class=\"fng-select-pseudo-checkbox\"\n              [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n            ></span>\n            <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n            <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n          </span>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n  <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n  <div class=\"fwe-select-description\" *ngIf=\"hint\">\n    {{ hint }}\n  </div>\n  <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n    {{ error }}\n  </div>\n</div>\n<div class=\"fwe-d-none\">\n  <ng-content></ng-content>\n</div>\n"]}
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/select/select.component.ts","../../../../../../projects/angular/src/lib/forms/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { takeUntil } from 'rxjs/operators';\nimport {\n  Component,\n  Input,\n  HostBinding,\n  OnInit,\n  ViewEncapsulation,\n  Renderer2,\n  Inject,\n  forwardRef,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  QueryList,\n  ContentChildren,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n  AfterContentInit\n} from '@angular/core';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FngSelectOptionComponent } from './select-option/select-option.component';\nimport { FngChipTextPipe } from './chip-text.pipe';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { Subject } from 'rxjs';\n\nexport interface FngSelectOption {\n  value: any;\n  text: string;\n}\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, FngChipTextPipe, FngSelectOptionComponent, OverlayModule],\n  selector: 'fng-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class FngSelectComponent implements ControlValueAccessor, OnInit, AfterViewInit, AfterContentInit {\n  static nextId = 0;\n\n  protected _disabled = false;\n  protected _required = false;\n  protected _value: any;\n  protected body: HTMLElement;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  set value(value: any) {\n    if (this.multiple === true) {\n      const index = this._value.indexOf(value);\n      if (index === -1) {\n        this._value.push(value);\n        this.checked.set(value, 'checked');\n      } else {\n        this._value.splice(index, 1);\n        this.checked.set(value, null);\n      }\n    } else {\n      this._value = value;\n    }\n\n    if (this.onChange != null) {\n      this.onChange(this.value);\n    }\n    this.fngChange.emit(this.value);\n  }\n\n  onChange: ((_: any) => void) | undefined;\n  onTouched: (() => void) | undefined;\n\n  touched = false;\n\n  @HostBinding()\n  id = `input-control-${++FngSelectComponent.nextId}`;\n\n  @Input() multiple: boolean = false;\n  @Input() size: number = 0;\n  @Input() options: any[] = [];\n  @Input() optionsValueKey: string | undefined;\n  @Input() optionsTextKey: string | undefined;\n  @Input() optionObjectAsValue: boolean | undefined;\n  @Input() error: string | undefined;\n  @Input() label = '';\n  @Input() hideLabel = false;\n  @Input() hint = '';\n  @Input() resetOption: string | undefined;\n  @ContentChildren(FngSelectOptionComponent) fngSelectOptions: QueryList<FngSelectOptionComponent> | undefined;\n  @ViewChild('div') elementRef: ElementRef | undefined;\n  @Output() fngChange = new EventEmitter<any>();\n\n  selectPanelClasses: string[] = ['fng-select-panel'];\n  showOptions = false;\n  empty: boolean = false;\n  triggerWidth: any;\n  checked = new Map();\n  hasProjectedOptions = false;\n  projectedHtml: any[] = [];\n  protected complete: Subject<boolean> = new Subject();\n\n  constructor(@Inject(DOCUMENT) protected document: any, protected renderer: Renderer2, public cd: ChangeDetectorRef) {\n    this.body = (this.document as Document).body;\n  }\n  ngAfterContentInit(): void {\n    // observe if any of the projected content (fng-select-option) changes\n    this.fngSelectOptions?.changes.pipe(takeUntil(this.complete)).subscribe(_ => {\n      // if content changes init again\n      this.options = [];\n      this.projectedHtml = [];\n      this.initProjectedOptions();\n    });\n  }\n\n  ngOnInit(): void {\n    if (this.size != null) {\n      this.selectPanelClasses.push('fng-select-panel-options-' + this.size);\n    }\n\n    if (this.multiple === true) {\n      this._value = [];\n      this.selectPanelClasses.push('fng-select-panel-multiple');\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n    this.initProjectedOptions();\n  }\n\n  ngOnDestroy(): void {\n    this.complete.next(true);\n    this.complete.unsubscribe();\n  }\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(shouldDisable: boolean): void {\n    this.disabled = shouldDisable;\n  }\n\n  writeValue(value: any | null): void {\n    if (value === undefined) {\n      return;\n    }\n\n    if (this.multiple === true) {\n      this._value = value;\n\n      // clear any previous state of overlay panel\n      this.checked.clear();\n\n      // set checkmarks in overlay panel, so that it is displayed correctly when user opens it\n      value?.forEach((v: any) => {\n        this.checked.set(v, 'checked');\n      });\n    } else {\n      this._value = value;\n    }\n  }\n\n  getOptionText(index: number) {\n    if (this.options[index] && this.optionsTextKey && this.options[index][this.optionsTextKey] != null) {\n      return this.options[index][this.optionsTextKey];\n    }\n    return undefined;\n  }\n\n  getOptionValue(index: number) {\n    // if set to true the complete option object is returned as value\n    if (this.optionObjectAsValue === true) {\n      return this.options[index];\n    }\n\n    // try to access standard property 'value'\n    const v = this.options[index]['value'];\n\n    if (v !== undefined) {\n      return v;\n    }\n\n    // try to map the value to a property of the option by given key\n    if (this.options[index] && this.optionsValueKey && this.options[index][this.optionsValueKey] != null) {\n      return this.options[index][this.optionsValueKey];\n    }\n    return undefined;\n  }\n\n  removeChip(event: any, chip: string) {\n    event.stopPropagation();\n    if (!this._disabled) {\n      this.markAsTouched();\n      this.value = chip;\n    }\n  }\n\n  onOpenedChange(isOpen: boolean) {\n    if (isOpen) {\n      this.renderer.addClass(this.body, 'fng-select-panel-open');\n    } else {\n      this.renderer.removeClass(this.body, 'fng-select-panel-open');\n    }\n  }\n\n  close() {\n    this.showOptions = false;\n    this.isEmpty();\n  }\n\n  toggle() {\n    if (false === this.disabled) {\n      this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n      this.showOptions = !this.showOptions;\n      this.onOpenedChange(this.showOptions);\n      this.isEmpty();\n    }\n  }\n\n  select(value: any, event: Event) {\n    if (!this._disabled) {\n      this.markAsTouched();\n      event.stopPropagation();\n      this.value = value;\n\n      if (this.multiple !== true) {\n        // closes overlay panel\n        this.toggle();\n      }\n    }\n  }\n\n  markAsTouched() {\n    if (!this.touched) {\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n      this.touched = true;\n    }\n  }\n\n  initProjectedOptions() {\n    if (this.fngSelectOptions?.length) {\n      this.hasProjectedOptions = true;\n      this.fngSelectOptions.forEach(component => {\n        component.update().then(el => {\n          if (el) {\n            this.options.push({ value: component.value, text: el.textContent?.trim() });\n            this.projectedHtml.push(el.innerHTML);\n            this.cd.detectChanges();\n          }\n        });\n      });\n    }\n    this.cd.detectChanges();\n  }\n\n  isEmpty() {\n    if (!this.showOptions && (!this._value || '' === this._value)) {\n      this.empty = true;\n    } else {\n      this.empty = false;\n    }\n  }\n}\n","<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n  <div\n    class=\"fwe-select\"\n    (click)=\"toggle()\"\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    [class.fwe-focus]=\"showOptions\"\n    [class.fwe-required]=\"required\"\n    [class.fwe-disabled]=\"disabled\"\n    [class.fwe-pty]=\"empty\"\n  >\n    <div class=\"fwe-select-content\">\n      <ng-container *ngIf=\"!multiple; else chips\">\n        {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n      </ng-container>\n      <ng-template #chips>\n        <div class=\"fwe-chip-container\">\n          <div\n            *ngFor=\"let v of value\"\n            class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n            [style.max-width.px]=\"triggerWidth\"\n            [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n          >\n            {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n            <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n          </div>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n  <ng-template\n    cdkConnectedOverlay\n    cdkConnectedOverlayHasBackdrop\n    cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n    [cdkConnectedOverlayOrigin]=\"trigger\"\n    [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n    [cdkConnectedOverlayOpen]=\"showOptions\"\n    [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n    (backdropClick)=\"close()\"\n  >\n    <div class=\"fng-select-panel-wrap\">\n      <ul class=\"fwe-select-options-container\">\n        <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n        <li\n          class=\"fwe-select-option\"\n          *ngFor=\"let option of options; let i = index\"\n          (click)=\"select(getOptionValue(i), $event)\"\n          [title]=\"getOptionText(i) || option?.text\"\n        >\n          <span class=\"fwe-select-option-content\">\n            <span\n              *ngIf=\"multiple\"\n              class=\"fng-select-pseudo-checkbox\"\n              [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n            ></span>\n            <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n            <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n          </span>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n  <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n  <div class=\"fwe-select-description\" *ngIf=\"hint\">\n    {{ hint }}\n  </div>\n  <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n    {{ error }}\n  </div>\n</div>\n<div class=\"fwe-d-none\">\n  <ng-content></ng-content>\n</div>\n"]}
|
|
@@ -5457,6 +5457,8 @@ class FngSelectComponent {
|
|
|
5457
5457
|
}
|
|
5458
5458
|
if (this.multiple === true) {
|
|
5459
5459
|
this._value = value;
|
|
5460
|
+
// clear any previous state of overlay panel
|
|
5461
|
+
this.checked.clear();
|
|
5460
5462
|
// set checkmarks in overlay panel, so that it is displayed correctly when user opens it
|
|
5461
5463
|
value === null || value === void 0 ? void 0 : value.forEach((v) => {
|
|
5462
5464
|
this.checked.set(v, 'checked');
|