@datarailsshared/datarailsshared 1.4.121 → 1.4.123

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 (50) hide show
  1. package/bundles/datarailsshared-datarailsshared.umd.js +526 -305
  2. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  3. package/datarailsshared-datarailsshared-1.4.123.tgz +0 -0
  4. package/datarailsshared-datarailsshared.d.ts +17 -14
  5. package/datarailsshared-datarailsshared.metadata.json +1 -1
  6. package/esm2015/datarailsshared-datarailsshared.js +18 -15
  7. package/esm2015/lib/date-tags/date-tag.module.js +5 -18
  8. package/esm2015/lib/date-tags/day-tag/day-tag.component.js +28 -21
  9. package/esm2015/lib/date-tags/forecast-tag/forecast-tag.component.js +23 -18
  10. package/esm2015/lib/date-tags/month-tag/month-tag.component.js +25 -23
  11. package/esm2015/lib/date-tags/quarter-tag/quarter-tag.component.js +26 -21
  12. package/esm2015/lib/date-tags/week-tag/week-tag.component.js +27 -63
  13. package/esm2015/lib/date-tags/year-tag/year-tag.component.js +22 -28
  14. package/esm2015/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.js +1 -1
  15. package/esm2015/lib/dr-dialog/components/dialog-wrapper/dialog-wrapper.component.js +1 -1
  16. package/esm2015/lib/dr-dialog/interfaces/dialog-data.js +2 -1
  17. package/esm2015/lib/dr-dynamic-tag/dr-dynamic-tag.component.js +91 -0
  18. package/esm2015/lib/dr-dynamic-tag/dr-dynamic-tag.module.js +19 -0
  19. package/esm2015/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.js +11 -2
  20. package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +7 -3
  21. package/esm2015/lib/dr-inputs/dr-inputs.module.js +4 -2
  22. package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +7 -2
  23. package/esm2015/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.js +65 -0
  24. package/esm2015/lib/dr-tags/dr-tag.component.js +102 -6
  25. package/esm2015/lib/dr-tags/dr-tag.module.js +4 -2
  26. package/esm2015/lib/list-tags/list-tag.component.js +3 -8
  27. package/esm2015/lib/list-tags/list-tag.module.js +3 -9
  28. package/esm2015/lib/models/serverTags.js +8 -2
  29. package/esm2015/public-api.js +2 -1
  30. package/fesm2015/datarailsshared-datarailsshared.js +538 -289
  31. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  32. package/lib/date-tags/day-tag/day-tag.component.d.ts +3 -5
  33. package/lib/date-tags/forecast-tag/forecast-tag.component.d.ts +1 -0
  34. package/lib/date-tags/month-tag/month-tag.component.d.ts +2 -6
  35. package/lib/date-tags/quarter-tag/quarter-tag.component.d.ts +2 -4
  36. package/lib/date-tags/week-tag/week-tag.component.d.ts +2 -9
  37. package/lib/date-tags/year-tag/year-tag.component.d.ts +2 -6
  38. package/lib/dr-dialog/interfaces/dialog-data.d.ts +2 -1
  39. package/lib/dr-dynamic-tag/dr-dynamic-tag.component.d.ts +20 -0
  40. package/lib/dr-dynamic-tag/dr-dynamic-tag.module.d.ts +2 -0
  41. package/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.d.ts +2 -0
  42. package/lib/dr-inputs/dr-input/dr-input.component.d.ts +2 -0
  43. package/lib/dr-inputs/dr-select/dr-select.component.d.ts +2 -0
  44. package/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.d.ts +21 -0
  45. package/lib/dr-tags/dr-tag.component.d.ts +17 -1
  46. package/lib/list-tags/list-tag.component.d.ts +0 -3
  47. package/lib/models/serverTags.d.ts +13 -1
  48. package/package.json +1 -1
  49. package/public-api.d.ts +1 -1
  50. package/datarailsshared-datarailsshared-1.4.121.tgz +0 -0
@@ -0,0 +1,91 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { find as _find, isNumber as _isNumber, isObject as _isObject, isNil as _isNil, map as _map } from 'lodash';
3
+ import * as moment from 'moment';
4
+ export class DrDynamicTagComponent {
5
+ constructor() {
6
+ this.tagChange = new EventEmitter();
7
+ this.tagAdd = new EventEmitter();
8
+ }
9
+ ngOnChanges(changes) {
10
+ this.updateDynamicTagValues();
11
+ }
12
+ onTagChanged($event) {
13
+ var _a, _b;
14
+ const resultEvent = {
15
+ id: this.tagConfig.id,
16
+ name: this.tagConfig.name,
17
+ value: $event,
18
+ };
19
+ if (!_isNil((_a = this.selectedTag) === null || _a === void 0 ? void 0 : _a.locked)) {
20
+ resultEvent.locked = this.selectedTag.locked;
21
+ }
22
+ if (!_isNil((_b = this.selectedTag) === null || _b === void 0 ? void 0 : _b.label)) {
23
+ resultEvent.label = this.selectedTag.label;
24
+ }
25
+ this.tagChange.emit(resultEvent);
26
+ }
27
+ onDynamicValueAdd($event) {
28
+ var _a;
29
+ const isPrimitiveDataSource = !_isObject((_a = Object.values(this.values)) === null || _a === void 0 ? void 0 : _a[0]);
30
+ const parentValueKey = this.getParentValueKey();
31
+ const parentValues = this.values[parentValueKey] || [];
32
+ if (isPrimitiveDataSource) {
33
+ this.values[parentValueKey] = [$event, ...parentValues];
34
+ }
35
+ else {
36
+ this.values[parentValueKey] = [{ value: $event }, ...parentValues];
37
+ }
38
+ this.selectedDynamicTag = $event;
39
+ this.currentValues = this.values[parentValueKey];
40
+ this.onTagChanged($event);
41
+ this.tagAdd.emit($event);
42
+ }
43
+ updateDynamicTagValues() {
44
+ var _a;
45
+ const parentValueKey = this.getParentValueKey();
46
+ this.currentValues = this.values[parentValueKey];
47
+ this.selectedDynamicTag = this.getSelectedDynamicTag(this.currentValues, (_a = this.selectedTag) === null || _a === void 0 ? void 0 : _a.value);
48
+ this.onTagChanged(this.selectedDynamicTag);
49
+ }
50
+ getSelectedDynamicTag(currentValues, selectedValue) {
51
+ if (!(currentValues === null || currentValues === void 0 ? void 0 : currentValues.length))
52
+ return null;
53
+ if (_isObject(currentValues[0])) {
54
+ const valueFromConfig = _find(currentValues, { value: selectedValue });
55
+ const favoriteValue = _find(currentValues, { is_favorite: true });
56
+ return (valueFromConfig || favoriteValue || currentValues[0]).value;
57
+ }
58
+ const valueFromConfig = _find(currentValues, (value) => value === selectedValue);
59
+ return (valueFromConfig || currentValues[0]);
60
+ }
61
+ getParentValueKey() {
62
+ return _map(this.connectedTags, this.tryToParseParentValue).join('__');
63
+ }
64
+ tryToParseParentValue(connectedTags) {
65
+ if (_isNumber(connectedTags.value)) {
66
+ const momentData = moment.unix(connectedTags.value);
67
+ const convertedParentValue = momentData.get('year'); // TODO: add input prop (selectedTimeDimension) or Format
68
+ if (momentData.isValid() && convertedParentValue) {
69
+ return convertedParentValue;
70
+ }
71
+ }
72
+ return connectedTags.value;
73
+ }
74
+ }
75
+ DrDynamicTagComponent.decorators = [
76
+ { type: Component, args: [{
77
+ selector: 'dr-dynamic-tag',
78
+ template: "<p class=\"dynamic-tag__label\">{{ tagConfig.name }}</p>\n<dr-select [(ngModel)]=\"selectedDynamicTag\"\n bindLabel=\"value\"\n bindValue=\"value\"\n [items]=\"currentValues\"\n (ngModelChange)=\"onTagChanged($event)\">\n <ng-template #optionHeaderTemplate *ngIf=\"isDynamicTagAddEnabled\">\n <dr-select-add-item bindValue=\"value\"\n [values]=\"currentValues\"\n [dynamicAddLabel]=\"' Add new ' + tagConfig.name\"\n (dynamicValueAdded)=\"onDynamicValueAdd($event)\"></dr-select-add-item>\n </ng-template>\n <ng-template #labelTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--label\">\n <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n <ng-template #optionTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--option\">\n <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n</dr-select>\n",
79
+ styles: [".dynamic-tag__label{margin:0 0 4px;color:#0c142b;font-size:14px;font-weight:400;line-height:22px}.dynamic-tag__field,.dynamic-tag__field--option,.dynamic-tag__field--label{cursor:pointer;height:24px}.dynamic-tag__field--option{width:100%;display:flex;justify-content:space-between;align-items:center}.dynamic-tag__field--label{display:flex;align-items:center}.dynamic-tag__field--label>.dynamic-tag__field__icon{position:absolute;right:25px}.dynamic-tag__field--label>dynamic-tag__field__text{margin:0}.dr-icon-star-fill{color:#f0bc57}\n"]
80
+ },] }
81
+ ];
82
+ DrDynamicTagComponent.propDecorators = {
83
+ values: [{ type: Input }],
84
+ tagConfig: [{ type: Input }],
85
+ selectedTag: [{ type: Input }],
86
+ connectedTags: [{ type: Input }],
87
+ isDynamicTagAddEnabled: [{ type: Input }],
88
+ tagChange: [{ type: Output }],
89
+ tagAdd: [{ type: Output }]
90
+ };
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dynamic-tag.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dynamic-tag/dr-dynamic-tag.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EAET,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,IAAI,IAAI,KAAK,EAAE,QAAQ,IAAI,SAAS,EAAE,QAAQ,IAAI,SAAS,EAAE,KAAK,IAAI,MAAM,EAAE,GAAG,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEnH,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAOjC,MAAM,OAAO,qBAAqB;IALlC;QAcc,cAAS,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAC3E,WAAM,GAAmC,IAAI,YAAY,EAAoB,CAAC;IAiF5F,CAAC;IA5EU,WAAW,CAAC,OAAsB;QACrC,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAEM,YAAY,CAAC,MAAc;;QAC9B,MAAM,WAAW,GAAkB;YAC/B,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;YACrB,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI;YACzB,KAAK,EAAE,MAAM;SAChB,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,MAAA,IAAI,CAAC,WAAW,0CAAE,MAAM,CAAC,EAAE;YACnC,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;SAChD;QAED,IAAI,CAAC,MAAM,CAAC,MAAA,IAAI,CAAC,WAAW,0CAAE,KAAK,CAAC,EAAE;YAClC,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;SAC9C;QAED,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACrC,CAAC;IAEM,iBAAiB,CAAC,MAAc;;QACnC,MAAM,qBAAqB,GAAG,CAAC,SAAS,CAAC,MAAA,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,0CAAG,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAChD,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QAEvD,IAAI,qBAAqB,EAAE;YACvB,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC;SAC3D;aAAM;YACH,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,GAAG,YAAY,CAAC,CAAC;SACtE;QAED,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC;QAEjC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QACjD,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAEO,sBAAsB;;QAC1B,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAChD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QACjD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,aAAa,EAAE,MAAA,IAAI,CAAC,WAAW,0CAAE,KAAK,CAAC,CAAC;QAClG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC/C,CAAC;IAEO,qBAAqB,CAAC,aAAiC,EAAE,aAA8B;QAC3F,IAAI,CAAC,CAAA,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,MAAM,CAAA;YAAE,OAAO,IAAI,CAAC;QAExC,IAAI,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE;YAC7B,MAAM,eAAe,GAAG,KAAK,CAAC,aAAa,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE,CAAgB,CAAC;YACtF,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAgB,CAAC;YACjF,OAAO,CAAC,eAAe,IAAI,aAAa,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;SACvE;QAED,MAAM,eAAe,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,aAAa,CAAC,CAAC;QACjF,OAAO,CAAC,eAAe,IAAI,aAAa,CAAC,CAAC,CAAC,CAAW,CAAC;IAC3D,CAAC;IAEO,iBAAiB;QACrB,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3E,CAAC;IAEO,qBAAqB,CAAC,aAA4B;QACtD,IAAI,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE;YAChC,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACpD,MAAM,oBAAoB,GAAG,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,yDAAyD;YAE9G,IAAI,UAAU,CAAC,OAAO,EAAE,IAAI,oBAAoB,EAAE;gBAC9C,OAAO,oBAAoB,CAAC;aAC/B;SACJ;QAED,OAAO,aAAa,CAAC,KAAK,CAAC;IAC/B,CAAC;;;YA/FJ,SAAS,SAAC;gBACP,QAAQ,EAAE,gBAAgB;gBAC1B,iyCAA8C;;aAEjD;;;qBAGI,KAAK;wBACL,KAAK;0BACL,KAAK;4BAEL,KAAK;qCACL,KAAK;wBAEL,MAAM;qBACN,MAAM","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChanges\n} from '@angular/core';\nimport { find as _find, isNumber as _isNumber, isObject as _isObject, isNil as _isNil, map as _map } from 'lodash';\nimport { IDynamicTag, ITag, ITagForServer, TDynamicTag, TDynamicTagValue } from '../models/serverTags';\nimport * as moment from 'moment';\n\n@Component({\n    selector: 'dr-dynamic-tag',\n    templateUrl: './dr-dynamic-tag.component.html',\n    styleUrls: ['./dr-dynamic-tag.component.scss']\n})\nexport class DrDynamicTagComponent implements OnChanges {\n\n    @Input() public values: TDynamicTag;\n    @Input() public tagConfig: ITag;\n    @Input() public selectedTag: ITagForServer;\n\n    @Input() public connectedTags: ITagForServer[];\n    @Input() public isDynamicTagAddEnabled: boolean;\n\n    @Output() tagChange: EventEmitter<ITagForServer> = new EventEmitter<ITagForServer>();\n    @Output() tagAdd: EventEmitter<TDynamicTagValue> = new EventEmitter<TDynamicTagValue>();\n\n    public selectedDynamicTag: TDynamicTagValue;\n    public currentValues: TDynamicTagValue[];\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        this.updateDynamicTagValues();\n    }\n\n    public onTagChanged($event: string): void {\n        const resultEvent: ITagForServer = {\n            id: this.tagConfig.id,\n            name: this.tagConfig.name,\n            value: $event,\n        };\n\n        if (!_isNil(this.selectedTag?.locked)) {\n            resultEvent.locked = this.selectedTag.locked;\n        }\n\n        if (!_isNil(this.selectedTag?.label)) {\n            resultEvent.label = this.selectedTag.label;\n        }\n\n        this.tagChange.emit(resultEvent);\n    }\n\n    public onDynamicValueAdd($event: string) {\n        const isPrimitiveDataSource = !_isObject(Object.values(this.values)?.[0]);\n        const parentValueKey = this.getParentValueKey();\n        const parentValues = this.values[parentValueKey] || [];\n\n        if (isPrimitiveDataSource) {\n            this.values[parentValueKey] = [$event, ...parentValues];\n        } else {\n            this.values[parentValueKey] = [{ value: $event }, ...parentValues];\n        }\n\n        this.selectedDynamicTag = $event;\n\n        this.currentValues = this.values[parentValueKey];\n        this.onTagChanged($event);\n        this.tagAdd.emit($event);\n    }\n\n    private updateDynamicTagValues(): void {\n        const parentValueKey = this.getParentValueKey();\n        this.currentValues = this.values[parentValueKey];\n        this.selectedDynamicTag = this.getSelectedDynamicTag(this.currentValues, this.selectedTag?.value);\n        this.onTagChanged(this.selectedDynamicTag);\n    }\n\n    private getSelectedDynamicTag(currentValues: TDynamicTagValue[], selectedValue: string | number): string {\n        if (!currentValues?.length) return null;\n\n        if (_isObject(currentValues[0])) {\n            const valueFromConfig = _find(currentValues, { value: selectedValue }) as IDynamicTag;\n            const favoriteValue = _find(currentValues, { is_favorite: true }) as IDynamicTag;\n            return (valueFromConfig || favoriteValue || currentValues[0]).value;\n        }\n\n        const valueFromConfig = _find(currentValues, (value) => value === selectedValue);\n        return (valueFromConfig || currentValues[0]) as string;\n    }\n\n    private getParentValueKey(): string {\n        return _map(this.connectedTags, this.tryToParseParentValue).join('__');\n    }\n\n    private tryToParseParentValue(connectedTags: ITagForServer) {\n        if (_isNumber(connectedTags.value)) {\n            const momentData = moment.unix(connectedTags.value);\n            const convertedParentValue = momentData.get('year'); // TODO: add input prop (selectedTimeDimension) or Format\n\n            if (momentData.isValid() && convertedParentValue) {\n                return convertedParentValue;\n            }\n        }\n\n        return connectedTags.value;\n    }\n}\n"]}
@@ -0,0 +1,19 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DrDynamicTagComponent } from './dr-dynamic-tag.component';
4
+ import { DrInputsModule } from '../dr-inputs/dr-inputs.module';
5
+ import { FormsModule } from '@angular/forms';
6
+ export class DrDynamicTagModule {
7
+ }
8
+ DrDynamicTagModule.decorators = [
9
+ { type: NgModule, args: [{
10
+ declarations: [DrDynamicTagComponent],
11
+ imports: [
12
+ CommonModule,
13
+ DrInputsModule,
14
+ FormsModule,
15
+ ],
16
+ exports: [DrDynamicTagComponent]
17
+ },] }
18
+ ];
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHluYW1pYy10YWcubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZHluYW1pYy10YWcvZHItZHluYW1pYy10YWcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ25FLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFZN0MsTUFBTSxPQUFPLGtCQUFrQjs7O1lBVDlCLFFBQVEsU0FBQztnQkFDTixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztnQkFDckMsT0FBTyxFQUFFO29CQUNMLFlBQVk7b0JBQ1osY0FBYztvQkFDZCxXQUFXO2lCQUNkO2dCQUNELE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2FBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEckR5bmFtaWNUYWdDb21wb25lbnQgfSBmcm9tICcuL2RyLWR5bmFtaWMtdGFnLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcklucHV0c01vZHVsZSB9IGZyb20gJy4uL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbRHJEeW5hbWljVGFnQ29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgRHJJbnB1dHNNb2R1bGUsXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW0RyRHluYW1pY1RhZ0NvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgRHJEeW5hbWljVGFnTW9kdWxlIHtcbn1cbiJdfQ==
@@ -6,6 +6,7 @@ import { DrDatePickerService } from '../services/dr-date-picker.service';
6
6
  import { Subject } from 'rxjs';
7
7
  import { takeUntil } from 'rxjs/operators';
8
8
  import { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';
9
+ // @ts-ignore
9
10
  const moment = require('moment');
10
11
  const noop = () => {
11
12
  };
@@ -32,6 +33,13 @@ export class DrDatePickerComponent {
32
33
  this.destroyed$ = new Subject();
33
34
  this.onTouchedCallback = noop;
34
35
  this.onChangeCallback = noop;
36
+ // Should be as arrow function to avoid lose scope
37
+ this.dateFilter = (moment) => {
38
+ if (this.datepickerFilter && moment) {
39
+ return this.datepickerFilter(moment);
40
+ }
41
+ return true;
42
+ };
35
43
  datePickerService.updatedQuarter$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {
36
44
  this.setValueFromMoment(value);
37
45
  });
@@ -174,7 +182,7 @@ export class DrDatePickerComponent {
174
182
  DrDatePickerComponent.decorators = [
175
183
  { type: Component, args: [{
176
184
  selector: 'dr-date-picker',
177
- template: "<i class=\"dr-icon-schedule\"></i>\n<input [(ngModel)]=\"value\"\n (click)=\"datePicker.open()\"\n [matDatepicker]=\"datePicker\"\n [placeholder]=\"placeholder\"\n [drDatePickerFormat]=\"datePickerService.format$ | async\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\"/>\n<mat-datepicker #datePicker\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH)\">\n</mat-datepicker>\n",
185
+ template: "<i class=\"dr-icon-schedule\"></i>\n<input [(ngModel)]=\"value\"\n (click)=\"datePicker.open()\"\n [matDatepicker]=\"datePicker\"\n [matDatepickerFilter]=\"dateFilter\"\n [placeholder]=\"placeholder\"\n [drDatePickerFormat]=\"datePickerService.format$ | async\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\"/>\n<mat-datepicker #datePicker\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH)\">\n</mat-datepicker>\n",
178
186
  changeDetection: ChangeDetectionStrategy.OnPush,
179
187
  providers: [
180
188
  { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true },
@@ -195,7 +203,8 @@ DrDatePickerComponent.propDecorators = {
195
203
  periodPosition: [{ type: Input }],
196
204
  placeholder: [{ type: Input }],
197
205
  fiscalYearMonthsModifier: [{ type: Input }],
206
+ datepickerFilter: [{ type: Input }],
198
207
  datePicker: [{ type: ViewChild, args: ['datePicker',] }]
199
208
  };
200
209
  export { ɵ0 };
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Input,\n    OnDestroy,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CalendarView, DatePickerPeriodPosition, TimeframeOption } from '../../../models/datePicker';\nimport { Moment } from 'moment';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';\nimport { MatCalendarView } from '@angular/material/datepicker';\nimport * as _ from 'lodash';\n\nconst moment = require('moment');\nconst noop = () => {\n};\n\n@Component({\n    selector: 'dr-date-picker',\n    templateUrl: './dr-date-picker.component.html',\n    styleUrls: ['./dr-date-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true },\n        { provide: DrDatePickerService }\n    ],\n})\nexport class DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n\n    @Input() set format(value) {\n        this.datePickerService.updateTimeframeAndFormat(value);\n    }\n\n    @Input() set min(minDate: number) {\n        this._min = moment.unix(minDate).utc();\n    }\n\n    @Input() set max(maxDate: number) {\n        this._max = moment.unix(maxDate).utc();\n    }\n\n    // Whether to transform date, taking end, start, middle of preiod (i.e. set middle of month if timeframe='month')\n    @Input() periodPosition: DatePickerPeriodPosition = DatePickerPeriodPosition.DEFAULT;\n\n    @Input() placeholder = 'Select';\n\n    @Input() fiscalYearMonthsModifier = 0;\n\n    @ViewChild('datePicker') public datePicker: any;\n\n    public calendarViewsTimeframeMapping: any = {\n        year: 'multi-year',\n        month: 'year',\n        quarter: 'none',\n        day: 'month',\n    };\n\n    public customHeader = DrDatePickerCustomHeaderComponent;\n    public readonly = true;\n    public _min: Moment;\n    public _max: Moment;\n    public readonly timeframeOption = TimeframeOption;\n\n    public get value(): Moment {\n        return this.innerValue;\n    }\n\n    public set value(v: Moment) {\n        if (v !== this.innerValue) {\n            this.setValueFromMoment(v);\n        }\n        this.cdr.markForCheck();\n    }\n\n    protected innerValue: Moment = null;\n    protected destroyed$ = new Subject<void>();\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService\n    ) {\n        datePickerService.updatedQuarter$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.datePickerService.fiscalYearMonthsModifier = this.fiscalYearMonthsModifier;\n        this.datePickerService.datePickerInstance = this.datePicker;\n        this.datePicker.startView = this.calendarViewsTimeframeMapping[this.datePickerService.timeframe];\n    }\n\n    ngOnDestroy() {\n        this.destroyed$.next();\n        this.destroyed$.complete();\n    }\n\n    /**\n     * Updating component inner value according to datepicker timeframe (day, month etc.)\n     * and date position in period (start, end, middle)\n     */\n    tryToNormalaizeTimeframe(): void {\n        const timeframe = this.datePickerService.timeframe;\n        switch (this.periodPosition) {\n            case DatePickerPeriodPosition.START_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.END_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setEndOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setEndOfQuarter(this.innerValue, 4);\n                } else {\n                    this.innerValue.endOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.MIDDLE_OF_PERIOD:\n                let endOfPeriod: Moment;\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                    this.datePickerService.setEndOfCurrentQuarter(endOfPeriod);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                    this.datePickerService.setEndOfQuarter(endOfPeriod, 4);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                    endOfPeriod = this.innerValue.clone().endOf(timeframe);\n                }\n                const diff = endOfPeriod.diff(this.innerValue, 'seconds');\n                this.innerValue.add(diff / 2 + 1, 'seconds');\n                break;\n            default:\n                this.innerValue.startOf(timeframe);\n                break;\n        }\n    }\n\n    public chosenPeriodHandler(chosenDate: Moment, timeframe: TimeframeOption) {\n\n        if (timeframe === TimeframeOption.YEAR) {\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(chosenDate);\n        }\n\n        if (this.datePickerService.timeframe === TimeframeOption.QUARTER && timeframe === TimeframeOption.YEAR) {\n            this.datePickerService.calendarInstance.currentView = CalendarView.FOR_QUARTERS as MatCalendarView;\n            this.datePickerService.calendarInstance.activeDate = chosenDate;\n            this.cdr.detectChanges();\n        } else if (this.datePickerService.timeframe === timeframe) {\n            this.setValueFromMoment(chosenDate);\n            this.datePicker.close();\n        }\n    }\n\n    /**\n     * Setting value from outside of component via ngModel or formControl updates\n     */\n    public writeValue(value: number): void {\n        this.innerValue = value ? moment.unix(value).utc() : value;\n        if (this.innerValue) {\n            this.tryToNormalaizeTimeframe();\n        }\n        this.cdr.markForCheck();\n    }\n\n    public onTouchedCallback: () => void = noop;\n    public onChangeCallback: (_: any) => void = noop;\n\n    public registerOnChange(fn: any): void {\n        this.onChangeCallback = fn;\n    }\n\n    public registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    /**\n     * Set inner value from Moment and propagate\n     *\n     * @param momentDate\n     */\n    protected setValueFromMoment(momentDate: Moment) {\n        this.setValue(momentDate.unix());\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n\n        // isValueUpdating is required for manage clicks on same dates: if isValueUpdating - true then\n        // days are different and subscription on calendar day click action won't trigger Accessor ngModel update\n        // one more time\n        this.datePickerService.isValueUpdating = true;\n        this.writeValue(timestamp);\n        this.onChangeCallback(this.innerValue.unix());\n        setTimeout(() => {\n            this.datePickerService.isValueUpdating = false;\n        });\n    }\n}\n"]}
210
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Input,\n    OnDestroy,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CalendarView, DatePickerPeriodPosition, TimeframeOption } from '../../../models/datePicker';\nimport { Moment } from 'moment';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';\nimport { MatCalendarView } from '@angular/material/datepicker';\n\n// @ts-ignore\nconst moment = require('moment');\nconst noop = () => {\n};\n\n@Component({\n    selector: 'dr-date-picker',\n    templateUrl: './dr-date-picker.component.html',\n    styleUrls: ['./dr-date-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true },\n        { provide: DrDatePickerService }\n    ],\n})\nexport class DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n\n    @Input() set format(value) {\n        this.datePickerService.updateTimeframeAndFormat(value);\n    }\n\n    @Input() set min(minDate: number) {\n        this._min = moment.unix(minDate).utc();\n    }\n\n    @Input() set max(maxDate: number) {\n        this._max = moment.unix(maxDate).utc();\n    }\n\n    // Whether to transform date, taking end, start, middle of preiod (i.e. set middle of month if timeframe='month')\n    @Input() periodPosition: DatePickerPeriodPosition = DatePickerPeriodPosition.DEFAULT;\n\n    @Input() placeholder = 'Select';\n\n    @Input() fiscalYearMonthsModifier = 0;\n\n    @Input() datepickerFilter: (moment: Moment) => boolean;\n\n    @ViewChild('datePicker') public datePicker: any;\n\n    public calendarViewsTimeframeMapping: any = {\n        year: 'multi-year',\n        month: 'year',\n        quarter: 'none',\n        day: 'month',\n    };\n\n    public customHeader = DrDatePickerCustomHeaderComponent;\n    public readonly = true;\n    public _min: Moment;\n    public _max: Moment;\n    public readonly timeframeOption = TimeframeOption;\n\n    public get value(): Moment {\n        return this.innerValue;\n    }\n\n    public set value(v: Moment) {\n        if (v !== this.innerValue) {\n            this.setValueFromMoment(v);\n        }\n        this.cdr.markForCheck();\n    }\n\n    protected innerValue: Moment = null;\n    protected destroyed$ = new Subject<void>();\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService\n    ) {\n        datePickerService.updatedQuarter$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.datePickerService.fiscalYearMonthsModifier = this.fiscalYearMonthsModifier;\n        this.datePickerService.datePickerInstance = this.datePicker;\n        this.datePicker.startView = this.calendarViewsTimeframeMapping[this.datePickerService.timeframe];\n    }\n\n    ngOnDestroy() {\n        this.destroyed$.next();\n        this.destroyed$.complete();\n    }\n\n    /**\n     * Updating component inner value according to datepicker timeframe (day, month etc.)\n     * and date position in period (start, end, middle)\n     */\n    tryToNormalaizeTimeframe(): void {\n        const timeframe = this.datePickerService.timeframe;\n        switch (this.periodPosition) {\n            case DatePickerPeriodPosition.START_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.END_OF_PERIOD:\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    this.datePickerService.setEndOfCurrentQuarter(this.innerValue);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    this.datePickerService.setEndOfQuarter(this.innerValue, 4);\n                } else {\n                    this.innerValue.endOf(timeframe);\n                }\n                break;\n            case DatePickerPeriodPosition.MIDDLE_OF_PERIOD:\n                let endOfPeriod: Moment;\n                if (this.datePickerService.timeframe === TimeframeOption.QUARTER) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfCurrentQuarter(this.innerValue);\n                    this.datePickerService.setEndOfCurrentQuarter(endOfPeriod);\n                } else if (this.datePickerService.timeframe === TimeframeOption.YEAR) {\n                    endOfPeriod = this.innerValue.clone();\n                    this.datePickerService.setStartOfQuarter(this.innerValue, 1);\n                    this.datePickerService.setEndOfQuarter(endOfPeriod, 4);\n                } else {\n                    this.innerValue.startOf(timeframe);\n                    endOfPeriod = this.innerValue.clone().endOf(timeframe);\n                }\n                const diff = endOfPeriod.diff(this.innerValue, 'seconds');\n                this.innerValue.add(diff / 2 + 1, 'seconds');\n                break;\n            default:\n                this.innerValue.startOf(timeframe);\n                break;\n        }\n    }\n\n    public chosenPeriodHandler(chosenDate: Moment, timeframe: TimeframeOption) {\n\n        if (timeframe === TimeframeOption.YEAR) {\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(chosenDate);\n        }\n\n        if (this.datePickerService.timeframe === TimeframeOption.QUARTER && timeframe === TimeframeOption.YEAR) {\n            this.datePickerService.calendarInstance.currentView = CalendarView.FOR_QUARTERS as MatCalendarView;\n            this.datePickerService.calendarInstance.activeDate = chosenDate;\n            this.cdr.detectChanges();\n        } else if (this.datePickerService.timeframe === timeframe) {\n            this.setValueFromMoment(chosenDate);\n            this.datePicker.close();\n        }\n    }\n\n    /**\n     * Setting value from outside of component via ngModel or formControl updates\n     */\n    public writeValue(value: number): void {\n        this.innerValue = value ? moment.unix(value).utc() : value;\n        if (this.innerValue) {\n            this.tryToNormalaizeTimeframe();\n        }\n        this.cdr.markForCheck();\n    }\n\n    public onTouchedCallback: () => void = noop;\n    public onChangeCallback: (_: any) => void = noop;\n\n    public registerOnChange(fn: any): void {\n        this.onChangeCallback = fn;\n    }\n\n    public registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    // Should be as arrow function to avoid lose scope\n    public dateFilter = (moment: Moment) => {\n        if (this.datepickerFilter && moment) {\n            return this.datepickerFilter(moment);\n        }\n\n        return true;\n    }\n\n    /**\n     * Set inner value from Moment and propagate\n     *\n     * @param momentDate\n     */\n    protected setValueFromMoment(momentDate: Moment) {\n        this.setValue(momentDate.unix());\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n\n        // isValueUpdating is required for manage clicks on same dates: if isValueUpdating - true then\n        // days are different and subscription on calendar day click action won't trigger Accessor ngModel update\n        // one more time\n        this.datePickerService.isValueUpdating = true;\n        this.writeValue(timestamp);\n        this.onChangeCallback(this.innerValue.unix());\n        setTimeout(() => {\n            this.datePickerService.isValueUpdating = false;\n        });\n    }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Output, Renderer2, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Output, Renderer2, ViewChild, } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { noop } from 'rxjs';
4
4
  export class DrInputComponent {
@@ -145,11 +145,14 @@ export class DrInputComponent {
145
145
  $event.stopPropagation();
146
146
  this.value = null;
147
147
  }
148
+ focus() {
149
+ this.inputElement.nativeElement.focus();
150
+ }
148
151
  }
