Socket
Socket
Sign inDemoInstall

angular-extensions

Package Overview
Dependencies
24
Maintainers
1
Versions
220
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 12.0.24 to 12.0.25

9

bundles/angular-extensions-controls-datetime-control.umd.js

@@ -359,3 +359,9 @@ (function (global, factory) {

core.overrideFunction(i6.NgxMatTimepickerComponent.prototype, function (timePicker) { return timePicker.ngOnInit; }, function () { });
core.overrideFunction(i6.NgxMatTimepickerComponent.prototype, function (timePicker) { return timePicker._updateModel; }, function (updateModel, timePicker) { return timePicker._model && updateModel(); });
// ensure timepicker model is set when user performs interaction
core.overrideFunction(i6.NgxMatTimepickerComponent.prototype, function (timePicker) { return timePicker._updateModel; }, function (updateModel, timePicker) {
if (!timePicker._model) {
timePicker._model = new Date();
}
return updateModel();
});
core.overrideFunction(i6.NgxMatTimepickerComponent.prototype, function (timePicker) { return timePicker.writeValue; }, function (writeValue, timePicker, value) {

@@ -451,3 +457,2 @@ if (!value) {

var _this = this;
this.timePicker._model = new Date();
core.overrideFunction(this.datepickerContent, function (content) { return content._handleUserSelection; }, function (handleUserSelection, _, event) {

@@ -454,0 +459,0 @@ handleUserSelection(event);

@@ -504,3 +504,3 @@ (function (global, factory) {

SelectControlComponent.prototype.showClearButton = function () {
return this.clearable && !this.field.isQuerying && this.selection.hasValue();
return this.field.control.enabled && this.clearable && !this.field.isQuerying && this.selection.hasValue();
};

@@ -507,0 +507,0 @@ SelectControlComponent.prototype.isSearchAvailable = function () {

@@ -758,3 +758,2 @@ (function (global, factory) {

: function (option, filter) { var _a; return (_a = _this.optionLabel(option)) === null || _a === void 0 ? void 0 : _a.toLowerCase().includes(filter.toLowerCase()); };
this.visibilityProvider = function () { return true; };
this.optionGroupLabel = function (optionGroup) { return optionGroup === null || optionGroup === void 0 ? void 0 : optionGroup.toString(); };

@@ -811,3 +810,3 @@ this.optionId = function (option) { return option instanceof Option ? option.id : option; };

get: function () {
return !!this.visibilityProvider(this.value);
return !this.visibilityProvider || this.visibilityProvider();
},

@@ -814,0 +813,0 @@ /**

@@ -23,3 +23,9 @@ import { switchMap } from "rxjs/operators";

overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker.ngOnInit, () => { });
overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker._updateModel, (updateModel, timePicker) => timePicker._model && updateModel());
// ensure timepicker model is set when user performs interaction
overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker._updateModel, (updateModel, timePicker) => {
if (!timePicker._model) {
timePicker._model = new Date();
}
return updateModel();
});
overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker.writeValue, (writeValue, timePicker, value) => {

@@ -96,3 +102,2 @@ if (!value) {

datePickerOpened() {
this.timePicker._model = new Date();
overrideFunction(this.datepickerContent, content => content._handleUserSelection, (handleUserSelection, _, event) => {

@@ -138,2 +143,2 @@ handleUserSelection(event);

}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/datetime-control/src/datetime-control.component.ts","../../../../../projects/angular-extensions/controls/datetime-control/src/datetime-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { switchMap } from \"rxjs/operators\";\r\nimport {\r\n  ChangeDetectionStrategy, ChangeDetectorRef, Component,\r\n  ElementRef, Inject, Input, OnInit, ViewChild, ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { MatDateFormats, MAT_DATE_FORMATS } from \"@angular/material/core\";\r\nimport { MatDatepicker, MatDatepickerContent } from \"@angular/material/datepicker\";\r\nimport { NgxMatTimepickerComponent } from \"@angular-material-components/datetime-picker\";\r\n\r\nimport { overrideFunction } from \"angular-extensions/core\";\r\nimport { AppMatDatepicker, AppNgxMatTimepickerComponent } from \"angular-extensions/models\";\r\nimport { ControlBase } from \"angular-extensions/controls/base-control\";\r\n\r\nfunction addTimepickerNullableModelSupport() {\r\n  // disable dead-loop of model => view and view <= model change events\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype,\r\n    timePicker => timePicker.ngOnInit,\r\n    () => { });\r\n\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype as any as AppNgxMatTimepickerComponent<any>,\r\n    timePicker => timePicker._updateModel,\r\n    (updateModel, timePicker) => timePicker._model && updateModel());\r\n\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype as any as AppNgxMatTimepickerComponent<any>,\r\n    timePicker => timePicker.writeValue,\r\n    (writeValue, timePicker, value) => {\r\n      if (!value) {\r\n        timePicker._model = value;\r\n\r\n        Object.values(timePicker.form.controls).forEach((control, index) => {\r\n          control.setValue(String(timePicker.defaultTime?.[index] || 0).padStart(2, \"0\"));\r\n        });\r\n      }\r\n      else {\r\n        writeValue(value);\r\n      }\r\n    });\r\n}\r\n\r\nfunction improveTimepickerStepper() {\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype as any as AppNgxMatTimepickerComponent<any>,\r\n    timePicker => timePicker._getNextValueByProp,\r\n    (getNextValueByProp, timePicker, property, up) => {\r\n      let keyProp = property[0].toUpperCase() + property.slice(1);\r\n\r\n      let result = getNextValueByProp(property, up);\r\n\r\n      if (up != null) {\r\n        result -= result % (timePicker as any)[`step${keyProp}`] as number;\r\n      }\r\n\r\n      return result;\r\n    });\r\n}\r\n\r\nimproveTimepickerStepper();\r\n\r\naddTimepickerNullableModelSupport();\r\n\r\n@Component({\r\n  selector: \"datetime-control\",\r\n  templateUrl: \"./datetime-control.component.html\",\r\n  styleUrls: [\"./datetime-control.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DateTimeControlComponent extends ControlBase<Date> implements OnInit {\r\n\r\n  @Input()\r\n  public initialTime: number[];\r\n\r\n  @Input()\r\n  public clearable: boolean;\r\n\r\n  @Input()\r\n  public disableMinute = false;\r\n\r\n  @Input()\r\n  public showSeconds = false;\r\n\r\n  @Input()\r\n  public format: string;\r\n\r\n  @ViewChild(MatDatepicker, { static: true })\r\n  public datePicker: AppMatDatepicker<Date>;\r\n\r\n  @ViewChild(NgxMatTimepickerComponent, { static: true })\r\n  public timePicker: AppNgxMatTimepickerComponent<Date>;\r\n\r\n  private get datepickerContent(): MatDatepickerContent<Date> | null {\r\n    return (this.datePicker._componentRef || this.datePicker._popupComponentRef)?.instance;\r\n  }\r\n\r\n  constructor(\r\n    private elementRef: ElementRef<HTMLElement>,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    @Inject(MAT_DATE_FORMATS) dateFormats: MatDateFormats,\r\n  ) {\r\n    super();\r\n\r\n    this.format = `${dateFormats.display.dateInput} HH:mm${this.showSeconds ? \":ss\" : \"\"}`;\r\n\r\n    // avoid datepicker input blur while popup is open\r\n    elementRef\r\n      .nativeElement\r\n      .addEventListener(\"blur\", event => this.datepickerContent && event.stopPropagation(), { capture: true });\r\n  }\r\n\r\n  public ngOnInit() {\r\n    // NgxMatTimepickerComponent updates value without \"emitModelToViewChange\", so this listener propagate those events instead\r\n    this.field$\r\n      .pipe(switchMap(field => field.control.valueChanges))\r\n      .subscribe(value => {\r\n        for (let callback of this.field.control._onChange) {\r\n          callback(value, false);\r\n        }\r\n      });\r\n  }\r\n\r\n  public onFieldClick(event: MouseEvent) {\r\n    if (this.elementRef.nativeElement.querySelector(\".mat-form-field-flex\").contains(event.target as HTMLElement)) {\r\n      this.datePicker.open();\r\n    }\r\n\r\n    event.preventDefault();\r\n  }\r\n\r\n  public onToggle(event: MouseEvent) {\r\n    if (this.clearable && this.field.control.enabled && this.field.value != null) {\r\n      this.field.control.setValue(null);\r\n\r\n      this.field.control.markAsTouched({ onlySelf: true });\r\n\r\n      event.preventDefault();\r\n      event.stopImmediatePropagation();\r\n\r\n      this.changeDetectorRef.markForCheck();\r\n    }\r\n    else {\r\n      this.focus();\r\n    }\r\n  }\r\n\r\n  public datePickerOpened() {\r\n    this.timePicker._model = new Date();\r\n\r\n    overrideFunction(\r\n      this.datepickerContent,\r\n      content => content._handleUserSelection,\r\n      (handleUserSelection, _, event) => {\r\n        handleUserSelection(event);\r\n\r\n        let timeValues = [this.timePicker.hour, this.timePicker.minute, this.timePicker.second];\r\n\r\n        this.timePicker._dateAdapter.setTimeByDefaultValues(event.value, timeValues);\r\n\r\n        this.timePicker._model = event.value;\r\n        this.datePicker._model.add(event.value);\r\n      });\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [control]=\"this\">\r\n  <mat-form-field [appearance]=\"appearance\"\r\n                  [ngClass]=\"fieldClass\"\r\n                  (click)=\"onFieldClick($event)\">\r\n    <mat-label>\r\n      {{ field.label }}\r\n    </mat-label>\r\n\r\n    <mat-hint>\r\n      <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n    </mat-hint>\r\n\r\n    <input matInput\r\n           readonly\r\n           [format]=\"format\"\r\n           [formControl]=\"field.control\"\r\n           [matDatepicker]=\"datePicker\">\r\n\r\n    <mat-datepicker-toggle matSuffix\r\n                           [for]=\"datePicker\">\r\n      <mat-icon matDatepickerToggleIcon\r\n                [matTooltip]=\"clearable && field.control.enabled && field.value != null ? 'Clear' : ''\"\r\n                (click)=\"onToggle($event)\">\r\n        {{ clearable && field.control.enabled && field.value != null ? 'close' : 'today' }}\r\n      </mat-icon>\r\n    </mat-datepicker-toggle>\r\n\r\n    <mat-datepicker panelClass=\"datetime-picker-container\"\r\n                    [restoreFocus]=\"false\"\r\n                    (opened)=\"datePickerOpened()\"\r\n                    (closed)=\"blur(); field.control.markAllAsTouched()\">\r\n      <mat-datepicker-actions>\r\n        <div class=\"w-100 d-flex flex-column align-items-center\">\r\n          <mat-divider class=\"w-100 mb-2\"></mat-divider>\r\n\r\n          <ngx-mat-timepicker [formControl]=\"field.control\"\r\n                              [color]=\"'primary'\"\r\n                              [stepMinute]=\"15\"\r\n                              [disableMinute]=\"disableMinute\"\r\n                              [defaultTime]=\"initialTime\"\r\n                              [showSeconds]=\"showSeconds\"></ngx-mat-timepicker>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n\r\n    <mat-error *ngIf=\"baseControl.initialized\">\r\n      <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    </mat-error>\r\n  </mat-form-field>\r\n</base-control>\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/datetime-control/src/datetime-control.component.ts","../../../../../projects/angular-extensions/controls/datetime-control/src/datetime-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { switchMap } from \"rxjs/operators\";\r\nimport {\r\n  ChangeDetectionStrategy, ChangeDetectorRef, Component,\r\n  ElementRef, Inject, Input, OnInit, ViewChild, ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { MatDateFormats, MAT_DATE_FORMATS } from \"@angular/material/core\";\r\nimport { MatDatepicker, MatDatepickerContent } from \"@angular/material/datepicker\";\r\nimport { NgxMatTimepickerComponent } from \"@angular-material-components/datetime-picker\";\r\n\r\nimport { overrideFunction } from \"angular-extensions/core\";\r\nimport { AppMatDatepicker, AppNgxMatTimepickerComponent } from \"angular-extensions/models\";\r\nimport { ControlBase } from \"angular-extensions/controls/base-control\";\r\n\r\nfunction addTimepickerNullableModelSupport() {\r\n  // disable dead-loop of model => view and view <= model change events\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype,\r\n    timePicker => timePicker.ngOnInit,\r\n    () => { });\r\n\r\n  // ensure timepicker model is set when user performs interaction\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype as any as AppNgxMatTimepickerComponent<any>,\r\n    timePicker => timePicker._updateModel,\r\n    (updateModel, timePicker) => {\r\n      if (!timePicker._model) {\r\n        timePicker._model = new Date();\r\n      }\r\n\r\n      return updateModel();\r\n    });\r\n\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype as any as AppNgxMatTimepickerComponent<any>,\r\n    timePicker => timePicker.writeValue,\r\n    (writeValue, timePicker, value) => {\r\n      if (!value) {\r\n        timePicker._model = value;\r\n\r\n        Object.values(timePicker.form.controls).forEach((control, index) => {\r\n          control.setValue(String(timePicker.defaultTime?.[index] || 0).padStart(2, \"0\"));\r\n        });\r\n      }\r\n      else {\r\n        writeValue(value);\r\n      }\r\n    });\r\n}\r\n\r\nfunction improveTimepickerStepper() {\r\n  overrideFunction(\r\n    NgxMatTimepickerComponent.prototype as any as AppNgxMatTimepickerComponent<any>,\r\n    timePicker => timePicker._getNextValueByProp,\r\n    (getNextValueByProp, timePicker, property, up) => {\r\n      let keyProp = property[0].toUpperCase() + property.slice(1);\r\n\r\n      let result = getNextValueByProp(property, up);\r\n\r\n      if (up != null) {\r\n        result -= result % (timePicker as any)[`step${keyProp}`] as number;\r\n      }\r\n\r\n      return result;\r\n    });\r\n}\r\n\r\nimproveTimepickerStepper();\r\n\r\naddTimepickerNullableModelSupport();\r\n\r\n@Component({\r\n  selector: \"datetime-control\",\r\n  templateUrl: \"./datetime-control.component.html\",\r\n  styleUrls: [\"./datetime-control.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DateTimeControlComponent extends ControlBase<Date> implements OnInit {\r\n\r\n  @Input()\r\n  public initialTime: number[];\r\n\r\n  @Input()\r\n  public clearable: boolean;\r\n\r\n  @Input()\r\n  public disableMinute = false;\r\n\r\n  @Input()\r\n  public showSeconds = false;\r\n\r\n  @Input()\r\n  public format: string;\r\n\r\n  @ViewChild(MatDatepicker, { static: true })\r\n  public datePicker: AppMatDatepicker<Date>;\r\n\r\n  @ViewChild(NgxMatTimepickerComponent, { static: true })\r\n  public timePicker: AppNgxMatTimepickerComponent<Date>;\r\n\r\n  private get datepickerContent(): MatDatepickerContent<Date> | null {\r\n    return (this.datePicker._componentRef || this.datePicker._popupComponentRef)?.instance;\r\n  }\r\n\r\n  constructor(\r\n    private elementRef: ElementRef<HTMLElement>,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    @Inject(MAT_DATE_FORMATS) dateFormats: MatDateFormats,\r\n  ) {\r\n    super();\r\n\r\n    this.format = `${dateFormats.display.dateInput} HH:mm${this.showSeconds ? \":ss\" : \"\"}`;\r\n\r\n    // avoid datepicker input blur while popup is open\r\n    elementRef\r\n      .nativeElement\r\n      .addEventListener(\"blur\", event => this.datepickerContent && event.stopPropagation(), { capture: true });\r\n  }\r\n\r\n  public ngOnInit() {\r\n    // NgxMatTimepickerComponent updates value without \"emitModelToViewChange\", so this listener propagate those events instead\r\n    this.field$\r\n      .pipe(switchMap(field => field.control.valueChanges))\r\n      .subscribe(value => {\r\n        for (let callback of this.field.control._onChange) {\r\n          callback(value, false);\r\n        }\r\n      });\r\n  }\r\n\r\n  public onFieldClick(event: MouseEvent) {\r\n    if (this.elementRef.nativeElement.querySelector(\".mat-form-field-flex\").contains(event.target as HTMLElement)) {\r\n      this.datePicker.open();\r\n    }\r\n\r\n    event.preventDefault();\r\n  }\r\n\r\n  public onToggle(event: MouseEvent) {\r\n    if (this.clearable && this.field.control.enabled && this.field.value != null) {\r\n      this.field.control.setValue(null);\r\n\r\n      this.field.control.markAsTouched({ onlySelf: true });\r\n\r\n      event.preventDefault();\r\n      event.stopImmediatePropagation();\r\n\r\n      this.changeDetectorRef.markForCheck();\r\n    }\r\n    else {\r\n      this.focus();\r\n    }\r\n  }\r\n\r\n  public datePickerOpened() {\r\n    overrideFunction(\r\n      this.datepickerContent,\r\n      content => content._handleUserSelection,\r\n      (handleUserSelection, _, event) => {\r\n        handleUserSelection(event);\r\n\r\n        let timeValues = [this.timePicker.hour, this.timePicker.minute, this.timePicker.second];\r\n\r\n        this.timePicker._dateAdapter.setTimeByDefaultValues(event.value, timeValues);\r\n\r\n        this.timePicker._model = event.value;\r\n        this.datePicker._model.add(event.value);\r\n      });\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [control]=\"this\">\r\n  <mat-form-field [appearance]=\"appearance\"\r\n                  [ngClass]=\"fieldClass\"\r\n                  (click)=\"onFieldClick($event)\">\r\n    <mat-label>\r\n      {{ field.label }}\r\n    </mat-label>\r\n\r\n    <mat-hint>\r\n      <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n    </mat-hint>\r\n\r\n    <input matInput\r\n           readonly\r\n           [format]=\"format\"\r\n           [formControl]=\"field.control\"\r\n           [matDatepicker]=\"datePicker\">\r\n\r\n    <mat-datepicker-toggle matSuffix\r\n                           [for]=\"datePicker\">\r\n      <mat-icon matDatepickerToggleIcon\r\n                [matTooltip]=\"clearable && field.control.enabled && field.value != null ? 'Clear' : ''\"\r\n                (click)=\"onToggle($event)\">\r\n        {{ clearable && field.control.enabled && field.value != null ? 'close' : 'today' }}\r\n      </mat-icon>\r\n    </mat-datepicker-toggle>\r\n\r\n    <mat-datepicker panelClass=\"datetime-picker-container\"\r\n                    [restoreFocus]=\"false\"\r\n                    (opened)=\"datePickerOpened()\"\r\n                    (closed)=\"blur(); field.control.markAllAsTouched()\">\r\n      <mat-datepicker-actions>\r\n        <div class=\"w-100 d-flex flex-column align-items-center\">\r\n          <mat-divider class=\"w-100 mb-2\"></mat-divider>\r\n\r\n          <ngx-mat-timepicker [formControl]=\"field.control\"\r\n                              [color]=\"'primary'\"\r\n                              [stepMinute]=\"15\"\r\n                              [disableMinute]=\"disableMinute\"\r\n                              [defaultTime]=\"initialTime\"\r\n                              [showSeconds]=\"showSeconds\"></ngx-mat-timepicker>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n\r\n    <mat-error *ngIf=\"baseControl.initialized\">\r\n      <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    </mat-error>\r\n  </mat-form-field>\r\n</base-control>\r\n"]}

@@ -128,3 +128,2 @@ import { xorBy } from "lodash-es";

: (option, filter) => { var _a; return (_a = this.optionLabel(option)) === null || _a === void 0 ? void 0 : _a.toLowerCase().includes(filter.toLowerCase()); };
this.visibilityProvider = () => true;
this.optionGroupLabel = optionGroup => optionGroup === null || optionGroup === void 0 ? void 0 : optionGroup.toString();

@@ -173,3 +172,3 @@ this.optionId = option => option instanceof Option ? option.id : option;

get visible() {
return !!this.visibilityProvider(this.value);
return !this.visibilityProvider || this.visibilityProvider();
}

@@ -320,2 +319,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.model.js","sourceRoot":"","sources":["../../../../projects/angular-extensions/models/src/field.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { xorBy } from \"lodash-es\";\r\nimport { Observable, of, Subject } from \"rxjs\";\r\nimport { catchError, filter as filterPredicate, first, map, pairwise, startWith, takeUntil } from \"rxjs/operators\";\r\nimport { FormControl, FormGroup } from \"@angular/forms\";\r\n\r\nimport { handleError } from \"angular-extensions/core\";\r\nimport { DatePipe, DateTimePipe, StartCasePipe } from \"angular-extensions/pipes\";\r\nimport { Validation, ValueProvider, ValidationConstructor } from \"./validation.model\";\r\nimport { NGX_DATE_FORMATS } from \"./datetime-configuration.model\";\r\n\r\n/**\r\n * Constructor object for Field class\r\n */\r\ntype FieldConstructor<TValue, TOption = TValue, TOptionGroup = any, TFormattedValue = any, TControlValue = any> =\r\n  Partial<Omit<Field<TValue, TOption, TOptionGroup, TFormattedValue, TControlValue>,\r\n    \"control\" | \"element\" | \"options\" | \"onValueChange\" | \"onOptionsChange\" | \"validation\" |\r\n    \"customOptionFilterPredicate\" | \"_initialStatus\" | \"destroy\" | \"setOptions\" | \"setFromOptions\" |\r\n    \"updateValidation\" | \"visible\" | \"formattedValue\" | \"formGroup\" | \"optionChanges\" | \"destroy$\"> & {\r\n      options: TOption[] | Observable<TOption[]>;\r\n\r\n      onValueChange: (value: TValue, previous: TValue) => void;\r\n\r\n      onOptionsChange: (value: TOption[]) => void;\r\n\r\n      validation: ValidationConstructor<TValue>;\r\n\r\n      /**\r\n       * Indicates field initial state\r\n       */\r\n      disabled: boolean;\r\n\r\n      /**\r\n       * Configures when {@link valueChanges} should emit event.\r\n       */\r\n      updateOn?: \"change\" | \"blur\" | \"submit\";\r\n    }>;\r\n\r\n/**\r\n * Commonly used Field value formatters\r\n */\r\nexport const Formatters = {\r\n\r\n  /**\r\n   * Formats Field<Date> value to UTC date (\"yyyy-MM-dd\") string.\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  utcDateFormatter: (field: Field<Date, any>): string => {\r\n    return new DatePipe(NGX_DATE_FORMATS).transform(field.value, \"yyyy-MM-dd\");\r\n  },\r\n\r\n  /**\r\n   * Formats Field<Date> value to UTC date/time (\"yyyy-MM-dd'T'HH:mm:ss'Z'\") string.\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  utcDateTimeFormatter: (field: Field<Date, any>): string => {\r\n    return new DatePipe(NGX_DATE_FORMATS).transform(field.value?.toUtcDate(), \"yyyy-MM-dd'T'HH:mm:ss'Z'\");\r\n  },\r\n\r\n  /**\r\n   * Formats Field<Date> value to date string with {@link DatePipe} and {@link NGX_DATE_FORMATS}\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  dateFormatter: (field: Field<Date, any>) => {\r\n    return new DatePipe(NGX_DATE_FORMATS).transform(field.value);\r\n  },\r\n\r\n  /**\r\n   * Formats Field<Date> value to date/time string with {@link DateTimePipe} and {@link NGX_DATE_FORMATS}\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  dateTimeFormatter: (field: Field<Date, any>) => {\r\n    return new DateTimePipe(NGX_DATE_FORMATS).transform(field.value);\r\n  }\r\n};\r\n\r\n/**\r\n * Field <=> Control value converter.\r\n * Useful when HTML input has different model that actual Field.\r\n *\r\n * @template TFieldValue Field Value\r\n * @template TControlValue Field's Control Value\r\n */\r\ninterface FieldControlValueConverter<TFieldValue, TControlValue> {\r\n\r\n  fromControlValue: (value: TControlValue) => TFieldValue;\r\n\r\n  toControlValue: (value: TFieldValue) => TControlValue;\r\n}\r\n\r\ninterface FormatterOptions {\r\n  insertSpaceBeforeDigits?: boolean;\r\n  insertSpaceBeforeAbbreviations?: boolean;\r\n}\r\n\r\n/**\r\n * Field option that can be used in select-control, etc.\r\n */\r\nexport class Option<TValue, TId = string> {\r\n\r\n  private static startCasePipe = new StartCasePipe();\r\n\r\n  public id: TId;\r\n\r\n  public name: string;\r\n\r\n  public label: string;\r\n\r\n  public value: TValue;\r\n\r\n  constructor(props?: Partial<Option<TValue, TId>>) {\r\n    Object.assign(this, props);\r\n\r\n    if (!this.name) {\r\n      this.name = this.value?.toString();\r\n    }\r\n\r\n    if (!this.id) {\r\n      this.id = this.name as any;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Creates options from specified Enum\r\n   *\r\n   * @param enumType Enum type\r\n   * @param insertSpaceBeforeDigits Should insert a space before digit present in string. E.g. \"every10Month\" => \"Every 10 Month\"\r\n   * @returns Collection of options\r\n   */\r\n  public static ForEnum<TEnum extends number | string>(\r\n    enumType: any,\r\n    options: FormatterOptions = { insertSpaceBeforeDigits: false, insertSpaceBeforeAbbreviations: false }): Option<TEnum>[] {\r\n    let entries = Object.entries(enumType) as [string, string | number][];;\r\n\r\n    let numberEntries = entries.filter(([, value]) => typeof value == \"number\") as [string, number][];\r\n\r\n    return (numberEntries.length > 0 ? numberEntries : entries)\r\n      .map(([key, value]: [string, string | number]) => {\r\n        return Object.assign(new Option<TEnum>({\r\n          label: this.startCasePipe.transform(key, options.insertSpaceBeforeDigits, options.insertSpaceBeforeAbbreviations),\r\n          name: key,\r\n          value: value as TEnum,\r\n        }));\r\n      });\r\n  }\r\n}\r\n\r\n/**\r\n * Provides simplified api to work with Angular reactive forms and predefined control components.\r\n */\r\nexport class Field<TValue, TOption = TValue, TOptionGroup = any, TFormattedValue = any, TControlValue = TValue> {\r\n\r\n  private optionChanges$ = new Subject<TOption[]>();\r\n\r\n  private _options: TOption[] = [];\r\n\r\n  public _initialStatus: { disabled: boolean };\r\n\r\n  public readonly destroy$ = new Subject();\r\n\r\n  /**\r\n   * Angular FormControl of field. Control components communicates via this control between Field and UI\r\n   */\r\n  public control: FormControl;\r\n\r\n  /**\r\n   * Reference to control root HTML element\r\n   */\r\n  public element?: HTMLElement;\r\n\r\n  /**\r\n   * Name of a field inside parent's FormGroup, etc.\r\n   */\r\n  public name: string;\r\n\r\n  /**\r\n   * Placeholder of a field\r\n   */\r\n  public placeholder?: string;\r\n\r\n  /**\r\n   * Label of a field\r\n   */\r\n  public label?: string;\r\n\r\n  /**\r\n   * Info text of field showed in mat-hint\r\n   */\r\n  public info?: string;\r\n\r\n  /**\r\n   * Validations of a field\r\n   */\r\n  public validation: Validation<TValue>;\r\n\r\n  /**\r\n   * Field value formatter which is used by {@link formattedValue}. See list of built-in {@link Formatters}\r\n   */\r\n  public formatter: (field: Field<TValue, TOption, TOptionGroup, TFormattedValue, TControlValue>) => TFormattedValue;\r\n\r\n  /**\r\n   * Field's Control value converter, conversion is done whenever value is being read from/written to a {@link control}.\r\n   */\r\n  public controlConverter: FieldControlValueConverter<TValue, TControlValue> = {\r\n    fromControlValue: controlValue => controlValue as any as TValue,\r\n    toControlValue: value => value as any as TControlValue,\r\n  };\r\n\r\n  /**\r\n   * Configures when field should be visible, by default is always visible.\r\n   */\r\n  public visibilityProvider: ValueProvider<TValue, boolean>;\r\n\r\n  /**\r\n   * Highlights field\r\n   */\r\n  public highlight?: () => void;\r\n\r\n  /**\r\n   * Determines whether field is querying data: options, etc.\r\n   */\r\n  public isQuerying: boolean;\r\n\r\n  /**\r\n   * Gets field's parent as form group\r\n   */\r\n  public get formGroup() {\r\n    return this.control?.parent as FormGroup | null;\r\n  }\r\n\r\n  /**\r\n   * Gets field's visibility status. Based on {@link visibilityProvider}.\r\n   */\r\n  public get visible() {\r\n    return !!this.visibilityProvider(this.value);\r\n  }\r\n\r\n  /**\r\n   * Sets field's visibility status. Based on {@link visibilityProvider}.\r\n   */\r\n  public set visible(isVisible: boolean) {\r\n    this.visibilityProvider = () => !!isVisible;\r\n\r\n    this.control.updateValueAndValidity();\r\n  }\r\n\r\n  /**\r\n   * Gets field's value. Applies conversion if specified at {@link controlConverter}.\r\n   */\r\n  public get value() {\r\n    return this.controlConverter.fromControlValue(this.control.value);\r\n  }\r\n\r\n  /**\r\n   * Sets field's value. Applies conversion if specified at {@link controlConverter}.\r\n   * If previous value is the same as current value, {@link onValueChange} wont emit changes\r\n   */\r\n  public set value(value: TValue) {\r\n    let convertedValue = this.controlConverter.toControlValue(value);\r\n\r\n    if (convertedValue != this.control.value) {\r\n      this.control.setValue(convertedValue, { onlySelf: true });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Gets formatted value, applies {@link formatter} if exists\r\n   */\r\n  public get formattedValue(): TFormattedValue {\r\n    return this.formatter\r\n      ? this.formatter(this)\r\n      : this.value as any;\r\n  }\r\n\r\n  /**\r\n   * Gets Field's options\r\n   */\r\n  public get options(): TOption[] {\r\n    return this._options;\r\n  }\r\n\r\n  /**\r\n   * Sets Field's options and notifies subscribers.\r\n   */\r\n  public set options(value: TOption[]) {\r\n    this._options = value;\r\n\r\n    if (this.value != null && this.updateValueWhenOptionsChanged) {\r\n      this.setFromOptions(option => {\r\n        if (this.value instanceof Array) {\r\n          return this.value.map(this.optionId).contains(this.optionId(option));\r\n        }\r\n        else {\r\n          return this.value?.valueOf() == this.optionValue(option)?.valueOf() ||\r\n            this.optionId(this.value as any) == this.optionId(option);\r\n        }\r\n      });\r\n    }\r\n\r\n    // triggers change detection for internal controls\r\n    this.control.setErrors(this.control.errors);\r\n\r\n    this.optionChanges$.next(value);\r\n  }\r\n\r\n  /**\r\n   * Gets option changes stream\r\n   */\r\n  public get optionChanges() {\r\n    return this.optionChanges$.asObservable().pipe(takeUntil(this.destroy$));\r\n  }\r\n\r\n  public readonly customOptionFilterPredicate: boolean;\r\n\r\n  /**\r\n   * Indicates whether field values should be updated when options changed.\r\n   */\r\n  public updateValueWhenOptionsChanged: boolean;\r\n\r\n  /**\r\n   * Configures when Field should be destroyed.\r\n   * If \"control\" - Field is destroyed when control ngOnDestroy method called.\r\n   * If \"editor\" - Field is destroyed when editor destroy method called.\r\n   *\r\n   * @default Default value: \"control\"\r\n   */\r\n  public destoryWith: \"control\" | \"editor\" = \"control\";\r\n\r\n  /**\r\n   * Options filter predicate that is used by select-control, by default filters by option label\r\n   */\r\n  public optionsFilterPredicate: (option: TOption, filter: string) => boolean;\r\n\r\n  /**\r\n   * Custom option identifier that is used by select-control to compare options\r\n   */\r\n  public optionId: (option: TOption, index?: number) => number | string;\r\n\r\n  /**\r\n   * Custom option label provider that is used by select-control\r\n   */\r\n  public optionLabel: (option: TOption) => string;\r\n\r\n  /**\r\n   * Allows to specify option display label when selected or being hovered\r\n   */\r\n  public optionDisplayLabel?: (option: TOption) => string;\r\n\r\n  /**\r\n   * Custom option value provider that is used by select-control\r\n   */\r\n  public optionValue: (option: TOption) => TControlValue;\r\n\r\n  /**\r\n   * Custom option availability provider that is used by select-control\r\n   */\r\n  public optionDisabled: (option: TOption) => boolean;\r\n\r\n  /**\r\n   * Options provider function accepting string query\r\n   */\r\n  public optionsProvider?: (query: string) => Observable<TOption[]>;\r\n\r\n  /**\r\n   * Options group provider that is used by select-control.\r\n   */\r\n  public optionsGroupProvider?: (option: TOption) => TOptionGroup;\r\n\r\n  /**\r\n   * Custom option group label provider that is used by select-control\r\n   */\r\n  public optionGroupLabel: (optionGroup: TOptionGroup) => string;\r\n\r\n  constructor(props: FieldConstructor<TValue, TOption, TOptionGroup, TFormattedValue, TControlValue>) {\r\n    this.validation = new Validation(props.validation || {});\r\n\r\n    this.control = new FormControl(\r\n      {\r\n        value: this.controlConverter.toControlValue(props.value),\r\n\r\n        // suppresses validation that might have dependencies\r\n        // on other fields that are not currently instantiated\r\n        disabled: props.disabled !== undefined\r\n          ? props.disabled\r\n          : true,\r\n      },\r\n      {\r\n        validators: Validation.getValidators(this.validation),\r\n        asyncValidators: Validation.getAsyncValidators(this.validation),\r\n        updateOn: props.updateOn,\r\n      });\r\n\r\n    this.customOptionFilterPredicate = !!props.optionsFilterPredicate;\r\n\r\n    // do not filter option if search provider is used\r\n    this.optionsFilterPredicate = props.optionsProvider\r\n      ? () => true\r\n      : (option, filter) => this.optionLabel(option)?.toLowerCase().includes(filter.toLowerCase());\r\n\r\n    this.visibilityProvider = () => true;\r\n    this.optionGroupLabel = optionGroup => optionGroup?.toString();\r\n    this.optionId = option => option instanceof Option ? option.id : option;\r\n    this.optionLabel = option => option instanceof Option ? option.label : option?.toString();\r\n    this.optionValue = option => option instanceof Option ? option.value : option;\r\n    this.optionDisabled = _ => false;\r\n\r\n    // indicated form that control should remain disabled\r\n    if (props.disabled) {\r\n      this._initialStatus = { disabled: props.disabled };\r\n\r\n      delete props.disabled;\r\n    }\r\n\r\n    if (props.onValueChange) {\r\n      let onValueChange = props.onValueChange;\r\n\r\n      this.control\r\n        .valueChanges\r\n        .pipe(\r\n          filterPredicate(() => this.control.enabled),\r\n          map(this.controlConverter.fromControlValue),\r\n          startWith(props.value),\r\n          pairwise(),\r\n          takeUntil(this.destroy$),\r\n        )\r\n        .subscribe(([previous, current]) => handleError(() => onValueChange(current as TValue, previous)));\r\n\r\n      delete props.onValueChange;\r\n    }\r\n\r\n    if (props.onOptionsChange) {\r\n      let onOptionsChange = props.onOptionsChange;\r\n\r\n      this.optionChanges$\r\n        .pipe(takeUntil(this.destroy$))\r\n        .subscribe(options => handleError(() => onOptionsChange(options)));\r\n\r\n      delete props.onOptionsChange;\r\n    }\r\n\r\n    if (props.options) {\r\n      this.setOptions(props.options);\r\n\r\n      delete props.options;\r\n    }\r\n\r\n    delete props.validation;\r\n\r\n    Object.assign(this, props);\r\n  }\r\n\r\n  /**\r\n   * Sets Field's options. Subscribes to Observable input and tracks status in {@link isQuerying} property\r\n   */\r\n  public setOptions(value: TOption[] | Observable<TOption[]>) {\r\n    if (value instanceof Observable) {\r\n      this.isQuerying = true;\r\n\r\n      // emit control status change event to trigger change detection by controls\r\n      this.control.markAsPending({ onlySelf: true });\r\n\r\n      value\r\n        .pipe(\r\n          first(),\r\n          catchError(() => of([])))\r\n        .subscribe({\r\n          next: options => {\r\n            this.options = options;\r\n            this.isQuerying = false;\r\n\r\n            // opposite action to \"control.markAsPending\"\r\n            this.control.setErrors(this.control.errors);\r\n          }\r\n        });\r\n    }\r\n    else {\r\n      this.options = value;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Selects values from available options based on options predicate. Honors\r\n   *\r\n   * @param optionPredicate Options predicate that will select values from\r\n   * @param config Configures default value if nothing selected or should it emit value change event.\r\n   * @returns Promise\r\n   */\r\n  public setFromOptions(\r\n    optionPredicate: (option: TOption) => boolean,\r\n    config: { defaultValue?: TValue; emitEvent?: boolean } = { defaultValue: undefined, emitEvent: true },\r\n  ) {\r\n    return new Promise<void>(resolve => {\r\n      let optionsProvider = () => {\r\n        if (this.control.value instanceof Array) {\r\n          let value = this.options.filter(optionPredicate).map(this.optionValue);\r\n\r\n          if (xorBy(this.control.value, value, this.optionId as any).length > 0) {\r\n            this.control.setValue(value as any as TControlValue, { emitEvent: config.emitEvent });\r\n          }\r\n        }\r\n        else {\r\n          let value = this.optionValue(this.options.find(optionPredicate)) ?? this.controlConverter.toControlValue(config.defaultValue);\r\n\r\n          if (value != null && this.control.value != null &&\r\n            this.optionId(value as any)?.valueOf() !== this.optionId(this.control.value as any)?.valueOf()\r\n          ) {\r\n            this.control.setValue(value, { emitEvent: config.emitEvent });\r\n          }\r\n          else if ((value != null) != (this.control.value != null)) {\r\n            this.control.setValue(value, { emitEvent: config.emitEvent });\r\n          }\r\n        }\r\n\r\n        resolve();\r\n      };\r\n\r\n      if (this.isQuerying) {\r\n        this.optionChanges$\r\n          .pipe(first())\r\n          .subscribe(() => optionsProvider());\r\n      }\r\n      else {\r\n        optionsProvider();\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Updates field validation\r\n   *\r\n   * @param validation Validation constructor parameters\r\n   */\r\n  public updateValidation(validation: ValidationConstructor<TValue>) {\r\n    Object.assign(this.validation, new Validation(validation));\r\n\r\n    this.control.setValidators(Validation.getValidators(this.validation));\r\n    this.control.setAsyncValidators(Validation.getAsyncValidators(this.validation));\r\n  }\r\n\r\n  /**\r\n   * Destroys field and its subscriptions\r\n   */\r\n  public destroy() {\r\n    this.destroy$.next(null);\r\n    this.destroy$.complete();\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.model.js","sourceRoot":"","sources":["../../../../projects/angular-extensions/models/src/field.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { xorBy } from \"lodash-es\";\r\nimport { Observable, of, Subject } from \"rxjs\";\r\nimport { catchError, filter as filterPredicate, first, map, pairwise, startWith, takeUntil } from \"rxjs/operators\";\r\nimport { FormControl, FormGroup } from \"@angular/forms\";\r\n\r\nimport { handleError } from \"angular-extensions/core\";\r\nimport { DatePipe, DateTimePipe, StartCasePipe } from \"angular-extensions/pipes\";\r\nimport { Validation, ValueProvider, ValidationConstructor } from \"./validation.model\";\r\nimport { NGX_DATE_FORMATS } from \"./datetime-configuration.model\";\r\n\r\n/**\r\n * Constructor object for Field class\r\n */\r\ntype FieldConstructor<TValue, TOption = TValue, TOptionGroup = any, TFormattedValue = any, TControlValue = any> =\r\n  Partial<Omit<Field<TValue, TOption, TOptionGroup, TFormattedValue, TControlValue>,\r\n    \"control\" | \"element\" | \"options\" | \"onValueChange\" | \"onOptionsChange\" | \"validation\" |\r\n    \"customOptionFilterPredicate\" | \"_initialStatus\" | \"destroy\" | \"setOptions\" | \"setFromOptions\" |\r\n    \"updateValidation\" | \"visible\" | \"formattedValue\" | \"formGroup\" | \"optionChanges\" | \"destroy$\"> & {\r\n      options: TOption[] | Observable<TOption[]>;\r\n\r\n      onValueChange: (value: TValue, previous: TValue) => void;\r\n\r\n      onOptionsChange: (value: TOption[]) => void;\r\n\r\n      validation: ValidationConstructor<TValue>;\r\n\r\n      /**\r\n       * Indicates field initial state\r\n       */\r\n      disabled: boolean;\r\n\r\n      /**\r\n       * Configures when {@link valueChanges} should emit event.\r\n       */\r\n      updateOn?: \"change\" | \"blur\" | \"submit\";\r\n    }>;\r\n\r\n/**\r\n * Commonly used Field value formatters\r\n */\r\nexport const Formatters = {\r\n\r\n  /**\r\n   * Formats Field<Date> value to UTC date (\"yyyy-MM-dd\") string.\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  utcDateFormatter: (field: Field<Date, any>): string => {\r\n    return new DatePipe(NGX_DATE_FORMATS).transform(field.value, \"yyyy-MM-dd\");\r\n  },\r\n\r\n  /**\r\n   * Formats Field<Date> value to UTC date/time (\"yyyy-MM-dd'T'HH:mm:ss'Z'\") string.\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  utcDateTimeFormatter: (field: Field<Date, any>): string => {\r\n    return new DatePipe(NGX_DATE_FORMATS).transform(field.value?.toUtcDate(), \"yyyy-MM-dd'T'HH:mm:ss'Z'\");\r\n  },\r\n\r\n  /**\r\n   * Formats Field<Date> value to date string with {@link DatePipe} and {@link NGX_DATE_FORMATS}\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  dateFormatter: (field: Field<Date, any>) => {\r\n    return new DatePipe(NGX_DATE_FORMATS).transform(field.value);\r\n  },\r\n\r\n  /**\r\n   * Formats Field<Date> value to date/time string with {@link DateTimePipe} and {@link NGX_DATE_FORMATS}\r\n   *\r\n   * @param field Field<Date>\r\n   * @returns String\r\n   */\r\n  dateTimeFormatter: (field: Field<Date, any>) => {\r\n    return new DateTimePipe(NGX_DATE_FORMATS).transform(field.value);\r\n  }\r\n};\r\n\r\n/**\r\n * Field <=> Control value converter.\r\n * Useful when HTML input has different model that actual Field.\r\n *\r\n * @template TFieldValue Field Value\r\n * @template TControlValue Field's Control Value\r\n */\r\ninterface FieldControlValueConverter<TFieldValue, TControlValue> {\r\n\r\n  fromControlValue: (value: TControlValue) => TFieldValue;\r\n\r\n  toControlValue: (value: TFieldValue) => TControlValue;\r\n}\r\n\r\ninterface FormatterOptions {\r\n  insertSpaceBeforeDigits?: boolean;\r\n  insertSpaceBeforeAbbreviations?: boolean;\r\n}\r\n\r\n/**\r\n * Field option that can be used in select-control, etc.\r\n */\r\nexport class Option<TValue, TId = string> {\r\n\r\n  private static startCasePipe = new StartCasePipe();\r\n\r\n  public id: TId;\r\n\r\n  public name: string;\r\n\r\n  public label: string;\r\n\r\n  public value: TValue;\r\n\r\n  constructor(props?: Partial<Option<TValue, TId>>) {\r\n    Object.assign(this, props);\r\n\r\n    if (!this.name) {\r\n      this.name = this.value?.toString();\r\n    }\r\n\r\n    if (!this.id) {\r\n      this.id = this.name as any;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Creates options from specified Enum\r\n   *\r\n   * @param enumType Enum type\r\n   * @param insertSpaceBeforeDigits Should insert a space before digit present in string. E.g. \"every10Month\" => \"Every 10 Month\"\r\n   * @returns Collection of options\r\n   */\r\n  public static ForEnum<TEnum extends number | string>(\r\n    enumType: any,\r\n    options: FormatterOptions = { insertSpaceBeforeDigits: false, insertSpaceBeforeAbbreviations: false }): Option<TEnum>[] {\r\n    let entries = Object.entries(enumType) as [string, string | number][];;\r\n\r\n    let numberEntries = entries.filter(([, value]) => typeof value == \"number\") as [string, number][];\r\n\r\n    return (numberEntries.length > 0 ? numberEntries : entries)\r\n      .map(([key, value]: [string, string | number]) => {\r\n        return Object.assign(new Option<TEnum>({\r\n          label: this.startCasePipe.transform(key, options.insertSpaceBeforeDigits, options.insertSpaceBeforeAbbreviations),\r\n          name: key,\r\n          value: value as TEnum,\r\n        }));\r\n      });\r\n  }\r\n}\r\n\r\n/**\r\n * Provides simplified api to work with Angular reactive forms and predefined control components.\r\n */\r\nexport class Field<TValue, TOption = TValue, TOptionGroup = any, TFormattedValue = any, TControlValue = TValue> {\r\n\r\n  private optionChanges$ = new Subject<TOption[]>();\r\n\r\n  private _options: TOption[] = [];\r\n\r\n  public _initialStatus: { disabled: boolean };\r\n\r\n  public readonly destroy$ = new Subject();\r\n\r\n  /**\r\n   * Angular FormControl of field. Control components communicates via this control between Field and UI\r\n   */\r\n  public control: FormControl;\r\n\r\n  /**\r\n   * Reference to control root HTML element\r\n   */\r\n  public element?: HTMLElement;\r\n\r\n  /**\r\n   * Name of a field inside parent's FormGroup, etc.\r\n   */\r\n  public name: string;\r\n\r\n  /**\r\n   * Placeholder of a field\r\n   */\r\n  public placeholder?: string;\r\n\r\n  /**\r\n   * Label of a field\r\n   */\r\n  public label?: string;\r\n\r\n  /**\r\n   * Info text of field showed in mat-hint\r\n   */\r\n  public info?: string;\r\n\r\n  /**\r\n   * Validations of a field\r\n   */\r\n  public validation: Validation<TValue>;\r\n\r\n  /**\r\n   * Field value formatter which is used by {@link formattedValue}. See list of built-in {@link Formatters}\r\n   */\r\n  public formatter: (field: Field<TValue, TOption, TOptionGroup, TFormattedValue, TControlValue>) => TFormattedValue;\r\n\r\n  /**\r\n   * Field's Control value converter, conversion is done whenever value is being read from/written to a {@link control}.\r\n   */\r\n  public controlConverter: FieldControlValueConverter<TValue, TControlValue> = {\r\n    fromControlValue: controlValue => controlValue as any as TValue,\r\n    toControlValue: value => value as any as TControlValue,\r\n  };\r\n\r\n  /**\r\n   * Configures when field should be visible, by default is always visible.\r\n   */\r\n  public visibilityProvider?: () => boolean;\r\n\r\n  /**\r\n   * Highlights field\r\n   */\r\n  public highlight?: () => void;\r\n\r\n  /**\r\n   * Determines whether field is querying data: options, etc.\r\n   */\r\n  public isQuerying: boolean;\r\n\r\n  /**\r\n   * Gets field's parent as form group\r\n   */\r\n  public get formGroup() {\r\n    return this.control?.parent as FormGroup | null;\r\n  }\r\n\r\n  /**\r\n   * Gets field's visibility status. Based on {@link visibilityProvider}.\r\n   */\r\n  public get visible() {\r\n    return !this.visibilityProvider || this.visibilityProvider();\r\n  }\r\n\r\n  /**\r\n   * Sets field's visibility status. Based on {@link visibilityProvider}.\r\n   */\r\n  public set visible(isVisible: boolean) {\r\n    this.visibilityProvider = () => !!isVisible;\r\n\r\n    this.control.updateValueAndValidity();\r\n  }\r\n\r\n  /**\r\n   * Gets field's value. Applies conversion if specified at {@link controlConverter}.\r\n   */\r\n  public get value() {\r\n    return this.controlConverter.fromControlValue(this.control.value);\r\n  }\r\n\r\n  /**\r\n   * Sets field's value. Applies conversion if specified at {@link controlConverter}.\r\n   * If previous value is the same as current value, {@link onValueChange} wont emit changes\r\n   */\r\n  public set value(value: TValue) {\r\n    let convertedValue = this.controlConverter.toControlValue(value);\r\n\r\n    if (convertedValue != this.control.value) {\r\n      this.control.setValue(convertedValue, { onlySelf: true });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Gets formatted value, applies {@link formatter} if exists\r\n   */\r\n  public get formattedValue(): TFormattedValue {\r\n    return this.formatter\r\n      ? this.formatter(this)\r\n      : this.value as any;\r\n  }\r\n\r\n  /**\r\n   * Gets Field's options\r\n   */\r\n  public get options(): TOption[] {\r\n    return this._options;\r\n  }\r\n\r\n  /**\r\n   * Sets Field's options and notifies subscribers.\r\n   */\r\n  public set options(value: TOption[]) {\r\n    this._options = value;\r\n\r\n    if (this.value != null && this.updateValueWhenOptionsChanged) {\r\n      this.setFromOptions(option => {\r\n        if (this.value instanceof Array) {\r\n          return this.value.map(this.optionId).contains(this.optionId(option));\r\n        }\r\n        else {\r\n          return this.value?.valueOf() == this.optionValue(option)?.valueOf() ||\r\n            this.optionId(this.value as any) == this.optionId(option);\r\n        }\r\n      });\r\n    }\r\n\r\n    // triggers change detection for internal controls\r\n    this.control.setErrors(this.control.errors);\r\n\r\n    this.optionChanges$.next(value);\r\n  }\r\n\r\n  /**\r\n   * Gets option changes stream\r\n   */\r\n  public get optionChanges() {\r\n    return this.optionChanges$.asObservable().pipe(takeUntil(this.destroy$));\r\n  }\r\n\r\n  public readonly customOptionFilterPredicate: boolean;\r\n\r\n  /**\r\n   * Indicates whether field values should be updated when options changed.\r\n   */\r\n  public updateValueWhenOptionsChanged: boolean;\r\n\r\n  /**\r\n   * Configures when Field should be destroyed.\r\n   * If \"control\" - Field is destroyed when control ngOnDestroy method called.\r\n   * If \"editor\" - Field is destroyed when editor destroy method called.\r\n   *\r\n   * @default Default value: \"control\"\r\n   */\r\n  public destoryWith: \"control\" | \"editor\" = \"control\";\r\n\r\n  /**\r\n   * Options filter predicate that is used by select-control, by default filters by option label\r\n   */\r\n  public optionsFilterPredicate: (option: TOption, filter: string) => boolean;\r\n\r\n  /**\r\n   * Custom option identifier that is used by select-control to compare options\r\n   */\r\n  public optionId: (option: TOption, index?: number) => number | string;\r\n\r\n  /**\r\n   * Custom option label provider that is used by select-control\r\n   */\r\n  public optionLabel: (option: TOption) => string;\r\n\r\n  /**\r\n   * Allows to specify option display label when selected or being hovered\r\n   */\r\n  public optionDisplayLabel?: (option: TOption) => string;\r\n\r\n  /**\r\n   * Custom option value provider that is used by select-control\r\n   */\r\n  public optionValue: (option: TOption) => TControlValue;\r\n\r\n  /**\r\n   * Custom option availability provider that is used by select-control\r\n   */\r\n  public optionDisabled: (option: TOption) => boolean;\r\n\r\n  /**\r\n   * Options provider function accepting string query\r\n   */\r\n  public optionsProvider?: (query: string) => Observable<TOption[]>;\r\n\r\n  /**\r\n   * Options group provider that is used by select-control.\r\n   */\r\n  public optionsGroupProvider?: (option: TOption) => TOptionGroup;\r\n\r\n  /**\r\n   * Custom option group label provider that is used by select-control\r\n   */\r\n  public optionGroupLabel: (optionGroup: TOptionGroup) => string;\r\n\r\n  constructor(props: FieldConstructor<TValue, TOption, TOptionGroup, TFormattedValue, TControlValue>) {\r\n    this.validation = new Validation(props.validation || {});\r\n\r\n    this.control = new FormControl(\r\n      {\r\n        value: this.controlConverter.toControlValue(props.value),\r\n\r\n        // suppresses validation that might have dependencies\r\n        // on other fields that are not currently instantiated\r\n        disabled: props.disabled !== undefined\r\n          ? props.disabled\r\n          : true,\r\n      },\r\n      {\r\n        validators: Validation.getValidators(this.validation),\r\n        asyncValidators: Validation.getAsyncValidators(this.validation),\r\n        updateOn: props.updateOn,\r\n      });\r\n\r\n    this.customOptionFilterPredicate = !!props.optionsFilterPredicate;\r\n\r\n    // do not filter option if search provider is used\r\n    this.optionsFilterPredicate = props.optionsProvider\r\n      ? () => true\r\n      : (option, filter) => this.optionLabel(option)?.toLowerCase().includes(filter.toLowerCase());\r\n\r\n    this.optionGroupLabel = optionGroup => optionGroup?.toString();\r\n    this.optionId = option => option instanceof Option ? option.id : option;\r\n    this.optionLabel = option => option instanceof Option ? option.label : option?.toString();\r\n    this.optionValue = option => option instanceof Option ? option.value : option;\r\n    this.optionDisabled = _ => false;\r\n\r\n    // indicated form that control should remain disabled\r\n    if (props.disabled) {\r\n      this._initialStatus = { disabled: props.disabled };\r\n\r\n      delete props.disabled;\r\n    }\r\n\r\n    if (props.onValueChange) {\r\n      let onValueChange = props.onValueChange;\r\n\r\n      this.control\r\n        .valueChanges\r\n        .pipe(\r\n          filterPredicate(() => this.control.enabled),\r\n          map(this.controlConverter.fromControlValue),\r\n          startWith(props.value),\r\n          pairwise(),\r\n          takeUntil(this.destroy$),\r\n        )\r\n        .subscribe(([previous, current]) => handleError(() => onValueChange(current as TValue, previous)));\r\n\r\n      delete props.onValueChange;\r\n    }\r\n\r\n    if (props.onOptionsChange) {\r\n      let onOptionsChange = props.onOptionsChange;\r\n\r\n      this.optionChanges$\r\n        .pipe(takeUntil(this.destroy$))\r\n        .subscribe(options => handleError(() => onOptionsChange(options)));\r\n\r\n      delete props.onOptionsChange;\r\n    }\r\n\r\n    if (props.options) {\r\n      this.setOptions(props.options);\r\n\r\n      delete props.options;\r\n    }\r\n\r\n    delete props.validation;\r\n\r\n    Object.assign(this, props);\r\n  }\r\n\r\n  /**\r\n   * Sets Field's options. Subscribes to Observable input and tracks status in {@link isQuerying} property\r\n   */\r\n  public setOptions(value: TOption[] | Observable<TOption[]>) {\r\n    if (value instanceof Observable) {\r\n      this.isQuerying = true;\r\n\r\n      // emit control status change event to trigger change detection by controls\r\n      this.control.markAsPending({ onlySelf: true });\r\n\r\n      value\r\n        .pipe(\r\n          first(),\r\n          catchError(() => of([])))\r\n        .subscribe({\r\n          next: options => {\r\n            this.options = options;\r\n            this.isQuerying = false;\r\n\r\n            // opposite action to \"control.markAsPending\"\r\n            this.control.setErrors(this.control.errors);\r\n          }\r\n        });\r\n    }\r\n    else {\r\n      this.options = value;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Selects values from available options based on options predicate. Honors\r\n   *\r\n   * @param optionPredicate Options predicate that will select values from\r\n   * @param config Configures default value if nothing selected or should it emit value change event.\r\n   * @returns Promise\r\n   */\r\n  public setFromOptions(\r\n    optionPredicate: (option: TOption) => boolean,\r\n    config: { defaultValue?: TValue; emitEvent?: boolean } = { defaultValue: undefined, emitEvent: true },\r\n  ) {\r\n    return new Promise<void>(resolve => {\r\n      let optionsProvider = () => {\r\n        if (this.control.value instanceof Array) {\r\n          let value = this.options.filter(optionPredicate).map(this.optionValue);\r\n\r\n          if (xorBy(this.control.value, value, this.optionId as any).length > 0) {\r\n            this.control.setValue(value as any as TControlValue, { emitEvent: config.emitEvent });\r\n          }\r\n        }\r\n        else {\r\n          let value = this.optionValue(this.options.find(optionPredicate)) ?? this.controlConverter.toControlValue(config.defaultValue);\r\n\r\n          if (value != null && this.control.value != null &&\r\n            this.optionId(value as any)?.valueOf() !== this.optionId(this.control.value as any)?.valueOf()\r\n          ) {\r\n            this.control.setValue(value, { emitEvent: config.emitEvent });\r\n          }\r\n          else if ((value != null) != (this.control.value != null)) {\r\n            this.control.setValue(value, { emitEvent: config.emitEvent });\r\n          }\r\n        }\r\n\r\n        resolve();\r\n      };\r\n\r\n      if (this.isQuerying) {\r\n        this.optionChanges$\r\n          .pipe(first())\r\n          .subscribe(() => optionsProvider());\r\n      }\r\n      else {\r\n        optionsProvider();\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Updates field validation\r\n   *\r\n   * @param validation Validation constructor parameters\r\n   */\r\n  public updateValidation(validation: ValidationConstructor<TValue>) {\r\n    Object.assign(this.validation, new Validation(validation));\r\n\r\n    this.control.setValidators(Validation.getValidators(this.validation));\r\n    this.control.setAsyncValidators(Validation.getAsyncValidators(this.validation));\r\n  }\r\n\r\n  /**\r\n   * Destroys field and its subscriptions\r\n   */\r\n  public destroy() {\r\n    this.destroy$.next(null);\r\n    this.destroy$.complete();\r\n  }\r\n}\r\n"]}

@@ -31,3 +31,9 @@ import { switchMap } from 'rxjs/operators';

overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker.ngOnInit, () => { });
overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker._updateModel, (updateModel, timePicker) => timePicker._model && updateModel());
// ensure timepicker model is set when user performs interaction
overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker._updateModel, (updateModel, timePicker) => {
if (!timePicker._model) {
timePicker._model = new Date();
}
return updateModel();
});
overrideFunction(NgxMatTimepickerComponent.prototype, timePicker => timePicker.writeValue, (writeValue, timePicker, value) => {

@@ -104,3 +110,2 @@ if (!value) {

datePickerOpened() {
this.timePicker._model = new Date();
overrideFunction(this.datepickerContent, content => content._handleUserSelection, (handleUserSelection, _, event) => {

@@ -107,0 +112,0 @@ handleUserSelection(event);

@@ -156,3 +156,3 @@ import { castArray } from 'lodash-es';

showClearButton() {
return this.clearable && !this.field.isQuerying && this.selection.hasValue();
return this.field.control.enabled && this.clearable && !this.field.isQuerying && this.selection.hasValue();
}

@@ -159,0 +159,0 @@ isSearchAvailable() {

@@ -413,3 +413,2 @@ import { from, Observable, Subject, of, forkJoin } from 'rxjs';

: (option, filter) => { var _a; return (_a = this.optionLabel(option)) === null || _a === void 0 ? void 0 : _a.toLowerCase().includes(filter.toLowerCase()); };
this.visibilityProvider = () => true;
this.optionGroupLabel = optionGroup => optionGroup === null || optionGroup === void 0 ? void 0 : optionGroup.toString();

@@ -458,3 +457,3 @@ this.optionId = option => option instanceof Option ? option.id : option;

get visible() {
return !!this.visibilityProvider(this.value);
return !this.visibilityProvider || this.visibilityProvider();
}

@@ -461,0 +460,0 @@ /**

import { Observable, Subject } from "rxjs";
import { FormControl, FormGroup } from "@angular/forms";
import { Validation, ValueProvider, ValidationConstructor } from "./validation.model";
import { Validation, ValidationConstructor } from "./validation.model";
/**

@@ -137,3 +137,3 @@ * Constructor object for Field class

*/
visibilityProvider: ValueProvider<TValue, boolean>;
visibilityProvider?: () => boolean;
/**

@@ -140,0 +140,0 @@ * Highlights field

{
"name": "angular-extensions",
"version": "12.0.24",
"version": "12.0.25",
"repository": "https://github.com/nazar-kuzo/angular-extensions.git",

@@ -5,0 +5,0 @@ "author": "Nazar Kuzo",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc