@rosoftlab/core 0.0.100 → 0.0.101

Sign up to get free protection for your applications and to get access to all the features.
Files changed (29) hide show
  1. package/esm2020/lib/base-components/base-form-edit.component.mjs +15 -41
  2. package/esm2020/lib/base-components/field-error-display/field-error-display.component.mjs +3 -3
  3. package/esm2020/lib/base-components/generic-table/generic-table.component.mjs +17 -80
  4. package/esm2020/lib/base-components/index.mjs +1 -2
  5. package/esm2020/lib/base-components/page-not-found/page-not-found.component.mjs +3 -3
  6. package/esm2020/lib/base-components/under-construction/under-construction.component.mjs +3 -3
  7. package/esm2020/lib/decorators/attribute.decorator.mjs +1 -4
  8. package/esm2020/lib/interfaces/attribute-decorator-options.interface.mjs +1 -1
  9. package/esm2020/lib/models/base.model.mjs +3 -46
  10. package/esm2020/lib/models/grid-layout-format.enum.mjs +1 -2
  11. package/esm2020/lib/module.mjs +5 -14
  12. package/esm2020/lib/services/base.service.mjs +2 -6
  13. package/fesm2015/rosoftlab-core.mjs +72 -443
  14. package/fesm2015/rosoftlab-core.mjs.map +1 -1
  15. package/fesm2020/rosoftlab-core.mjs +72 -438
  16. package/fesm2020/rosoftlab-core.mjs.map +1 -1
  17. package/lib/base-components/base-form-edit.component.d.ts +4 -9
  18. package/lib/base-components/field-error-display/field-error-display.component.d.ts +1 -1
  19. package/lib/base-components/generic-table/generic-table.component.d.ts +4 -17
  20. package/lib/base-components/index.d.ts +0 -1
  21. package/lib/base-components/page-not-found/page-not-found.component.d.ts +1 -1
  22. package/lib/base-components/under-construction/under-construction.component.d.ts +1 -1
  23. package/lib/interfaces/attribute-decorator-options.interface.d.ts +0 -1
  24. package/lib/models/base.model.d.ts +3 -7
  25. package/lib/models/grid-layout-format.enum.d.ts +1 -2
  26. package/lib/module.d.ts +6 -8
  27. package/package.json +3 -3
  28. package/esm2020/lib/base-components/searchable-dropdown/searchable-dropdown.component.mjs +0 -231
  29. package/lib/base-components/searchable-dropdown/searchable-dropdown.component.d.ts +0 -62
@@ -33,26 +33,21 @@ export declare abstract class BaseFormEditComponent<T extends BaseModel> impleme
33
33
  initForm(customInclude?: string, newModelId?: string, model?: T): void;
34
34
  generateForm(model?: T): void;
35
35
  afterFormGenerated(): void;
36
- private getFromGroup;
37
- validateAllFormFields(formGroup?: FormGroup | string): void;
38
- isFieldValid(field: string, formGroup?: FormGroup | string): boolean;
39
- isFieldValidFromArray(arrayIndex: number, field: string, arrayName?: string): boolean;
40
- displayFieldCss(field: string): {
36
+ validateAllFormFields(formGroup: FormGroup): void;
37
+ isFieldValid(form: FormGroup, field: string): boolean;
38
+ displayFieldCss(form: FormGroup, field: string): {
41
39
  'has-error': boolean;
42
40
  'has-feedback': boolean;
43
41
  };
44
42
  onCancel(): void;
45
43
  onSave(): void;
46
- saveModel(formGroup?: FormGroup | string): void;
47
44
  serverErrors(err: any): void;
48
45
  canDeactivate(): Observable<boolean> | boolean;
49
46
  getFiledName(filedTranslationKey: string): {
50
47
  field: any;
51
48
  };
52
49
  getCustomErrorMessage(error: any, fieldLabel: string): string;
53
- getErrorMessageFromArray(arrayIndex: number, field: string, filedTranslationKey: string, arrayName?: string): string;
54
- getErrorMessage(field: string, filedTranslationKey: string, formGroup?: FormGroup | string): string;
55
- getErrorMessageForField(fieldControl: any, filedTranslationKey: string): string;
50
+ getErrorMessage(field: string, filedTranslationKey: string): string;
56
51
  static ɵfac: i0.ɵɵFactoryDeclaration<BaseFormEditComponent<any>, never>;
57
52
  static ɵcmp: i0.ɵɵComponentDeclaration<BaseFormEditComponent<any>, "app-base.form.edit", never, {}, {}, never, never>;
58
53
  }
@@ -3,5 +3,5 @@ export declare class FieldErrorDisplayComponent {
3
3
  errorMsg: string;
4
4
  displayError: boolean;
5
5
  static ɵfac: i0.ɵɵFactoryDeclaration<FieldErrorDisplayComponent, never>;
6
- static ɵcmp: i0.ɵɵComponentDeclaration<FieldErrorDisplayComponent, "rsl-field-error-display", never, { "errorMsg": "errorMsg"; "displayError": "displayError"; }, {}, never, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<FieldErrorDisplayComponent, "app-field-error-display", never, { "errorMsg": "errorMsg"; "displayError": "displayError"; }, {}, never, never>;
7
7
  }
@@ -1,6 +1,6 @@
1
1
  import { CdkDragDrop } from '@angular/cdk/drag-drop';
2
2
  import { DatePipe, DecimalPipe, PercentPipe } from '@angular/common';
3
- import { AfterViewInit, ElementRef, EventEmitter, OnChanges, OnInit, Renderer2 } from '@angular/core';
3
+ import { ElementRef, EventEmitter, OnChanges, OnInit } from '@angular/core';
4
4
  import { MatPaginator } from '@angular/material/paginator';
5
5
  import { MatSort, SortDirection } from '@angular/material/sort';
6
6
  import { MatTable, MatTableDataSource } from '@angular/material/table';
@@ -15,13 +15,12 @@ import { BaseService } from '../../services/base.service';
15
15
  import { DialogService } from '../../services/dialog.service';
16
16
  import { GridLayoutService } from '../../services/grid-layout.service';
17
17
  import * as i0 from "@angular/core";
18
- export declare class GenericTableComponent<T extends BaseModel> implements OnInit, OnChanges, AfterViewInit {
18
+ export declare class GenericTableComponent<T extends BaseModel> implements OnInit, OnChanges {
19
19
  dialogService: DialogService;
20
20
  router: Router;
21
21
  private datePipe;
22
22
  private numberPipe;
23
23
  private percentPipe;
24
- private renderer;
25
24
  modelType: new (...args: any[]) => T;
26
25
  baseService: BaseService<T>;
27
26
  gridLayoutService?: GridLayoutService<T>;
@@ -41,7 +40,6 @@ export declare class GenericTableComponent<T extends BaseModel> implements OnIni
41
40
  popupEdit: boolean;
42
41
  customInclude: string;
43
42
  changeItemPosition: (prevItem: T, currentItem: T) => boolean;
44
- infiniteScroll: boolean;
45
43
  dataSource: MatTableDataSource<T>;
46
44
  resultsLength: number;
47
45
  isLoadingResults: boolean;
@@ -53,18 +51,13 @@ export declare class GenericTableComponent<T extends BaseModel> implements OnIni
53
51
  sort: MatSort;
54
52
  filter: ElementRef;
55
53
  table: MatTable<any>;
56
- matTableRef: ElementRef;
57
54
  resizeSubscription: any;
58
55
  selectedItem: T;
59
56
  gridLayout: GridLayoutModel[];
60
57
  selectedObject: EventEmitter<T>;
61
- click: EventEmitter<{
62
- propertyName: string;
63
- model: T;
64
- }>;
65
58
  editModel: EventEmitter<T>;
66
59
  displayedColumns: string[];
67
- constructor(dialogService: DialogService, router: Router, datePipe: DatePipe, numberPipe: DecimalPipe, percentPipe: PercentPipe, renderer: Renderer2);
60
+ constructor(dialogService: DialogService, router: Router, datePipe: DatePipe, numberPipe: DecimalPipe, percentPipe: PercentPipe);
68
61
  ngOnChanges(): void;
69
62
  ngOnInit(): void;
70
63
  getData(): Observable<BaseQueryData<T>>;
@@ -74,9 +67,7 @@ export declare class GenericTableComponent<T extends BaseModel> implements OnIni
74
67
  editObject(model: T): void;
75
68
  getFlexStyle(column: GridLayoutModel): string;
76
69
  getCellTextAlign(column: GridLayoutModel): CellTextAlign;
77
- showPictureCell(column: GridLayoutModel): boolean;
78
70
  deleteDisabled(model: T): boolean;
79
- cellClick(model: T, propertyName: string): void;
80
71
  private evaluateRule;
81
72
  getCelValue(row: any, propertyName: string): any;
82
73
  private getFormatedValue;
@@ -84,10 +75,6 @@ export declare class GenericTableComponent<T extends BaseModel> implements OnIni
84
75
  dropTable(event: CdkDragDrop<any>): void;
85
76
  isColumnSticky(name: string): boolean;
86
77
  updateElement(model: T): void;
87
- ngAfterViewInit(): void;
88
- onTableScroll(e: any): void;
89
- private scrollTo;
90
- getCellClass(model: T, property: string): string;
91
78
  static ɵfac: i0.ɵɵFactoryDeclaration<GenericTableComponent<any>, never>;
92
- static ɵcmp: i0.ɵɵComponentDeclaration<GenericTableComponent<any>, "rsl-generic-table", never, { "modelType": "modelType"; "baseService": "baseService"; "gridLayoutService": "gridLayoutService"; "editLink": "editLink"; "defaultSort": "defaultSort"; "defaultSortDirection": "defaultSortDirection"; "deleteDisableRule": "deleteDisableRule"; "deletePropertyName": "deletePropertyName"; "hasSearch": "hasSearch"; "searchFields": "searchFields"; "defaultFilter": "defaultFilter"; "allowReorderItems": "allowReorderItems"; "stickyColumns": "stickyColumns"; "editOnClick": "editOnClick"; "editOnDblClick": "editOnDblClick"; "allowEdit": "allowEdit"; "popupEdit": "popupEdit"; "customInclude": "customInclude"; "changeItemPosition": "changeItemPosition"; "infiniteScroll": "infiniteScroll"; }, { "selectedObject": "selectedObject"; "click": "click"; "editModel": "editModel"; }, never, never>;
79
+ static ɵcmp: i0.ɵɵComponentDeclaration<GenericTableComponent<any>, "app-generic-table", never, { "modelType": "modelType"; "baseService": "baseService"; "gridLayoutService": "gridLayoutService"; "editLink": "editLink"; "defaultSort": "defaultSort"; "defaultSortDirection": "defaultSortDirection"; "deleteDisableRule": "deleteDisableRule"; "deletePropertyName": "deletePropertyName"; "hasSearch": "hasSearch"; "searchFields": "searchFields"; "defaultFilter": "defaultFilter"; "allowReorderItems": "allowReorderItems"; "stickyColumns": "stickyColumns"; "editOnClick": "editOnClick"; "editOnDblClick": "editOnDblClick"; "allowEdit": "allowEdit"; "popupEdit": "popupEdit"; "customInclude": "customInclude"; "changeItemPosition": "changeItemPosition"; }, { "selectedObject": "selectedObject"; "editModel": "editModel"; }, never, never>;
93
80
  }
@@ -1,4 +1,3 @@
1
1
  export * from './field-error-display/field-error-display.component';
2
2
  export * from './page-not-found/page-not-found.component';
3
- export * from './searchable-dropdown/searchable-dropdown.component';
4
3
  export * from './under-construction/under-construction.component';
@@ -4,5 +4,5 @@ export declare class PageNotFoundComponent implements OnInit {
4
4
  constructor();
5
5
  ngOnInit(): void;
6
6
  static ɵfac: i0.ɵɵFactoryDeclaration<PageNotFoundComponent, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<PageNotFoundComponent, "rsl-page-not-found", never, {}, {}, never, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<PageNotFoundComponent, "app-page-not-found", never, {}, {}, never, never>;
8
8
  }
@@ -2,5 +2,5 @@ import * as i0 from "@angular/core";
2
2
  export declare class UnderConstructionComponent {
3
3
  constructor();
4
4
  static ɵfac: i0.ɵɵFactoryDeclaration<UnderConstructionComponent, never>;
5
- static ɵcmp: i0.ɵɵComponentDeclaration<UnderConstructionComponent, "rsl-under-construction", never, {}, {}, never, never>;
5
+ static ɵcmp: i0.ɵɵComponentDeclaration<UnderConstructionComponent, "app-under-construction", never, {}, {}, never, never>;
6
6
  }
@@ -4,5 +4,4 @@ export interface AttributeDecoratorOptions {
4
4
  converter?: PropertyConverter;
5
5
  required?: boolean;
6
6
  defaultValue?: any;
7
- formSubGroup?: string;
8
7
  }
@@ -20,14 +20,10 @@ export declare class BaseModel {
20
20
  get modelConfig(): ModelConfig;
21
21
  protected deserializeModel<T extends BaseModel>(modelType: ModelType<T>, data: any): T;
22
22
  protected transformSerializedNamesToPropertyNames<T extends BaseModel>(modelType: ModelType<T>, attributes: any): any;
23
- getModelPropertyNames(model: BaseModel): any;
24
- getModelRequiredPropertyNames(model: BaseModel): any;
25
- getModelDefaultPropertyValues(model: BaseModel): any;
26
- getModelSubGroupPropertyNames(model: BaseModel): any;
23
+ private getModelPropertyNames;
24
+ private getModelRequiredPropertyNames;
25
+ private getModelDefaultPropertyValues;
27
26
  getFromGroup(fb: FormBuilder): FormGroup;
28
- private getSubFromGroup;
29
- getModelFromFormGroup(formGroup: FormGroup, id?: any): void;
30
27
  getGridLayout(): GridLayoutModel[];
31
28
  getSerializedModel(): any;
32
- getCellClass(property: string): string;
33
29
  }
@@ -2,8 +2,7 @@ export declare enum GridLayoutFormat {
2
2
  none = 0,
3
3
  date = 1,
4
4
  number = 2,
5
- percent = 3,
6
- picture = 4
5
+ percent = 3
7
6
  }
8
7
  export declare enum CellTextAlign {
9
8
  left = "left",
package/lib/module.d.ts CHANGED
@@ -1,14 +1,12 @@
1
1
  import * as i0 from "@angular/core";
2
2
  import * as i1 from "./base-components/generic-table/generic-table.component";
3
- import * as i2 from "./base-components/searchable-dropdown/searchable-dropdown.component";
4
- import * as i3 from "@angular/common";
5
- import * as i4 from "@ngx-translate/core";
6
- import * as i5 from "./material";
7
- import * as i6 from "@angular/forms";
8
- import * as i7 from "ng-block-ui";
9
- import * as i8 from "@angular/common/http";
3
+ import * as i2 from "@angular/common";
4
+ import * as i3 from "@ngx-translate/core";
5
+ import * as i4 from "./material";
6
+ import * as i5 from "ng-block-ui";
7
+ import * as i6 from "@angular/common/http";
10
8
  export declare class RslBaseModule {
11
9
  static ɵfac: i0.ɵɵFactoryDeclaration<RslBaseModule, never>;
12
- static ɵmod: i0.ɵɵNgModuleDeclaration<RslBaseModule, [typeof i1.GenericTableComponent, typeof i2.SearchableDropdownComponent], [typeof i3.CommonModule, typeof i4.TranslateModule, typeof i5.MaterialModule, typeof i6.ReactiveFormsModule, typeof i7.BlockUIModule], [typeof i8.HttpClientModule, typeof i1.GenericTableComponent, typeof i2.SearchableDropdownComponent]>;
10
+ static ɵmod: i0.ɵɵNgModuleDeclaration<RslBaseModule, [typeof i1.GenericTableComponent], [typeof i2.CommonModule, typeof i3.TranslateModule, typeof i4.MaterialModule, typeof i5.BlockUIModule], [typeof i6.HttpClientModule, typeof i1.GenericTableComponent]>;
13
11
  static ɵinj: i0.ɵɵInjectorDeclaration<RslBaseModule>;
14
12
  }
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@rosoftlab/core",
3
- "version": "0.0.100",
3
+ "version": "0.0.101",
4
4
  "peerDependencies": {
5
- "@angular/common": "^15.0.0",
6
- "@angular/core": "^15.0.0",
5
+ "@angular/common": "~13.3.0",
6
+ "@angular/core": "~13.3.0",
7
7
  "fast-json-patch": "^3.1.0",
8
8
  "date-fns": "^2.28.0",
9
9
  "@types/qs": "^6.9.7",
@@ -1,231 +0,0 @@
1
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
- import { Component, EventEmitter, Input, Optional, Output, Self } from '@angular/core';
3
- import { FormControl } from '@angular/forms';
4
- import { Subject } from 'rxjs';
5
- import { debounceTime, filter, finalize, switchMap, takeUntil, tap } from 'rxjs/operators';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "@angular/cdk/a11y";
8
- import * as i2 from "@angular/forms";
9
- import * as i3 from "@angular/material/form-field";
10
- import * as i4 from "@angular/material/button";
11
- import * as i5 from "@angular/material/icon";
12
- import * as i6 from "@angular/material/autocomplete";
13
- import * as i7 from "@angular/material/core";
14
- import * as i8 from "@angular/material/input";
15
- import * as i9 from "@angular/common";
16
- import * as i10 from "@ngx-translate/core";
17
- export class SearchableDropdownComponent {
18
- constructor(_focusMonitor, _elementRef, ngControl) {
19
- this._focusMonitor = _focusMonitor;
20
- this._elementRef = _elementRef;
21
- this.ngControl = ngControl;
22
- this.onChange = (_) => { };
23
- this.onTouched = () => { };
24
- this.stateChanges = new Subject();
25
- this.focused = false;
26
- this.errorState = false;
27
- this.id = `rsl-searchable-dropdown-${SearchableDropdownComponent.nextId++}`;
28
- // label for the search dropdown
29
- this.label = '';
30
- //Fields for sorting the API data
31
- this.sortFields = '';
32
- // The value used to populate the control value
33
- this.valueField = 'id';
34
- // The minumum char for search
35
- this.minLengthTerm = 3;
36
- this.modelSelected = new EventEmitter();
37
- this._required = false;
38
- this._disabled = false;
39
- this.showSerach = true;
40
- this.isLoading = false;
41
- this.options = [];
42
- this.filteredOptions = [];
43
- /** Subject that emits when the component has been destroyed. */
44
- this._onDestroy = new Subject();
45
- this.searchControl = new FormControl('');
46
- _focusMonitor.monitor(_elementRef, true).subscribe(origin => {
47
- if (this.focused && !origin) {
48
- this.onTouched();
49
- }
50
- this.focused = !!origin;
51
- this.stateChanges.next();
52
- });
53
- if (this.ngControl) {
54
- this.ngControl.valueAccessor = this;
55
- }
56
- }
57
- get empty() {
58
- return !this.value;
59
- }
60
- get required() { return this._required; }
61
- set required(value) {
62
- this._required = coerceBooleanProperty(value);
63
- this.stateChanges.next();
64
- }
65
- get disabled() { return this._disabled; }
66
- set disabled(value) {
67
- this._disabled = coerceBooleanProperty(value);
68
- this.stateChanges.next();
69
- }
70
- get value() {
71
- return this._value;
72
- }
73
- set value(value) {
74
- if (value)
75
- if (this._value !== value) {
76
- this.loadModel(value);
77
- }
78
- this._value = value;
79
- this.stateChanges.next();
80
- }
81
- ngOnInit() {
82
- if (!this.displayFields)
83
- this.displayFields = this.searchFields;
84
- this.loadModel(this.ngControl.value);
85
- if (this.preloadElementsCount) {
86
- this.serviceRef.getAll(1, this.preloadElementsCount).subscribe({
87
- next: (data) => {
88
- this.showSerach = false;
89
- this.options = data.getModels();
90
- this.filteredOptions = this.options;
91
- }
92
- });
93
- }
94
- this.searchControl.valueChanges
95
- .pipe(filter((res) => {
96
- const result = res !== null && res.length >= this.minLengthTerm;
97
- if (!result) {
98
- this.options = [];
99
- this.filteredOptions = [];
100
- }
101
- this.showSerach = !result;
102
- return result;
103
- }), debounceTime(300), tap(() => {
104
- this.filteredOptions = [];
105
- this.isLoading = true;
106
- }), switchMap((value) => this.serviceRef
107
- .getAll(1, 10, this.sortFields, `${this.searchFields.replace(',', '|')}@=*${value}`)
108
- .pipe(finalize(() => {
109
- this.isLoading = false;
110
- }))), takeUntil(this._onDestroy))
111
- .subscribe((options) => {
112
- this.filteredOptions = options.getModels();
113
- });
114
- }
115
- onSelected($event) {
116
- const value = $event.option.value;
117
- this.searchControl.setValue(value);
118
- this.modelSelected.emit(value);
119
- if (this.valueField in value) {
120
- this.setControlValue(value[this.valueField]);
121
- }
122
- }
123
- setControlValue(value) {
124
- this.value = value;
125
- this.ngControl.control.setValue(value);
126
- }
127
- displayWith(value) {
128
- return this.getConcatedFields(value);
129
- }
130
- clearSelection() {
131
- this.modelSelected.emit(null);
132
- this.setControlValue(null);
133
- this.searchControl.setValue(null);
134
- this.filteredOptions = this.options;
135
- }
136
- getConcatedFields(option) {
137
- if (!option)
138
- return null;
139
- const filtersArr = this.displayFields.split(',');
140
- return filtersArr.reduce((acc, cv) => {
141
- return acc.concat(option[cv] + ' ');
142
- }, '');
143
- }
144
- ngOnDestroy() {
145
- this.searchControl = null;
146
- this.stateChanges.complete();
147
- this._focusMonitor.stopMonitoring(this._elementRef);
148
- this._onDestroy.next();
149
- this._onDestroy.complete();
150
- }
151
- getSearchText() {
152
- return `Enter ${this.minLengthTerm} characters to start search`;
153
- }
154
- writeValue(model) {
155
- console.log(model);
156
- this.value = model;
157
- }
158
- registerOnChange(fn) {
159
- this.onChange = fn;
160
- }
161
- registerOnTouched(fn) {
162
- this.onTouched = fn;
163
- }
164
- setDisabledState(isDisabled) {
165
- this.disabled = isDisabled;
166
- }
167
- loadModel(id) {
168
- //Load the model from API to display the value
169
- let needLoad = false;
170
- if (id) {
171
- if (!this.searchControl.value)
172
- needLoad = true;
173
- else {
174
- if (this.searchControl.value[this.valueField] !== id) {
175
- needLoad = true;
176
- }
177
- }
178
- }
179
- if (needLoad) {
180
- this.serviceRef.get(id).subscribe({
181
- next: (model) => {
182
- this.options.push(model);
183
- this.filteredOptions = this.options;
184
- this.searchControl.setValue(model);
185
- }
186
- });
187
- }
188
- }
189
- }
190
- SearchableDropdownComponent.nextId = 0;
191
- SearchableDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: SearchableDropdownComponent, deps: [{ token: i1.FocusMonitor }, { token: i0.ElementRef }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
192
- SearchableDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: SearchableDropdownComponent, selector: "rsl-searchable-dropdown", inputs: { label: "label", fControlName: "fControlName", serviceRef: "serviceRef", searchFields: "searchFields", displayFields: "displayFields", sortFields: "sortFields", valueField: "valueField", minLengthTerm: "minLengthTerm", preloadElementsCount: "preloadElementsCount", required: "required", disabled: "disabled", value: "value" }, outputs: { modelSelected: "modelSelected" }, host: { properties: { "class.example-floating": "shouldLabelFloat", "id": "id", "attr.aria-describedby": "describedBy" } }, ngImport: i0, template: "<div class=\"form-group\">\r\n <label>{{label | translate}}</label>\r\n <mat-form-field appearance=\"outline\" fxFlex>\r\n <input matInput [matAutocomplete]=\"auto\" [formControl]=\"searchControl\">\r\n <button *ngIf=\"searchControl.value\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearSelection()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\"\r\n [displayWith]=\"displayWith.bind(this)\">\r\n <mat-option *ngIf=\"isLoading\">Loading...</mat-option>\r\n <mat-option *ngIf=\"!isLoading && filteredOptions.length == 0 && !showSerach\" disabled>Not found</mat-option>\r\n <mat-option *ngIf=\"showSerach\" disabled>{{getSearchText()}}</mat-option>\r\n <ng-container *ngIf=\"!isLoading && filteredOptions.length > 0\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\r\n <span><b>{{getConcatedFields(option)}}</b></span>\r\n </mat-option>\r\n </ng-container>\r\n\r\n </mat-autocomplete>\r\n </mat-form-field>\r\n</div>", components: [{ type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i7.MatOption, selector: "mat-option", exportAs: ["matOption"] }], directives: [{ type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.MatSuffix, selector: "[matSuffix]" }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i10.TranslatePipe } });
193
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: SearchableDropdownComponent, decorators: [{
194
- type: Component,
195
- args: [{ selector: 'rsl-searchable-dropdown', host: {
196
- '[class.example-floating]': 'shouldLabelFloat',
197
- '[id]': 'id',
198
- '[attr.aria-describedby]': 'describedBy',
199
- }, template: "<div class=\"form-group\">\r\n <label>{{label | translate}}</label>\r\n <mat-form-field appearance=\"outline\" fxFlex>\r\n <input matInput [matAutocomplete]=\"auto\" [formControl]=\"searchControl\">\r\n <button *ngIf=\"searchControl.value\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearSelection()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\"\r\n [displayWith]=\"displayWith.bind(this)\">\r\n <mat-option *ngIf=\"isLoading\">Loading...</mat-option>\r\n <mat-option *ngIf=\"!isLoading && filteredOptions.length == 0 && !showSerach\" disabled>Not found</mat-option>\r\n <mat-option *ngIf=\"showSerach\" disabled>{{getSearchText()}}</mat-option>\r\n <ng-container *ngIf=\"!isLoading && filteredOptions.length > 0\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\r\n <span><b>{{getConcatedFields(option)}}</b></span>\r\n </mat-option>\r\n </ng-container>\r\n\r\n </mat-autocomplete>\r\n </mat-form-field>\r\n</div>" }]
200
- }], ctorParameters: function () { return [{ type: i1.FocusMonitor }, { type: i0.ElementRef }, { type: i2.NgControl, decorators: [{
201
- type: Optional
202
- }, {
203
- type: Self
204
- }] }]; }, propDecorators: { label: [{
205
- type: Input
206
- }], fControlName: [{
207
- type: Input
208
- }], serviceRef: [{
209
- type: Input
210
- }], searchFields: [{
211
- type: Input
212
- }], displayFields: [{
213
- type: Input
214
- }], sortFields: [{
215
- type: Input
216
- }], valueField: [{
217
- type: Input
218
- }], minLengthTerm: [{
219
- type: Input
220
- }], preloadElementsCount: [{
221
- type: Input
222
- }], modelSelected: [{
223
- type: Output
224
- }], required: [{
225
- type: Input
226
- }], disabled: [{
227
- type: Input
228
- }], value: [{
229
- type: Input
230
- }] } });
231
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../projects/rosoftlab/core/src/lib/base-components/searchable-dropdown/searchable-dropdown.component.ts","../../../../../../../projects/rosoftlab/core/src/lib/base-components/searchable-dropdown/searchable-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\r\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Optional, Output, Self } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, filter, finalize, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { BaseQueryData } from '../../models/base-query-data';\r\nimport { BaseModel } from '../../models/base.model';\r\nimport { BaseService } from '../../services/base.service';\r\n\r\n@Component({\r\n  selector: 'rsl-searchable-dropdown',\r\n  templateUrl: './searchable-dropdown.component.html',\r\n  // styleUrls: ['./searchable-dropdown.component.scss'],\r\n  host: {\r\n    '[class.example-floating]': 'shouldLabelFloat',\r\n    '[id]': 'id',\r\n    '[attr.aria-describedby]': 'describedBy',\r\n  }\r\n})\r\nexport class SearchableDropdownComponent<T extends BaseModel> implements OnInit, OnDestroy, ControlValueAccessor {\r\n  static nextId = 0;\r\n  onChange = (_: any) => { };\r\n  onTouched = () => { };\r\n  stateChanges = new Subject<void>();\r\n  focused = false;\r\n  errorState = false;\r\n  id = `rsl-searchable-dropdown-${SearchableDropdownComponent.nextId++}`;\r\n\r\n  // label for the search dropdown\r\n  @Input() label: string = '';\r\n\r\n  //Name of the form control\r\n  @Input() fControlName: string;\r\n\r\n  //Reference of the service\r\n  @Input() serviceRef: BaseService<T>;\r\n\r\n  //Fields for filtering\r\n  @Input() searchFields: string;\r\n\r\n  //Fields for display \r\n  @Input() displayFields: string;\r\n\r\n  //Fields for sorting the API data\r\n  @Input() sortFields: string = '';\r\n\r\n  // The value used to populate the control value\r\n  @Input() valueField: string = 'id';\r\n\r\n  // The minumum char for search\r\n  @Input() minLengthTerm: number = 3;\r\n\r\n  // The preload x elements\r\n  @Input() preloadElementsCount: number;\r\n\r\n  @Output() modelSelected: EventEmitter<BaseModel> = new EventEmitter();\r\n\r\n\r\n  get empty() {\r\n    return !this.value;\r\n  }\r\n\r\n\r\n  @Input()\r\n  get required(): boolean { return this._required; }\r\n  set required(value: boolean) {\r\n    this._required = coerceBooleanProperty(value);\r\n    this.stateChanges.next();\r\n  }\r\n  private _required = false;\r\n\r\n  @Input()\r\n  get disabled(): boolean { return this._disabled; }\r\n  set disabled(value: boolean) {\r\n    this._disabled = coerceBooleanProperty(value);\r\n    this.stateChanges.next();\r\n  }\r\n  private _disabled = false;\r\n\r\n\r\n\r\n  @Input()\r\n  get value(): any | null {\r\n    return this._value;\r\n  }\r\n  set value(value: any | null) {\r\n    if (value)\r\n      if (this._value !== value) {\r\n        this.loadModel(value);\r\n      }\r\n    this._value = value;\r\n    this.stateChanges.next();\r\n  }\r\n  private _value: any;\r\n  // Search form control\r\n  searchControl: AbstractControl;\r\n\r\n  showSerach = true;\r\n  isLoading = false;\r\n  options = [];\r\n  filteredOptions = [];\r\n  /** Subject that emits when the component has been destroyed. */\r\n  protected _onDestroy = new Subject<void>();\r\n\r\n  constructor(\r\n    private _focusMonitor: FocusMonitor,\r\n    private _elementRef: ElementRef<HTMLElement>,\r\n    @Optional() @Self() public ngControl: NgControl\r\n  ) {\r\n\r\n    this.searchControl = new FormControl('');\r\n    _focusMonitor.monitor(_elementRef, true).subscribe(origin => {\r\n      if (this.focused && !origin) {\r\n        this.onTouched();\r\n      }\r\n      this.focused = !!origin;\r\n      this.stateChanges.next();\r\n    });\r\n\r\n    if (this.ngControl) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (!this.displayFields)\r\n      this.displayFields = this.searchFields;\r\n\r\n    this.loadModel(this.ngControl.value)\r\n\r\n    if (this.preloadElementsCount) {\r\n      this.serviceRef.getAll(1, this.preloadElementsCount).subscribe({\r\n        next: (data: BaseQueryData<T>) => {\r\n          this.showSerach = false;\r\n          this.options = data.getModels();\r\n          this.filteredOptions = this.options;\r\n        }\r\n      })\r\n    }\r\n\r\n    this.searchControl.valueChanges\r\n      .pipe(\r\n        filter((res) => {\r\n          const result = res !== null && res.length >= this.minLengthTerm;\r\n          if (!result) {\r\n            this.options = [];\r\n            this.filteredOptions = [];\r\n          }\r\n          this.showSerach = !result;\r\n          return result;\r\n        }),\r\n        debounceTime(300),\r\n        tap(() => {\r\n          this.filteredOptions = [];\r\n          this.isLoading = true;\r\n        }),\r\n        switchMap((value: string) =>\r\n          this.serviceRef\r\n            .getAll(1, 10, this.sortFields, `${this.searchFields.replace(',', '|')}@=*${value}`)\r\n            .pipe(\r\n              finalize(() => {\r\n                this.isLoading = false;\r\n              })\r\n            )\r\n        ),\r\n        takeUntil(this._onDestroy)\r\n      )\r\n      .subscribe((options: any) => {\r\n        this.filteredOptions = options.getModels();\r\n      });\r\n  }\r\n\r\n  onSelected($event) {\r\n    const value = $event.option.value;\r\n    this.searchControl.setValue(value);\r\n    this.modelSelected.emit(value);\r\n    if (this.valueField in value) {\r\n      this.setControlValue(value[this.valueField]);\r\n    }\r\n\r\n  }\r\n  setControlValue(value: any) {\r\n    this.value = value;\r\n    this.ngControl.control.setValue(value);\r\n  }\r\n  displayWith(value: any) {\r\n    return this.getConcatedFields(value);\r\n  }\r\n\r\n  clearSelection() {\r\n    this.modelSelected.emit(null);\r\n    this.setControlValue(null);\r\n    this.searchControl.setValue(null);\r\n    this.filteredOptions = this.options;\r\n  }\r\n\r\n  getConcatedFields(option): string {\r\n    if (!option) return null;\r\n    const filtersArr = this.displayFields.split(',');\r\n    return filtersArr.reduce((acc, cv) => {\r\n      return acc.concat(option[cv] + ' ');\r\n    }, '');\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.searchControl = null;\r\n    this.stateChanges.complete();\r\n    this._focusMonitor.stopMonitoring(this._elementRef);\r\n    this._onDestroy.next();\r\n    this._onDestroy.complete();\r\n  }\r\n  getSearchText(): string {\r\n    return `Enter ${this.minLengthTerm} characters to start search`;\r\n\r\n  }\r\n  writeValue(model: T | null): void {\r\n    console.log(model);\r\n    this.value = model;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n  private loadModel(id: string) {\r\n    //Load the model from API to display the value\r\n    let needLoad = false;\r\n    if (id) {\r\n      if (!this.searchControl.value)\r\n        needLoad = true\r\n      else {\r\n        if (this.searchControl.value[this.valueField] !== id) {\r\n          needLoad = true\r\n        }\r\n      }\r\n    }\r\n    if (needLoad) {\r\n      this.serviceRef.get(id).subscribe({\r\n        next: (model: T) => {\r\n          this.options.push(model);\r\n          this.filteredOptions = this.options;\r\n          this.searchControl.setValue(model);\r\n        }\r\n      })\r\n    }\r\n  }\r\n}\r\n","<div class=\"form-group\">\r\n  <label>{{label | translate}}</label>\r\n  <mat-form-field appearance=\"outline\" fxFlex>\r\n    <input matInput [matAutocomplete]=\"auto\" [formControl]=\"searchControl\">\r\n    <button *ngIf=\"searchControl.value\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"clearSelection()\">\r\n      <mat-icon>close</mat-icon>\r\n    </button>\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\"\r\n      [displayWith]=\"displayWith.bind(this)\">\r\n      <mat-option *ngIf=\"isLoading\">Loading...</mat-option>\r\n      <mat-option *ngIf=\"!isLoading && filteredOptions.length == 0 && !showSerach\" disabled>Not found</mat-option>\r\n      <mat-option *ngIf=\"showSerach\" disabled>{{getSearchText()}}</mat-option>\r\n      <ng-container *ngIf=\"!isLoading && filteredOptions.length > 0\">\r\n        <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\r\n          <span><b>{{getConcatedFields(option)}}</b></span>\r\n        </mat-option>\r\n      </ng-container>\r\n\r\n    </mat-autocomplete>\r\n  </mat-form-field>\r\n</div>"]}
@@ -1,62 +0,0 @@
1
- import { FocusMonitor } from '@angular/cdk/a11y';
2
- import { ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
3
- import { AbstractControl, ControlValueAccessor, NgControl } from '@angular/forms';
4
- import { Subject } from 'rxjs';
5
- import { BaseModel } from '../../models/base.model';
6
- import { BaseService } from '../../services/base.service';
7
- import * as i0 from "@angular/core";
8
- export declare class SearchableDropdownComponent<T extends BaseModel> implements OnInit, OnDestroy, ControlValueAccessor {
9
- private _focusMonitor;
10
- private _elementRef;
11
- ngControl: NgControl;
12
- static nextId: number;
13
- onChange: (_: any) => void;
14
- onTouched: () => void;
15
- stateChanges: Subject<void>;
16
- focused: boolean;
17
- errorState: boolean;
18
- id: string;
19
- label: string;
20
- fControlName: string;
21
- serviceRef: BaseService<T>;
22
- searchFields: string;
23
- displayFields: string;
24
- sortFields: string;
25
- valueField: string;
26
- minLengthTerm: number;
27
- preloadElementsCount: number;
28
- modelSelected: EventEmitter<BaseModel>;
29
- get empty(): boolean;
30
- get required(): boolean;
31
- set required(value: boolean);
32
- private _required;
33
- get disabled(): boolean;
34
- set disabled(value: boolean);
35
- private _disabled;
36
- get value(): any | null;
37
- set value(value: any | null);
38
- private _value;
39
- searchControl: AbstractControl;
40
- showSerach: boolean;
41
- isLoading: boolean;
42
- options: any[];
43
- filteredOptions: any[];
44
- /** Subject that emits when the component has been destroyed. */
45
- protected _onDestroy: Subject<void>;
46
- constructor(_focusMonitor: FocusMonitor, _elementRef: ElementRef<HTMLElement>, ngControl: NgControl);
47
- ngOnInit(): void;
48
- onSelected($event: any): void;
49
- setControlValue(value: any): void;
50
- displayWith(value: any): string;
51
- clearSelection(): void;
52
- getConcatedFields(option: any): string;
53
- ngOnDestroy(): void;
54
- getSearchText(): string;
55
- writeValue(model: T | null): void;
56
- registerOnChange(fn: any): void;
57
- registerOnTouched(fn: any): void;
58
- setDisabledState(isDisabled: boolean): void;
59
- private loadModel;
60
- static ɵfac: i0.ɵɵFactoryDeclaration<SearchableDropdownComponent<any>, [null, null, { optional: true; self: true; }]>;
61
- static ɵcmp: i0.ɵɵComponentDeclaration<SearchableDropdownComponent<any>, "rsl-searchable-dropdown", never, { "label": "label"; "fControlName": "fControlName"; "serviceRef": "serviceRef"; "searchFields": "searchFields"; "displayFields": "displayFields"; "sortFields": "sortFields"; "valueField": "valueField"; "minLengthTerm": "minLengthTerm"; "preloadElementsCount": "preloadElementsCount"; "required": "required"; "disabled": "disabled"; "value": "value"; }, { "modelSelected": "modelSelected"; }, never, never>;
62
- }