@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.
Files changed (54) hide show
  1. package/date/date-base.d.ts +65 -65
  2. package/date/date-date-range.component.d.ts +32 -32
  3. package/date/date-date.component.d.ts +53 -53
  4. package/date/date-validator.d.ts +17 -17
  5. package/date/date.module.d.ts +16 -16
  6. package/dropdown/dropdown-index.d.ts +6 -6
  7. package/dropdown/dropdown-select-result.component.d.ts +23 -23
  8. package/dropdown/dropdown-select.component.d.ts +76 -76
  9. package/dropdown/dropdown.component.d.ts +40 -40
  10. package/dropdown/dropdown.module.d.ts +13 -13
  11. package/dropdown/dropdown.service.d.ts +51 -51
  12. package/dropdown/messages.d.ts +11 -11
  13. package/dropdown/select-item.d.ts +16 -16
  14. package/dropdown/template-dropdown.directive.d.ts +12 -12
  15. package/esm2022/date/date-base.mjs +114 -114
  16. package/esm2022/date/date-date-range.component.mjs +92 -92
  17. package/esm2022/date/date-date.component.mjs +189 -189
  18. package/esm2022/date/date-validator.mjs +40 -40
  19. package/esm2022/date/date.module.mjs +60 -60
  20. package/esm2022/dropdown/dropdown-index.mjs +5 -5
  21. package/esm2022/dropdown/dropdown-select-result.component.mjs +85 -85
  22. package/esm2022/dropdown/dropdown-select.component.mjs +360 -360
  23. package/esm2022/dropdown/dropdown.component.mjs +170 -170
  24. package/esm2022/dropdown/dropdown.module.mjs +50 -50
  25. package/esm2022/dropdown/dropdown.service.mjs +133 -133
  26. package/esm2022/dropdown/messages.mjs +9 -9
  27. package/esm2022/dropdown/select-item.mjs +11 -11
  28. package/esm2022/dropdown/template-dropdown.directive.mjs +26 -26
  29. package/esm2022/huntsman-cancer-institute-input.mjs +4 -4
  30. package/esm2022/index.mjs +19 -19
  31. package/esm2022/inline/inline.component.mjs +179 -179
  32. package/esm2022/inline/inline.module.mjs +28 -28
  33. package/esm2022/search/search.component.mjs +157 -157
  34. package/esm2022/search/search.module.mjs +32 -32
  35. package/esm2022/select/custom-combobox.component.mjs +531 -531
  36. package/esm2022/select/custom-multi-combobox.component.mjs +232 -232
  37. package/esm2022/select/md-multi-select.component.mjs +127 -127
  38. package/esm2022/select/md-select.component.mjs +107 -107
  39. package/esm2022/select/native-select.component.mjs +188 -188
  40. package/esm2022/select/select.module.mjs +83 -83
  41. package/fesm2022/huntsman-cancer-institute-input.mjs +2797 -2797
  42. package/fesm2022/huntsman-cancer-institute-input.mjs.map +1 -1
  43. package/index.d.ts +20 -20
  44. package/inline/inline.component.d.ts +66 -66
  45. package/inline/inline.module.d.ts +9 -9
  46. package/package.json +7 -7
  47. package/search/search.component.d.ts +42 -42
  48. package/search/search.module.d.ts +10 -10
  49. package/select/custom-combobox.component.d.ts +98 -98
  50. package/select/custom-multi-combobox.component.d.ts +50 -50
  51. package/select/md-multi-select.component.d.ts +32 -32
  52. package/select/md-select.component.d.ts +30 -30
  53. package/select/native-select.component.d.ts +37 -37
  54. package/select/select.module.d.ts +21 -21