149
152
  DrInputComponent.decorators = [
150
153
  { type: Component, args: [{
151
154
  selector: 'dr-input',
152
- template: "<ng-content select=\"[prefixIcon]\"></ng-content>\n<input [(ngModel)]=\"value\"\n (ngModelChange)=\"updateChanges()\"\n (ngModelDebounceChange)=\"ngModelDebounceChange.emit($event)\"\n (blur)=\"blur.emit(value); onTouched()\"\n [disabled]=\"_disabled\"\n [readonly]=\"readonly\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [name]=\"name\"\n [min]=\"min\"\n [max]=\"max\"\n [minLength]=\"minLength\"\n [maxlength]=\"maxlength\"\n [step]=\"step\"\n>\n<span *ngIf=\"value\" class=\"clear-icon\" (click)=\"onClear($event)\"></span>\n<span *ngIf=\"type === 'search'\" class=\"search-icon\" (click)=\"onSearchClicked($event)\"></span>\n<ng-content select=\"[suffixIcon]\"></ng-content>\n<button *ngIf=\"_buttonOptions.show || (_buttonOptions.showOnFocus && _buttonOptions.focusSet)\"\n (click)=\"onButtonClicked($event)\">\n {{_buttonOptions.text}}\n</button>\n",
155
+ template: "<ng-content select=\"[prefixIcon]\"></ng-content>\n<input #inputRef\n [(ngModel)]=\"value\"\n (ngModelChange)=\"updateChanges()\"\n (ngModelDebounceChange)=\"ngModelDebounceChange.emit($event)\"\n (blur)=\"blur.emit(value); onTouched()\"\n [disabled]=\"_disabled\"\n [readonly]=\"readonly\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [name]=\"name\"\n [min]=\"min\"\n [max]=\"max\"\n [minLength]=\"minLength\"\n [maxlength]=\"maxlength\"\n [step]=\"step\"\n>\n<span *ngIf=\"value\" class=\"clear-icon\" (click)=\"onClear($event)\"></span>\n<span *ngIf=\"type === 'search'\" class=\"search-icon\" (click)=\"onSearchClicked($event)\"></span>\n<ng-content select=\"[suffixIcon]\"></ng-content>\n<button *ngIf=\"_buttonOptions.show || (_buttonOptions.showOnFocus && _buttonOptions.focusSet)\"\n (click)=\"onButtonClicked($event)\">\n {{_buttonOptions.text}}\n</button>\n",
153
156
  providers: [{
154
157
  provide: NG_VALUE_ACCESSOR,
155
158
  useExisting: forwardRef(() => DrInputComponent),
@@ -183,8 +186,9 @@ DrInputComponent.propDecorators = {
183
186
  searchHandler: [{ type: Output }],
184
187
  clearHandler: [{ type: Output }],
185
188
  buttonHandler: [{ type: Output }],
189
+ inputElement: [{ type: ViewChild, args: ['inputRef',] }],
186
190
  prefixIcon: [{ type: ContentChild, args: ['prefix', { static: false },] }],
187
191
  suffixIcon: [{ type: ContentChild, args: ['suffix', { static: false },] }],
188
192
  tabindex: [{ type: HostBinding, args: ['tabindex',] }]
189
193
  };
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-input.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-input/dr-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { noop } from 'rxjs';\n\n@Component({\n    selector: 'dr-input',\n    templateUrl: './dr-input.component.html',\n    styleUrls: ['./dr-input.component.scss'],\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => DrInputComponent),\n        multi: true\n    }],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrInputComponent implements AfterViewInit, ControlValueAccessor, OnDestroy {\n    _clearable = false;\n\n    @Input() set disabled(value) {\n        this.setDisabledState(value);\n    }\n\n    @Input() set buttonOptions(value) {\n        if (value) {\n            this._buttonOptions = { ...this._buttonOptions, ...value };\n            if (this._buttonOptions?.show || this._buttonOptions?.showOnFocus) {\n                this._elementClass.push('with-button');\n            }\n        }\n        if (this._buttonOptions.showOnFocus) {\n            this.listenFunc = this.renderer.listen(this.elementRef.nativeElement, 'click', (event) => {\n                this._buttonOptions.focusSet = true;\n                this.cdr.markForCheck();\n            });\n            this.globalListenFunc = this.renderer.listen('document', 'click', event => {\n                if (event.target.parentNode !== this.elementRef.nativeElement) {\n                    if (this._buttonOptions.checkFocusOut(event.target, this.elementRef.nativeElement)) {\n                        this.onButtonClicked(event);\n                    }\n                }\n            });\n        }\n        this.cdr.markForCheck();\n    }\n\n    @Input() type = 'string';\n    @Input() name: string;\n    @Input() placeholder = '';\n    @Input() readonly = false;\n\n    @Input() set clearable(val) {\n        this._clearable = !!val;\n        if (this._clearable) {\n            this._elementClass.push('clearable');\n        } else {\n            this._elementClass = this._elementClass.filter(item => item !== 'clearable');\n        }\n        this.cdr.markForCheck();\n    }\n\n    @Input() min: number | string;\n    @Input() max: number | string;\n    @Input() minLength: number;\n    @Input() maxlength: number;\n    @Input() step;\n    @Output() blur = new EventEmitter();\n    @Output() ngModelDebounceChange = new EventEmitter();\n\n    @HostBinding('class')\n    get elementClass(): string {\n        return this._elementClass.join(' ');\n    }\n\n    innerValue = null;\n    _disabled = null;\n    _elementClass: string[] = [];\n    _buttonOptions = {\n        show: false,\n        showOnFocus: false,\n        focusSet: false,\n        checkFocusOut: (target: any, element: any) => true,\n        text: 'Save'\n    };\n    listenFunc: (...params) => any;\n    globalListenFunc: (...params) => any;\n\n\n    @Output() searchHandler = new EventEmitter<any>();\n    @Output() clearHandler = new EventEmitter<any>();\n    @Output() buttonHandler = new EventEmitter<any>();\n\n    @ContentChild('prefix', { static: false }) prefixIcon: ElementRef;\n    @ContentChild('suffix', { static: false }) suffixIcon: ElementRef;\n\n    @HostBinding('tabindex') tabindex = -1;\n    onChangeCallback: (_: any) => void = noop;\n    onTouchedCallback: () => void = noop;\n    onChange: (value: any) => void = () => {\n    };\n    onTouched: () => void = () => {\n    };\n\n    set(val: string) {\n        this._elementClass = val.split(' ');\n    }\n\n    public get value(): string | number {\n        return this.innerValue;\n    }\n\n    public set value(v: string | number) {\n        if (v !== this.innerValue) {\n            this.innerValue = this.type === 'number' ? +v : v;\n            this.onChangeCallback(this.innerValue);\n        }\n        this.cdr.markForCheck();\n    }\n\n\n    constructor(private elementRef: ElementRef,\n                private renderer: Renderer2,\n                private cdr: ChangeDetectorRef) {\n    }\n\n    ngAfterViewInit(): void {\n        if (this.clearable) {\n            this._elementClass.push('clearable');\n        }\n        if (this.prefixIcon) {\n            this._elementClass.push('with-prefix');\n        }\n        if (this.suffixIcon) {\n            this._elementClass.push('with-suffix');\n        }\n        if (this.type === 'search') {\n            this._elementClass.push('search-type');\n        }\n    }\n\n    registerOnChange(fn: any) {\n        this.onChangeCallback = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    writeValue(value: number | string) {\n        if (value !== this.innerValue) {\n            this.innerValue = value;\n            this.updateChanges();\n            this.cdr.markForCheck();\n        }\n    }\n\n    updateChanges() {\n        this.onChange(this.value);\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        if (isDisabled) {\n            this._elementClass.push('disabled');\n        } else {\n            this._elementClass = this._elementClass.filter(item => item !== 'disabled');\n        }\n        this._disabled = isDisabled;\n        this.cdr.markForCheck();\n    }\n\n    onSearchClicked($event: any) {\n        this.searchHandler.emit($event);\n    }\n\n    onButtonClicked($event: any) {\n        this.buttonHandler.emit($event);\n        this._buttonOptions.focusSet = false;\n        this.cdr.markForCheck();\n    }\n\n    ngOnDestroy(): void {\n        if (this.listenFunc) {\n            this.listenFunc();\n            this.globalListenFunc();\n        }\n    }\n\n    onClear($event) {\n        this.clearHandler.emit($event);\n        $event.preventDefault();\n        $event.stopPropagation();\n        this.value = null;\n    }\n}\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-input.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-input/dr-input.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EAEL,MAAM,EACN,SAAS,EAAE,SAAS,GACvB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAa5B,MAAM,OAAO,gBAAgB;IAyGzB,YAAoB,UAAsB,EACtB,QAAmB,EACnB,GAAsB;QAFtB,eAAU,GAAV,UAAU,CAAY;QACtB,aAAQ,GAAR,QAAQ,CAAW;QACnB,QAAG,GAAH,GAAG,CAAmB;QA1G1C,eAAU,GAAG,KAAK,CAAC;QA6BV,SAAI,GAAG,QAAQ,CAAC;QAEhB,gBAAW,GAAG,EAAE,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QAiBhB,SAAI,GAAG,IAAI,YAAY,EAAE,CAAC;QAC1B,0BAAqB,GAAG,IAAI,YAAY,EAAE,CAAC;QAOrD,eAAU,GAAG,IAAI,CAAC;QAClB,cAAS,GAAG,IAAI,CAAC;QACjB,kBAAa,GAAa,EAAE,CAAC;QAC7B,mBAAc,GAAG;YACb,IAAI,EAAE,KAAK;YACX,WAAW,EAAE,KAAK;YAClB,QAAQ,EAAE,KAAK;YACf,aAAa,EAAE,CAAC,MAAW,EAAE,OAAY,EAAE,EAAE,CAAC,IAAI;YAClD,IAAI,EAAE,MAAM;SACf,CAAC;QAKQ,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;QACvC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QAMzB,aAAQ,GAAG,CAAC,CAAC,CAAC;QACvC,qBAAgB,GAAqB,IAAI,CAAC;QAC1C,sBAAiB,GAAe,IAAI,CAAC;QACrC,aAAQ,GAAyB,GAAG,EAAE;QACtC,CAAC,CAAC;QACF,cAAS,GAAe,GAAG,EAAE;QAC7B,CAAC,CAAC;IAsBF,CAAC;IAzGD,IAAa,QAAQ,CAAC,KAAK;QACvB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,IAAa,aAAa,CAAC,KAAK;;QAC5B,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,cAAc,mCAAQ,IAAI,CAAC,cAAc,GAAK,KAAK,CAAE,CAAC;YAC3D,IAAI,CAAA,MAAA,IAAI,CAAC,cAAc,0CAAE,IAAI,MAAI,MAAA,IAAI,CAAC,cAAc,0CAAE,WAAW,CAAA,EAAE;gBAC/D,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aAC1C;SACJ;QACD,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE;YACjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBACrF,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACpC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC5B,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE;gBACtE,IAAI,KAAK,CAAC,MAAM,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE;oBAC3D,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE;wBAChF,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;qBAC/B;iBACJ;YACL,CAAC,CAAC,CAAC;SACN;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAOD,IAAa,SAAS,CAAC,GAAG;QACtB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC;QACxB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACxC;aAAM;YACH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC;SAChF;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAUD,IACI,YAAY;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACxC,CAAC;IAgCD,GAAG,CAAC,GAAW;QACX,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACxC,CAAC;IAED,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED,IAAW,KAAK,CAAC,CAAkB;QAC/B,IAAI,CAAC,KAAK,IAAI,CAAC,UAAU,EAAE;YACvB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAClD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAC1C;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAQD,eAAe;QACX,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACxC;QACD,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAC1C;QACD,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAC1C;QACD,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE;YACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAC1C;IACL,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,KAAsB;QAC7B,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;SAC3B;IACL,CAAC;IAED,aAAa;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAChC,IAAI,UAAU,EAAE;YACZ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACvC;aAAM;YACH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;SAC/E;QACD,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC;QAC5B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,eAAe,CAAC,MAAW;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,eAAe,CAAC,MAAW;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,KAAK,CAAC;QACrC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;IACL,CAAC;IAED,OAAO,CAAC,MAAM;QACV,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/B,MAAM,CAAC,cAAc,EAAE,CAAC;QACxB,MAAM,CAAC,eAAe,EAAE,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,KAAK;QACD,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC5C,CAAC;;;YAhMJ,SAAS,SAAC;gBACP,QAAQ,EAAE,UAAU;gBACpB,q9BAAwC;gBAExC,SAAS,EAAE,CAAC;wBACR,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC;wBAC/C,KAAK,EAAE,IAAI;qBACd,CAAC;gBACF,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAClD;;;YAtBG,UAAU;YAOV,SAAS;YAVT,iBAAiB;;;uBA6BhB,KAAK;4BAIL,KAAK;mBAuBL,KAAK;mBACL,KAAK;0BACL,KAAK;uBACL,KAAK;wBAEL,KAAK;kBAUL,KAAK;kBACL,KAAK;wBACL,KAAK;wBACL,KAAK;mBACL,KAAK;mBACL,MAAM;oCACN,MAAM;2BAEN,WAAW,SAAC,OAAO;4BAmBnB,MAAM;2BACN,MAAM;4BACN,MAAM;2BAEN,SAAS,SAAC,UAAU;yBACpB,YAAY,SAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;yBACxC,YAAY,SAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;uBAExC,WAAW,SAAC,UAAU","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2, ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { noop } from 'rxjs';\n\n@Component({\n    selector: 'dr-input',\n    templateUrl: './dr-input.component.html',\n    styleUrls: ['./dr-input.component.scss'],\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => DrInputComponent),\n        multi: true\n    }],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrInputComponent implements AfterViewInit, ControlValueAccessor, OnDestroy {\n    _clearable = false;\n\n    @Input() set disabled(value) {\n        this.setDisabledState(value);\n    }\n\n    @Input() set buttonOptions(value) {\n        if (value) {\n            this._buttonOptions = { ...this._buttonOptions, ...value };\n            if (this._buttonOptions?.show || this._buttonOptions?.showOnFocus) {\n                this._elementClass.push('with-button');\n            }\n        }\n        if (this._buttonOptions.showOnFocus) {\n            this.listenFunc = this.renderer.listen(this.elementRef.nativeElement, 'click', (event) => {\n                this._buttonOptions.focusSet = true;\n                this.cdr.markForCheck();\n            });\n            this.globalListenFunc = this.renderer.listen('document', 'click', event => {\n                if (event.target.parentNode !== this.elementRef.nativeElement) {\n                    if (this._buttonOptions.checkFocusOut(event.target, this.elementRef.nativeElement)) {\n                        this.onButtonClicked(event);\n                    }\n                }\n            });\n        }\n        this.cdr.markForCheck();\n    }\n\n    @Input() type = 'string';\n    @Input() name: string;\n    @Input() placeholder = '';\n    @Input() readonly = false;\n\n    @Input() set clearable(val) {\n        this._clearable = !!val;\n        if (this._clearable) {\n            this._elementClass.push('clearable');\n        } else {\n            this._elementClass = this._elementClass.filter(item => item !== 'clearable');\n        }\n        this.cdr.markForCheck();\n    }\n\n    @Input() min: number | string;\n    @Input() max: number | string;\n    @Input() minLength: number;\n    @Input() maxlength: number;\n    @Input() step;\n    @Output() blur = new EventEmitter();\n    @Output() ngModelDebounceChange = new EventEmitter();\n\n    @HostBinding('class')\n    get elementClass(): string {\n        return this._elementClass.join(' ');\n    }\n\n    innerValue = null;\n    _disabled = null;\n    _elementClass: string[] = [];\n    _buttonOptions = {\n        show: false,\n        showOnFocus: false,\n        focusSet: false,\n        checkFocusOut: (target: any, element: any) => true,\n        text: 'Save'\n    };\n    listenFunc: (...params) => any;\n    globalListenFunc: (...params) => any;\n\n\n    @Output() searchHandler = new EventEmitter<any>();\n    @Output() clearHandler = new EventEmitter<any>();\n    @Output() buttonHandler = new EventEmitter<any>();\n\n    @ViewChild('inputRef') private readonly inputElement: ElementRef<HTMLInputElement>;\n    @ContentChild('prefix', { static: false }) prefixIcon: ElementRef;\n    @ContentChild('suffix', { static: false }) suffixIcon: ElementRef;\n\n    @HostBinding('tabindex') tabindex = -1;\n    onChangeCallback: (_: any) => void = noop;\n    onTouchedCallback: () => void = noop;\n    onChange: (value: any) => void = () => {\n    };\n    onTouched: () => void = () => {\n    };\n\n    set(val: string) {\n        this._elementClass = val.split(' ');\n    }\n\n    public get value(): string | number {\n        return this.innerValue;\n    }\n\n    public set value(v: string | number) {\n        if (v !== this.innerValue) {\n            this.innerValue = this.type === 'number' ? +v : v;\n            this.onChangeCallback(this.innerValue);\n        }\n        this.cdr.markForCheck();\n    }\n\n\n    constructor(private elementRef: ElementRef,\n                private renderer: Renderer2,\n                private cdr: ChangeDetectorRef) {\n    }\n\n    ngAfterViewInit(): void {\n        if (this.clearable) {\n            this._elementClass.push('clearable');\n        }\n        if (this.prefixIcon) {\n            this._elementClass.push('with-prefix');\n        }\n        if (this.suffixIcon) {\n            this._elementClass.push('with-suffix');\n        }\n        if (this.type === 'search') {\n            this._elementClass.push('search-type');\n        }\n    }\n\n    registerOnChange(fn: any) {\n        this.onChangeCallback = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    writeValue(value: number | string) {\n        if (value !== this.innerValue) {\n            this.innerValue = value;\n            this.updateChanges();\n            this.cdr.markForCheck();\n        }\n    }\n\n    updateChanges() {\n        this.onChange(this.value);\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        if (isDisabled) {\n            this._elementClass.push('disabled');\n        } else {\n            this._elementClass = this._elementClass.filter(item => item !== 'disabled');\n        }\n        this._disabled = isDisabled;\n        this.cdr.markForCheck();\n    }\n\n    onSearchClicked($event: any) {\n        this.searchHandler.emit($event);\n    }\n\n    onButtonClicked($event: any) {\n        this.buttonHandler.emit($event);\n        this._buttonOptions.focusSet = false;\n        this.cdr.markForCheck();\n    }\n\n    ngOnDestroy(): void {\n        if (this.listenFunc) {\n            this.listenFunc();\n            this.globalListenFunc();\n        }\n    }\n\n    onClear($event) {\n        this.clearHandler.emit($event);\n        $event.preventDefault();\n        $event.stopPropagation();\n        this.value = null;\n    }\n\n    focus() {\n        this.inputElement.nativeElement.focus();\n    }\n}\n"]}
@@ -17,6 +17,7 @@ import { DrToggleButtonComponent } from './dr-toggle-button/dr-toggle-button.com
17
17
  import { DrModelDebounceChangeDirective } from './dr-model-debounce-change.directive';
18
18
  import { DrDatePickerCustomHeaderComponent } from './date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component';
19
19
  import { DrShowTimeframePipe } from './date-pickers/dr-show-timeframe.pipe';
20
+ import { DrSelectAddItemComponent } from './dr-select-add-item/dr-select-add-item.component';
20
21
  import { MatTooltipModule } from '@angular/material/tooltip';
21
22
  import { DrTooltipModule } from '../dr-tooltip/dr-tooltip.module';
22
23
  // !!! Please do not use such approach in other places
@@ -39,7 +40,8 @@ const components = [
39
40
  DrDatePickerFormatDirective,
40
41
  DrDatePickerCustomHeaderComponent,
41
42
  DrModelDebounceChangeDirective,
42
- DrShowTimeframePipe
43
+ DrShowTimeframePipe,
44
+ DrSelectAddItemComponent
43
45
  ];
44
46
  export class DrInputsModule {
45
47
  }
@@ -58,4 +60,4 @@ DrInputsModule.decorators = [
58
60
  ]
59
61
  },] }
60
62
  ];
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItaW5wdXRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLHNGQUFzRixDQUFDO0FBQzFJLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3hHLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLG9GQUFvRixDQUFDO0FBQ3ZJLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVsRSxzREFBc0Q7QUFDdEQsOENBQThDO0FBQzlDLFdBQVcsQ0FBQyxTQUFTLENBQUMsZUFBZSxHQUFHOztJQUNwQyxNQUFBLElBQUksQ0FBQyx3QkFBd0IsRUFBRSwwQ0FBRSxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUM3RCxDQUFDLENBQUM7QUFFRixNQUFNLFVBQVUsR0FBRztJQUNmLGlCQUFpQjtJQUNqQixvQkFBb0I7SUFDcEIsbUJBQW1CO0lBQ25CLGlCQUFpQjtJQUNqQixnQkFBZ0I7SUFDaEIsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIscUJBQXFCO0lBQ3JCLGtDQUFrQztJQUNsQywyQkFBMkI7SUFDM0IsaUNBQWlDO0lBQ2pDLDhCQUE4QjtJQUM5QixtQkFBbUI7Q0FDdEIsQ0FBQztBQWdCRixNQUFNLE9BQU8sY0FBYzs7O1lBZDFCLFFBQVEsU0FBQztnQkFDTixZQUFZLEVBQUUsVUFBVTtnQkFDeEIsT0FBTyxFQUFFLFVBQVU7Z0JBQ25CLE9BQU8sRUFBRTtvQkFDTCxXQUFXO29CQUNYLG1CQUFtQjtvQkFDbkIsWUFBWTtvQkFDWixjQUFjO29CQUNkLG1CQUFtQjtvQkFDbkIsZ0JBQWdCO29CQUNoQixlQUFlO2lCQUNsQjthQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgTmdTZWxlY3RNb2R1bGUgfSBmcm9tICdAbmctc2VsZWN0L25nLXNlbGVjdCc7XG5cbmltcG9ydCB7IERySW5wdXRDb21wb25lbnQgfSBmcm9tICcuL2RyLWlucHV0L2RyLWlucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEclNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vZHItc2VsZWN0L2RyLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSYWRpb0J1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgUmFkaW9Hcm91cENvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8tYnV0dG9uL3JhZGlvLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEclRvZ2dsZUNvbXBvbmVudCB9IGZyb20gJy4vZHItdG9nZ2xlL2RyLXRvZ2dsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcblxuaW1wb3J0IHsgTWF0Q2FsZW5kYXIsIE1hdERhdGVwaWNrZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyJztcbmltcG9ydCB7IERyRGF0ZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyL2RyLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJXaXRoVGltZWZyYW1lQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUuY29tcG9uZW50JztcbmltcG9ydCB7IERyRGF0ZVBpY2tlckZvcm1hdERpcmVjdGl2ZSB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RpcmVjdGl2ZXMvZHItZGF0ZS1waWNrZXItZm9ybWF0LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEclRvZ2dsZUJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vZHItdG9nZ2xlLWJ1dHRvbi9kci10b2dnbGUtYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEck1vZGVsRGVib3VuY2VDaGFuZ2VEaXJlY3RpdmUgfSBmcm9tICcuL2RyLW1vZGVsLWRlYm91bmNlLWNoYW5nZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJEYXRlUGlja2VyQ3VzdG9tSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXJfY3VzdG9tLWhlYWRlci9kci1kYXRlLXBpY2tlcl9jdXN0b20taGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEclNob3dUaW1lZnJhbWVQaXBlIH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItc2hvdy10aW1lZnJhbWUucGlwZSc7XG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5pbXBvcnQgeyBEclRvb2x0aXBNb2R1bGUgfSBmcm9tICcuLi9kci10b29sdGlwL2RyLXRvb2x0aXAubW9kdWxlJztcblxuLy8gISEhIFBsZWFzZSBkbyBub3QgdXNlIHN1Y2ggYXBwcm9hY2ggaW4gb3RoZXIgcGxhY2VzXG4vLyBIYXJkIGZpeCBmb3IgJ25vbmUnIGNhbGVuZGFyIHZpZXcgc2VsZWN0aW9uXG5NYXRDYWxlbmRhci5wcm90b3R5cGUuZm9jdXNBY3RpdmVDZWxsID0gZnVuY3Rpb24oKSB7XG4gICAgdGhpcy5fZ2V0Q3VycmVudFZpZXdDb21wb25lbnQoKT8uX2ZvY3VzQWN0aXZlQ2VsbChmYWxzZSk7XG59O1xuXG5jb25zdCBjb21wb25lbnRzID0gW1xuICAgIERyQnV0dG9uQ29tcG9uZW50LFxuICAgIFJhZGlvQnV0dG9uQ29tcG9uZW50LFxuICAgIFJhZGlvR3JvdXBDb21wb25lbnQsXG4gICAgQ2hlY2tib3hDb21wb25lbnQsXG4gICAgRHJJbnB1dENvbXBvbmVudCxcbiAgICBEclNlbGVjdENvbXBvbmVudCxcbiAgICBEclRvZ2dsZUNvbXBvbmVudCxcbiAgICBEclRvZ2dsZUJ1dHRvbkNvbXBvbmVudCxcbiAgICBEckRhdGVQaWNrZXJDb21wb25lbnQsXG4gICAgRHJEYXRlUGlja2VyV2l0aFRpbWVmcmFtZUNvbXBvbmVudCxcbiAgICBEckRhdGVQaWNrZXJGb3JtYXREaXJlY3RpdmUsXG4gICAgRHJEYXRlUGlja2VyQ3VzdG9tSGVhZGVyQ29tcG9uZW50LFxuICAgIERyTW9kZWxEZWJvdW5jZUNoYW5nZURpcmVjdGl2ZSxcbiAgICBEclNob3dUaW1lZnJhbWVQaXBlXG5dO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogY29tcG9uZW50cyxcbiAgICBleHBvcnRzOiBjb21wb25lbnRzLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgTmdTZWxlY3RNb2R1bGUsXG4gICAgICAgIE1hdERhdGVwaWNrZXJNb2R1bGUsXG4gICAgICAgIE1hdFRvb2x0aXBNb2R1bGUsXG4gICAgICAgIERyVG9vbHRpcE1vZHVsZVxuICAgIF1cbn0pXG5cbmV4cG9ydCBjbGFzcyBEcklucHV0c01vZHVsZSB7XG5cbn1cbiJdfQ==
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItaW5wdXRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLHNGQUFzRixDQUFDO0FBQzFJLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3hHLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLG9GQUFvRixDQUFDO0FBQ3ZJLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzVFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQzdGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVsRSxzREFBc0Q7QUFDdEQsOENBQThDO0FBQzlDLFdBQVcsQ0FBQyxTQUFTLENBQUMsZUFBZSxHQUFHOztJQUNwQyxNQUFBLElBQUksQ0FBQyx3QkFBd0IsRUFBRSwwQ0FBRSxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUM3RCxDQUFDLENBQUM7QUFFRixNQUFNLFVBQVUsR0FBRztJQUNmLGlCQUFpQjtJQUNqQixvQkFBb0I7SUFDcEIsbUJBQW1CO0lBQ25CLGlCQUFpQjtJQUNqQixnQkFBZ0I7SUFDaEIsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIscUJBQXFCO0lBQ3JCLGtDQUFrQztJQUNsQywyQkFBMkI7SUFDM0IsaUNBQWlDO0lBQ2pDLDhCQUE4QjtJQUM5QixtQkFBbUI7SUFDbkIsd0JBQXdCO0NBQzNCLENBQUM7QUFnQkYsTUFBTSxPQUFPLGNBQWM7OztZQWQxQixRQUFRLFNBQUM7Z0JBQ04sWUFBWSxFQUFFLFVBQVU7Z0JBQ3hCLE9BQU8sRUFBRSxVQUFVO2dCQUNuQixPQUFPLEVBQUU7b0JBQ0wsV0FBVztvQkFDWCxtQkFBbUI7b0JBQ25CLFlBQVk7b0JBQ1osY0FBYztvQkFDZCxtQkFBbUI7b0JBQ25CLGdCQUFnQjtvQkFDaEIsZUFBZTtpQkFDbEI7YUFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IE5nU2VsZWN0TW9kdWxlIH0gZnJvbSAnQG5nLXNlbGVjdC9uZy1zZWxlY3QnO1xuXG5pbXBvcnQgeyBEcklucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9kci1pbnB1dC9kci1pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL2RyLXNlbGVjdC9kci1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IENoZWNrYm94Q29tcG9uZW50IH0gZnJvbSAnLi9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUmFkaW9CdXR0b25Db21wb25lbnQgfSBmcm9tICcuL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IFJhZGlvR3JvdXBDb21wb25lbnQgfSBmcm9tICcuL3JhZGlvLWJ1dHRvbi9yYWRpby1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJUb2dnbGVDb21wb25lbnQgfSBmcm9tICcuL2RyLXRvZ2dsZS9kci10b2dnbGUuY29tcG9uZW50JztcbmltcG9ydCB7IERyQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XG5cbmltcG9ydCB7IE1hdENhbGVuZGFyLCBNYXREYXRlcGlja2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGF0ZXBpY2tlcic7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtcGlja2Vycy9kci1kYXRlLXBpY2tlci9kci1kYXRlLXBpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJEYXRlUGlja2VyV2l0aFRpbWVmcmFtZUNvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyLXdpdGgtdGltZWZyYW1lL2RyLWRhdGUtcGlja2VyLXdpdGgtdGltZWZyYW1lLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJGb3JtYXREaXJlY3RpdmUgfSBmcm9tICcuL2RhdGUtcGlja2Vycy9kaXJlY3RpdmVzL2RyLWRhdGUtcGlja2VyLWZvcm1hdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJUb2dnbGVCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2RyLXRvZ2dsZS1idXR0b24vZHItdG9nZ2xlLWJ1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJNb2RlbERlYm91bmNlQ2hhbmdlRGlyZWN0aXZlIH0gZnJvbSAnLi9kci1tb2RlbC1kZWJvdW5jZS1jaGFuZ2UuZGlyZWN0aXZlJztcbmltcG9ydCB7IERyRGF0ZVBpY2tlckN1c3RvbUhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyX2N1c3RvbS1oZWFkZXIvZHItZGF0ZS1waWNrZXJfY3VzdG9tLWhlYWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJTaG93VGltZWZyYW1lUGlwZSB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RyLXNob3ctdGltZWZyYW1lLnBpcGUnO1xuaW1wb3J0IHsgRHJTZWxlY3RBZGRJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9kci1zZWxlY3QtYWRkLWl0ZW0vZHItc2VsZWN0LWFkZC1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5pbXBvcnQgeyBEclRvb2x0aXBNb2R1bGUgfSBmcm9tICcuLi9kci10b29sdGlwL2RyLXRvb2x0aXAubW9kdWxlJztcblxuLy8gISEhIFBsZWFzZSBkbyBub3QgdXNlIHN1Y2ggYXBwcm9hY2ggaW4gb3RoZXIgcGxhY2VzXG4vLyBIYXJkIGZpeCBmb3IgJ25vbmUnIGNhbGVuZGFyIHZpZXcgc2VsZWN0aW9uXG5NYXRDYWxlbmRhci5wcm90b3R5cGUuZm9jdXNBY3RpdmVDZWxsID0gZnVuY3Rpb24oKSB7XG4gICAgdGhpcy5fZ2V0Q3VycmVudFZpZXdDb21wb25lbnQoKT8uX2ZvY3VzQWN0aXZlQ2VsbChmYWxzZSk7XG59O1xuXG5jb25zdCBjb21wb25lbnRzID0gW1xuICAgIERyQnV0dG9uQ29tcG9uZW50LFxuICAgIFJhZGlvQnV0dG9uQ29tcG9uZW50LFxuICAgIFJhZGlvR3JvdXBDb21wb25lbnQsXG4gICAgQ2hlY2tib3hDb21wb25lbnQsXG4gICAgRHJJbnB1dENvbXBvbmVudCxcbiAgICBEclNlbGVjdENvbXBvbmVudCxcbiAgICBEclRvZ2dsZUNvbXBvbmVudCxcbiAgICBEclRvZ2dsZUJ1dHRvbkNvbXBvbmVudCxcbiAgICBEckRhdGVQaWNrZXJDb21wb25lbnQsXG4gICAgRHJEYXRlUGlja2VyV2l0aFRpbWVmcmFtZUNvbXBvbmVudCxcbiAgICBEckRhdGVQaWNrZXJGb3JtYXREaXJlY3RpdmUsXG4gICAgRHJEYXRlUGlja2VyQ3VzdG9tSGVhZGVyQ29tcG9uZW50LFxuICAgIERyTW9kZWxEZWJvdW5jZUNoYW5nZURpcmVjdGl2ZSxcbiAgICBEclNob3dUaW1lZnJhbWVQaXBlLFxuICAgIERyU2VsZWN0QWRkSXRlbUNvbXBvbmVudFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IGNvbXBvbmVudHMsXG4gICAgZXhwb3J0czogY29tcG9uZW50cyxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIE5nU2VsZWN0TW9kdWxlLFxuICAgICAgICBNYXREYXRlcGlja2VyTW9kdWxlLFxuICAgICAgICBNYXRUb29sdGlwTW9kdWxlLFxuICAgICAgICBEclRvb2x0aXBNb2R1bGVcbiAgICBdXG59KVxuXG5leHBvcnQgY2xhc3MgRHJJbnB1dHNNb2R1bGUge1xuXG59XG4iXX0=
@@ -1,5 +1,6 @@
1
- import { Component, ContentChild, ElementRef, EventEmitter, HostBinding, Input, Output } from '@angular/core';
1
+ import { Component, ContentChild, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { NgSelectComponent } from '@ng-select/ng-select';
3
4
  const SELECT_HOST_ATTRIBUTES = [
4
5
  'no-left-border',
5
6
  'no-left-border-radius',
@@ -47,6 +48,9 @@ export class DrSelectComponent {
47
48
  setDisabledState(isDisabled) {
48
49
  this.disabled = isDisabled;
49
50
  }
51
+ close() {
52
+ this.ngSelect.close();
53
+ }
50
54
  getHostElement() {
51
55
  return this.elementRef.nativeElement;
52
56
  }
@@ -95,10 +99,11 @@ DrSelectComponent.propDecorators = {
95
99
  isOpen: [{ type: Input }],
96
100
  change: [{ type: Output }],
97
101
  open: [{ type: Output }],
102
+ ngSelect: [{ type: ViewChild, args: [NgSelectComponent, { read: NgSelectComponent },] }],
98
103
  labelTemplate: [{ type: ContentChild, args: ['labelTemplate',] }],
99
104
  optionTemplate: [{ type: ContentChild, args: ['optionTemplate',] }],
100
105
  optionHeaderTemplate: [{ type: ContentChild, args: ['optionHeaderTemplate',] }],
101
106
  optionFooterTemplate: [{ type: ContentChild, args: ['optionFooterTemplate',] }],
102
107
  asTextView: [{ type: HostBinding, args: ['class.textView',] }]
103
108
  };
104
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kci1zZWxlY3QvZHItc2VsZWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUNULFlBQVksRUFDWixVQUFVLEVBQ1YsWUFBWSxFQUNaLFdBQVcsRUFDWCxLQUFLLEVBQ0wsTUFBTSxFQUVULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV6RSxNQUFNLHNCQUFzQixHQUFHO0lBQzNCLGdCQUFnQjtJQUNoQix1QkFBdUI7SUFDdkIsaUJBQWlCO0lBQ2pCLHdCQUF3QjtDQUMzQixDQUFDO0FBWUYsTUFBTSxPQUFPLGlCQUFpQjtJQXNDMUIsWUFBb0IsVUFBbUM7UUFBbkMsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFuQzlDLFVBQUssR0FBZSxFQUFFLENBQUM7UUFFdkIsYUFBUSxHQUFHLE1BQU0sQ0FBQztRQVdsQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLFlBQU8sR0FBRyxJQUFJLENBQUM7UUFDZiwwQkFBcUIsR0FBRyxLQUFLLENBQUM7UUFFOUIsY0FBUyxHQUF1QyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUM7UUFTMUQsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBQ3BELFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQU03QixlQUFVLEdBQUcsS0FBSyxDQUFDO1FBVWxELGFBQVEsR0FBNkIsR0FBRyxFQUFFO1FBQzFDLENBQUMsQ0FBQztRQUNGLGNBQVMsR0FBZSxHQUFHLEVBQUU7UUFDN0IsQ0FBQyxDQUFDO1FBVkUsS0FBSyxNQUFNLElBQUksSUFBSSxzQkFBc0IsRUFBRTtZQUN2QyxJQUFJLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDOUIsQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQy9DO1NBQ0o7SUFDTCxDQUFDO0lBckJELElBQWEsUUFBUSxDQUFDLEdBQVk7UUFDOUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUM7SUFDMUIsQ0FBQztJQTBCRCxVQUFVLENBQUMsS0FBVTtRQUNqQixJQUFJLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztRQUMxQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsRUFBTztRQUNwQixJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztRQUVuQixJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ3pCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1NBQ3BDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDckIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELGdCQUFnQixDQUFDLFVBQW1CO1FBQ2hDLElBQUksQ0FBQyxRQUFRLEdBQUcsVUFBVSxDQUFDO0lBQy9CLENBQUM7SUFFTyxjQUFjO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUM7SUFDekMsQ0FBQztJQUVPLGlCQUFpQixDQUFDLEdBQUcsVUFBb0I7UUFDN0MsT0FBTyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ3ZGLENBQUM7OztZQXhGSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLFdBQVc7Z0JBQ3JCLHF4RUFBeUM7Z0JBRXpDLFNBQVMsRUFBRSxDQUFDO3dCQUNSLE9BQU8sRUFBRSxpQkFBaUI7d0JBQzFCLFdBQVcsRUFBRSxpQkFBaUI7d0JBQzlCLEtBQUssRUFBRSxJQUFJO3FCQUNkLENBQUM7O2FBQ0w7OztZQXpCRyxVQUFVOzs7d0JBNEJULEtBQUs7b0JBQ0wsS0FBSztxQkFDTCxLQUFLO3VCQUNMLEtBQUs7d0JBQ0wsS0FBSzt3QkFDTCxLQUFLO3dCQUNMLEtBQUs7eUJBQ0wsS0FBSzt1QkFDTCxLQUFLO3VCQUNMLEtBQUs7MkJBQ0wsS0FBSzswQkFDTCxLQUFLO3NCQUNMLEtBQUs7dUJBQ0wsS0FBSzt1QkFDTCxLQUFLO3NCQUNMLEtBQUs7b0NBQ0wsS0FBSztpQkFDTCxLQUFLO3dCQUNMLEtBQUs7MkJBQ0wsS0FBSzt1QkFFTCxLQUFLO3dCQUlMLEtBQUs7cUJBQ0wsS0FBSztxQkFDTCxNQUFNO21CQUNOLE1BQU07NEJBRU4sWUFBWSxTQUFDLGVBQWU7NkJBQzVCLFlBQVksU0FBQyxnQkFBZ0I7bUNBQzdCLFlBQVksU0FBQyxzQkFBc0I7bUNBQ25DLFlBQVksU0FBQyxzQkFBc0I7eUJBQ25DLFdBQVcsU0FBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENvbXBvbmVudCxcbiAgICBDb250ZW50Q2hpbGQsXG4gICAgRWxlbWVudFJlZixcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxuICAgIFRlbXBsYXRlUmVmXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5jb25zdCBTRUxFQ1RfSE9TVF9BVFRSSUJVVEVTID0gW1xuICAgICduby1sZWZ0LWJvcmRlcicsXG4gICAgJ25vLWxlZnQtYm9yZGVyLXJhZGl1cycsXG4gICAgJ25vLXJpZ2h0LWJvcmRlcicsXG4gICAgJ25vLXJpZ2h0LWJvcmRlci1yYWRpdXMnLFxuXTtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkci1zZWxlY3QnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9kci1zZWxlY3QuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2RyLXNlbGVjdC5jb21wb25lbnQuc2NzcyddLFxuICAgIHByb3ZpZGVyczogW3tcbiAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICAgIHVzZUV4aXN0aW5nOiBEclNlbGVjdENvbXBvbmVudCxcbiAgICAgICAgbXVsdGk6IHRydWVcbiAgICB9XVxufSlcbmV4cG9ydCBjbGFzcyBEclNlbGVjdENvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcblxuICAgIEBJbnB1dCgpIGNsYXNzTmFtZTogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGl0ZW1zOiBBcnJheTxhbnk+ID0gW107XG4gICAgQElucHV0KCkgYWRkVGFnOiBib29sZWFuIHwgKCh0ZXJtOiBzdHJpbmcpID0+IGFueSB8IFByb21pc2U8YW55Pik7XG4gICAgQElucHV0KCkgYXBwZW5kVG8gPSAnYm9keSc7XG4gICAgQElucHV0KCkgYmluZExhYmVsOiBzdHJpbmc7XG4gICAgQElucHV0KCkgYmluZFZhbHVlOiBzdHJpbmc7XG4gICAgQElucHV0KCkgY2xlYXJhYmxlOiBib29sZWFuO1xuICAgIEBJbnB1dCgpIHNlYXJjaGFibGU6IGJvb2xlYW47XG4gICAgQElucHV0KCkgc2VhcmNoRm46ICh0ZXJtOiBzdHJpbmcsIGl0ZW06IGFueSkgPT4gYm9vbGVhbjtcbiAgICBASW5wdXQoKSBtdWx0aXBsZTogYm9vbGVhbjtcbiAgICBASW5wdXQoKSBoaWRlU2VsZWN0ZWQ6IGJvb2xlYW47XG4gICAgQElucHV0KCkgcGxhY2Vob2xkZXI6IHN0cmluZztcbiAgICBASW5wdXQoKSBsb2FkaW5nOiBib29sZWFuO1xuICAgIEBJbnB1dCgpIHJlYWRvbmx5OiBib29sZWFuO1xuICAgIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XG4gICAgQElucHV0KCkgZ3JvdXBCeSA9IG51bGw7XG4gICAgQElucHV0KCkgb3B0aW9uV2l0aERlc2NyaXB0aW9uID0gZmFsc2U7XG4gICAgQElucHV0KCkgaWQ6IHN0cmluZztcbiAgICBASW5wdXQoKSBrZXlEb3duRm46ICgkZXZlbnQ6IEtleWJvYXJkRXZlbnQpID0+IGJvb2xlYW4gPSAoKSA9PiB0cnVlO1xuICAgIEBJbnB1dCgpIHNlbGVjdGVkSXRlbTogYW55O1xuXG4gICAgQElucHV0KCkgc2V0IHRleHRWaWV3KHZhbDogYm9vbGVhbikge1xuICAgICAgICB0aGlzLmFzVGV4dFZpZXcgPSB2YWw7XG4gICAgfVxuXG4gICAgQElucHV0KCkgYXV0b2ZvY3VzOiBib29sZWFuO1xuICAgIEBJbnB1dCgpIGlzT3BlbjogYm9vbGVhbjtcbiAgICBAT3V0cHV0KCkgY2hhbmdlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuICAgIEBPdXRwdXQoKSBvcGVuOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gICAgQENvbnRlbnRDaGlsZCgnbGFiZWxUZW1wbGF0ZScpIGxhYmVsVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG4gICAgQENvbnRlbnRDaGlsZCgnb3B0aW9uVGVtcGxhdGUnKSBvcHRpb25UZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcbiAgICBAQ29udGVudENoaWxkKCdvcHRpb25IZWFkZXJUZW1wbGF0ZScpIG9wdGlvbkhlYWRlclRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xuICAgIEBDb250ZW50Q2hpbGQoJ29wdGlvbkZvb3RlclRlbXBsYXRlJykgb3B0aW9uRm9vdGVyVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy50ZXh0VmlldycpIGFzVGV4dFZpZXcgPSBmYWxzZTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHtcbiAgICAgICAgZm9yIChjb25zdCBhdHRyIG9mIFNFTEVDVF9IT1NUX0FUVFJJQlVURVMpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLmhhc0hvc3RBdHRyaWJ1dGVzKGF0dHIpKSB7XG4gICAgICAgICAgICAgICAgKHRoaXMuZ2V0SG9zdEVsZW1lbnQoKSkuY2xhc3NMaXN0LmFkZChhdHRyKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIG9uQ2hhbmdlOiAodmFsdWU6IGJvb2xlYW4pID0+IHZvaWQgPSAoKSA9PiB7XG4gICAgfTtcbiAgICBvblRvdWNoZWQ6ICgpID0+IHZvaWQgPSAoKSA9PiB7XG4gICAgfTtcblxuICAgIHdyaXRlVmFsdWUodmFsdWU6IGFueSk6IHZvaWQge1xuICAgICAgICB0aGlzLnNlbGVjdGVkSXRlbSA9IHZhbHVlO1xuICAgICAgICB0aGlzLm9uQ2hhbmdlKHRoaXMuc2VsZWN0ZWRJdGVtKTtcbiAgICB9XG5cbiAgICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuXG4gICAgICAgIGlmIChmbiAmJiB0aGlzLnNlbGVjdGVkSXRlbSkge1xuICAgICAgICAgICAgdGhpcy5vbkNoYW5nZSh0aGlzLnNlbGVjdGVkSXRlbSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XG4gICAgICAgIHRoaXMub25Ub3VjaGVkID0gZm47XG4gICAgfVxuXG4gICAgc2V0RGlzYWJsZWRTdGF0ZShpc0Rpc2FibGVkOiBib29sZWFuKSB7XG4gICAgICAgIHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0SG9zdEVsZW1lbnQoKTogSFRNTEVsZW1lbnQge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBoYXNIb3N0QXR0cmlidXRlcyguLi5hdHRyaWJ1dGVzOiBzdHJpbmdbXSk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gYXR0cmlidXRlcy5zb21lKGF0dHJpYnV0ZSA9PiB0aGlzLmdldEhvc3RFbGVtZW50KCkuaGFzQXR0cmlidXRlKGF0dHJpYnV0ZSkpO1xuICAgIH1cbn1cbiJdfQ==
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    TemplateRef, ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgSelectComponent } from '@ng-select/ng-select';\n\nconst SELECT_HOST_ATTRIBUTES = [\n    'no-left-border',\n    'no-left-border-radius',\n    'no-right-border',\n    'no-right-border-radius',\n];\n\ninterface INgSelectComponentAccessor {\n    close: () => void;\n}\n\n@Component({\n    selector: 'dr-select',\n    templateUrl: './dr-select.component.html',\n    styleUrls: ['./dr-select.component.scss'],\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: DrSelectComponent,\n        multi: true\n    }]\n})\nexport class DrSelectComponent implements ControlValueAccessor {\n    @Input() className: string;\n    @Input() items: Array<any> = [];\n    @Input() addTag: boolean | ((term: string) => any | Promise<any>);\n    @Input() appendTo = 'body';\n    @Input() bindLabel: string;\n    @Input() bindValue: string;\n    @Input() clearable: boolean;\n    @Input() searchable: boolean;\n    @Input() searchFn: (term: string, item: any) => boolean;\n    @Input() multiple: boolean;\n    @Input() hideSelected: boolean;\n    @Input() placeholder: string;\n    @Input() loading: boolean;\n    @Input() readonly: boolean;\n    @Input() disabled = false;\n    @Input() groupBy = null;\n    @Input() optionWithDescription = false;\n    @Input() id: string;\n    @Input() keyDownFn: ($event: KeyboardEvent) => boolean = () => true;\n    @Input() selectedItem: any;\n\n    @Input() set textView(val: boolean) {\n        this.asTextView = val;\n    }\n\n    @Input() autofocus: boolean;\n    @Input() isOpen: boolean;\n    @Output() change: EventEmitter<any> = new EventEmitter<any>();\n    @Output() open: EventEmitter<any> = new EventEmitter<any>();\n    @ViewChild(NgSelectComponent, { read: NgSelectComponent }) private readonly ngSelect: INgSelectComponentAccessor;\n    @ContentChild('labelTemplate') labelTemplate: TemplateRef<any>;\n    @ContentChild('optionTemplate') optionTemplate: TemplateRef<any>;\n    @ContentChild('optionHeaderTemplate') optionHeaderTemplate: TemplateRef<any>;\n    @ContentChild('optionFooterTemplate') optionFooterTemplate: TemplateRef<any>;\n    @HostBinding('class.textView') asTextView = false;\n\n    constructor(private elementRef: ElementRef<HTMLElement>) {\n        for (const attr of SELECT_HOST_ATTRIBUTES) {\n            if (this.hasHostAttributes(attr)) {\n                (this.getHostElement()).classList.add(attr);\n            }\n        }\n    }\n\n    onChange: (value: boolean) => void = () => {\n    };\n    onTouched: () => void = () => {\n    };\n\n    writeValue(value: any): void {\n        this.selectedItem = value;\n        this.onChange(this.selectedItem);\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n\n        if (fn && this.selectedItem) {\n            this.onChange(this.selectedItem);\n        }\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    close(): void {\n        this.ngSelect.close();\n    }\n\n    private getHostElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    private hasHostAttributes(...attributes: string[]): boolean {\n        return attributes.some(attribute => this.getHostElement().hasAttribute(attribute));\n    }\n}\n"]}
@@ -0,0 +1,65 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { DrSelectComponent } from '../dr-select/dr-select.component';
3
+ import { reduce as _reduce } from 'lodash';
4
+ export class DrSelectAddItemComponent {
5
+ constructor(drSelect) {
6
+ this.drSelect = drSelect;
7
+ this.dynamicAddLabel = 'Add new';
8
+ this.values = [];
9
+ this.dynamicValueAdded = new EventEmitter();
10
+ }
11
+ set inputRef(input) {
12
+ if (!input)
13
+ return;
14
+ input.focus();
15
+ }
16
+ ngOnChanges(changes) {
17
+ this.calculateCurrentValues();
18
+ }
19
+ ngOnInit() {
20
+ this.calculateCurrentValues();
21
+ }
22
+ onDynamicAdding() {
23
+ this.isDynamicAdding = true;
24
+ }
25
+ onDynamicAddingClose() {
26
+ this.isDynamicAdding = false;
27
+ this.dynamicValue = '';
28
+ }
29
+ onDynamicAdd(value, keydownEvent) {
30
+ const trimmedValue = value === null || value === void 0 ? void 0 : value.trim();
31
+ if (this.currentValues.includes(trimmedValue))
32
+ return;
33
+ if (keydownEvent && keydownEvent.key !== 'Enter')
34
+ return;
35
+ this.onDynamicAddingClose();
36
+ this.drSelect.close();
37
+ this.dynamicValueAdded.emit(trimmedValue);
38
+ }
39
+ calculateCurrentValues() {
40
+ this.currentValues = this.bindValue
41
+ ? _reduce(this.values, (acc, curr) => {
42
+ acc.push(curr[this.bindValue]);
43
+ return acc;
44
+ }, [])
45
+ : this.values;
46
+ }
47
+ }
48
+ DrSelectAddItemComponent.decorators = [
49
+ { type: Component, args: [{
50
+ selector: 'dr-select-add-item',
51
+ template: "<div class=\"dr-select__dynamic-add dynamic-add\">\n <div class=\"dynamic-add__add-item\" (click)=\"onDynamicAdding()\">\n <i class=\"dr-icon-add\"></i>\n <p class=\"dynamic-add__add-item__text\">{{ dynamicAddLabel }}</p>\n </div>\n <div *ngIf=\"isDynamicAdding\" class=\"dynamic-add__field\">\n <dr-input #dynamicInputRef\n class=\"dynamic-add__field__input\"\n [class.dynamic-add__field__input--error]=\"currentValues.includes(dynamicValue)\"\n [(ngModel)]=\"dynamicValue\"\n (keydown)=\"onDynamicAdd(dynamicValue, $event)\"\n placeholder=\"Type...\"></dr-input>\n <div class=\"dynamic-add__field__buttons\">\n <dr-button *ngIf=\"dynamicValue && !currentValues.includes(dynamicValue)\"\n theme=\"icon\"\n icon=\"dr-icon-approve\"\n iconSize=\"18px\"\n (click)=\"onDynamicAdd(dynamicValue)\"></dr-button>\n <dr-button theme=\"icon\"\n icon=\"dr-icon-exit\"\n iconSize=\"18px\"\n (click)=\"onDynamicAddingClose()\"></dr-button>\n </div>\n </div>\n</div>\n",
52
+ styles: [".dynamic-add__add-item{cursor:pointer;display:flex;align-items:center;border-bottom:1px solid #dfe0e3;padding:6px}.dynamic-add__add-item:hover{background:#f9f7ff}.dynamic-add__add-item__text{font-size:14px;line-height:22px;margin:0}.dynamic-add__field{position:relative}.dynamic-add__field__buttons{position:absolute;top:0;right:0;bottom:0;display:flex;align-items:center}::ng-deep .ng-dropdown-panel .ng-dropdown-header:has(.dynamic-add){padding:0;border:none}::ng-deep .dynamic-add__field__input{padding-left:12px!important;height:36px!important;border:none!important;background:#f9f7ff!important;border-radius:0!important}::ng-deep .dynamic-add__field__input>input{background:#f9f7ff}::ng-deep .dynamic-add__field__input>input::placeholder{line-height:22px;font-size:14px;font-weight:400;color:#9ea1aa}::ng-deep .dynamic-add__field__input--error{background:#ffdfe4!important}::ng-deep .dynamic-add__field__input--error>input{background:#ffdfe4}\n"]
53
+ },] }
54
+ ];
55
+ DrSelectAddItemComponent.ctorParameters = () => [
56
+ { type: DrSelectComponent }
57
+ ];
58
+ DrSelectAddItemComponent.propDecorators = {
59
+ dynamicAddLabel: [{ type: Input }],
60
+ bindValue: [{ type: Input }],
61
+ values: [{ type: Input }],
62
+ dynamicValueAdded: [{ type: Output }],
63
+ inputRef: [{ type: ViewChild, args: ['dynamicInputRef',] }]
64
+ };
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc2VsZWN0LWFkZC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kci1zZWxlY3QtYWRkLWl0ZW0vZHItc2VsZWN0LWFkZC1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQXFCLE1BQU0sRUFBaUIsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BILE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxNQUFNLElBQUksT0FBTyxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBUTNDLE1BQU0sT0FBTyx3QkFBd0I7SUFlakMsWUFBb0IsUUFBMkI7UUFBM0IsYUFBUSxHQUFSLFFBQVEsQ0FBbUI7UUFWL0Isb0JBQWUsR0FBVyxTQUFTLENBQUM7UUFFbkMsV0FBTSxHQUFVLEVBQUUsQ0FBQztRQUNsQixzQkFBaUIsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQVFqRixDQUFDO0lBTkQsSUFBa0MsUUFBUSxDQUFDLEtBQXVCO1FBQzlELElBQUksQ0FBQyxLQUFLO1lBQUUsT0FBTztRQUNuQixLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDbEIsQ0FBQztJQUtNLFdBQVcsQ0FBQyxPQUFzQjtRQUNyQyxJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztJQUNsQyxDQUFDO0lBRU0sUUFBUTtRQUNYLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO0lBQ2xDLENBQUM7SUFFTSxlQUFlO1FBQ2xCLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxvQkFBb0I7UUFDdkIsSUFBSSxDQUFDLGVBQWUsR0FBRyxLQUFLLENBQUM7UUFDN0IsSUFBSSxDQUFDLFlBQVksR0FBRyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVNLFlBQVksQ0FBQyxLQUFhLEVBQUUsWUFBNEI7UUFDM0QsTUFBTSxZQUFZLEdBQUcsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLElBQUksRUFBRSxDQUFDO1FBQ25DLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDO1lBQUUsT0FBTztRQUN0RCxJQUFJLFlBQVksSUFBSSxZQUFZLENBQUMsR0FBRyxLQUFLLE9BQU87WUFBRSxPQUFPO1FBRXpELElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1FBQzVCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDdEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRU8sc0JBQXNCO1FBQzFCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFNBQVM7WUFDL0IsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxFQUFFO2dCQUNqQyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztnQkFDL0IsT0FBTyxHQUFHLENBQUM7WUFDZixDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQ04sQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDdEIsQ0FBQzs7O1lBekRKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsb0JBQW9CO2dCQUM5QiwydkNBQWtEOzthQUVyRDs7O1lBUlEsaUJBQWlCOzs7OEJBY3JCLEtBQUs7d0JBQ0wsS0FBSztxQkFDTCxLQUFLO2dDQUNMLE1BQU07dUJBRU4sU0FBUyxTQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIE91dHB1dCwgU2ltcGxlQ2hhbmdlcywgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEclNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4uL2RyLXNlbGVjdC9kci1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IHJlZHVjZSBhcyBfcmVkdWNlIH0gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IERySW5wdXRDb21wb25lbnQgfSBmcm9tICcuLi9kci1pbnB1dC9kci1pbnB1dC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RyLXNlbGVjdC1hZGQtaXRlbScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RyLXNlbGVjdC1hZGQtaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZHItc2VsZWN0LWFkZC1pdGVtLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRHJTZWxlY3RBZGRJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICAgIHB1YmxpYyBpc0R5bmFtaWNBZGRpbmc6IGJvb2xlYW47XG4gICAgcHVibGljIGR5bmFtaWNWYWx1ZTogc3RyaW5nO1xuICAgIHB1YmxpYyBjdXJyZW50VmFsdWVzOiBhbnlbXTtcblxuICAgIEBJbnB1dCgpIHB1YmxpYyBkeW5hbWljQWRkTGFiZWw6IHN0cmluZyA9ICdBZGQgbmV3JztcbiAgICBASW5wdXQoKSBwdWJsaWMgYmluZFZhbHVlOiBzdHJpbmc7XG4gICAgQElucHV0KCkgcHJpdmF0ZSB2YWx1ZXM6IGFueVtdID0gW107XG4gICAgQE91dHB1dCgpIHByaXZhdGUgZHluYW1pY1ZhbHVlQWRkZWQ6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgICBAVmlld0NoaWxkKCdkeW5hbWljSW5wdXRSZWYnKSBzZXQgaW5wdXRSZWYoaW5wdXQ6IERySW5wdXRDb21wb25lbnQpIHtcbiAgICAgICAgaWYgKCFpbnB1dCkgcmV0dXJuO1xuICAgICAgICBpbnB1dC5mb2N1cygpO1xuICAgIH1cblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZHJTZWxlY3Q6IERyU2VsZWN0Q29tcG9uZW50KSB7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcbiAgICAgICAgdGhpcy5jYWxjdWxhdGVDdXJyZW50VmFsdWVzKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmNhbGN1bGF0ZUN1cnJlbnRWYWx1ZXMoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25EeW5hbWljQWRkaW5nKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzRHluYW1pY0FkZGluZyA9IHRydWU7XG4gICAgfVxuXG4gICAgcHVibGljIG9uRHluYW1pY0FkZGluZ0Nsb3NlKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzRHluYW1pY0FkZGluZyA9IGZhbHNlO1xuICAgICAgICB0aGlzLmR5bmFtaWNWYWx1ZSA9ICcnO1xuICAgIH1cblxuICAgIHB1YmxpYyBvbkR5bmFtaWNBZGQodmFsdWU6IHN0cmluZywga2V5ZG93bkV2ZW50PzogS2V5Ym9hcmRFdmVudCk6IHZvaWQge1xuICAgICAgICBjb25zdCB0cmltbWVkVmFsdWUgPSB2YWx1ZT8udHJpbSgpO1xuICAgICAgICBpZiAodGhpcy5jdXJyZW50VmFsdWVzLmluY2x1ZGVzKHRyaW1tZWRWYWx1ZSkpIHJldHVybjtcbiAgICAgICAgaWYgKGtleWRvd25FdmVudCAmJiBrZXlkb3duRXZlbnQua2V5ICE9PSAnRW50ZXInKSByZXR1cm47XG5cbiAgICAgICAgdGhpcy5vbkR5bmFtaWNBZGRpbmdDbG9zZSgpO1xuICAgICAgICB0aGlzLmRyU2VsZWN0LmNsb3NlKCk7XG4gICAgICAgIHRoaXMuZHluYW1pY1ZhbHVlQWRkZWQuZW1pdCh0cmltbWVkVmFsdWUpO1xuICAgIH1cblxuICAgIHByaXZhdGUgY2FsY3VsYXRlQ3VycmVudFZhbHVlcygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jdXJyZW50VmFsdWVzID0gdGhpcy5iaW5kVmFsdWVcbiAgICAgICAgICAgID8gX3JlZHVjZSh0aGlzLnZhbHVlcywgKGFjYywgY3VycikgPT4ge1xuICAgICAgICAgICAgICAgIGFjYy5wdXNoKGN1cnJbdGhpcy5iaW5kVmFsdWVdKTtcbiAgICAgICAgICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgICAgICAgfSwgW10pXG4gICAgICAgICAgICA6IHRoaXMudmFsdWVzO1xuICAgIH1cbn1cbiJdfQ==