@huntsman-cancer-institute/input 16.0.1 → 17.0.1
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/date/date-base.d.ts +65 -65
- package/date/date-date-range.component.d.ts +32 -32
- package/date/date-date.component.d.ts +53 -53
- package/date/date-validator.d.ts +17 -17
- package/date/date.module.d.ts +16 -16
- package/dropdown/dropdown-index.d.ts +6 -6
- package/dropdown/dropdown-select-result.component.d.ts +23 -23
- package/dropdown/dropdown-select.component.d.ts +76 -76
- package/dropdown/dropdown.component.d.ts +40 -40
- package/dropdown/dropdown.module.d.ts +13 -13
- package/dropdown/dropdown.service.d.ts +51 -51
- package/dropdown/messages.d.ts +11 -11
- package/dropdown/select-item.d.ts +16 -16
- package/dropdown/template-dropdown.directive.d.ts +12 -12
- package/esm2022/date/date-base.mjs +114 -114
- package/esm2022/date/date-date-range.component.mjs +92 -92
- package/esm2022/date/date-date.component.mjs +189 -189
- package/esm2022/date/date-validator.mjs +40 -40
- package/esm2022/date/date.module.mjs +60 -60
- package/esm2022/dropdown/dropdown-index.mjs +5 -5
- package/esm2022/dropdown/dropdown-select-result.component.mjs +85 -85
- package/esm2022/dropdown/dropdown-select.component.mjs +360 -360
- package/esm2022/dropdown/dropdown.component.mjs +170 -170
- package/esm2022/dropdown/dropdown.module.mjs +50 -50
- package/esm2022/dropdown/dropdown.service.mjs +133 -133
- package/esm2022/dropdown/messages.mjs +9 -9
- package/esm2022/dropdown/select-item.mjs +11 -11
- package/esm2022/dropdown/template-dropdown.directive.mjs +26 -26
- package/esm2022/huntsman-cancer-institute-input.mjs +4 -4
- package/esm2022/index.mjs +19 -19
- package/esm2022/inline/inline.component.mjs +179 -179
- package/esm2022/inline/inline.module.mjs +28 -28
- package/esm2022/search/search.component.mjs +157 -157
- package/esm2022/search/search.module.mjs +32 -32
- package/esm2022/select/custom-combobox.component.mjs +531 -531
- package/esm2022/select/custom-multi-combobox.component.mjs +232 -232
- package/esm2022/select/md-multi-select.component.mjs +127 -127
- package/esm2022/select/md-select.component.mjs +107 -107
- package/esm2022/select/native-select.component.mjs +188 -188
- package/esm2022/select/select.module.mjs +83 -83
- package/fesm2022/huntsman-cancer-institute-input.mjs +2797 -2797
- package/fesm2022/huntsman-cancer-institute-input.mjs.map +1 -1
- package/index.d.ts +20 -20
- package/inline/inline.component.d.ts +66 -66
- package/inline/inline.module.d.ts +9 -9
- package/package.json +7 -7
- package/search/search.component.d.ts +42 -42
- package/search/search.module.d.ts +10 -10
- package/select/custom-combobox.component.d.ts +98 -98
- package/select/custom-multi-combobox.component.d.ts +50 -50
- package/select/md-multi-select.component.d.ts +32 -32
- package/select/md-select.component.d.ts +30 -30
- package/select/native-select.component.d.ts +37 -37
- package/select/select.module.d.ts +21 -21
|
@@ -1,144 +1,144 @@
|
|
|
1
|
-
import { Component, forwardRef, HostBinding, Input, ChangeDetectorRef } from "@angular/core";
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
3
|
-
import { HttpClient } from "@angular/common/http";
|
|
4
|
-
import { DictionaryService } from "@huntsman-cancer-institute/dictionary-service";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@huntsman-cancer-institute/dictionary-service";
|
|
7
|
-
import * as i2 from "@angular/common/http";
|
|
8
|
-
import * as i3 from "@angular/common";
|
|
9
|
-
import * as i4 from "@angular/forms";
|
|
10
|
-
export class NativeSelectComponent {
|
|
11
|
-
get filter() {
|
|
12
|
-
return this._filter;
|
|
13
|
-
}
|
|
14
|
-
set filter(f) {
|
|
15
|
-
this._filter = f;
|
|
16
|
-
if (this.filterKey != null && this.filter != null && this.unfilteredEntries != null) {
|
|
17
|
-
this.entries = this.unfilteredEntries;
|
|
18
|
-
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
19
|
-
this.entries = newlist;
|
|
20
|
-
if (this.sortKey != null) {
|
|
21
|
-
if (this.sortNumeric) {
|
|
22
|
-
this.entries.sort((a, b) => {
|
|
23
|
-
return a[this.sortKey] - b[this.sortKey];
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
this.entries.sort((a, b) => {
|
|
28
|
-
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
constructor(dictionaryService, http, cdr) {
|
|
35
|
-
this.dictionaryService = dictionaryService;
|
|
36
|
-
this.http = http;
|
|
37
|
-
this.cdr = cdr;
|
|
38
|
-
this.classList = "";
|
|
39
|
-
this.required = false;
|
|
40
|
-
this.idKey = "id";
|
|
41
|
-
this.displayKey = "display";
|
|
42
|
-
this.disabled = false;
|
|
43
|
-
this.sortKey = null;
|
|
44
|
-
this.sortNumeric = false;
|
|
45
|
-
this.filterKey = null;
|
|
46
|
-
this._filter = null;
|
|
47
|
-
}
|
|
48
|
-
ngOnInit() {
|
|
49
|
-
if (this.url && this.url.indexOf("/") === -1) {
|
|
50
|
-
this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries) => {
|
|
51
|
-
this.entries = entries;
|
|
52
|
-
if (this.filterKey != null && this.filter != null) {
|
|
53
|
-
this.unfilteredEntries = this.entries;
|
|
54
|
-
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
55
|
-
this.entries = newlist;
|
|
56
|
-
}
|
|
57
|
-
if (this.sortKey != null) {
|
|
58
|
-
if (this.sortNumeric) {
|
|
59
|
-
this.entries.sort((a, b) => {
|
|
60
|
-
return a[this.sortKey] - b[this.sortKey];
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
else {
|
|
64
|
-
this.entries.sort((a, b) => {
|
|
65
|
-
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
else if (this.url) {
|
|
72
|
-
this.http.get(this.url).subscribe((entries) => {
|
|
73
|
-
this.entries = entries;
|
|
74
|
-
if (this.filterKey != null && this.filter != null) {
|
|
75
|
-
this.unfilteredEntries = this.entries;
|
|
76
|
-
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
77
|
-
this.entries = newlist;
|
|
78
|
-
}
|
|
79
|
-
if (this.sortKey != null) {
|
|
80
|
-
if (this.sortNumeric) {
|
|
81
|
-
this.entries.sort((a, b) => {
|
|
82
|
-
return a[this.sortKey] - b[this.sortKey];
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
this.entries.sort((a, b) => {
|
|
87
|
-
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
else {
|
|
94
|
-
if (this.filterKey != null && this.filter != null) {
|
|
95
|
-
this.unfilteredEntries = this.entries;
|
|
96
|
-
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
97
|
-
this.entries = newlist;
|
|
98
|
-
}
|
|
99
|
-
if (this.sortKey != null) {
|
|
100
|
-
if (this.sortNumeric) {
|
|
101
|
-
this.entries.sort((a, b) => {
|
|
102
|
-
return a[this.sortKey] - b[this.sortKey];
|
|
103
|
-
});
|
|
104
|
-
}
|
|
105
|
-
else {
|
|
106
|
-
this.entries.sort((a, b) => {
|
|
107
|
-
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
if (this.classList.length > 0) {
|
|
113
|
-
this.classList += " native-input"; //?
|
|
114
|
-
}
|
|
115
|
-
else {
|
|
116
|
-
this.classList = "native-input";
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
setHeight(h) {
|
|
120
|
-
this.height = h;
|
|
121
|
-
// avoid ExpressionChangedAfterItHasBeenCheckedError
|
|
122
|
-
this.cdr.detectChanges();
|
|
123
|
-
}
|
|
124
|
-
writeValue(value) {
|
|
125
|
-
if (value !== undefined) {
|
|
126
|
-
this.value = value;
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
registerOnChange(fn) {
|
|
130
|
-
this.onChange = () => {
|
|
131
|
-
fn(this.value);
|
|
132
|
-
};
|
|
133
|
-
}
|
|
134
|
-
registerOnTouched(fn) { }
|
|
135
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
136
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
137
|
-
{
|
|
138
|
-
provide: NG_VALUE_ACCESSOR,
|
|
139
|
-
useExisting: forwardRef(() => NativeSelectComponent),
|
|
140
|
-
multi: true
|
|
141
|
-
}
|
|
1
|
+
import { Component, forwardRef, HostBinding, Input, ChangeDetectorRef } from "@angular/core";
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
3
|
+
import { HttpClient } from "@angular/common/http";
|
|
4
|
+
import { DictionaryService } from "@huntsman-cancer-institute/dictionary-service";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@huntsman-cancer-institute/dictionary-service";
|
|
7
|
+
import * as i2 from "@angular/common/http";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
import * as i4 from "@angular/forms";
|
|
10
|
+
export class NativeSelectComponent {
|
|
11
|
+
get filter() {
|
|
12
|
+
return this._filter;
|
|
13
|
+
}
|
|
14
|
+
set filter(f) {
|
|
15
|
+
this._filter = f;
|
|
16
|
+
if (this.filterKey != null && this.filter != null && this.unfilteredEntries != null) {
|
|
17
|
+
this.entries = this.unfilteredEntries;
|
|
18
|
+
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
19
|
+
this.entries = newlist;
|
|
20
|
+
if (this.sortKey != null) {
|
|
21
|
+
if (this.sortNumeric) {
|
|
22
|
+
this.entries.sort((a, b) => {
|
|
23
|
+
return a[this.sortKey] - b[this.sortKey];
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.entries.sort((a, b) => {
|
|
28
|
+
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
constructor(dictionaryService, http, cdr) {
|
|
35
|
+
this.dictionaryService = dictionaryService;
|
|
36
|
+
this.http = http;
|
|
37
|
+
this.cdr = cdr;
|
|
38
|
+
this.classList = "";
|
|
39
|
+
this.required = false;
|
|
40
|
+
this.idKey = "id";
|
|
41
|
+
this.displayKey = "display";
|
|
42
|
+
this.disabled = false;
|
|
43
|
+
this.sortKey = null;
|
|
44
|
+
this.sortNumeric = false;
|
|
45
|
+
this.filterKey = null;
|
|
46
|
+
this._filter = null;
|
|
47
|
+
}
|
|
48
|
+
ngOnInit() {
|
|
49
|
+
if (this.url && this.url.indexOf("/") === -1) {
|
|
50
|
+
this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries) => {
|
|
51
|
+
this.entries = entries;
|
|
52
|
+
if (this.filterKey != null && this.filter != null) {
|
|
53
|
+
this.unfilteredEntries = this.entries;
|
|
54
|
+
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
55
|
+
this.entries = newlist;
|
|
56
|
+
}
|
|
57
|
+
if (this.sortKey != null) {
|
|
58
|
+
if (this.sortNumeric) {
|
|
59
|
+
this.entries.sort((a, b) => {
|
|
60
|
+
return a[this.sortKey] - b[this.sortKey];
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
this.entries.sort((a, b) => {
|
|
65
|
+
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
else if (this.url) {
|
|
72
|
+
this.http.get(this.url).subscribe((entries) => {
|
|
73
|
+
this.entries = entries;
|
|
74
|
+
if (this.filterKey != null && this.filter != null) {
|
|
75
|
+
this.unfilteredEntries = this.entries;
|
|
76
|
+
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
77
|
+
this.entries = newlist;
|
|
78
|
+
}
|
|
79
|
+
if (this.sortKey != null) {
|
|
80
|
+
if (this.sortNumeric) {
|
|
81
|
+
this.entries.sort((a, b) => {
|
|
82
|
+
return a[this.sortKey] - b[this.sortKey];
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
this.entries.sort((a, b) => {
|
|
87
|
+
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
if (this.filterKey != null && this.filter != null) {
|
|
95
|
+
this.unfilteredEntries = this.entries;
|
|
96
|
+
var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);
|
|
97
|
+
this.entries = newlist;
|
|
98
|
+
}
|
|
99
|
+
if (this.sortKey != null) {
|
|
100
|
+
if (this.sortNumeric) {
|
|
101
|
+
this.entries.sort((a, b) => {
|
|
102
|
+
return a[this.sortKey] - b[this.sortKey];
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
this.entries.sort((a, b) => {
|
|
107
|
+
return a[this.sortKey].localeCompare(b[this.sortKey]);
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
if (this.classList.length > 0) {
|
|
113
|
+
this.classList += " native-input"; //?
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
this.classList = "native-input";
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
setHeight(h) {
|
|
120
|
+
this.height = h;
|
|
121
|
+
// avoid ExpressionChangedAfterItHasBeenCheckedError
|
|
122
|
+
this.cdr.detectChanges();
|
|
123
|
+
}
|
|
124
|
+
writeValue(value) {
|
|
125
|
+
if (value !== undefined) {
|
|
126
|
+
this.value = value;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
registerOnChange(fn) {
|
|
130
|
+
this.onChange = () => {
|
|
131
|
+
fn(this.value);
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
registerOnTouched(fn) { }
|
|
135
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: NativeSelectComponent, deps: [{ token: i1.DictionaryService }, { token: i2.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
136
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: NativeSelectComponent, selector: "hci-native-select", inputs: { classList: ["class", "classList"], name: "name", label: "label", url: "url", entries: "entries", required: "required", idKey: "idKey", displayKey: "displayKey", disabled: "disabled", sortKey: "sortKey", sortNumeric: "sortNumeric", filterKey: "filterKey", filter: "filter" }, host: { properties: { "class": "this.classList" } }, providers: [
|
|
137
|
+
{
|
|
138
|
+
provide: NG_VALUE_ACCESSOR,
|
|
139
|
+
useExisting: forwardRef(() => NativeSelectComponent),
|
|
140
|
+
multi: true
|
|
141
|
+
}
|
|
142
142
|
], ngImport: i0, template: `
|
|
143
143
|
<div *ngIf="label" class="label">
|
|
144
144
|
{{label}}{{(required) ? " *" : ""}}
|
|
@@ -158,12 +158,12 @@ export class NativeSelectComponent {
|
|
|
158
158
|
{{ row[displayKey] }}
|
|
159
159
|
</option>
|
|
160
160
|
</select>
|
|
161
|
-
`, isInline: true, 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: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
162
|
-
}
|
|
163
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
164
|
-
type: Component,
|
|
165
|
-
args: [{
|
|
166
|
-
selector: "hci-native-select",
|
|
161
|
+
`, isInline: true, 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: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
162
|
+
}
|
|
163
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: NativeSelectComponent, decorators: [{
|
|
164
|
+
type: Component,
|
|
165
|
+
args: [{
|
|
166
|
+
selector: "hci-native-select",
|
|
167
167
|
template: `
|
|
168
168
|
<div *ngIf="label" class="label">
|
|
169
169
|
{{label}}{{(required) ? " *" : ""}}
|
|
@@ -183,44 +183,44 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
183
183
|
{{ row[displayKey] }}
|
|
184
184
|
</option>
|
|
185
185
|
</select>
|
|
186
|
-
`,
|
|
187
|
-
providers: [
|
|
188
|
-
{
|
|
189
|
-
provide: NG_VALUE_ACCESSOR,
|
|
190
|
-
useExisting: forwardRef(() => NativeSelectComponent),
|
|
191
|
-
multi: true
|
|
192
|
-
}
|
|
193
|
-
]
|
|
194
|
-
}]
|
|
195
|
-
}], ctorParameters:
|
|
196
|
-
type: HostBinding,
|
|
197
|
-
args: ["class"]
|
|
198
|
-
}, {
|
|
199
|
-
type: Input,
|
|
200
|
-
args: ["class"]
|
|
201
|
-
}], name: [{
|
|
202
|
-
type: Input
|
|
203
|
-
}], label: [{
|
|
204
|
-
type: Input
|
|
205
|
-
}], url: [{
|
|
206
|
-
type: Input
|
|
207
|
-
}], entries: [{
|
|
208
|
-
type: Input
|
|
209
|
-
}], required: [{
|
|
210
|
-
type: Input
|
|
211
|
-
}], idKey: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], displayKey: [{
|
|
214
|
-
type: Input
|
|
215
|
-
}], disabled: [{
|
|
216
|
-
type: Input
|
|
217
|
-
}], sortKey: [{
|
|
218
|
-
type: Input
|
|
219
|
-
}], sortNumeric: [{
|
|
220
|
-
type: Input
|
|
221
|
-
}], filterKey: [{
|
|
222
|
-
type: Input
|
|
223
|
-
}], filter: [{
|
|
224
|
-
type: Input
|
|
225
|
-
}] } });
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"native-select.component.js","sourceRoot":"","sources":["../../../../projects/input/src/select/native-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, Input, ChangeDetectorRef} from \"@angular/core\";\r\n\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {HttpClient} from \"@angular/common/http\";\r\nimport {DictionaryService, DropdownEntry} from \"@huntsman-cancer-institute/dictionary-service\";\r\n\r\n@Component({\r\n  selector: \"hci-native-select\",\r\n  template: `\r\n    <div *ngIf=\"label\" class=\"label\">\r\n      {{label}}{{(required) ? \" *\" : \"\"}}\r\n    </div>\r\n    <select [(ngModel)]=\"value\"\r\n            [style.height.px]=\"height\"\r\n            (change)=\"onChange()\"\r\n            [disabled]=\"disabled\"\r\n            class=\"form-control flex-grow-1\"\r\n            style=\"min-width: 4rem;\">\r\n      <ng-container *ngIf=\"!required\">\r\n        <option [ngValue]=\"undefined\">\r\n        </option>\r\n      </ng-container>\r\n      <option *ngFor=\"let row of entries\"\r\n              [ngValue]=\"row[idKey]\">\r\n        {{ row[displayKey] }}\r\n      </option>\r\n    </select>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => NativeSelectComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class NativeSelectComponent implements ControlValueAccessor {\r\n\r\n  @HostBinding(\"class\") @Input(\"class\") classList: string = \"\";\r\n\r\n  value: any;\r\n  height: number;\r\n  unfilteredEntries: DropdownEntry[];\r\n\r\n  @Input() name: string;\r\n  @Input() label: string;\r\n  @Input() url: string;\r\n  @Input() entries: DropdownEntry[];\r\n  @Input() required: boolean = false;\r\n  @Input() idKey: string = \"id\";\r\n  @Input() displayKey: string = \"display\";\r\n  @Input() disabled: boolean = false;\r\n  @Input() sortKey: string = null;\r\n  @Input() sortNumeric: boolean = false;\r\n  @Input() filterKey: string = null;\r\n\r\n  _filter: any = null;\r\n  get filter(): any{\r\n    return this._filter;\r\n  }\r\n  @Input() set filter(f: any){\r\n    this._filter = f;\r\n\r\n    if(this.filterKey != null && this.filter != null && this.unfilteredEntries != null) {\r\n      this.entries = this.unfilteredEntries;\r\n      var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n      this.entries = newlist;\r\n\r\n      if(this.sortKey != null) {\r\n        if(this.sortNumeric) {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey] - b[this.sortKey];\r\n          });\r\n        }else {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  onChange: any;\r\n\r\n  constructor(private dictionaryService: DictionaryService, private http: HttpClient, private cdr: ChangeDetectorRef) {}\r\n\r\n  ngOnInit(): void {\r\n    if (this.url && this.url.indexOf(\"/\") === -1) {\r\n      this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries: DropdownEntry[]) => {\r\n        this.entries = entries;\r\n\r\n        if(this.filterKey != null && this.filter != null) {\r\n          this.unfilteredEntries = this.entries;\r\n          var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n          this.entries = newlist;\r\n        }\r\n\r\n        if(this.sortKey != null) {\r\n          if(this.sortNumeric) {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey] - b[this.sortKey];\r\n            });\r\n          }else {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n            });\r\n          }\r\n        }\r\n\r\n      });\r\n    } else if (this.url) {\r\n      this.http.get(this.url).subscribe((entries: any[]) => {\r\n        this.entries = entries;\r\n\r\n        if(this.filterKey != null && this.filter != null) {\r\n          this.unfilteredEntries = this.entries;\r\n          var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n          this.entries = newlist;\r\n        }\r\n\r\n        if(this.sortKey != null) {\r\n          if(this.sortNumeric) {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey] - b[this.sortKey];\r\n            });\r\n          }else {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n            });\r\n          }\r\n        }\r\n      });\r\n    }else {\r\n\r\n      if(this.filterKey != null && this.filter != null) {\r\n        this.unfilteredEntries = this.entries;\r\n        var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n        this.entries = newlist;\r\n      }\r\n\r\n      if(this.sortKey != null) {\r\n        if(this.sortNumeric) {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey] - b[this.sortKey];\r\n          });\r\n        }else {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n    if(this.classList.length > 0) {\r\n      this.classList += \" native-input\"; //?\r\n    }else {\r\n      this.classList = \"native-input\";\r\n    }\r\n  }\r\n\r\n  public setHeight(h: number) {\r\n    this.height = h;\r\n    // avoid ExpressionChangedAfterItHasBeenCheckedError\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  writeValue(value: any) {\r\n    if (value !== undefined) {\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.onChange = () => {\r\n      fn(this.value);\r\n    };\r\n  }\r\n\r\n  registerOnTouched(fn: () => void): void {}\r\n}\r\n"]}
|
|
186
|
+
`,
|
|
187
|
+
providers: [
|
|
188
|
+
{
|
|
189
|
+
provide: NG_VALUE_ACCESSOR,
|
|
190
|
+
useExisting: forwardRef(() => NativeSelectComponent),
|
|
191
|
+
multi: true
|
|
192
|
+
}
|
|
193
|
+
]
|
|
194
|
+
}]
|
|
195
|
+
}], ctorParameters: () => [{ type: i1.DictionaryService }, { type: i2.HttpClient }, { type: i0.ChangeDetectorRef }], propDecorators: { classList: [{
|
|
196
|
+
type: HostBinding,
|
|
197
|
+
args: ["class"]
|
|
198
|
+
}, {
|
|
199
|
+
type: Input,
|
|
200
|
+
args: ["class"]
|
|
201
|
+
}], name: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], label: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}], url: [{
|
|
206
|
+
type: Input
|
|
207
|
+
}], entries: [{
|
|
208
|
+
type: Input
|
|
209
|
+
}], required: [{
|
|
210
|
+
type: Input
|
|
211
|
+
}], idKey: [{
|
|
212
|
+
type: Input
|
|
213
|
+
}], displayKey: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], disabled: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}], sortKey: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], sortNumeric: [{
|
|
220
|
+
type: Input
|
|
221
|
+
}], filterKey: [{
|
|
222
|
+
type: Input
|
|
223
|
+
}], filter: [{
|
|
224
|
+
type: Input
|
|
225
|
+
}] } });
|
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"native-select.component.js","sourceRoot":"","sources":["../../../../projects/input/src/select/native-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, Input, ChangeDetectorRef} from \"@angular/core\";\r\n\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {HttpClient} from \"@angular/common/http\";\r\nimport {DictionaryService, DropdownEntry} from \"@huntsman-cancer-institute/dictionary-service\";\r\n\r\n@Component({\r\n  selector: \"hci-native-select\",\r\n  template: `\r\n    <div *ngIf=\"label\" class=\"label\">\r\n      {{label}}{{(required) ? \" *\" : \"\"}}\r\n    </div>\r\n    <select [(ngModel)]=\"value\"\r\n            [style.height.px]=\"height\"\r\n            (change)=\"onChange()\"\r\n            [disabled]=\"disabled\"\r\n            class=\"form-control flex-grow-1\"\r\n            style=\"min-width: 4rem;\">\r\n      <ng-container *ngIf=\"!required\">\r\n        <option [ngValue]=\"undefined\">\r\n        </option>\r\n      </ng-container>\r\n      <option *ngFor=\"let row of entries\"\r\n              [ngValue]=\"row[idKey]\">\r\n        {{ row[displayKey] }}\r\n      </option>\r\n    </select>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => NativeSelectComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class NativeSelectComponent implements ControlValueAccessor {\r\n\r\n  @HostBinding(\"class\") @Input(\"class\") classList: string = \"\";\r\n\r\n  value: any;\r\n  height: number;\r\n  unfilteredEntries: DropdownEntry[];\r\n\r\n  @Input() name: string;\r\n  @Input() label: string;\r\n  @Input() url: string;\r\n  @Input() entries: DropdownEntry[];\r\n  @Input() required: boolean = false;\r\n  @Input() idKey: string = \"id\";\r\n  @Input() displayKey: string = \"display\";\r\n  @Input() disabled: boolean = false;\r\n  @Input() sortKey: string = null;\r\n  @Input() sortNumeric: boolean = false;\r\n  @Input() filterKey: string = null;\r\n\r\n  _filter: any = null;\r\n  get filter(): any{\r\n    return this._filter;\r\n  }\r\n  @Input() set filter(f: any){\r\n    this._filter = f;\r\n\r\n    if(this.filterKey != null && this.filter != null && this.unfilteredEntries != null) {\r\n      this.entries = this.unfilteredEntries;\r\n      var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n      this.entries = newlist;\r\n\r\n      if(this.sortKey != null) {\r\n        if(this.sortNumeric) {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey] - b[this.sortKey];\r\n          });\r\n        }else {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  onChange: any;\r\n\r\n  constructor(private dictionaryService: DictionaryService, private http: HttpClient, private cdr: ChangeDetectorRef) {}\r\n\r\n  ngOnInit(): void {\r\n    if (this.url && this.url.indexOf(\"/\") === -1) {\r\n      this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries: DropdownEntry[]) => {\r\n        this.entries = entries;\r\n\r\n        if(this.filterKey != null && this.filter != null) {\r\n          this.unfilteredEntries = this.entries;\r\n          var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n          this.entries = newlist;\r\n        }\r\n\r\n        if(this.sortKey != null) {\r\n          if(this.sortNumeric) {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey] - b[this.sortKey];\r\n            });\r\n          }else {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n            });\r\n          }\r\n        }\r\n\r\n      });\r\n    } else if (this.url) {\r\n      this.http.get(this.url).subscribe((entries: any[]) => {\r\n        this.entries = entries;\r\n\r\n        if(this.filterKey != null && this.filter != null) {\r\n          this.unfilteredEntries = this.entries;\r\n          var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n          this.entries = newlist;\r\n        }\r\n\r\n        if(this.sortKey != null) {\r\n          if(this.sortNumeric) {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey] - b[this.sortKey];\r\n            });\r\n          }else {\r\n            this.entries.sort((a, b) => {\r\n              return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n            });\r\n          }\r\n        }\r\n      });\r\n    }else {\r\n\r\n      if(this.filterKey != null && this.filter != null) {\r\n        this.unfilteredEntries = this.entries;\r\n        var newlist = this.entries.filter(entry => entry[this.filterKey] == this.filter);\r\n        this.entries = newlist;\r\n      }\r\n\r\n      if(this.sortKey != null) {\r\n        if(this.sortNumeric) {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey] - b[this.sortKey];\r\n          });\r\n        }else {\r\n          this.entries.sort((a, b) => {\r\n            return a[this.sortKey].localeCompare(b[this.sortKey]);\r\n          });\r\n        }\r\n      }\r\n    }\r\n\r\n    if(this.classList.length > 0) {\r\n      this.classList += \" native-input\"; //?\r\n    }else {\r\n      this.classList = \"native-input\";\r\n    }\r\n  }\r\n\r\n  public setHeight(h: number) {\r\n    this.height = h;\r\n    // avoid ExpressionChangedAfterItHasBeenCheckedError\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  writeValue(value: any) {\r\n    if (value !== undefined) {\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.onChange = () => {\r\n      fn(this.value);\r\n    };\r\n  }\r\n\r\n  registerOnTouched(fn: () => void): void {}\r\n}\r\n"]}
|