@gloww/gloww 0.9.0-beta.34 → 0.9.0-beta.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/Components/auto-complete/auto-complete.component.mjs +28 -30
- package/esm2020/lib/Components/select/select.component.mjs +2 -2
- package/fesm2015/gloww-gloww.mjs +28 -30
- package/fesm2015/gloww-gloww.mjs.map +1 -1
- package/fesm2020/gloww-gloww.mjs +28 -30
- package/fesm2020/gloww-gloww.mjs.map +1 -1
- package/lib/Components/auto-complete/auto-complete.component.d.ts +7 -3
- package/package.json +3 -2
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { catchError, debounceTime, distinctUntilChanged, filter, map, switchMap, tap } from 'rxjs/operators';
|
|
2
|
-
import { Component, Input, Inject } from '@angular/core';
|
|
2
|
+
import { Component, Input, Inject, forwardRef } from '@angular/core';
|
|
3
3
|
import { FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
4
|
import { of } from 'rxjs';
|
|
5
|
+
import { TranslateDefaultParser } from '@ngx-translate/core';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/forms";
|
|
7
8
|
import * as i2 from "@angular/material/form-field";
|
|
@@ -18,34 +19,14 @@ export class AutoCompleteComponent {
|
|
|
18
19
|
this.searchField = null;
|
|
19
20
|
this.returnField = null;
|
|
20
21
|
this.displayField = null;
|
|
22
|
+
this.displayExpr = null;
|
|
21
23
|
this.displayFct = null;
|
|
22
24
|
this.placeHolder = null;
|
|
23
25
|
this.data = null;
|
|
24
26
|
this.onChange = () => { };
|
|
25
27
|
this.onTouched = () => { };
|
|
26
28
|
this.items = [];
|
|
27
|
-
|
|
28
|
-
this.error = null;
|
|
29
|
-
if (!this.searchRequest) {
|
|
30
|
-
this.searchRequest = this.glowwService[`search${this.objectName}`];
|
|
31
|
-
}
|
|
32
|
-
let queryParams: any = {};
|
|
33
|
-
if (this.data) {
|
|
34
|
-
Object.keys(this.data).forEach(name => {
|
|
35
|
-
queryParams[name] = this.data[name];
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
//debugger;
|
|
40
|
-
this.searchRequest.call(this.glowwService, queryParams).subscribe(items => this.items = items,
|
|
41
|
-
error => {
|
|
42
|
-
this.error = error;
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
}
|
|
46
|
-
ngAfterContentInit(): void {
|
|
47
|
-
|
|
48
|
-
}*/
|
|
29
|
+
this.parser = new TranslateDefaultParser();
|
|
49
30
|
this.options = []; //Observable<unknown>;
|
|
50
31
|
this.propagateChange = (_) => { };
|
|
51
32
|
this.glowwService = glowwService;
|
|
@@ -53,13 +34,21 @@ export class AutoCompleteComponent {
|
|
|
53
34
|
this.form = this.formBuilder.group({
|
|
54
35
|
__result: this.resultCtrl
|
|
55
36
|
});
|
|
56
|
-
|
|
37
|
+
}
|
|
38
|
+
ngAfterViewInit() {
|
|
57
39
|
}
|
|
58
40
|
ngOnInit() {
|
|
41
|
+
//debugger;
|
|
42
|
+
this.searchRequest = this.glowwService[`search${this.objectName}`];
|
|
59
43
|
this.resultCtrl.valueChanges.pipe(filter(res => res != null && res.length > 2), distinctUntilChanged(), debounceTime(250), tap(() => { this.error = ""; this.options = []; }), switchMap(searchStr => {
|
|
60
44
|
let searchObj = {};
|
|
45
|
+
if (this.data) {
|
|
46
|
+
Object.keys(this.data).forEach(k => {
|
|
47
|
+
searchObj[k] = this.data[k];
|
|
48
|
+
});
|
|
49
|
+
}
|
|
61
50
|
searchObj[this.searchField] = searchStr;
|
|
62
|
-
return this.
|
|
51
|
+
return this.searchRequest.call(this.glowwService, searchObj).pipe(map(res => res), catchError(err => {
|
|
63
52
|
this.error = err.message;
|
|
64
53
|
this.ref.markForCheck();
|
|
65
54
|
return of([]);
|
|
@@ -73,7 +62,7 @@ export class AutoCompleteComponent {
|
|
|
73
62
|
});
|
|
74
63
|
}
|
|
75
64
|
writeValue(val) {
|
|
76
|
-
val && this.form.setValue(val, { emitEvent: false });
|
|
65
|
+
val && this.form.setValue({ __result: val }, { emitEvent: false });
|
|
77
66
|
}
|
|
78
67
|
registerOnChange(fn) {
|
|
79
68
|
this.onChange = fn;
|
|
@@ -94,21 +83,27 @@ export class AutoCompleteComponent {
|
|
|
94
83
|
//TODO
|
|
95
84
|
}
|
|
96
85
|
displayObj(item) {
|
|
86
|
+
if (!item)
|
|
87
|
+
return null;
|
|
97
88
|
console.log("displayOf");
|
|
98
89
|
if (this.displayField) {
|
|
99
90
|
return item[this.displayField];
|
|
100
91
|
}
|
|
92
|
+
else if (this.displayExpr) {
|
|
93
|
+
return this.parser.interpolate(this.displayExpr.replace(/\\\{/g, "{").replace(/\\\}/g, "}"), item);
|
|
94
|
+
//return '?1' + this.parser.interpolate("{{Name}}", { Name: "test" }) + '?2' + this.parser.interpolate("{{Name}}", item)+'?3'+this.parser.interpolate(this.displayExpr.replace(/\\\{/g,"{").replace(/\\\}/g,"}"), item) +'?4'+ item;
|
|
95
|
+
}
|
|
101
96
|
else if (this.displayFct) {
|
|
102
97
|
return this.displayFct(item);
|
|
103
98
|
}
|
|
104
99
|
}
|
|
105
100
|
}
|
|
106
101
|
AutoCompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AutoCompleteComponent, deps: [{ token: 'glowwService' }, { token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
-
AutoCompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AutoCompleteComponent, selector: "gloww-auto-complete", inputs: { _value: ["value", "_value"], objectName: "objectName", searchField: "searchField", returnField: "returnField", displayField: "displayField", displayFct: "displayFct", placeHolder: "placeHolder", data: "data", searchRequest: "searchRequest" }, providers: [
|
|
102
|
+
AutoCompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AutoCompleteComponent, selector: "gloww-auto-complete", inputs: { _value: ["value", "_value"], objectName: "objectName", searchField: "searchField", returnField: "returnField", displayField: "displayField", displayExpr: "displayExpr", displayFct: "displayFct", placeHolder: "placeHolder", data: "data", searchRequest: "searchRequest" }, providers: [
|
|
108
103
|
{
|
|
109
104
|
provide: NG_VALUE_ACCESSOR,
|
|
110
105
|
multi: true,
|
|
111
|
-
useExisting: AutoCompleteComponent
|
|
106
|
+
useExisting: forwardRef(() => AutoCompleteComponent)
|
|
112
107
|
}
|
|
113
108
|
], ngImport: i0, template: "<div [formGroup]=\"form\" style=\"width:100%\">\n <div style=\"color:red\">{{error}}</div>\n <mat-form-field style=\"width:100%\">\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n </mat-form-field>\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n {{displayObj(option)}}\n </mat-option>\n </mat-autocomplete>\n</div>", styles: [""], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i3.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }], directives: [{ type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.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: i1.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: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
114
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AutoCompleteComponent, decorators: [{
|
|
@@ -117,7 +112,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
117
112
|
{
|
|
118
113
|
provide: NG_VALUE_ACCESSOR,
|
|
119
114
|
multi: true,
|
|
120
|
-
useExisting: AutoCompleteComponent
|
|
115
|
+
useExisting: forwardRef(() => AutoCompleteComponent)
|
|
121
116
|
}
|
|
122
117
|
], template: "<div [formGroup]=\"form\" style=\"width:100%\">\n <div style=\"color:red\">{{error}}</div>\n <mat-form-field style=\"width:100%\">\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n </mat-form-field>\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n {{displayObj(option)}}\n </mat-option>\n </mat-autocomplete>\n</div>", styles: [""] }]
|
|
123
118
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
@@ -138,6 +133,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
138
133
|
}], displayField: [{
|
|
139
134
|
type: Input,
|
|
140
135
|
args: ['displayField']
|
|
136
|
+
}], displayExpr: [{
|
|
137
|
+
type: Input,
|
|
138
|
+
args: ['displayExpr']
|
|
141
139
|
}], displayFct: [{
|
|
142
140
|
type: Input,
|
|
143
141
|
args: ['displayFct']
|
|
@@ -150,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
150
148
|
}], searchRequest: [{
|
|
151
149
|
type: Input
|
|
152
150
|
}] } });
|
|
153
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.component.js","sourceRoot":"","sources":["../../../../../../projects/gloww/src/lib/Components/auto-complete/auto-complete.component.ts","../../../../../../projects/gloww/src/lib/Components/auto-complete/auto-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { catchError, debounceTime, distinctUntilChanged, filter, finalize, map, switchMap, tap } from 'rxjs/operators';\nimport { Component, OnInit, Input, AfterViewInit, Inject, ChangeDetectorRef } from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, of } from 'rxjs';\nimport { GlowwService } from '../../Services/gloww.service';\nimport { CodeEditorComponent } from '../code-editor/code-editor.component';\n\n@Component({\n  selector: 'gloww-auto-complete',\n  templateUrl: './auto-complete.component.html',\n  styleUrls: ['./auto-complete.component.css'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: AutoCompleteComponent\n    }\n  ]\n})\nexport class AutoCompleteComponent implements ControlValueAccessor, OnInit {\n  @Input('value') _value: any = null;\n  @Input('objectName') objectName: any = null;\n  @Input('searchField') searchField: any = null;\n  @Input('returnField') returnField: any = null;\n  @Input('displayField') displayField: any = null;\n  @Input('displayFct') displayFct: any = null;\n  @Input('placeHolder') placeHolder: any = null;\n  @Input('data') data: any = null;\n  onChange: any = () => { };\n  onTouched: any = () => { };\n  public items: any[] = [];\n  public error: string;\n\n  @Input() searchRequest: (obj?: any) => Observable<[]>;\n\n  public form: FormGroup;\n  glowwService: any;\n  resultCtrl: FormControl;\n\n  constructor(@Inject('glowwService') glowwService: any, private formBuilder: FormBuilder, private ref: ChangeDetectorRef) {\n    this.glowwService = glowwService;\n    this.resultCtrl = new FormControl();\n    this.form = this.formBuilder.group({\n      __result: this.resultCtrl\n    });\n    this.searchRequest = this.glowwService[`search${this.objectName}`];\n  }\n\n  /*  ngAfterViewInit(): void {\n      this.error = null;\n      if (!this.searchRequest) {\n        this.searchRequest = this.glowwService[`search${this.objectName}`];\n      }\n      let queryParams: any = {};\n      if (this.data) {\n        Object.keys(this.data).forEach(name => {\n          queryParams[name] = this.data[name];\n        });\n      }\n  \n      //debugger;\n      this.searchRequest.call(this.glowwService, queryParams).subscribe(items => this.items = items,\n        error => {\n          this.error = error;\n        });\n  \n    }\n    ngAfterContentInit(): void {\n  \n    }*/\n\n  public options: any[] = [];//Observable<unknown>;\n  ngOnInit(): void {\n    this.resultCtrl.valueChanges.pipe(\n      filter(res => res != null && res.length > 2),\n      distinctUntilChanged(),\n      debounceTime(250),\n      tap(() => { this.error = \"\"; this.options = []; }),\n      switchMap(searchStr => {\n        let searchObj = {};\n        searchObj[this.searchField] = searchStr;\n        return this.glowwService.searchEntityDef(searchObj).pipe(\n          map(res => res),\n          catchError(err => {\n            this.error = err.message;\n            this.ref.markForCheck();\n            return of([])\n          })\n        )\n      })\n    ).subscribe(\n      {\n        next: (data: any[]) => {\n          this.options = data;\n          this.ref.markForCheck();\n        },\n        error: (error) => { this.error = error }\n      }\n    );\n  }\n\n\n  writeValue(val: any): void {\n    val && this.form.setValue(val, { emitEvent: false });\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n    this.form.valueChanges.subscribe(data => {\n      if (this.returnField) {\n        this.onChange(this.form.value.__result[this.returnField]);\n      } else {\n        this.onChange(this.form.value.__result);\n      }\n    });\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  propagateChange = (_: any) => { };\n\n  setDisabledState?(isDisabled: boolean): void {\n    const status = isDisabled ? 'disable' : 'enable';\n    //TODO\n  }\n\n  displayObj(item) {\n    console.log(\"displayOf\");\n    if (this.displayField) {\n      return item[this.displayField];\n    } else if (this.displayFct) {\n      return this.displayFct(item);\n    }\n  }\n}\n\n","<div [formGroup]=\"form\" style=\"width:100%\">\n    <div style=\"color:red\">{{error}}</div>\n    <mat-form-field style=\"width:100%\">\n        <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n    </mat-form-field>\n    <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n        <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n            {{displayObj(option)}}\n        </mat-option>\n    </mat-autocomplete>\n</div>"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.component.js","sourceRoot":"","sources":["../../../../../../projects/gloww/src/lib/Components/auto-complete/auto-complete.component.ts","../../../../../../projects/gloww/src/lib/Components/auto-complete/auto-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { catchError, debounceTime, distinctUntilChanged, filter, map, switchMap, tap } from 'rxjs/operators';\r\nimport { Component, OnInit, Input, AfterViewInit, Inject, ChangeDetectorRef, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { Observable, of } from 'rxjs';\r\nimport { TranslateDefaultParser } from '@ngx-translate/core';\r\n\r\n@Component({\r\n  selector: 'gloww-auto-complete',\r\n  templateUrl: './auto-complete.component.html',\r\n  styleUrls: ['./auto-complete.component.css'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: forwardRef(() => AutoCompleteComponent)\r\n    }\r\n  ]\r\n})\r\nexport class AutoCompleteComponent implements ControlValueAccessor, OnInit, AfterViewInit {\r\n  @Input('value') _value: any = null;\r\n  @Input('objectName') objectName: any = null;\r\n  @Input('searchField') searchField: any = null;\r\n  @Input('returnField') returnField: any = null;\r\n  @Input('displayField') displayField: any = null;\r\n  @Input('displayExpr') displayExpr: any = null;\r\n  @Input('displayFct') displayFct: any = null;\r\n  @Input('placeHolder') placeHolder: any = null;\r\n  @Input('data') data: any = null;\r\n  onChange: any = () => { };\r\n  onTouched: any = () => { };\r\n  public items: any[] = [];\r\n  public error: string;\r\n\r\n  @Input() searchRequest: (obj?: any) => Observable<[]>;\r\n\r\n  public form: FormGroup;\r\n  glowwService: any;\r\n  resultCtrl: FormControl;\r\n  public parser = new TranslateDefaultParser();\r\n\r\n  constructor(@Inject('glowwService') glowwService: any, private formBuilder: FormBuilder, private ref: ChangeDetectorRef) {\r\n    this.glowwService = glowwService;\r\n    this.resultCtrl = new FormControl();\r\n    this.form = this.formBuilder.group({\r\n      __result: this.resultCtrl\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n  }\r\n\r\n  public options: any[] = [];//Observable<unknown>;\r\n  ngOnInit(): void {\r\n    //debugger;\r\n    this.searchRequest = this.glowwService[`search${this.objectName}`];\r\n    this.resultCtrl.valueChanges.pipe(\r\n      filter(res => res != null && res.length > 2),\r\n      distinctUntilChanged(),\r\n      debounceTime(250),\r\n      tap(() => { this.error = \"\"; this.options = []; }),\r\n      switchMap(searchStr => {\r\n        let searchObj = {};\r\n        if (this.data) {\r\n          Object.keys(this.data).forEach(k => {\r\n            searchObj[k] = this.data[k];\r\n          });\r\n        }\r\n        searchObj[this.searchField] = searchStr;\r\n        return this.searchRequest.call(this.glowwService, searchObj).pipe(\r\n          map(res => res),\r\n          catchError(err => {\r\n            this.error = err.message;\r\n            this.ref.markForCheck();\r\n            return of([])\r\n          })\r\n        )\r\n      })\r\n    ).subscribe(\r\n      {\r\n        next: (data: any[]) => {\r\n          this.options = data;\r\n          this.ref.markForCheck();\r\n        },\r\n        error: (error) => { this.error = error }\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n  writeValue(val: any): void {\r\n    val && this.form.setValue({ __result: val }, { emitEvent: false });\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n    this.form.valueChanges.subscribe(data => {\r\n      if (this.returnField) {\r\n        this.onChange(this.form.value.__result[this.returnField]);\r\n      } else {\r\n        this.onChange(this.form.value.__result);\r\n      }\r\n    });\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  propagateChange = (_: any) => { };\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    const status = isDisabled ? 'disable' : 'enable';\r\n    //TODO\r\n  }\r\n\r\n  displayObj(item) {\r\n\tif (!item) return null;\r\n    console.log(\"displayOf\");\r\n    if (this.displayField) {\r\n      return item[this.displayField];\r\n    } else if (this.displayExpr) {\r\n      return this.parser.interpolate(this.displayExpr.replace(/\\\\\\{/g,\"{\").replace(/\\\\\\}/g,\"}\"), item);\r\n//return '?1' + this.parser.interpolate(\"{{Name}}\", { Name: \"test\" }) + '?2' + this.parser.interpolate(\"{{Name}}\", item)+'?3'+this.parser.interpolate(this.displayExpr.replace(/\\\\\\{/g,\"{\").replace(/\\\\\\}/g,\"}\"), item) +'?4'+ item;\r\n    } else if (this.displayFct) {\r\n      return this.displayFct(item);\r\n    }\r\n  }\r\n}\r\n\r\n","<div [formGroup]=\"form\" style=\"width:100%\">\n    <div style=\"color:red\">{{error}}</div>\n    <mat-form-field style=\"width:100%\">\n        <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n    </mat-form-field>\n    <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n        <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n            {{displayObj(option)}}\n        </mat-option>\n    </mat-autocomplete>\n</div>"]}
|
|
@@ -47,7 +47,7 @@ export class SelectComponent {
|
|
|
47
47
|
ngOnInit() {
|
|
48
48
|
}
|
|
49
49
|
writeValue(val) {
|
|
50
|
-
val && this.form.setValue(val, { emitEvent: false });
|
|
50
|
+
val && this.form.setValue({ select: val }, { emitEvent: false });
|
|
51
51
|
}
|
|
52
52
|
registerOnChange(fn) {
|
|
53
53
|
this.onChange = fn;
|
|
@@ -120,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
120
120
|
}], searchRequest: [{
|
|
121
121
|
type: Input
|
|
122
122
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/gloww/src/lib/Components/select/select.component.ts","../../../../../../projects/gloww/src/lib/Components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, AfterViewInit, Inject } from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, FormGroup, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable } from 'rxjs';\nimport { GlowwService } from '../../Services/gloww.service';\nimport { CodeEditorComponent } from '../code-editor/code-editor.component';\n\n@Component({\n  selector: 'gloww-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.css'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: SelectComponent\n    }\n  ]\n})\nexport class SelectComponent implements ControlValueAccessor, AfterViewInit {\n  @Input('value') _value: any = null;\n  @Input('objectName') objectName: any = null;\n  @Input('returnField') returnField: any = null;\n  @Input('displayField') displayField: any = null;\n  @Input('displayFct') displayFct: any = null;\n  @Input('placeHolder') placeHolder: any = null;\n  @Input('data') data: any = null;\n  onChange: any = () => { };\n  onTouched: any = () => { };\n  public items: any[] = [];\n  public error: string;\n\n  @Input() searchRequest: (obj?: any) => Observable<[]>;\n\n  public form: FormGroup;\n  glowwService: any;\n\n  constructor(@Inject('glowwService') glowwService: any, private formBuilder: FormBuilder) {\n    this.glowwService = glowwService;\n    this.form = this.formBuilder.group({\n      select: [null, null]\n    });\n    this.searchRequest = this.glowwService[`search${this.objectName}`];\n  }\n\n  ngAfterViewInit(): void {\n    this.error = null;\n    if (!this.searchRequest) {\n      this.searchRequest = this.glowwService[`search${this.objectName}`];\n    }\n    let queryParams: any = {};\n    if (this.data) {\n      Object.keys(this.data).forEach(name => {\n        queryParams[name] = this.data[name];\n      });\n    }\n\n    //debugger;\n    this.searchRequest.call(this.glowwService, queryParams).subscribe(items => this.items = items,\n      error => {\n        this.error = error;\n      });\n\n  }\n  ngAfterContentInit(): void {\n\n  }\n\n  ngOnInit(): void {\n  }\n\n\n  writeValue(val: any): void {\n    val && this.form.setValue({ select: val }, { emitEvent: false });\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n    this.form.valueChanges.subscribe(data => {\n      if (this.returnField) {\n        this.onChange(this.form.value.select[this.returnField]);\n      } else {\n        this.onChange(this.form.value.select);\n      }\n    });\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  propagateChange = (_: any) => { };\n\n  setDisabledState?(isDisabled: boolean): void {\n    const status = isDisabled ? 'disable' : 'enable';\n    //TODO\n  }\n\n  displayObj(item) {\n    if (this.displayField) {\n      return item[this.displayField];\n    } else if (this.displayFct) {\n      return this.displayFct(item);\n    }\n  }\n\n}\n\n","<form [formGroup]=\"form\">\n    <div *ngIf=\"error\" style=\"color:red\">{{error}}</div>\n    <mat-form-field>\n        <mat-select [placeholder]=\"placeHolder\" formControlName=\"select\">\n            <mat-option *ngFor=\"let item of items\" [value]=\"item\">{{displayObj(item)}}</mat-option>\n        </mat-select>\n    </mat-form-field>\n</form>"]}
|
package/fesm2015/gloww-gloww.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { InjectionToken, Injectable, Pipe, Component, Inject, Input, EventEmitter, Directive, HostBinding, Output, HostListener, ViewChild, ContentChildren, PLATFORM_ID, Optional, ContentChild, NgModule, SecurityContext } from '@angular/core';
|
|
2
|
+
import { InjectionToken, Injectable, Pipe, Component, Inject, Input, EventEmitter, Directive, HostBinding, Output, HostListener, ViewChild, ContentChildren, PLATFORM_ID, Optional, ContentChild, NgModule, SecurityContext, forwardRef } from '@angular/core';
|
|
3
3
|
import { Subject, BehaviorSubject, of, combineLatest, forkJoin, throwError } from 'rxjs';
|
|
4
4
|
import * as i1 from '@angular/common/http';
|
|
5
5
|
import { HttpClient, HttpParams, HttpEventType, HTTP_INTERCEPTORS, HttpClientModule, HttpResponse } from '@angular/common/http';
|
|
@@ -57,6 +57,7 @@ import jwt_decode from 'jwt-decode';
|
|
|
57
57
|
import { __awaiter } from 'tslib';
|
|
58
58
|
import * as FileSaver from 'file-saver';
|
|
59
59
|
import * as JSZip from 'jszip';
|
|
60
|
+
import { TranslateDefaultParser } from '@ngx-translate/core';
|
|
60
61
|
import * as i3$1 from '@angular/material/autocomplete';
|
|
61
62
|
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
62
63
|
import * as moment from 'moment';
|
|
@@ -3016,7 +3017,7 @@ class SelectComponent {
|
|
|
3016
3017
|
ngOnInit() {
|
|
3017
3018
|
}
|
|
3018
3019
|
writeValue(val) {
|
|
3019
|
-
val && this.form.setValue(val, { emitEvent: false });
|
|
3020
|
+
val && this.form.setValue({ select: val }, { emitEvent: false });
|
|
3020
3021
|
}
|
|
3021
3022
|
registerOnChange(fn) {
|
|
3022
3023
|
this.onChange = fn;
|
|
@@ -3101,34 +3102,14 @@ class AutoCompleteComponent {
|
|
|
3101
3102
|
this.searchField = null;
|
|
3102
3103
|
this.returnField = null;
|
|
3103
3104
|
this.displayField = null;
|
|
3105
|
+
this.displayExpr = null;
|
|
3104
3106
|
this.displayFct = null;
|
|
3105
3107
|
this.placeHolder = null;
|
|
3106
3108
|
this.data = null;
|
|
3107
3109
|
this.onChange = () => { };
|
|
3108
3110
|
this.onTouched = () => { };
|
|
3109
3111
|
this.items = [];
|
|
3110
|
-
|
|
3111
|
-
this.error = null;
|
|
3112
|
-
if (!this.searchRequest) {
|
|
3113
|
-
this.searchRequest = this.glowwService[`search${this.objectName}`];
|
|
3114
|
-
}
|
|
3115
|
-
let queryParams: any = {};
|
|
3116
|
-
if (this.data) {
|
|
3117
|
-
Object.keys(this.data).forEach(name => {
|
|
3118
|
-
queryParams[name] = this.data[name];
|
|
3119
|
-
});
|
|
3120
|
-
}
|
|
3121
|
-
|
|
3122
|
-
//debugger;
|
|
3123
|
-
this.searchRequest.call(this.glowwService, queryParams).subscribe(items => this.items = items,
|
|
3124
|
-
error => {
|
|
3125
|
-
this.error = error;
|
|
3126
|
-
});
|
|
3127
|
-
|
|
3128
|
-
}
|
|
3129
|
-
ngAfterContentInit(): void {
|
|
3130
|
-
|
|
3131
|
-
}*/
|
|
3112
|
+
this.parser = new TranslateDefaultParser();
|
|
3132
3113
|
this.options = []; //Observable<unknown>;
|
|
3133
3114
|
this.propagateChange = (_) => { };
|
|
3134
3115
|
this.glowwService = glowwService;
|
|
@@ -3136,13 +3117,21 @@ class AutoCompleteComponent {
|
|
|
3136
3117
|
this.form = this.formBuilder.group({
|
|
3137
3118
|
__result: this.resultCtrl
|
|
3138
3119
|
});
|
|
3139
|
-
|
|
3120
|
+
}
|
|
3121
|
+
ngAfterViewInit() {
|
|
3140
3122
|
}
|
|
3141
3123
|
ngOnInit() {
|
|
3124
|
+
//debugger;
|
|
3125
|
+
this.searchRequest = this.glowwService[`search${this.objectName}`];
|
|
3142
3126
|
this.resultCtrl.valueChanges.pipe(filter(res => res != null && res.length > 2), distinctUntilChanged(), debounceTime(250), tap(() => { this.error = ""; this.options = []; }), switchMap(searchStr => {
|
|
3143
3127
|
let searchObj = {};
|
|
3128
|
+
if (this.data) {
|
|
3129
|
+
Object.keys(this.data).forEach(k => {
|
|
3130
|
+
searchObj[k] = this.data[k];
|
|
3131
|
+
});
|
|
3132
|
+
}
|
|
3144
3133
|
searchObj[this.searchField] = searchStr;
|
|
3145
|
-
return this.
|
|
3134
|
+
return this.searchRequest.call(this.glowwService, searchObj).pipe(map(res => res), catchError(err => {
|
|
3146
3135
|
this.error = err.message;
|
|
3147
3136
|
this.ref.markForCheck();
|
|
3148
3137
|
return of([]);
|
|
@@ -3156,7 +3145,7 @@ class AutoCompleteComponent {
|
|
|
3156
3145
|
});
|
|
3157
3146
|
}
|
|
3158
3147
|
writeValue(val) {
|
|
3159
|
-
val && this.form.setValue(val, { emitEvent: false });
|
|
3148
|
+
val && this.form.setValue({ __result: val }, { emitEvent: false });
|
|
3160
3149
|
}
|
|
3161
3150
|
registerOnChange(fn) {
|
|
3162
3151
|
this.onChange = fn;
|
|
@@ -3177,21 +3166,27 @@ class AutoCompleteComponent {
|
|
|
3177
3166
|
//TODO
|
|
3178
3167
|
}
|
|
3179
3168
|
displayObj(item) {
|
|
3169
|
+
if (!item)
|
|
3170
|
+
return null;
|
|
3180
3171
|
console.log("displayOf");
|
|
3181
3172
|
if (this.displayField) {
|
|
3182
3173
|
return item[this.displayField];
|
|
3183
3174
|
}
|
|
3175
|
+
else if (this.displayExpr) {
|
|
3176
|
+
return this.parser.interpolate(this.displayExpr.replace(/\\\{/g, "{").replace(/\\\}/g, "}"), item);
|
|
3177
|
+
//return '?1' + this.parser.interpolate("{{Name}}", { Name: "test" }) + '?2' + this.parser.interpolate("{{Name}}", item)+'?3'+this.parser.interpolate(this.displayExpr.replace(/\\\{/g,"{").replace(/\\\}/g,"}"), item) +'?4'+ item;
|
|
3178
|
+
}
|
|
3184
3179
|
else if (this.displayFct) {
|
|
3185
3180
|
return this.displayFct(item);
|
|
3186
3181
|
}
|
|
3187
3182
|
}
|
|
3188
3183
|
}
|
|
3189
3184
|
AutoCompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AutoCompleteComponent, deps: [{ token: 'glowwService' }, { token: i1$3.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
3190
|
-
AutoCompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AutoCompleteComponent, selector: "gloww-auto-complete", inputs: { _value: ["value", "_value"], objectName: "objectName", searchField: "searchField", returnField: "returnField", displayField: "displayField", displayFct: "displayFct", placeHolder: "placeHolder", data: "data", searchRequest: "searchRequest" }, providers: [
|
|
3185
|
+
AutoCompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AutoCompleteComponent, selector: "gloww-auto-complete", inputs: { _value: ["value", "_value"], objectName: "objectName", searchField: "searchField", returnField: "returnField", displayField: "displayField", displayExpr: "displayExpr", displayFct: "displayFct", placeHolder: "placeHolder", data: "data", searchRequest: "searchRequest" }, providers: [
|
|
3191
3186
|
{
|
|
3192
3187
|
provide: NG_VALUE_ACCESSOR,
|
|
3193
3188
|
multi: true,
|
|
3194
|
-
useExisting: AutoCompleteComponent
|
|
3189
|
+
useExisting: forwardRef(() => AutoCompleteComponent)
|
|
3195
3190
|
}
|
|
3196
3191
|
], ngImport: i0, template: "<div [formGroup]=\"form\" style=\"width:100%\">\n <div style=\"color:red\">{{error}}</div>\n <mat-form-field style=\"width:100%\">\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n </mat-form-field>\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n {{displayObj(option)}}\n </mat-option>\n </mat-autocomplete>\n</div>", styles: [""], components: [{ type: i1$4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i3$1.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }], directives: [{ type: i1$3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1$3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5$2.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: i1$3.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: i3$1.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1$3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
3197
3192
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AutoCompleteComponent, decorators: [{
|
|
@@ -3200,7 +3195,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
3200
3195
|
{
|
|
3201
3196
|
provide: NG_VALUE_ACCESSOR,
|
|
3202
3197
|
multi: true,
|
|
3203
|
-
useExisting: AutoCompleteComponent
|
|
3198
|
+
useExisting: forwardRef(() => AutoCompleteComponent)
|
|
3204
3199
|
}
|
|
3205
3200
|
], template: "<div [formGroup]=\"form\" style=\"width:100%\">\n <div style=\"color:red\">{{error}}</div>\n <mat-form-field style=\"width:100%\">\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n </mat-form-field>\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n {{displayObj(option)}}\n </mat-option>\n </mat-autocomplete>\n</div>", styles: [""] }]
|
|
3206
3201
|
}], ctorParameters: function () {
|
|
@@ -3223,6 +3218,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
3223
3218
|
}], displayField: [{
|
|
3224
3219
|
type: Input,
|
|
3225
3220
|
args: ['displayField']
|
|
3221
|
+
}], displayExpr: [{
|
|
3222
|
+
type: Input,
|
|
3223
|
+
args: ['displayExpr']
|
|
3226
3224
|
}], displayFct: [{
|
|
3227
3225
|
type: Input,
|
|
3228
3226
|
args: ['displayFct']
|