@rosoftlab/material 1.0.0-alpha-19 → 1.0.1-alpha-3

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,233 +0,0 @@
1
- import { FocusMonitor } from '@angular/cdk/a11y';
2
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
3
- import { Component, ElementRef, EventEmitter, Input, Optional, Output, Self } from '@angular/core';
4
- import { NgControl, UntypedFormControl } from '@angular/forms';
5
- import { BaseService } from '@rosoftlab/core';
6
- import { Subject } from 'rxjs';
7
- import { debounceTime, filter, finalize, switchMap, takeUntil, tap } from 'rxjs/operators';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/cdk/a11y";
10
- import * as i2 from "@angular/forms";
11
- import * as i3 from "@angular/common";
12
- import * as i4 from "@angular/material/autocomplete";
13
- import * as i5 from "@angular/material/core";
14
- import * as i6 from "@angular/material/button";
15
- import * as i7 from "@angular/material/icon";
16
- import * as i8 from "@angular/material/input";
17
- import * as i9 from "@angular/material/form-field";
18
- import * as i10 from "@ngx-translate/core";
19
- export class SearchableDropdownComponent {
20
- static { this.nextId = 0; }
21
- get empty() {
22
- return !this.value;
23
- }
24
- get required() { return this._required; }
25
- set required(value) {
26
- this._required = coerceBooleanProperty(value);
27
- this.stateChanges.next();
28
- }
29
- get disabled() { return this._disabled; }
30
- set disabled(value) {
31
- this._disabled = coerceBooleanProperty(value);
32
- this.stateChanges.next();
33
- }
34
- get value() {
35
- return this._value;
36
- }
37
- set value(value) {
38
- if (value)
39
- if (this._value !== value) {
40
- this.loadModel(value);
41
- }
42
- this._value = value;
43
- this.stateChanges.next();
44
- }
45
- constructor(_focusMonitor, _elementRef, ngControl) {
46
- this._focusMonitor = _focusMonitor;
47
- this._elementRef = _elementRef;
48
- this.ngControl = ngControl;
49
- this.onChange = (_) => { };
50
- this.onTouched = () => { };
51
- this.stateChanges = new Subject();
52
- this.focused = false;
53
- this.errorState = false;
54
- this.id = `rsl-searchable-dropdown-${SearchableDropdownComponent.nextId++}`;
55
- // label for the search dropdown
56
- this.label = '';
57
- //Fields for sorting the API data
58
- this.sortFields = '';
59
- // The value used to populate the control value
60
- this.valueField = 'id';
61
- // The minumum char for search
62
- this.minLengthTerm = 3;
63
- this.modelSelected = new EventEmitter();
64
- this._required = false;
65
- this._disabled = false;
66
- this.showSerach = true;
67
- this.isLoading = false;
68
- this.options = [];
69
- this.filteredOptions = [];
70
- /** Subject that emits when the component has been destroyed. */
71
- this._onDestroy = new Subject();
72
- this.searchControl = new UntypedFormControl('');
73
- _focusMonitor.monitor(_elementRef, true).subscribe(origin => {
74
- if (this.focused && !origin) {
75
- this.onTouched();
76
- }
77
- this.focused = !!origin;
78
- this.stateChanges.next();
79
- });
80
- if (this.ngControl) {
81
- this.ngControl.valueAccessor = this;
82
- }
83
- }
84
- ngOnInit() {
85
- if (!this.displayFields)
86
- this.displayFields = this.searchFields;
87
- this.loadModel(this.ngControl.value);
88
- if (this.preloadElementsCount) {
89
- this.serviceRef.getAll(1, this.preloadElementsCount).subscribe({
90
- next: (data) => {
91
- this.showSerach = false;
92
- this.options = data.getModels();
93
- this.filteredOptions = this.options;
94
- }
95
- });
96
- }
97
- this.searchControl.valueChanges
98
- .pipe(filter((res) => {
99
- const result = res !== null && res.length >= this.minLengthTerm;
100
- if (!result) {
101
- this.options = [];
102
- this.filteredOptions = [];
103
- }
104
- this.showSerach = !result;
105
- return result;
106
- }), debounceTime(300), tap(() => {
107
- this.filteredOptions = [];
108
- this.isLoading = true;
109
- }), switchMap((value) => this.serviceRef
110
- .getAll(1, 10, this.sortFields, `${this.searchFields.replace(',', '|')}@=*${value}`)
111
- .pipe(finalize(() => {
112
- this.isLoading = false;
113
- }))), takeUntil(this._onDestroy))
114
- .subscribe((options) => {
115
- this.filteredOptions = options.getModels();
116
- });
117
- }
118
- onSelected($event) {
119
- const value = $event.option.value;
120
- this.searchControl.setValue(value);
121
- this.modelSelected.emit(value);
122
- if (this.valueField in value) {
123
- this.setControlValue(value[this.valueField]);
124
- }
125
- }
126
- setControlValue(value) {
127
- this.value = value;
128
- this.ngControl.control.setValue(value);
129
- }
130
- displayWith(value) {
131
- return this.getConcatedFields(value);
132
- }
133
- clearSelection() {
134
- this.modelSelected.emit(null);
135
- this.setControlValue(null);
136
- this.searchControl.setValue(null);
137
- this.filteredOptions = this.options;
138
- }
139
- getConcatedFields(option) {
140
- if (!option)
141
- return null;
142
- const filtersArr = this.displayFields.split(',');
143
- return filtersArr.reduce((acc, cv) => {
144
- return acc.concat(option[cv] + ' ');
145
- }, '');
146
- }
147
- ngOnDestroy() {
148
- this.searchControl = null;
149
- this.stateChanges.complete();
150
- this._focusMonitor.stopMonitoring(this._elementRef);
151
- this._onDestroy.next();
152
- this._onDestroy.complete();
153
- }
154
- getSearchText() {
155
- return `Enter ${this.minLengthTerm} characters to start search`;
156
- }
157
- writeValue(model) {
158
- console.log(model);
159
- this.value = model;
160
- }
161
- registerOnChange(fn) {
162
- this.onChange = fn;
163
- }
164
- registerOnTouched(fn) {
165
- this.onTouched = fn;
166
- }
167
- setDisabledState(isDisabled) {
168
- this.disabled = isDisabled;
169
- }
170
- loadModel(id) {
171
- //Load the model from API to display the value
172
- let needLoad = false;
173
- if (id) {
174
- if (!this.searchControl.value)
175
- needLoad = true;
176
- else {
177
- if (this.searchControl.value[this.valueField] !== id) {
178
- needLoad = true;
179
- }
180
- }
181
- }
182
- if (needLoad) {
183
- this.serviceRef.get(id).subscribe({
184
- next: (model) => {
185
- this.options.push(model);
186
- this.filteredOptions = this.options;
187
- this.searchControl.setValue(model);
188
- }
189
- });
190
- }
191
- }
192
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: SearchableDropdownComponent, deps: [{ token: i1.FocusMonitor }, { token: i0.ElementRef }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
193
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", 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>", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", 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]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", 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"] }, { kind: "component", type: i9.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i9.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }] }); }
194
- }
195
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: SearchableDropdownComponent, decorators: [{
196
- type: Component,
197
- args: [{ selector: 'rsl-searchable-dropdown', host: {
198
- '[class.example-floating]': 'shouldLabelFloat',
199
- '[id]': 'id',
200
- '[attr.aria-describedby]': 'describedBy',
201
- }, 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>" }]
202
- }], ctorParameters: () => [{ type: i1.FocusMonitor }, { type: i0.ElementRef }, { type: i2.NgControl, decorators: [{
203
- type: Optional
204
- }, {
205
- type: Self
206
- }] }], propDecorators: { label: [{
207
- type: Input
208
- }], fControlName: [{
209
- type: Input
210
- }], serviceRef: [{
211
- type: Input
212
- }], searchFields: [{
213
- type: Input
214
- }], displayFields: [{
215
- type: Input
216
- }], sortFields: [{
217
- type: Input
218
- }], valueField: [{
219
- type: Input
220
- }], minLengthTerm: [{
221
- type: Input
222
- }], preloadElementsCount: [{
223
- type: Input
224
- }], modelSelected: [{
225
- type: Output
226
- }], required: [{
227
- type: Input
228
- }], disabled: [{
229
- type: Input
230
- }], value: [{
231
- type: Input
232
- }] } });
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../projects/rosoftlab/material/src/lib/components/searchable-dropdown/searchable-dropdown.component.ts","../../../../../../../projects/rosoftlab/material/src/lib/components/searchable-dropdown/searchable-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,KAAK,EAAqB,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACtH,OAAO,EAAyC,SAAS,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACtG,OAAO,EAA4B,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACxE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;AAW3F,MAAM,OAAO,2BAA2B;aAC/B,WAAM,GAAG,CAAC,AAAJ,CAAK;IAsClB,IAAI,KAAK;QACP,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC;IACrB,CAAC;IAGD,IACI,QAAQ,KAAc,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD,IACI,QAAQ,KAAc,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAKD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IACD,IAAI,KAAK,CAAC,KAAiB;QACzB,IAAI,KAAK;YACP,IAAI,IAAI,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;gBAC1B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACxB,CAAC;QACH,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAYD,YACU,aAA2B,EAC3B,WAAoC,EACjB,SAAoB;QAFvC,kBAAa,GAAb,aAAa,CAAc;QAC3B,gBAAW,GAAX,WAAW,CAAyB;QACjB,cAAS,GAAT,SAAS,CAAW;QAtFjD,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAG,CAAC,CAAC;QAC3B,cAAS,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC;QACtB,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QACnC,YAAO,GAAG,KAAK,CAAC;QAChB,eAAU,GAAG,KAAK,CAAC;QACnB,OAAE,GAAG,2BAA2B,2BAA2B,CAAC,MAAM,EAAE,EAAE,CAAC;QAEvE,gCAAgC;QACvB,UAAK,GAAW,EAAE,CAAC;QAc5B,iCAAiC;QACxB,eAAU,GAAW,EAAE,CAAC;QAEjC,+CAA+C;QACtC,eAAU,GAAW,IAAI,CAAC;QAEnC,8BAA8B;QACrB,kBAAa,GAAW,CAAC,CAAC;QAKzB,kBAAa,GAA4B,IAAI,YAAY,EAAE,CAAC;QAc9D,cAAS,GAAG,KAAK,CAAC;QAQlB,cAAS,GAAG,KAAK,CAAC;QAoB1B,eAAU,GAAG,IAAI,CAAC;QAClB,cAAS,GAAG,KAAK,CAAC;QAClB,YAAO,GAAG,EAAE,CAAC;QACb,oBAAe,GAAG,EAAE,CAAC;QACrB,gEAAgE;QACtD,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAQzC,IAAI,CAAC,aAAa,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAChD,aAAa,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YAC1D,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;gBAC5B,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,CAAC;YACD,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,MAAM,CAAC;YACxB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;QACtC,CAAC;IACH,CAAC;IAED,QAAQ;QAEN,IAAI,CAAC,IAAI,CAAC,aAAa;YACrB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC;QAEzC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QAEpC,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC,SAAS,CAAC;gBAC7D,IAAI,EAAE,CAAC,IAAsB,EAAE,EAAE;oBAC/B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;oBACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;oBAChC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC;gBACtC,CAAC;aACF,CAAC,CAAA;QACJ,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,YAAY;aAC5B,IAAI,CACH,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;YACb,MAAM,MAAM,GAAG,GAAG,KAAK,IAAI,IAAI,GAAG,CAAC,MAAM,IAAI,IAAI,CAAC,aAAa,CAAC;YAChE,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;gBAClB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;YAC5B,CAAC;YACD,IAAI,CAAC,UAAU,GAAG,CAAC,MAAM,CAAC;YAC1B,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,EACF,YAAY,CAAC,GAAG,CAAC,EACjB,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACxB,CAAC,CAAC,EACF,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE,CAC1B,IAAI,CAAC,UAAU;aACZ,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,KAAK,EAAE,CAAC;aACnF,IAAI,CACH,QAAQ,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC,CACH,CACJ,EACD,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,OAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;IACP,CAAC;IAED,UAAU,CAAC,MAAM;QACf,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC;QAClC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,IAAI,CAAC,UAAU,IAAI,KAAK,EAAE,CAAC;YAC7B,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC/C,CAAC;IAEH,CAAC;IACD,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IACD,WAAW,CAAC,KAAU;QACpB,OAAO,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC;IACtC,CAAC;IAED,iBAAiB,CAAC,MAAM;QACtB,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC;QACzB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACjD,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE;YACnC,OAAO,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC;QACtC,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QAC7B,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpD,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IACD,aAAa;QACX,OAAO,SAAS,IAAI,CAAC,aAAa,6BAA6B,CAAC;IAElE,CAAC;IACD,UAAU,CAAC,KAAe;QACxB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IACO,SAAS,CAAC,EAAU;QAC1B,8CAA8C;QAC9C,IAAI,QAAQ,GAAG,KAAK,CAAC;QACrB,IAAI,EAAE,EAAE,CAAC;YACP,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK;gBAC3B,QAAQ,GAAG,IAAI,CAAA;iBACZ,CAAC;gBACJ,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC;oBACrD,QAAQ,GAAG,IAAI,CAAA;gBACjB,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC;gBAChC,IAAI,EAAE,CAAC,KAAQ,EAAE,EAAE;oBACjB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBACzB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC;oBACpC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACrC,CAAC;aACF,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;8GA1OU,2BAA2B;kGAA3B,2BAA2B,wjBCjBxC,umCAoBM;;2FDHO,2BAA2B;kBATvC,SAAS;+BACE,yBAAyB,QAE7B;wBACJ,0BAA0B,EAAE,kBAAkB;wBAC9C,MAAM,EAAE,IAAI;wBACZ,yBAAyB,EAAE,aAAa;qBACzC;;0BA0FE,QAAQ;;0BAAI,IAAI;yCA9EV,KAAK;sBAAb,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,oBAAoB;sBAA5B,KAAK;gBAEI,aAAa;sBAAtB,MAAM;gBASH,QAAQ;sBADX,KAAK;gBASF,QAAQ;sBADX,KAAK;gBAWF,KAAK;sBADR,KAAK","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, NgControl, UntypedFormControl } from '@angular/forms';\r\nimport { BaseModel, BaseQueryData, BaseService } from '@rosoftlab/core';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, filter, finalize, switchMap, takeUntil, tap } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: 'rsl-searchable-dropdown',\r\n  templateUrl: './searchable-dropdown.component.html',\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 UntypedFormControl('');\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,6 +0,0 @@
1
- export * from './components';
2
- export * from './decorators';
3
- export * from './models';
4
- export * from './rsl-material-module';
5
- export * from './services';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Jvc29mdGxhYi9tYXRlcmlhbC9zcmMvbGliL2NvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLFlBQVksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGVjb3JhdG9ycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWxzJztcclxuZXhwb3J0ICogZnJvbSAnLi9yc2wtbWF0ZXJpYWwtbW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcyc7XHJcblxyXG4iXX0=
@@ -1,23 +0,0 @@
1
- import { CellTextAlign, GridLayoutFormat } from '@rosoftlab/core';
2
- export function GridLayout(translateKey, width, grow = 0, shrink = 0, subProperty, formating = GridLayoutFormat.none, format = '', order = 0, textAlign = CellTextAlign.left) {
3
- return (target, propertyName) => {
4
- const annotations = Reflect.getMetadata('GridLayout', target) || [];
5
- let propName = propertyName;
6
- if (subProperty) {
7
- propName = propertyName.toString() + '.' + subProperty;
8
- }
9
- annotations.push({
10
- propertyName: propName,
11
- translateKey,
12
- width,
13
- grow,
14
- shrink,
15
- formating,
16
- format,
17
- order,
18
- textAlign
19
- });
20
- Reflect.defineMetadata('GridLayout', annotations, target);
21
- };
22
- }
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1sYXlvdXQuZGVjb3JhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcm9zb2Z0bGFiL21hdGVyaWFsL3NyYy9saWIvZGVjb3JhdG9ycy9ncmlkLWxheW91dC5kZWNvcmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2xFLE1BQU0sVUFBVSxVQUFVLENBQUMsWUFBb0IsRUFBRSxLQUFxQixFQUNsRSxPQUFjLENBQUMsRUFBRSxTQUFnQixDQUFDLEVBQUUsV0FBMkIsRUFDL0QsWUFBOEIsZ0JBQWdCLENBQUMsSUFBSSxFQUNuRCxTQUFpQixFQUFFLEVBQUUsUUFBZ0IsQ0FBQyxFQUFFLFlBQTJCLGFBQWEsQ0FBQyxJQUFJO0lBQ3JGLE9BQU8sQ0FBQyxNQUFXLEVBQUUsWUFBNkIsRUFBRSxFQUFFO1FBQ2xELE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNwRSxJQUFJLFFBQVEsR0FBRyxZQUFZLENBQUE7UUFDM0IsSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUNkLFFBQVEsR0FBRyxZQUFZLENBQUMsUUFBUSxFQUFFLEdBQUcsR0FBRyxHQUFHLFdBQVcsQ0FBQztRQUMzRCxDQUFDO1FBQ0QsV0FBVyxDQUFDLElBQUksQ0FBQztZQUNiLFlBQVksRUFBRSxRQUFRO1lBQ3RCLFlBQVk7WUFDWixLQUFLO1lBQ0wsSUFBSTtZQUNKLE1BQU07WUFDTixTQUFTO1lBQ1QsTUFBTTtZQUNOLEtBQUs7WUFDTCxTQUFTO1NBQ1osQ0FBQyxDQUFDO1FBRUgsT0FBTyxDQUFDLGNBQWMsQ0FBQyxZQUFZLEVBQUUsV0FBVyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzlELENBQUMsQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZWxsVGV4dEFsaWduLCBHcmlkTGF5b3V0Rm9ybWF0IH0gZnJvbSAnQHJvc29mdGxhYi9jb3JlJztcclxuZXhwb3J0IGZ1bmN0aW9uIEdyaWRMYXlvdXQodHJhbnNsYXRlS2V5OiBzdHJpbmcsIHdpZHRoPzogbnVtYmVyIHwgbnVsbCxcclxuICAgIGdyb3c6IDAgfCAxID0gMCwgc2hyaW5rOiAwIHwgMSA9IDAsIHN1YlByb3BlcnR5Pzogc3RyaW5nIHwgbnVsbCxcclxuICAgIGZvcm1hdGluZzogR3JpZExheW91dEZvcm1hdCA9IEdyaWRMYXlvdXRGb3JtYXQubm9uZSxcclxuICAgIGZvcm1hdDogc3RyaW5nID0gJycsIG9yZGVyOiBudW1iZXIgPSAwLCB0ZXh0QWxpZ246IENlbGxUZXh0QWxpZ24gPSBDZWxsVGV4dEFsaWduLmxlZnQpIHtcclxuICAgIHJldHVybiAodGFyZ2V0OiBhbnksIHByb3BlcnR5TmFtZTogc3RyaW5nIHwgc3ltYm9sKSA9PiB7XHJcbiAgICAgICAgY29uc3QgYW5ub3RhdGlvbnMgPSBSZWZsZWN0LmdldE1ldGFkYXRhKCdHcmlkTGF5b3V0JywgdGFyZ2V0KSB8fCBbXTtcclxuICAgICAgICBsZXQgcHJvcE5hbWUgPSBwcm9wZXJ0eU5hbWVcclxuICAgICAgICBpZiAoc3ViUHJvcGVydHkpIHtcclxuICAgICAgICAgICAgcHJvcE5hbWUgPSBwcm9wZXJ0eU5hbWUudG9TdHJpbmcoKSArICcuJyArIHN1YlByb3BlcnR5O1xyXG4gICAgICAgIH1cclxuICAgICAgICBhbm5vdGF0aW9ucy5wdXNoKHtcclxuICAgICAgICAgICAgcHJvcGVydHlOYW1lOiBwcm9wTmFtZSxcclxuICAgICAgICAgICAgdHJhbnNsYXRlS2V5LFxyXG4gICAgICAgICAgICB3aWR0aCxcclxuICAgICAgICAgICAgZ3JvdyxcclxuICAgICAgICAgICAgc2hyaW5rLFxyXG4gICAgICAgICAgICBmb3JtYXRpbmcsXHJcbiAgICAgICAgICAgIGZvcm1hdCxcclxuICAgICAgICAgICAgb3JkZXIsXHJcbiAgICAgICAgICAgIHRleHRBbGlnblxyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgICBSZWZsZWN0LmRlZmluZU1ldGFkYXRhKCdHcmlkTGF5b3V0JywgYW5ub3RhdGlvbnMsIHRhcmdldCk7XHJcbiAgICB9O1xyXG59XHJcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export { GridLayout } from './grid-layout.decorator';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yb3NvZnRsYWIvbWF0ZXJpYWwvc3JjL2xpYi9kZWNvcmF0b3JzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEdyaWRMYXlvdXQgfSBmcm9tICcuL2dyaWQtbGF5b3V0LmRlY29yYXRvcic7XHJcbiJdfQ==
@@ -1,18 +0,0 @@
1
- import { CellTextAlign, GridLayoutFormat } from '@rosoftlab/core';
2
- export class GridLayoutModel {
3
- constructor(propertyName, translateKey = null, width = null, grow = 0, shrink = 0, formating = GridLayoutFormat.none, format = '', order = 0, textAlign = CellTextAlign.left) {
4
- this.formating = GridLayoutFormat.none;
5
- this.order = 0;
6
- this.textAlign = CellTextAlign.left;
7
- this.propertyName = propertyName;
8
- this.translateKey = translateKey;
9
- this.width = width;
10
- this.grow = grow;
11
- this.shrink = shrink;
12
- this.formating = formating;
13
- this.format = format;
14
- this.order = order;
15
- this.textAlign = textAlign;
16
- }
17
- }
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1sYXlvdXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yb3NvZnRsYWIvbWF0ZXJpYWwvc3JjL2xpYi9tb2RlbHMvZ3JpZC1sYXlvdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2xFLE1BQU0sT0FBTyxlQUFlO0lBQ3hCLFlBQ0ksWUFBb0IsRUFBRSxlQUFvQixJQUFJLEVBQUUsUUFBYSxJQUFJLEVBQUUsT0FBYyxDQUFDLEVBQUUsU0FBZ0IsQ0FBQyxFQUNyRyxZQUE4QixnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsTUFBTSxHQUFHLEVBQUUsRUFBRSxLQUFLLEdBQUcsQ0FBQyxFQUMzRSxZQUEyQixhQUFhLENBQUMsSUFBSTtRQWdCMUMsY0FBUyxHQUFxQixnQkFBZ0IsQ0FBQyxJQUFJLENBQUM7UUFFcEQsVUFBSyxHQUFXLENBQUMsQ0FBQztRQUNsQixjQUFTLEdBQWtCLGFBQWEsQ0FBQyxJQUFJLENBQUM7UUFsQmpELElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1FBQzNCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQy9CLENBQUM7Q0FVSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENlbGxUZXh0QWxpZ24sIEdyaWRMYXlvdXRGb3JtYXQgfSBmcm9tICdAcm9zb2Z0bGFiL2NvcmUnO1xyXG5leHBvcnQgY2xhc3MgR3JpZExheW91dE1vZGVsIHtcclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByb3BlcnR5TmFtZTogc3RyaW5nLCB0cmFuc2xhdGVLZXk6IGFueSA9IG51bGwsIHdpZHRoOiBhbnkgPSBudWxsLCBncm93OiAwIHwgMSA9IDAsIHNocmluazogMCB8IDEgPSAwLFxyXG4gICAgICAgIGZvcm1hdGluZzogR3JpZExheW91dEZvcm1hdCA9IEdyaWRMYXlvdXRGb3JtYXQubm9uZSwgZm9ybWF0ID0gJycsIG9yZGVyID0gMCxcclxuICAgICAgICB0ZXh0QWxpZ246IENlbGxUZXh0QWxpZ24gPSBDZWxsVGV4dEFsaWduLmxlZnQpIHtcclxuICAgICAgICB0aGlzLnByb3BlcnR5TmFtZSA9IHByb3BlcnR5TmFtZTtcclxuICAgICAgICB0aGlzLnRyYW5zbGF0ZUtleSA9IHRyYW5zbGF0ZUtleTtcclxuICAgICAgICB0aGlzLndpZHRoID0gd2lkdGg7XHJcbiAgICAgICAgdGhpcy5ncm93ID0gZ3JvdztcclxuICAgICAgICB0aGlzLnNocmluayA9IHNocmluaztcclxuICAgICAgICB0aGlzLmZvcm1hdGluZyA9IGZvcm1hdGluZztcclxuICAgICAgICB0aGlzLmZvcm1hdCA9IGZvcm1hdDtcclxuICAgICAgICB0aGlzLm9yZGVyID0gb3JkZXI7XHJcbiAgICAgICAgdGhpcy50ZXh0QWxpZ24gPSB0ZXh0QWxpZ247XHJcbiAgICB9XHJcbiAgICBwdWJsaWMgcHJvcGVydHlOYW1lOiBzdHJpbmc7XHJcbiAgICBwdWJsaWMgdHJhbnNsYXRlS2V5OiBzdHJpbmc7XHJcbiAgICBwdWJsaWMgd2lkdGg6IG51bWJlcjtcclxuICAgIHB1YmxpYyBncm93OiAwIHwgMTtcclxuICAgIHB1YmxpYyBzaHJpbms6IDAgfCAxO1xyXG4gICAgcHVibGljIGZvcm1hdGluZzogR3JpZExheW91dEZvcm1hdCA9IEdyaWRMYXlvdXRGb3JtYXQubm9uZTtcclxuICAgIHB1YmxpYyBmb3JtYXQ6IHN0cmluZztcclxuICAgIHB1YmxpYyBvcmRlcjogbnVtYmVyID0gMDtcclxuICAgIHB1YmxpYyB0ZXh0QWxpZ246IENlbGxUZXh0QWxpZ24gPSBDZWxsVGV4dEFsaWduLmxlZnQ7XHJcbn1cclxuIl19
@@ -1,3 +0,0 @@
1
- export { GridLayoutModel } from './grid-layout';
2
- export { MaterialBaseModel } from './material-base-model';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yb3NvZnRsYWIvbWF0ZXJpYWwvc3JjL2xpYi9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEdyaWRMYXlvdXRNb2RlbCB9IGZyb20gJy4vZ3JpZC1sYXlvdXQnXHJcbmV4cG9ydCB7IE1hdGVyaWFsQmFzZU1vZGVsIH0gZnJvbSAnLi9tYXRlcmlhbC1iYXNlLW1vZGVsJ1xyXG5cclxuIl19
@@ -1,17 +0,0 @@
1
- import { BaseModel } from '@rosoftlab/core';
2
- import { GridLayoutModel } from './grid-layout';
3
- export class MaterialBaseModel extends BaseModel {
4
- getGridLayout() {
5
- const result = Array();
6
- const gridLayout = Reflect.getMetadata('GridLayout', this);
7
- if (gridLayout) {
8
- for (const layout of gridLayout) {
9
- const data = new GridLayoutModel(layout.propertyName, layout.translateKey, layout.width, layout.shrink, layout.grow, layout.formating, layout.format, layout.order, layout.textAlign);
10
- result.push(data);
11
- }
12
- }
13
- return result.sort(function (a, b) { return a.order - b.order; });
14
- //result;
15
- }
16
- }
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtYmFzZS1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Jvc29mdGxhYi9tYXRlcmlhbC9zcmMvbGliL21vZGVscy9tYXRlcmlhbC1iYXNlLW1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxTQUFTO0lBRXJDLGFBQWE7UUFDaEIsTUFBTSxNQUFNLEdBQUcsS0FBSyxFQUFtQixDQUFDO1FBQ3hDLE1BQU0sVUFBVSxHQUFRLE9BQU8sQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ2hFLElBQUksVUFBVSxFQUFFLENBQUM7WUFDYixLQUFLLE1BQU0sTUFBTSxJQUFJLFVBQVUsRUFBRSxDQUFDO2dCQUM5QixNQUFNLElBQUksR0FBRyxJQUFJLGVBQWUsQ0FBQyxNQUFNLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxZQUFZLEVBQ3JFLE1BQU0sQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsSUFBSSxFQUN4QyxNQUFNLENBQUMsU0FBUyxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7Z0JBQ3JFLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdEIsQ0FBQztRQUNMLENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDakUsU0FBUztJQUNiLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VNb2RlbCB9IGZyb20gJ0Byb3NvZnRsYWIvY29yZSc7XHJcbmltcG9ydCB7IEdyaWRMYXlvdXRNb2RlbCB9IGZyb20gJy4vZ3JpZC1sYXlvdXQnO1xyXG5leHBvcnQgY2xhc3MgTWF0ZXJpYWxCYXNlTW9kZWwgZXh0ZW5kcyBCYXNlTW9kZWwge1xyXG5cclxuICAgIHB1YmxpYyBnZXRHcmlkTGF5b3V0KCk6IEdyaWRMYXlvdXRNb2RlbFtdIHtcclxuICAgICAgICBjb25zdCByZXN1bHQgPSBBcnJheTxHcmlkTGF5b3V0TW9kZWw+KCk7XHJcbiAgICAgICAgY29uc3QgZ3JpZExheW91dDogYW55ID0gUmVmbGVjdC5nZXRNZXRhZGF0YSgnR3JpZExheW91dCcsIHRoaXMpO1xyXG4gICAgICAgIGlmIChncmlkTGF5b3V0KSB7XHJcbiAgICAgICAgICAgIGZvciAoY29uc3QgbGF5b3V0IG9mIGdyaWRMYXlvdXQpIHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IGRhdGEgPSBuZXcgR3JpZExheW91dE1vZGVsKGxheW91dC5wcm9wZXJ0eU5hbWUsIGxheW91dC50cmFuc2xhdGVLZXksXHJcbiAgICAgICAgICAgICAgICAgICAgbGF5b3V0LndpZHRoLCBsYXlvdXQuc2hyaW5rLCBsYXlvdXQuZ3JvdyxcclxuICAgICAgICAgICAgICAgICAgICBsYXlvdXQuZm9ybWF0aW5nLCBsYXlvdXQuZm9ybWF0LCBsYXlvdXQub3JkZXIsIGxheW91dC50ZXh0QWxpZ24pO1xyXG4gICAgICAgICAgICAgICAgcmVzdWx0LnB1c2goZGF0YSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHJlc3VsdC5zb3J0KGZ1bmN0aW9uIChhLCBiKSB7IHJldHVybiBhLm9yZGVyIC0gYi5vcmRlcjsgfSlcclxuICAgICAgICAvL3Jlc3VsdDtcclxuICAgIH1cclxufVxyXG4iXX0=
@@ -1,105 +0,0 @@
1
- import { DragDropModule } from '@angular/cdk/drag-drop';
2
- import { PortalModule } from '@angular/cdk/portal';
3
- import { CdkStepperModule } from '@angular/cdk/stepper';
4
- import { CommonModule } from '@angular/common';
5
- import { NgModule } from '@angular/core';
6
- import { ReactiveFormsModule } from '@angular/forms';
7
- import { MatAutocompleteModule } from '@angular/material/autocomplete';
8
- import { MatBadgeModule } from '@angular/material/badge';
9
- import { MatButtonModule } from '@angular/material/button';
10
- import { MatButtonToggleModule } from '@angular/material/button-toggle';
11
- import { MatCardModule } from '@angular/material/card';
12
- import { MatCheckboxModule } from '@angular/material/checkbox';
13
- import { MatChipsModule } from '@angular/material/chips';
14
- import { MatNativeDateModule, MatOptionModule, MatRippleModule } from '@angular/material/core';
15
- import { MatDatepickerModule } from '@angular/material/datepicker';
16
- import { MatDialogModule } from '@angular/material/dialog';
17
- import { MatDividerModule } from '@angular/material/divider';
18
- import { MatExpansionModule } from '@angular/material/expansion';
19
- import { MatGridListModule } from '@angular/material/grid-list';
20
- import { MatIconModule } from '@angular/material/icon';
21
- import { MatInputModule } from '@angular/material/input';
22
- import { MatListModule } from '@angular/material/list';
23
- import { MatMenuModule } from '@angular/material/menu';
24
- import { MatPaginatorModule } from '@angular/material/paginator';
25
- import { MatProgressBarModule } from '@angular/material/progress-bar';
26
- import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
27
- import { MatRadioModule } from '@angular/material/radio';
28
- import { MatSelectModule } from '@angular/material/select';
29
- import { MatSidenavModule } from '@angular/material/sidenav';
30
- import { MatSlideToggleModule } from '@angular/material/slide-toggle';
31
- import { MatSliderModule } from '@angular/material/slider';
32
- import { MatSnackBarModule } from '@angular/material/snack-bar';
33
- import { MatSortModule } from '@angular/material/sort';
34
- import { MatStepperModule } from '@angular/material/stepper';
35
- import { MatTableModule } from '@angular/material/table';
36
- import { MatTabsModule } from '@angular/material/tabs';
37
- import { MatToolbarModule } from '@angular/material/toolbar';
38
- import { MatTooltipModule } from '@angular/material/tooltip';
39
- import { MatTreeModule } from '@angular/material/tree';
40
- import { TranslateModule } from '@ngx-translate/core';
41
- import { GenericTableComponent, SearchableDropdownComponent } from './components';
42
- import * as i0 from "@angular/core";
43
- const COMMON_MODULES = [
44
- CommonModule,
45
- ReactiveFormsModule,
46
- MatAutocompleteModule, MatButtonModule, MatButtonToggleModule, MatCardModule, MatCheckboxModule, MatChipsModule, MatDatepickerModule,
47
- MatDialogModule, MatExpansionModule, MatGridListModule, MatIconModule,
48
- MatInputModule, MatListModule, MatMenuModule, MatNativeDateModule,
49
- MatPaginatorModule, MatProgressBarModule, MatProgressSpinnerModule, MatRadioModule, MatRippleModule, MatSelectModule, MatSidenavModule,
50
- MatSliderModule, MatSlideToggleModule, MatSnackBarModule, MatSortModule, MatTableModule, MatTabsModule, MatToolbarModule,
51
- MatTooltipModule, MatOptionModule, DragDropModule, MatDividerModule, PortalModule, MatTreeModule, MatBadgeModule, MatStepperModule,
52
- CdkStepperModule
53
- ];
54
- export class RSLMaterialModule {
55
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: RSLMaterialModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
56
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: RSLMaterialModule, declarations: [GenericTableComponent,
57
- SearchableDropdownComponent], imports: [CommonModule,
58
- ReactiveFormsModule,
59
- MatAutocompleteModule, MatButtonModule, MatButtonToggleModule, MatCardModule, MatCheckboxModule, MatChipsModule, MatDatepickerModule,
60
- MatDialogModule, MatExpansionModule, MatGridListModule, MatIconModule,
61
- MatInputModule, MatListModule, MatMenuModule, MatNativeDateModule,
62
- MatPaginatorModule, MatProgressBarModule, MatProgressSpinnerModule, MatRadioModule, MatRippleModule, MatSelectModule, MatSidenavModule,
63
- MatSliderModule, MatSlideToggleModule, MatSnackBarModule, MatSortModule, MatTableModule, MatTabsModule, MatToolbarModule,
64
- MatTooltipModule, MatOptionModule, DragDropModule, MatDividerModule, PortalModule, MatTreeModule, MatBadgeModule, MatStepperModule,
65
- CdkStepperModule, TranslateModule], exports: [CommonModule,
66
- ReactiveFormsModule,
67
- MatAutocompleteModule, MatButtonModule, MatButtonToggleModule, MatCardModule, MatCheckboxModule, MatChipsModule, MatDatepickerModule,
68
- MatDialogModule, MatExpansionModule, MatGridListModule, MatIconModule,
69
- MatInputModule, MatListModule, MatMenuModule, MatNativeDateModule,
70
- MatPaginatorModule, MatProgressBarModule, MatProgressSpinnerModule, MatRadioModule, MatRippleModule, MatSelectModule, MatSidenavModule,
71
- MatSliderModule, MatSlideToggleModule, MatSnackBarModule, MatSortModule, MatTableModule, MatTabsModule, MatToolbarModule,
72
- MatTooltipModule, MatOptionModule, DragDropModule, MatDividerModule, PortalModule, MatTreeModule, MatBadgeModule, MatStepperModule,
73
- CdkStepperModule, GenericTableComponent,
74
- SearchableDropdownComponent,
75
- TranslateModule] }); }
76
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: RSLMaterialModule, imports: [COMMON_MODULES, TranslateModule, CommonModule,
77
- ReactiveFormsModule,
78
- MatAutocompleteModule, MatButtonModule, MatButtonToggleModule, MatCardModule, MatCheckboxModule, MatChipsModule, MatDatepickerModule,
79
- MatDialogModule, MatExpansionModule, MatGridListModule, MatIconModule,
80
- MatInputModule, MatListModule, MatMenuModule, MatNativeDateModule,
81
- MatPaginatorModule, MatProgressBarModule, MatProgressSpinnerModule, MatRadioModule, MatRippleModule, MatSelectModule, MatSidenavModule,
82
- MatSliderModule, MatSlideToggleModule, MatSnackBarModule, MatSortModule, MatTableModule, MatTabsModule, MatToolbarModule,
83
- MatTooltipModule, MatOptionModule, DragDropModule, MatDividerModule, PortalModule, MatTreeModule, MatBadgeModule, MatStepperModule,
84
- CdkStepperModule, TranslateModule] }); }
85
- }
86
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: RSLMaterialModule, decorators: [{
87
- type: NgModule,
88
- args: [{
89
- declarations: [
90
- GenericTableComponent,
91
- SearchableDropdownComponent,
92
- ],
93
- imports: [
94
- ...COMMON_MODULES,
95
- TranslateModule
96
- ],
97
- exports: [
98
- ...COMMON_MODULES,
99
- GenericTableComponent,
100
- SearchableDropdownComponent,
101
- TranslateModule
102
- ],
103
- }]
104
- }] });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rsl-material-module.js","sourceRoot":"","sources":["../../../../../projects/rosoftlab/material/src/lib/rsl-material-module.ts"],"names":[],"mappings":"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","sourcesContent":["import { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { PortalModule } from '@angular/cdk/portal';\r\nimport { CdkStepperModule } from '@angular/cdk/stepper';\r\nimport { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\r\nimport { MatBadgeModule } from '@angular/material/badge';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatButtonToggleModule } from '@angular/material/button-toggle';\r\nimport { MatCardModule } from '@angular/material/card';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatNativeDateModule, MatOptionModule, MatRippleModule } from '@angular/material/core';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatDialogModule } from '@angular/material/dialog';\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatExpansionModule } from '@angular/material/expansion';\r\nimport { MatGridListModule } from '@angular/material/grid-list';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatListModule } from '@angular/material/list';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { MatPaginatorModule } from '@angular/material/paginator';\r\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { MatRadioModule } from '@angular/material/radio';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { MatSidenavModule } from '@angular/material/sidenav';\r\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\r\nimport { MatSliderModule } from '@angular/material/slider';\r\nimport { MatSnackBarModule } from '@angular/material/snack-bar';\r\nimport { MatSortModule } from '@angular/material/sort';\r\nimport { MatStepperModule } from '@angular/material/stepper';\r\nimport { MatTableModule } from '@angular/material/table';\r\nimport { MatTabsModule } from '@angular/material/tabs';\r\nimport { MatToolbarModule } from '@angular/material/toolbar';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatTreeModule } from '@angular/material/tree';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { GenericTableComponent, SearchableDropdownComponent } from './components';\r\n\r\nconst COMMON_MODULES = [\r\n  CommonModule,\r\n  ReactiveFormsModule,\r\n  MatAutocompleteModule, MatButtonModule, MatButtonToggleModule, MatCardModule, MatCheckboxModule, MatChipsModule, MatDatepickerModule,\r\n  MatDialogModule, MatExpansionModule, MatGridListModule, MatIconModule,\r\n  MatInputModule, MatListModule, MatMenuModule, MatNativeDateModule,\r\n  MatPaginatorModule, MatProgressBarModule, MatProgressSpinnerModule, MatRadioModule, MatRippleModule, MatSelectModule, MatSidenavModule,\r\n  MatSliderModule, MatSlideToggleModule, MatSnackBarModule, MatSortModule, MatTableModule, MatTabsModule, MatToolbarModule,\r\n  MatTooltipModule, MatOptionModule, DragDropModule, MatDividerModule, PortalModule, MatTreeModule, MatBadgeModule, MatStepperModule,\r\n  CdkStepperModule\r\n];\r\n\r\n@NgModule({\r\n  declarations: [\r\n    GenericTableComponent,\r\n    SearchableDropdownComponent,\r\n  ],\r\n  imports: [\r\n    ...COMMON_MODULES,\r\n    TranslateModule\r\n  ],\r\n  exports: [\r\n    ...COMMON_MODULES,\r\n    GenericTableComponent,\r\n    SearchableDropdownComponent,\r\n    TranslateModule],\r\n})\r\nexport class RSLMaterialModule {\r\n}\r\n"]}
@@ -1,110 +0,0 @@
1
- import { HttpErrorResponse } from '@angular/common/http';
2
- import { Injectable } from '@angular/core';
3
- import { from } from 'rxjs';
4
- import Swal from 'sweetalert2';
5
- import * as i0 from "@angular/core";
6
- /**
7
- * Async modal dialog service
8
- * DialogService makes this app easier to test by faking this service.
9
- * TODO: better modal implementation that doesn't use window.confirm
10
- */
11
- export class DialogServiceMaterial {
12
- /**
13
- * Ask user to confirm an action. `message` explains the action and choices.
14
- * Returns observable resolving to `true`=confirm or `false`=cancel
15
- */
16
- constructor() { }
17
- confirm(message, text, confirmButtonText = 'Delete', cancelButtonText = 'Cancel') {
18
- const confirmation = Swal.fire({
19
- title: message || 'Are you sure?',
20
- icon: 'warning',
21
- text: text || '',
22
- showCancelButton: true,
23
- confirmButtonText: confirmButtonText,
24
- cancelButtonText: cancelButtonText,
25
- customClass: {
26
- confirmButton: 'btn btn-red btn-fill btn-wd',
27
- cancelButton: 'btn btn-grey btn-fill btn-wd',
28
- },
29
- buttonsStyling: false,
30
- reverseButtons: true
31
- })
32
- .then((result) => {
33
- if (result.value) {
34
- return true;
35
- }
36
- else {
37
- return false;
38
- }
39
- }).catch();
40
- return from(confirmation);
41
- }
42
- showSaveMessage(message, title) {
43
- const confirmation = Swal.fire({
44
- icon: 'success',
45
- title: message,
46
- timer: 2000,
47
- showConfirmButton: false,
48
- // customClass: 'overflow-hidden',
49
- buttonsStyling: false
50
- }).then(() => {
51
- return true;
52
- }, () => {
53
- return false;
54
- }).catch();
55
- return from(confirmation);
56
- }
57
- showRegisteredMessage(message, title) {
58
- const confirmation = Swal.fire({
59
- icon: 'success',
60
- title: message,
61
- showConfirmButton: true,
62
- customClass: {
63
- confirmButton: 'btn btn-success',
64
- },
65
- buttonsStyling: false
66
- }).then(() => {
67
- return true;
68
- }, () => {
69
- return false;
70
- }).catch();
71
- return from(confirmation);
72
- }
73
- showErrorMessage(e, message) {
74
- if (!message) {
75
- message = 'Validation errors';
76
- }
77
- if (e instanceof HttpErrorResponse) {
78
- // Validation errors
79
- if (e.status === 400) {
80
- const errors = e.error.errors;
81
- if (errors) {
82
- errors.forEach(error => {
83
- message += error.field + ' ' + error.detail + '\n';
84
- });
85
- }
86
- }
87
- }
88
- const confirmation = Swal.fire({
89
- icon: 'error',
90
- title: message,
91
- // timer: 2000,
92
- showConfirmButton: true,
93
- customClass: {
94
- confirmButton: 'btn btn-success',
95
- },
96
- buttonsStyling: false
97
- }).then(() => {
98
- return true;
99
- }, () => {
100
- return false;
101
- }).catch();
102
- return from(confirmation);
103
- }
104
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DialogServiceMaterial, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
105
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DialogServiceMaterial }); }
106
- }
107
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DialogServiceMaterial, decorators: [{
108
- type: Injectable
109
- }], ctorParameters: () => [] });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service-implementation.js","sourceRoot":"","sources":["../../../../../../projects/rosoftlab/material/src/lib/services/dialog.service-implementation.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { DialogService } from '@rosoftlab/core';\r\n\r\nimport { from, Observable } from 'rxjs';\r\nimport Swal from 'sweetalert2';\r\ndeclare var $: any;\r\n\r\n/**\r\n * Async modal dialog service\r\n * DialogService makes this app easier to test by faking this service.\r\n * TODO: better modal implementation that doesn't use window.confirm\r\n */\r\n@Injectable()\r\nexport class DialogServiceMaterial implements DialogService {\r\n  /**\r\n   * Ask user to confirm an action. `message` explains the action and choices.\r\n   * Returns observable resolving to `true`=confirm or `false`=cancel\r\n   */\r\n  constructor() { }\r\n  confirm(message?: string, text?: string,\r\n    confirmButtonText: string = 'Delete',\r\n    cancelButtonText: string = 'Cancel'): Observable<boolean> {\r\n    const confirmation = Swal.fire({\r\n      title: message || 'Are you sure?',\r\n      icon: 'warning',\r\n      text: text || '',\r\n      showCancelButton: true,\r\n      confirmButtonText: confirmButtonText,\r\n      cancelButtonText: cancelButtonText,\r\n      customClass: {\r\n        confirmButton: 'btn btn-red btn-fill btn-wd',\r\n        cancelButton: 'btn btn-grey btn-fill btn-wd',\r\n      },\r\n      buttonsStyling: false,\r\n      reverseButtons: true\r\n    })\r\n\r\n      .then((result: any) => {\r\n        if (result.value) {\r\n          return true;\r\n        } else {\r\n          return false;\r\n        }\r\n      }).catch();\r\n    return from(confirmation);\r\n  }\r\n  showSaveMessage(message?: string, title?: string): Observable<boolean> {\r\n    const confirmation = Swal.fire({\r\n      icon: 'success',\r\n      title: message,\r\n      timer: 2000,\r\n      showConfirmButton: false,\r\n      // customClass: 'overflow-hidden',\r\n      buttonsStyling: false\r\n    }).then(() => {\r\n      return true;\r\n    }, () => {\r\n      return false;\r\n    }).catch();\r\n    return from(confirmation);\r\n  }\r\n  showRegisteredMessage(message?: string, title?: string): Observable<boolean> {\r\n    const confirmation = Swal.fire({\r\n      icon: 'success',\r\n      title: message,\r\n      showConfirmButton: true,\r\n      customClass: {\r\n        confirmButton: 'btn btn-success',\r\n      },\r\n      buttonsStyling: false\r\n    }).then(() => {\r\n      return true;\r\n    }, () => {\r\n      return false;\r\n    }).catch();\r\n    return from(confirmation);\r\n  }\r\n\r\n  showErrorMessage(e: any, message?: string): Observable<boolean> {\r\n    if (!message) {\r\n      message = 'Validation errors';\r\n    }\r\n    if (e instanceof HttpErrorResponse) {\r\n      // Validation errors\r\n      if (e.status === 400) {\r\n        const errors = e.error.errors;\r\n        if (errors) {\r\n          errors.forEach(error => {\r\n            message += error.field + ' ' + error.detail + '\\n';\r\n          });        \r\n        }\r\n      }\r\n    }\r\n    const confirmation = Swal.fire({\r\n      icon: 'error',\r\n      title: message,\r\n      // timer: 2000,\r\n      showConfirmButton: true,\r\n      customClass: {\r\n        confirmButton: 'btn btn-success',\r\n      },\r\n      buttonsStyling: false\r\n    }).then(() => {\r\n      return true;\r\n    }, () => {\r\n      return false;\r\n    }).catch();\r\n    return from(confirmation);\r\n  } \r\n}\r\n\r\n"]}