@@ -1,93 +1,93 @@
1
- import { Component, forwardRef, HostBinding, Input } from "@angular/core";
2
- import { HttpClient } from "@angular/common/http";
3
- import { UntypedFormControl, NG_VALUE_ACCESSOR } from "@angular/forms";
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
- import * as i5 from "@angular/material/legacy-form-field";
11
- import * as i6 from "@angular/material/legacy-select";
12
- import * as i7 from "@angular/material/legacy-core";
13
- export class MdMultiSelectComponent {
14
- constructor(dictionaryService, http) {
15
- this.dictionaryService = dictionaryService;
16
- this.http = http;
17
- this.classList = "";
18
- this.required = false;
19
- this.idKey = "id";
20
- this.displayKey = "display";
21
- this.options = new UntypedFormControl();
22
- this.onChangeCallback = () => { };
23
- this.onTouchedCallback = () => { };
24
- }
25
- ngOnInit() {
26
- if (this.url && this.url.indexOf("/") === -1) {
27
- this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries) => {
28
- this.entries = entries;
29
- });
30
- }
31
- else if (this.url) {
32
- this.http.get(this.url).subscribe((entries) => {
33
- this.entries = entries;
34
- });
35
- }
36
- if (this.classList.length > 0) {
37
- this.classList += " material-input";
38
- }
39
- else {
40
- this.classList = "material-input";
41
- }
42
- }
43
- getOptionDisplay(value) {
44
- for (let entry of this.entries) {
45
- if (entry[this.idKey] === value) {
46
- return entry[this.displayKey];
47
- }
48
- }
49
- return undefined;
50
- }
51
- remove(value) {
52
- console.debug(this.options);
53
- let newValue = [];
54
- for (let option of this.options.value) {
55
- if (option !== value) {
56
- newValue.push(option);
57
- }
58
- }
59
- this.writeValue(newValue);
60
- }
61
- get value() {
62
- return this._value;
63
- }
64
- set value(newValue) {
65
- this._value = newValue;
66
- this.options.setValue(newValue);
67
- this.onChangeCallback(newValue);
68
- }
69
- onBlur() {
70
- this.onTouchedCallback();
71
- }
72
- writeValue(value) {
73
- if (value !== this.value) {
74
- this.value = value;
75
- this.options.setValue(value);
76
- }
77
- }
78
- registerOnChange(callback) {
79
- this.onChangeCallback = callback;
80
- }
81
- registerOnTouched(callback) {
82
- this.onTouchedCallback = callback;
83
- }
84
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MdMultiSelectComponent, deps: [{ token: i1.DictionaryService }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
85
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MdMultiSelectComponent, selector: "hci-md-multi-select", inputs: { classList: ["class", "classList"], name: "name", label: "label", url: "url", entries: "entries", required: "required", idKey: "idKey", displayKey: "displayKey" }, host: { properties: { "class": "this.classList" } }, providers: [
86
- {
87
- provide: NG_VALUE_ACCESSOR,
88
- useExisting: forwardRef(() => MdMultiSelectComponent),
89
- multi: true
90
- }
1
+ import { Component, forwardRef, HostBinding, Input } from "@angular/core";
2
+ import { HttpClient } from "@angular/common/http";
3
+ import { UntypedFormControl, NG_VALUE_ACCESSOR } from "@angular/forms";
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
+ import * as i5 from "@angular/material/legacy-form-field";
11
+ import * as i6 from "@angular/material/legacy-select";
12
+ import * as i7 from "@angular/material/legacy-core";
13
+ export class MdMultiSelectComponent {
14
+ constructor(dictionaryService, http) {
15
+ this.dictionaryService = dictionaryService;
16
+ this.http = http;
17
+ this.classList = "";
18
+ this.required = false;
19
+ this.idKey = "id";
20
+ this.displayKey = "display";
21
+ this.options = new UntypedFormControl();
22
+ this.onChangeCallback = () => { };
23
+ this.onTouchedCallback = () => { };
24
+ }
25
+ ngOnInit() {
26
+ if (this.url && this.url.indexOf("/") === -1) {
27
+ this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries) => {
28
+ this.entries = entries;
29
+ });
30
+ }
31
+ else if (this.url) {
32
+ this.http.get(this.url).subscribe((entries) => {
33
+ this.entries = entries;
34
+ });
35
+ }
36
+ if (this.classList.length > 0) {
37
+ this.classList += " material-input";
38
+ }
39
+ else {
40
+ this.classList = "material-input";
41
+ }
42
+ }
43
+ getOptionDisplay(value) {
44
+ for (let entry of this.entries) {
45
+ if (entry[this.idKey] === value) {
46
+ return entry[this.displayKey];
47
+ }
48
+ }
49
+ return undefined;
50
+ }
51
+ remove(value) {
52
+ console.debug(this.options);
53
+ let newValue = [];
54
+ for (let option of this.options.value) {
55
+ if (option !== value) {
56
+ newValue.push(option);
57
+ }
58
+ }
59
+ this.writeValue(newValue);
60
+ }
61
+ get value() {
62
+ return this._value;
63
+ }
64
+ set value(newValue) {
65
+ this._value = newValue;
66
+ this.options.setValue(newValue);
67
+ this.onChangeCallback(newValue);
68
+ }
69
+ onBlur() {
70
+ this.onTouchedCallback();
71
+ }
72
+ writeValue(value) {
73
+ if (value !== this.value) {
74
+ this.value = value;
75
+ this.options.setValue(value);
76
+ }
77
+ }
78
+ registerOnChange(callback) {
79
+ this.onChangeCallback = callback;
80
+ }
81
+ registerOnTouched(callback) {
82
+ this.onTouchedCallback = callback;
83
+ }
84
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MdMultiSelectComponent, deps: [{ token: i1.DictionaryService }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
85
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: MdMultiSelectComponent, selector: "hci-md-multi-select", inputs: { classList: ["class", "classList"], name: "name", label: "label", url: "url", entries: "entries", required: "required", idKey: "idKey", displayKey: "displayKey" }, host: { properties: { "class": "this.classList" } }, providers: [
86
+ {
87
+ provide: NG_VALUE_ACCESSOR,
88
+ useExisting: forwardRef(() => MdMultiSelectComponent),
89
+ multi: true
90
+ }
91
91
  ], ngImport: i0, template: `
92
92
  <mat-form-field class="flex-grow-1">
93
93
  <mat-label>{{label}}</mat-label>
@@ -103,12 +103,12 @@ export class MdMultiSelectComponent {
103
103
  <mat-option *ngFor="let row of entries" [value]="row[idKey]">{{ row[displayKey] }}</mat-option>
104
104
  </mat-select>
105
105
  </mat-form-field>
106
- `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLegacyLabel, selector: "mat-label" }, { kind: "component", type: i6.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "directive", type: i6.MatLegacySelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i7.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
107
- }
108
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MdMultiSelectComponent, decorators: [{
109
- type: Component,
110
- args: [{
111
- selector: "hci-md-multi-select",
106
+ `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLegacyLabel, selector: "mat-label" }, { kind: "component", type: i6.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "directive", type: i6.MatLegacySelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i7.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
107
+ }
108
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MdMultiSelectComponent, decorators: [{
109
+ type: Component,
110
+ args: [{
111
+ selector: "hci-md-multi-select",
112
112
  template: `
113
113
  <mat-form-field class="flex-grow-1">
114
114
  <mat-label>{{label}}</mat-label>
@@ -124,34 +124,34 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
124
124
  <mat-option *ngFor="let row of entries" [value]="row[idKey]">{{ row[displayKey] }}</mat-option>
125
125
  </mat-select>
126
126
  </mat-form-field>
127
- `,
128
- providers: [
129
- {
130
- provide: NG_VALUE_ACCESSOR,
131
- useExisting: forwardRef(() => MdMultiSelectComponent),
132
- multi: true
133
- }
134
- ]
135
- }]
136
- }], ctorParameters: function () { return [{ type: i1.DictionaryService }, { type: i2.HttpClient }]; }, propDecorators: { classList: [{
137
- type: HostBinding,
138
- args: ["class"]
139
- }, {
140
- type: Input,
141
- args: ["class"]
142
- }], name: [{
143
- type: Input
144
- }], label: [{
145
- type: Input
146
- }], url: [{
147
- type: Input
148
- }], entries: [{
149
- type: Input
150
- }], required: [{
151
- type: Input
152
- }], idKey: [{
153
- type: Input
154
- }], displayKey: [{
155
- type: Input
156
- }] } });
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"md-multi-select.component.js","sourceRoot":"","sources":["../../../../projects/input/src/select/md-multi-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, Input} from \"@angular/core\";\r\nimport {HttpClient} from \"@angular/common/http\";\r\nimport {ControlValueAccessor, UntypedFormControl, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\n\r\nimport {DictionaryService, DropdownEntry} from \"@huntsman-cancer-institute/dictionary-service\";\r\n\r\n@Component({\r\n  selector: \"hci-md-multi-select\",\r\n  template: `\r\n    <mat-form-field class=\"flex-grow-1\">\r\n      <mat-label>{{label}}</mat-label>\r\n      <mat-select [(value)]=\"value\" [formControl]=\"options\" [required]=\"required\" multiple>\r\n        <mat-select-trigger class=\"d-flex flex-wrap\">\r\n          <div *ngFor=\"let option of options.value\" class=\"chip\">\r\n            {{getOptionDisplay(option)}}\r\n            <div (click)=\"$event.stopPropagation(); remove(option)\" class=\"chip-remove\">\r\n              <i class=\"fa fa-times-circle fa-xs\"></i>\r\n            </div>\r\n          </div>\r\n        </mat-select-trigger>\r\n        <mat-option *ngFor=\"let row of entries\" [value]=\"row[idKey]\">{{ row[displayKey] }}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => MdMultiSelectComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class MdMultiSelectComponent implements ControlValueAccessor {\r\n\r\n  @HostBinding(\"class\") @Input(\"class\") classList: string = \"\";\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\r\n  options = new UntypedFormControl();\r\n\r\n  private _value: any[];\r\n  private onChangeCallback: (_: any[]) => void = () => {};\r\n  private onTouchedCallback: () => void = () => {};\r\n\r\n  constructor(private dictionaryService: DictionaryService, private http: HttpClient) {}\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    } else if (this.url) {\r\n      this.http.get(this.url).subscribe((entries: any[]) => {\r\n        this.entries = entries;\r\n      });\r\n    }\r\n\r\n    if(this.classList.length > 0) {\r\n      this.classList += \" material-input\";\r\n    }else {\r\n      this.classList = \"material-input\";\r\n    }\r\n  }\r\n\r\n  getOptionDisplay(value: any): string {\r\n    for (let entry of this.entries) {\r\n      if (entry[this.idKey] === value) {\r\n        return entry[this.displayKey];\r\n      }\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n\r\n  remove(value: any): void {\r\n    console.debug(this.options);\r\n\r\n    let newValue: any[] = [];\r\n\r\n    for (let option of this.options.value) {\r\n      if (option !== value) {\r\n        newValue.push(option);\r\n      }\r\n    }\r\n\r\n    this.writeValue(newValue);\r\n  }\r\n\r\n  public get value(): any[] {\r\n    return this._value;\r\n  }\r\n\r\n  public set value(newValue: any[]) {\r\n    this._value = newValue;\r\n    this.options.setValue(newValue);\r\n    this.onChangeCallback(newValue);\r\n  }\r\n\r\n  public onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  public writeValue(value: any[]) {\r\n    if (value !== this.value) {\r\n      this.value = value;\r\n      this.options.setValue(value);\r\n    }\r\n  }\r\n\r\n  public registerOnChange(callback: (_: any[]) => void) {\r\n    this.onChangeCallback = callback;\r\n  }\r\n\r\n\r\n  public registerOnTouched(callback: () => void) {\r\n    this.onTouchedCallback = callback;\r\n  }\r\n}\r\n"]}
127
+ `,
128
+ providers: [
129
+ {
130
+ provide: NG_VALUE_ACCESSOR,
131
+ useExisting: forwardRef(() => MdMultiSelectComponent),
132
+ multi: true
133
+ }
134
+ ]
135
+ }]
136
+ }], ctorParameters: () => [{ type: i1.DictionaryService }, { type: i2.HttpClient }], propDecorators: { classList: [{
137
+ type: HostBinding,
138
+ args: ["class"]
139
+ }, {
140
+ type: Input,
141
+ args: ["class"]
142
+ }], name: [{
143
+ type: Input
144
+ }], label: [{
145
+ type: Input
146
+ }], url: [{
147
+ type: Input
148
+ }], entries: [{
149
+ type: Input
150
+ }], required: [{
151
+ type: Input
152
+ }], idKey: [{
153
+ type: Input
154
+ }], displayKey: [{
155
+ type: Input
156
+ }] } });
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"md-multi-select.component.js","sourceRoot":"","sources":["../../../../projects/input/src/select/md-multi-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, Input} from \"@angular/core\";\r\nimport {HttpClient} from \"@angular/common/http\";\r\nimport {ControlValueAccessor, UntypedFormControl, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\n\r\nimport {DictionaryService, DropdownEntry} from \"@huntsman-cancer-institute/dictionary-service\";\r\n\r\n@Component({\r\n  selector: \"hci-md-multi-select\",\r\n  template: `\r\n    <mat-form-field class=\"flex-grow-1\">\r\n      <mat-label>{{label}}</mat-label>\r\n      <mat-select [(value)]=\"value\" [formControl]=\"options\" [required]=\"required\" multiple>\r\n        <mat-select-trigger class=\"d-flex flex-wrap\">\r\n          <div *ngFor=\"let option of options.value\" class=\"chip\">\r\n            {{getOptionDisplay(option)}}\r\n            <div (click)=\"$event.stopPropagation(); remove(option)\" class=\"chip-remove\">\r\n              <i class=\"fa fa-times-circle fa-xs\"></i>\r\n            </div>\r\n          </div>\r\n        </mat-select-trigger>\r\n        <mat-option *ngFor=\"let row of entries\" [value]=\"row[idKey]\">{{ row[displayKey] }}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => MdMultiSelectComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class MdMultiSelectComponent implements ControlValueAccessor {\r\n\r\n  @HostBinding(\"class\") @Input(\"class\") classList: string = \"\";\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\r\n  options = new UntypedFormControl();\r\n\r\n  private _value: any[];\r\n  private onChangeCallback: (_: any[]) => void = () => {};\r\n  private onTouchedCallback: () => void = () => {};\r\n\r\n  constructor(private dictionaryService: DictionaryService, private http: HttpClient) {}\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    } else if (this.url) {\r\n      this.http.get(this.url).subscribe((entries: any[]) => {\r\n        this.entries = entries;\r\n      });\r\n    }\r\n\r\n    if(this.classList.length > 0) {\r\n      this.classList += \" material-input\";\r\n    }else {\r\n      this.classList = \"material-input\";\r\n    }\r\n  }\r\n\r\n  getOptionDisplay(value: any): string {\r\n    for (let entry of this.entries) {\r\n      if (entry[this.idKey] === value) {\r\n        return entry[this.displayKey];\r\n      }\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n\r\n  remove(value: any): void {\r\n    console.debug(this.options);\r\n\r\n    let newValue: any[] = [];\r\n\r\n    for (let option of this.options.value) {\r\n      if (option !== value) {\r\n        newValue.push(option);\r\n      }\r\n    }\r\n\r\n    this.writeValue(newValue);\r\n  }\r\n\r\n  public get value(): any[] {\r\n    return this._value;\r\n  }\r\n\r\n  public set value(newValue: any[]) {\r\n    this._value = newValue;\r\n    this.options.setValue(newValue);\r\n    this.onChangeCallback(newValue);\r\n  }\r\n\r\n  public onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  public writeValue(value: any[]) {\r\n    if (value !== this.value) {\r\n      this.value = value;\r\n      this.options.setValue(value);\r\n    }\r\n  }\r\n\r\n  public registerOnChange(callback: (_: any[]) => void) {\r\n    this.onChangeCallback = callback;\r\n  }\r\n\r\n\r\n  public registerOnTouched(callback: () => void) {\r\n    this.onTouchedCallback = callback;\r\n  }\r\n}\r\n"]}
@@ -1,71 +1,71 @@
1
- import { Component, forwardRef, HostBinding, Input } 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/material/legacy-form-field";
10
- import * as i5 from "@angular/material/legacy-select";
11
- import * as i6 from "@angular/material/legacy-core";
12
- export class MdSelectComponent {
13
- constructor(dictionaryService, http) {
14
- this.dictionaryService = dictionaryService;
15
- this.http = http;
16
- this.classList = "";
17
- this.required = false;
18
- this.idKey = "id";
19
- this.displayKey = "display";
20
- this.onChangeCallback = () => { };
21
- this.onTouchedCallback = () => { };
22
- }
23
- ngOnInit() {
24
- if (this.url && this.url.indexOf("/") === -1) {
25
- this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries) => {
26
- this.entries = entries;
27
- });
28
- }
29
- else if (this.url) {
30
- this.http.get(this.url).subscribe((entries) => {
31
- this.entries = entries;
32
- });
33
- }
34
- if (this.classList.length > 0) {
35
- this.classList += " material-input";
36
- }
37
- else {
38
- this.classList = "material-input";
39
- }
40
- }
41
- get value() {
42
- return this._value;
43
- }
44
- set value(newValue) {
45
- this._value = newValue;
46
- this.onChangeCallback(newValue);
47
- }
48
- onBlur() {
49
- this.onTouchedCallback();
50
- }
51
- writeValue(value) {
52
- if (value !== this.value) {
53
- this.value = value;
54
- }
55
- }
56
- registerOnChange(callback) {
57
- this.onChangeCallback = callback;
58
- }
59
- registerOnTouched(callback) {
60
- this.onTouchedCallback = callback;
61
- }
62
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MdSelectComponent, deps: [{ token: i1.DictionaryService }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
63
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MdSelectComponent, selector: "hci-md-select", inputs: { classList: ["class", "classList"], name: "name", label: "label", url: "url", className: "className", entries: "entries", required: "required", idKey: "idKey", displayKey: "displayKey" }, host: { properties: { "class": "this.classList" } }, providers: [
64
- {
65
- provide: NG_VALUE_ACCESSOR,
66
- useExisting: forwardRef(() => MdSelectComponent),
67
- multi: true
68
- }
1
+ import { Component, forwardRef, HostBinding, Input } 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/material/legacy-form-field";
10
+ import * as i5 from "@angular/material/legacy-select";
11
+ import * as i6 from "@angular/material/legacy-core";
12
+ export class MdSelectComponent {
13
+ constructor(dictionaryService, http) {
14
+ this.dictionaryService = dictionaryService;
15
+ this.http = http;
16
+ this.classList = "";
17
+ this.required = false;
18
+ this.idKey = "id";
19
+ this.displayKey = "display";
20
+ this.onChangeCallback = () => { };
21
+ this.onTouchedCallback = () => { };
22
+ }
23
+ ngOnInit() {
24
+ if (this.url && this.url.indexOf("/") === -1) {
25
+ this.dictionaryService.getDictionaryDropdownEntries(this.url).subscribe((entries) => {
26
+ this.entries = entries;
27
+ });
28
+ }
29
+ else if (this.url) {
30
+ this.http.get(this.url).subscribe((entries) => {
31
+ this.entries = entries;
32
+ });
33
+ }
34
+ if (this.classList.length > 0) {
35
+ this.classList += " material-input";
36
+ }
37
+ else {
38
+ this.classList = "material-input";
39
+ }
40
+ }
41
+ get value() {
42
+ return this._value;
43
+ }
44
+ set value(newValue) {
45
+ this._value = newValue;
46
+ this.onChangeCallback(newValue);
47
+ }
48
+ onBlur() {
49
+ this.onTouchedCallback();
50
+ }
51
+ writeValue(value) {
52
+ if (value !== this.value) {
53
+ this.value = value;
54
+ }
55
+ }
56
+ registerOnChange(callback) {
57
+ this.onChangeCallback = callback;
58
+ }
59
+ registerOnTouched(callback) {
60
+ this.onTouchedCallback = callback;
61
+ }
62
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MdSelectComponent, deps: [{ token: i1.DictionaryService }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
63
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: MdSelectComponent, selector: "hci-md-select", inputs: { classList: ["class", "classList"], name: "name", label: "label", url: "url", className: "className", entries: "entries", required: "required", idKey: "idKey", displayKey: "displayKey" }, host: { properties: { "class": "this.classList" } }, providers: [
64
+ {
65
+ provide: NG_VALUE_ACCESSOR,
66
+ useExisting: forwardRef(() => MdSelectComponent),
67
+ multi: true
68
+ }
69
69
  ], ngImport: i0, template: `
70
70
  <mat-form-field>
71
71
  <mat-label>{{label}}</mat-label>
@@ -74,12 +74,12 @@ export class MdSelectComponent {
74
74
  <mat-option *ngFor="let row of entries" [value]="row[idKey]">{{ row[displayKey] }}</mat-option>
75
75
  </mat-select>
76
76
  </mat-form-field>
77
- `, 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: "component", type: i4.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLegacyLabel, selector: "mat-label" }, { kind: "component", type: i5.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
78
- }
79
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MdSelectComponent, decorators: [{
80
- type: Component,
81
- args: [{
82
- selector: "hci-md-select",
77
+ `, 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: "component", type: i4.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLegacyLabel, selector: "mat-label" }, { kind: "component", type: i5.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
78
+ }
79
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MdSelectComponent, decorators: [{
80
+ type: Component,
81
+ args: [{
82
+ selector: "hci-md-select",
83
83
  template: `
84
84
  <mat-form-field>
85
85
  <mat-label>{{label}}</mat-label>
@@ -88,36 +88,36 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
88
88
  <mat-option *ngFor="let row of entries" [value]="row[idKey]">{{ row[displayKey] }}</mat-option>
89
89
  </mat-select>
90
90
  </mat-form-field>
91
- `,
92
- providers: [
93
- {
94
- provide: NG_VALUE_ACCESSOR,
95
- useExisting: forwardRef(() => MdSelectComponent),
96
- multi: true
97
- }
98
- ]
99
- }]
100
- }], ctorParameters: function () { return [{ type: i1.DictionaryService }, { type: i2.HttpClient }]; }, propDecorators: { classList: [{
101
- type: HostBinding,
102
- args: ["class"]
103
- }, {
104
- type: Input,
105
- args: ["class"]
106
- }], name: [{
107
- type: Input
108
- }], label: [{
109
- type: Input
110
- }], url: [{
111
- type: Input
112
- }], className: [{
113
- type: Input
114
- }], entries: [{
115
- type: Input
116
- }], required: [{
117
- type: Input
118
- }], idKey: [{
119
- type: Input
120
- }], displayKey: [{
121
- type: Input
122
- }] } });
123
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWQtc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2lucHV0L3NyYy9zZWxlY3QvbWQtc2VsZWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3hFLE9BQU8sRUFBdUIsaUJBQWlCLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFFaEQsT0FBTyxFQUFDLGlCQUFpQixFQUFnQixNQUFNLCtDQUErQyxDQUFDOzs7Ozs7OztBQXFCL0YsTUFBTSxPQUFPLGlCQUFpQjtJQWlCNUIsWUFBb0IsaUJBQW9DLEVBQVUsSUFBZ0I7UUFBOUQsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUFVLFNBQUksR0FBSixJQUFJLENBQVk7UUFmNUMsY0FBUyxHQUFXLEVBQUUsQ0FBQztRQU9wRCxhQUFRLEdBQVksS0FBSyxDQUFDO1FBQzFCLFVBQUssR0FBVyxJQUFJLENBQUM7UUFDckIsZUFBVSxHQUFXLFNBQVMsQ0FBQztRQUdoQyxxQkFBZ0IsR0FBd0IsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO1FBQ2pELHNCQUFpQixHQUFlLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztJQUVvQyxDQUFDO0lBRXRGLFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUU7WUFDNUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLDRCQUE0QixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUF3QixFQUFFLEVBQUU7Z0JBQ25HLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1lBQ3pCLENBQUMsQ0FBQyxDQUFDO1NBQ0o7YUFBTSxJQUFJLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE9BQWMsRUFBRSxFQUFFO2dCQUNuRCxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztZQUN6QixDQUFDLENBQUMsQ0FBQztTQUNKO1FBRUQsSUFBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDNUIsSUFBSSxDQUFDLFNBQVMsSUFBSSxpQkFBaUIsQ0FBQztTQUNyQzthQUFLO1lBQ0osSUFBSSxDQUFDLFNBQVMsR0FBRyxnQkFBZ0IsQ0FBQztTQUNuQztJQUNILENBQUM7SUFFRCxJQUFXLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQUVELElBQVcsS0FBSyxDQUFDLFFBQWdCO1FBQy9CLElBQUksQ0FBQyxNQUFNLEdBQUcsUUFBUSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRU0sTUFBTTtRQUNYLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFTSxVQUFVLENBQUMsS0FBYTtRQUM3QixJQUFJLEtBQUssS0FBSyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ3hCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1NBQ3BCO0lBQ0gsQ0FBQztJQUVNLGdCQUFnQixDQUFDLFFBQTZCO1FBQ25ELElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxRQUFRLENBQUM7SUFDbkMsQ0FBQztJQUdNLGlCQUFpQixDQUFDLFFBQW9CO1FBQzNDLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxRQUFRLENBQUM7SUFDcEMsQ0FBQzsrR0EvRFUsaUJBQWlCO21HQUFqQixpQkFBaUIsa1NBUmpCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztnQkFDaEQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLDBCQWZTOzs7Ozs7OztHQVFUOzs0RkFTVSxpQkFBaUI7a0JBbkI3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxlQUFlO29CQUN6QixRQUFRLEVBQUU7Ozs7Ozs7O0dBUVQ7b0JBQ0QsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLGtCQUFrQixDQUFDOzRCQUNoRCxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRjtpQkFDRjtpSUFHdUMsU0FBUztzQkFBOUMsV0FBVzt1QkFBQyxPQUFPOztzQkFBRyxLQUFLO3VCQUFDLE9BQU87Z0JBRTNCLElBQUk7c0JBQVosS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csR0FBRztzQkFBWCxLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgZm9yd2FyZFJlZiwgSG9zdEJpbmRpbmcsIElucHV0fSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUn0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7SHR0cENsaWVudH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcblxyXG5pbXBvcnQge0RpY3Rpb25hcnlTZXJ2aWNlLCBEcm9wZG93bkVudHJ5fSBmcm9tIFwiQGh1bnRzbWFuLWNhbmNlci1pbnN0aXR1dGUvZGljdGlvbmFyeS1zZXJ2aWNlXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJoY2ktbWQtc2VsZWN0XCIsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxtYXQtZm9ybS1maWVsZD5cclxuICAgICAgPG1hdC1sYWJlbD57e2xhYmVsfX08L21hdC1sYWJlbD5cclxuICAgICAgPG1hdC1zZWxlY3QgWyh2YWx1ZSldPVwidmFsdWVcIiBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIj5cclxuICAgICAgICA8bWF0LW9wdGlvbiAqbmdJZj1cIiFyZXF1aXJlZFwiIFt2YWx1ZV09XCJ1bmRlZmluZWRcIj48L21hdC1vcHRpb24+XHJcbiAgICAgICAgPG1hdC1vcHRpb24gKm5nRm9yPVwibGV0IHJvdyBvZiBlbnRyaWVzXCIgW3ZhbHVlXT1cInJvd1tpZEtleV1cIj57eyByb3dbZGlzcGxheUtleV0gfX08L21hdC1vcHRpb24+XHJcbiAgICAgIDwvbWF0LXNlbGVjdD5cclxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XHJcbiAgYCxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IE1kU2VsZWN0Q29tcG9uZW50KSxcclxuICAgICAgbXVsdGk6IHRydWVcclxuICAgIH1cclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNZFNlbGVjdENvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKFwiY2xhc3NcIikgQElucHV0KFwiY2xhc3NcIikgY2xhc3NMaXN0OiBzdHJpbmcgPSBcIlwiO1xyXG5cclxuICBASW5wdXQoKSBuYW1lOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbGFiZWw6IHN0cmluZztcclxuICBASW5wdXQoKSB1cmw6IHN0cmluZztcclxuICBASW5wdXQoKSBjbGFzc05hbWU6IHN0cmluZztcclxuICBASW5wdXQoKSBlbnRyaWVzOiBEcm9wZG93bkVudHJ5W107XHJcbiAgQElucHV0KCkgcmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICBASW5wdXQoKSBpZEtleTogc3RyaW5nID0gXCJpZFwiO1xyXG4gIEBJbnB1dCgpIGRpc3BsYXlLZXk6IHN0cmluZyA9IFwiZGlzcGxheVwiO1xyXG5cclxuICBwcml2YXRlIF92YWx1ZTogbnVtYmVyO1xyXG4gIHByaXZhdGUgb25DaGFuZ2VDYWxsYmFjazogKF86IG51bWJlcikgPT4gdm9pZCA9ICgpID0+IHt9O1xyXG4gIHByaXZhdGUgb25Ub3VjaGVkQ2FsbGJhY2s6ICgpID0+IHZvaWQgPSAoKSA9PiB7fTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBkaWN0aW9uYXJ5U2VydmljZTogRGljdGlvbmFyeVNlcnZpY2UsIHByaXZhdGUgaHR0cDogSHR0cENsaWVudCkge31cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy51cmwgJiYgdGhpcy51cmwuaW5kZXhPZihcIi9cIikgPT09IC0xKSB7XHJcbiAgICAgIHRoaXMuZGljdGlvbmFyeVNlcnZpY2UuZ2V0RGljdGlvbmFyeURyb3Bkb3duRW50cmllcyh0aGlzLnVybCkuc3Vic2NyaWJlKChlbnRyaWVzOiBEcm9wZG93bkVudHJ5W10pID0+IHtcclxuICAgICAgICB0aGlzLmVudHJpZXMgPSBlbnRyaWVzO1xyXG4gICAgICB9KTtcclxuICAgIH0gZWxzZSBpZiAodGhpcy51cmwpIHtcclxuICAgICAgdGhpcy5odHRwLmdldCh0aGlzLnVybCkuc3Vic2NyaWJlKChlbnRyaWVzOiBhbnlbXSkgPT4ge1xyXG4gICAgICAgIHRoaXMuZW50cmllcyA9IGVudHJpZXM7XHJcbiAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIGlmKHRoaXMuY2xhc3NMaXN0Lmxlbmd0aCA+IDApIHtcclxuICAgICAgdGhpcy5jbGFzc0xpc3QgKz0gXCIgbWF0ZXJpYWwtaW5wdXRcIjtcclxuICAgIH1lbHNlIHtcclxuICAgICAgdGhpcy5jbGFzc0xpc3QgPSBcIm1hdGVyaWFsLWlucHV0XCI7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHZhbHVlKCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0IHZhbHVlKG5ld1ZhbHVlOiBudW1iZXIpIHtcclxuICAgIHRoaXMuX3ZhbHVlID0gbmV3VmFsdWU7XHJcbiAgICB0aGlzLm9uQ2hhbmdlQ2FsbGJhY2sobmV3VmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uQmx1cigpIHtcclxuICAgIHRoaXMub25Ub3VjaGVkQ2FsbGJhY2soKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyB3cml0ZVZhbHVlKHZhbHVlOiBudW1iZXIpIHtcclxuICAgIGlmICh2YWx1ZSAhPT0gdGhpcy52YWx1ZSkge1xyXG4gICAgICB0aGlzLnZhbHVlID0gdmFsdWU7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgcmVnaXN0ZXJPbkNoYW5nZShjYWxsYmFjazogKF86IG51bWJlcikgPT4gdm9pZCkge1xyXG4gICAgdGhpcy5vbkNoYW5nZUNhbGxiYWNrID0gY2FsbGJhY2s7XHJcbiAgfVxyXG5cclxuXHJcbiAgcHVibGljIHJlZ2lzdGVyT25Ub3VjaGVkKGNhbGxiYWNrOiAoKSA9PiB2b2lkKSB7XHJcbiAgICB0aGlzLm9uVG91Y2hlZENhbGxiYWNrID0gY2FsbGJhY2s7XHJcbiAgfVxyXG59XHJcbiJdfQ==
91
+ `,
92
+ providers: [
93
+ {
94
+ provide: NG_VALUE_ACCESSOR,
95
+ useExisting: forwardRef(() => MdSelectComponent),
96
+ multi: true
97
+ }
98
+ ]
99
+ }]
100
+ }], ctorParameters: () => [{ type: i1.DictionaryService }, { type: i2.HttpClient }], propDecorators: { classList: [{
101
+ type: HostBinding,
102
+ args: ["class"]
103
+ }, {
104
+ type: Input,
105
+ args: ["class"]
106
+ }], name: [{
107
+ type: Input
108
+ }], label: [{
109
+ type: Input
110
+ }], url: [{
111
+ type: Input
112
+ }], className: [{
113
+ type: Input
114
+ }], entries: [{
115
+ type: Input
116
+ }], required: [{
117
+ type: Input
118
+ }], idKey: [{
119
+ type: Input
120
+ }], displayKey: [{
121
+ type: Input
122
+ }] } });
123
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWQtc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2lucHV0L3NyYy9zZWxlY3QvbWQtc2VsZWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3hFLE9BQU8sRUFBdUIsaUJBQWlCLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFFaEQsT0FBTyxFQUFDLGlCQUFpQixFQUFnQixNQUFNLCtDQUErQyxDQUFDOzs7Ozs7OztBQXFCL0YsTUFBTSxPQUFPLGlCQUFpQjtJQWlCNUIsWUFBb0IsaUJBQW9DLEVBQVUsSUFBZ0I7UUFBOUQsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUFVLFNBQUksR0FBSixJQUFJLENBQVk7UUFmNUMsY0FBUyxHQUFXLEVBQUUsQ0FBQztRQU9wRCxhQUFRLEdBQVksS0FBSyxDQUFDO1FBQzFCLFVBQUssR0FBVyxJQUFJLENBQUM7UUFDckIsZUFBVSxHQUFXLFNBQVMsQ0FBQztRQUdoQyxxQkFBZ0IsR0FBd0IsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO1FBQ2pELHNCQUFpQixHQUFlLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztJQUVvQyxDQUFDO0lBRXRGLFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUM3QyxJQUFJLENBQUMsaUJBQWlCLENBQUMsNEJBQTRCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE9BQXdCLEVBQUUsRUFBRTtnQkFDbkcsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7WUFDekIsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO2FBQU0sSUFBSSxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE9BQWMsRUFBRSxFQUFFO2dCQUNuRCxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztZQUN6QixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7UUFFRCxJQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzdCLElBQUksQ0FBQyxTQUFTLElBQUksaUJBQWlCLENBQUM7UUFDdEMsQ0FBQzthQUFLLENBQUM7WUFDTCxJQUFJLENBQUMsU0FBUyxHQUFHLGdCQUFnQixDQUFDO1FBQ3BDLENBQUM7SUFDSCxDQUFDO0lBRUQsSUFBVyxLQUFLO1FBQ2QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxJQUFXLEtBQUssQ0FBQyxRQUFnQjtRQUMvQixJQUFJLENBQUMsTUFBTSxHQUFHLFFBQVEsQ0FBQztRQUN2QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVNLE1BQU07UUFDWCxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRU0sVUFBVSxDQUFDLEtBQWE7UUFDN0IsSUFBSSxLQUFLLEtBQUssSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3pCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ3JCLENBQUM7SUFDSCxDQUFDO0lBRU0sZ0JBQWdCLENBQUMsUUFBNkI7UUFDbkQsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFFBQVEsQ0FBQztJQUNuQyxDQUFDO0lBR00saUJBQWlCLENBQUMsUUFBb0I7UUFDM0MsSUFBSSxDQUFDLGlCQUFpQixHQUFHLFFBQVEsQ0FBQztJQUNwQyxDQUFDOzhHQS9EVSxpQkFBaUI7a0dBQWpCLGlCQUFpQixrU0FSakI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLGlCQUFpQixDQUFDO2dCQUNoRCxLQUFLLEVBQUUsSUFBSTthQUNaO1NBQ0YsMEJBZlM7Ozs7Ozs7O0dBUVQ7OzJGQVNVLGlCQUFpQjtrQkFuQjdCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFFBQVEsRUFBRTs7Ozs7Ozs7R0FRVDtvQkFDRCxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsa0JBQWtCLENBQUM7NEJBQ2hELEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGO2lCQUNGOytHQUd1QyxTQUFTO3NCQUE5QyxXQUFXO3VCQUFDLE9BQU87O3NCQUFHLEtBQUs7dUJBQUMsT0FBTztnQkFFM0IsSUFBSTtzQkFBWixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxHQUFHO3NCQUFYLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBmb3J3YXJkUmVmLCBIb3N0QmluZGluZywgSW5wdXR9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHtIdHRwQ2xpZW50fSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcclxuXHJcbmltcG9ydCB7RGljdGlvbmFyeVNlcnZpY2UsIERyb3Bkb3duRW50cnl9IGZyb20gXCJAaHVudHNtYW4tY2FuY2VyLWluc3RpdHV0ZS9kaWN0aW9uYXJ5LXNlcnZpY2VcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImhjaS1tZC1zZWxlY3RcIixcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPG1hdC1mb3JtLWZpZWxkPlxyXG4gICAgICA8bWF0LWxhYmVsPnt7bGFiZWx9fTwvbWF0LWxhYmVsPlxyXG4gICAgICA8bWF0LXNlbGVjdCBbKHZhbHVlKV09XCJ2YWx1ZVwiIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiPlxyXG4gICAgICAgIDxtYXQtb3B0aW9uICpuZ0lmPVwiIXJlcXVpcmVkXCIgW3ZhbHVlXT1cInVuZGVmaW5lZFwiPjwvbWF0LW9wdGlvbj5cclxuICAgICAgICA8bWF0LW9wdGlvbiAqbmdGb3I9XCJsZXQgcm93IG9mIGVudHJpZXNcIiBbdmFsdWVdPVwicm93W2lkS2V5XVwiPnt7IHJvd1tkaXNwbGF5S2V5XSB9fTwvbWF0LW9wdGlvbj5cclxuICAgICAgPC9tYXQtc2VsZWN0PlxyXG4gICAgPC9tYXQtZm9ybS1maWVsZD5cclxuICBgLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gTWRTZWxlY3RDb21wb25lbnQpLFxyXG4gICAgICBtdWx0aTogdHJ1ZVxyXG4gICAgfVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIE1kU2VsZWN0Q29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xyXG5cclxuICBASG9zdEJpbmRpbmcoXCJjbGFzc1wiKSBASW5wdXQoXCJjbGFzc1wiKSBjbGFzc0xpc3Q6IHN0cmluZyA9IFwiXCI7XHJcblxyXG4gIEBJbnB1dCgpIG5hbWU6IHN0cmluZztcclxuICBASW5wdXQoKSBsYWJlbDogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIHVybDogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGNsYXNzTmFtZTogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGVudHJpZXM6IERyb3Bkb3duRW50cnlbXTtcclxuICBASW5wdXQoKSByZXF1aXJlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIGlkS2V5OiBzdHJpbmcgPSBcImlkXCI7XHJcbiAgQElucHV0KCkgZGlzcGxheUtleTogc3RyaW5nID0gXCJkaXNwbGF5XCI7XHJcblxyXG4gIHByaXZhdGUgX3ZhbHVlOiBudW1iZXI7XHJcbiAgcHJpdmF0ZSBvbkNoYW5nZUNhbGxiYWNrOiAoXzogbnVtYmVyKSA9PiB2b2lkID0gKCkgPT4ge307XHJcbiAgcHJpdmF0ZSBvblRvdWNoZWRDYWxsYmFjazogKCkgPT4gdm9pZCA9ICgpID0+IHt9O1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRpY3Rpb25hcnlTZXJ2aWNlOiBEaWN0aW9uYXJ5U2VydmljZSwgcHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50KSB7fVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLnVybCAmJiB0aGlzLnVybC5pbmRleE9mKFwiL1wiKSA9PT0gLTEpIHtcclxuICAgICAgdGhpcy5kaWN0aW9uYXJ5U2VydmljZS5nZXREaWN0aW9uYXJ5RHJvcGRvd25FbnRyaWVzKHRoaXMudXJsKS5zdWJzY3JpYmUoKGVudHJpZXM6IERyb3Bkb3duRW50cnlbXSkgPT4ge1xyXG4gICAgICAgIHRoaXMuZW50cmllcyA9IGVudHJpZXM7XHJcbiAgICAgIH0pO1xyXG4gICAgfSBlbHNlIGlmICh0aGlzLnVybCkge1xyXG4gICAgICB0aGlzLmh0dHAuZ2V0KHRoaXMudXJsKS5zdWJzY3JpYmUoKGVudHJpZXM6IGFueVtdKSA9PiB7XHJcbiAgICAgICAgdGhpcy5lbnRyaWVzID0gZW50cmllcztcclxuICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgaWYodGhpcy5jbGFzc0xpc3QubGVuZ3RoID4gMCkge1xyXG4gICAgICB0aGlzLmNsYXNzTGlzdCArPSBcIiBtYXRlcmlhbC1pbnB1dFwiO1xyXG4gICAgfWVsc2Uge1xyXG4gICAgICB0aGlzLmNsYXNzTGlzdCA9IFwibWF0ZXJpYWwtaW5wdXRcIjtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgdmFsdWUoKTogbnVtYmVyIHtcclxuICAgIHJldHVybiB0aGlzLl92YWx1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzZXQgdmFsdWUobmV3VmFsdWU6IG51bWJlcikge1xyXG4gICAgdGhpcy5fdmFsdWUgPSBuZXdWYWx1ZTtcclxuICAgIHRoaXMub25DaGFuZ2VDYWxsYmFjayhuZXdWYWx1ZSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25CbHVyKCkge1xyXG4gICAgdGhpcy5vblRvdWNoZWRDYWxsYmFjaygpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHdyaXRlVmFsdWUodmFsdWU6IG51bWJlcikge1xyXG4gICAgaWYgKHZhbHVlICE9PSB0aGlzLnZhbHVlKSB7XHJcbiAgICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyByZWdpc3Rlck9uQ2hhbmdlKGNhbGxiYWNrOiAoXzogbnVtYmVyKSA9PiB2b2lkKSB7XHJcbiAgICB0aGlzLm9uQ2hhbmdlQ2FsbGJhY2sgPSBjYWxsYmFjaztcclxuICB9XHJcblxyXG5cclxuICBwdWJsaWMgcmVnaXN0ZXJPblRvdWNoZWQoY2FsbGJhY2s6ICgpID0+IHZvaWQpIHtcclxuICAgIHRoaXMub25Ub3VjaGVkQ2FsbGJhY2sgPSBjYWxsYmFjaztcclxuICB9XHJcbn1cclxuIl19