@datarailsshared/datarailsshared 1.6.208 → 1.6.210

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.
@@ -9,42 +9,55 @@ import * as i3 from "@angular/forms";
9
9
  import * as i4 from "@angular/common";
10
10
  import * as i5 from "../dr-input/dr-input.component";
11
11
  const _c0 = ["dynamicInputRef"];
12
- function DrSelectAddItemComponent_div_5_p_1_Template(rf, ctx) { if (rf & 1) {
13
- i0.ɵɵelementStart(0, "p", 12);
12
+ function DrSelectAddItemComponent_div_1_Template(rf, ctx) { if (rf & 1) {
13
+ const _r3 = i0.ɵɵgetCurrentView();
14
+ i0.ɵɵelementStart(0, "div", 3);
15
+ i0.ɵɵlistener("click", function DrSelectAddItemComponent_div_1_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r3); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.onDynamicAdding()); });
16
+ i0.ɵɵelement(1, "i", 4);
17
+ i0.ɵɵelementStart(2, "p", 5);
18
+ i0.ɵɵtext(3);
19
+ i0.ɵɵelementEnd()();
20
+ } if (rf & 2) {
21
+ const ctx_r0 = i0.ɵɵnextContext();
22
+ i0.ɵɵadvance(3);
23
+ i0.ɵɵtextInterpolate(ctx_r0.dynamicAddLabel);
24
+ } }
25
+ function DrSelectAddItemComponent_div_2_p_1_Template(rf, ctx) { if (rf & 1) {
26
+ i0.ɵɵelementStart(0, "p", 13);
14
27
  i0.ɵɵtext(1);
15
28
  i0.ɵɵelementEnd();
16
29
  } if (rf & 2) {
17
- const ctx_r1 = i0.ɵɵnextContext(2);
30
+ const ctx_r4 = i0.ɵɵnextContext(2);
18
31
  i0.ɵɵadvance(1);
19
- i0.ɵɵtextInterpolate(ctx_r1.alertMsg);
32
+ i0.ɵɵtextInterpolate(ctx_r4.alertMsg);
20
33
  } }
21
- function DrSelectAddItemComponent_div_5_dr_button_5_Template(rf, ctx) { if (rf & 1) {
22
- const _r5 = i0.ɵɵgetCurrentView();
23
- i0.ɵɵelementStart(0, "dr-button", 13);
24
- i0.ɵɵlistener("click", function DrSelectAddItemComponent_div_5_dr_button_5_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r4.onDynamicAdd(ctx_r4.dynamicValue)); });
34
+ function DrSelectAddItemComponent_div_2_dr_button_5_Template(rf, ctx) { if (rf & 1) {
35
+ const _r8 = i0.ɵɵgetCurrentView();
36
+ i0.ɵɵelementStart(0, "dr-button", 14);
37
+ i0.ɵɵlistener("click", function DrSelectAddItemComponent_div_2_dr_button_5_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r8); const ctx_r7 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r7.onDynamicAdd(ctx_r7.dynamicValue)); });
25
38
  i0.ɵɵelementEnd();
26
39
  } }
27
- function DrSelectAddItemComponent_div_5_Template(rf, ctx) { if (rf & 1) {
28
- const _r7 = i0.ɵɵgetCurrentView();
29
- i0.ɵɵelementStart(0, "div", 5);
30
- i0.ɵɵtemplate(1, DrSelectAddItemComponent_div_5_p_1_Template, 2, 1, "p", 6);
31
- i0.ɵɵelementStart(2, "dr-input", 7, 8);
32
- i0.ɵɵlistener("ngModelChange", function DrSelectAddItemComponent_div_5_Template_dr_input_ngModelChange_2_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.dynamicValue = $event); })("keydown", function DrSelectAddItemComponent_div_5_Template_dr_input_keydown_2_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.onDynamicAdd(ctx_r8.dynamicValue, $event)); });
40
+ function DrSelectAddItemComponent_div_2_Template(rf, ctx) { if (rf & 1) {
41
+ const _r10 = i0.ɵɵgetCurrentView();
42
+ i0.ɵɵelementStart(0, "div", 6);
43
+ i0.ɵɵtemplate(1, DrSelectAddItemComponent_div_2_p_1_Template, 2, 1, "p", 7);
44
+ i0.ɵɵelementStart(2, "dr-input", 8, 9);
45
+ i0.ɵɵlistener("ngModelChange", function DrSelectAddItemComponent_div_2_Template_dr_input_ngModelChange_2_listener($event) { i0.ɵɵrestoreView(_r10); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.dynamicValue = $event); })("keydown", function DrSelectAddItemComponent_div_2_Template_dr_input_keydown_2_listener($event) { i0.ɵɵrestoreView(_r10); const ctx_r11 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r11.onDynamicAdd(ctx_r11.dynamicValue, $event)); });
33
46
  i0.ɵɵelementEnd();
34
- i0.ɵɵelementStart(4, "div", 9);
35
- i0.ɵɵtemplate(5, DrSelectAddItemComponent_div_5_dr_button_5_Template, 1, 0, "dr-button", 10);
36
- i0.ɵɵelementStart(6, "dr-button", 11);
37
- i0.ɵɵlistener("click", function DrSelectAddItemComponent_div_5_Template_dr_button_click_6_listener() { i0.ɵɵrestoreView(_r7); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.onDynamicAddingClose()); });
47
+ i0.ɵɵelementStart(4, "div", 10);
48
+ i0.ɵɵtemplate(5, DrSelectAddItemComponent_div_2_dr_button_5_Template, 1, 0, "dr-button", 11);
49
+ i0.ɵɵelementStart(6, "dr-button", 12);
50
+ i0.ɵɵlistener("click", function DrSelectAddItemComponent_div_2_Template_dr_button_click_6_listener() { i0.ɵɵrestoreView(_r10); const ctx_r12 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r12.onDynamicAddingClose()); });
38
51
  i0.ɵɵelementEnd()()();
39
52
  } if (rf & 2) {
40
- const ctx_r0 = i0.ɵɵnextContext();
53
+ const ctx_r1 = i0.ɵɵnextContext();
41
54
  i0.ɵɵadvance(1);
42
- i0.ɵɵproperty("ngIf", ctx_r0.alertMsg && !ctx_r0.isDynamicValueValid() && ctx_r0.isDirty);
55
+ i0.ɵɵproperty("ngIf", ctx_r1.alertMsg && !ctx_r1.isDynamicValueValid() && ctx_r1.isDirty);
43
56
  i0.ɵɵadvance(1);
44
- i0.ɵɵclassProp("dynamic-add__field__input--error", !ctx_r0.isDynamicValueValid() && ctx_r0.isDirty);
45
- i0.ɵɵproperty("ngModel", ctx_r0.dynamicValue);
57
+ i0.ɵɵclassProp("dynamic-add__field__input--error", !ctx_r1.isDynamicValueValid() && ctx_r1.isDirty);
58
+ i0.ɵɵproperty("ngModel", ctx_r1.dynamicValue);
46
59
  i0.ɵɵadvance(3);
47
- i0.ɵɵproperty("ngIf", ctx_r0.dynamicValue && ctx_r0.isDynamicValueValid());
60
+ i0.ɵɵproperty("ngIf", ctx_r1.dynamicValue && ctx_r1.isDynamicValueValid());
48
61
  } }
49
62
  export class DrSelectAddItemComponent {
50
63
  set inputRef(input) {
@@ -57,6 +70,7 @@ export class DrSelectAddItemComponent {
57
70
  this.currentValues = [];
58
71
  this.dynamicAddLabel = 'Add new';
59
72
  this.values = [];
73
+ this.showOnlyInput = false;
60
74
  this.dynamicValueAdded = new EventEmitter();
61
75
  }
62
76
  ngOnChanges(changes) {
@@ -102,25 +116,21 @@ export class DrSelectAddItemComponent {
102
116
  } if (rf & 2) {
103
117
  let _t;
104
118
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.inputRef = _t.first);
105
- } }, inputs: { dynamicAddLabel: "dynamicAddLabel", bindValue: "bindValue", values: "values", alertMsg: "alertMsg" }, outputs: { dynamicValueAdded: "dynamicValueAdded" }, features: [i0.ɵɵNgOnChangesFeature], decls: 6, vars: 2, consts: [[1, "dr-select__dynamic-add", "dynamic-add"], [1, "dynamic-add__add-item", 3, "click"], [1, "dr-icon-add"], [1, "dynamic-add__add-item__text"], ["class", "dynamic-add__field", 4, "ngIf"], [1, "dynamic-add__field"], ["class", "dynamic-add__field__alert", 4, "ngIf"], ["placeholder", "Type...", 1, "dynamic-add__field__input", 3, "ngModel", "ngModelChange", "keydown"], ["dynamicInputRef", ""], [1, "dynamic-add__field__buttons"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click", 4, "ngIf"], ["theme", "icon", "icon", "dr-icon-exit", "iconSize", "18px", 3, "click"], [1, "dynamic-add__field__alert"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click"]], template: function DrSelectAddItemComponent_Template(rf, ctx) { if (rf & 1) {
106
- i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
107
- i0.ɵɵlistener("click", function DrSelectAddItemComponent_Template_div_click_1_listener() { return ctx.onDynamicAdding(); });
108
- i0.ɵɵelement(2, "i", 2);
109
- i0.ɵɵelementStart(3, "p", 3);
110
- i0.ɵɵtext(4);
111
- i0.ɵɵelementEnd()();
112
- i0.ɵɵtemplate(5, DrSelectAddItemComponent_div_5_Template, 7, 5, "div", 4);
119
+ } }, inputs: { dynamicAddLabel: "dynamicAddLabel", bindValue: "bindValue", values: "values", alertMsg: "alertMsg", showOnlyInput: "showOnlyInput" }, outputs: { dynamicValueAdded: "dynamicValueAdded" }, features: [i0.ɵɵNgOnChangesFeature], decls: 3, vars: 2, consts: [[1, "dr-select__dynamic-add", "dynamic-add"], ["class", "dynamic-add__add-item", 3, "click", 4, "ngIf"], ["class", "dynamic-add__field", 4, "ngIf"], [1, "dynamic-add__add-item", 3, "click"], [1, "dr-icon-add"], [1, "dynamic-add__add-item__text"], [1, "dynamic-add__field"], ["class", "dynamic-add__field__alert", 4, "ngIf"], ["placeholder", "Type...", 1, "dynamic-add__field__input", 3, "ngModel", "ngModelChange", "keydown"], ["dynamicInputRef", ""], [1, "dynamic-add__field__buttons"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click", 4, "ngIf"], ["theme", "icon", "icon", "dr-icon-exit", "iconSize", "18px", 3, "click"], [1, "dynamic-add__field__alert"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click"]], template: function DrSelectAddItemComponent_Template(rf, ctx) { if (rf & 1) {
120
+ i0.ɵɵelementStart(0, "div", 0);
121
+ i0.ɵɵtemplate(1, DrSelectAddItemComponent_div_1_Template, 4, 1, "div", 1);
122
+ i0.ɵɵtemplate(2, DrSelectAddItemComponent_div_2_Template, 7, 5, "div", 2);
113
123
  i0.ɵɵelementEnd();
114
124
  } if (rf & 2) {
115
- i0.ɵɵadvance(4);
116
- i0.ɵɵtextInterpolate(ctx.dynamicAddLabel);
125
+ i0.ɵɵadvance(1);
126
+ i0.ɵɵproperty("ngIf", !(ctx.showOnlyInput && ctx.isDynamicAdding));
117
127
  i0.ɵɵadvance(1);
118
128
  i0.ɵɵproperty("ngIf", ctx.isDynamicAdding);
119
129
  } }, dependencies: [i2.DrButtonComponent, i3.NgControlStatus, i3.NgModel, i4.NgIf, i5.DrInputComponent], styles: [".dynamic-add__add-item[_ngcontent-%COMP%]{cursor:pointer;display:flex;align-items:center;border-bottom:1px solid #dfe0e3;padding:6px}.dynamic-add__add-item[_ngcontent-%COMP%]:hover{background:#f9f7ff}.dynamic-add__add-item__text[_ngcontent-%COMP%]{font-size:14px;line-height:22px;margin:0;color:#6d6e6f}.dynamic-add__add-item[_ngcontent-%COMP%] .dr-icon-add[_ngcontent-%COMP%]{color:#6d6e6f}.dynamic-add__field[_ngcontent-%COMP%]{position:relative}.dynamic-add__field__buttons[_ngcontent-%COMP%]{position:absolute;top:0;right:0;bottom:0;display:flex;align-items:center}.dynamic-add__field__alert[_ngcontent-%COMP%]{font-size:12px;position:absolute;color:#bf1d30;z-index:100;right:30px} .ng-dropdown-panel .ng-dropdown-footer:has(.dynamic-add), .ng-dropdown-panel .ng-dropdown-header:has(.dynamic-add){padding:0;border:none} .ng-dropdown-panel .ng-dropdown-footer .dynamic-add__add-item{border-bottom:none} .dynamic-add__field__input{padding-left:12px!important;height:36px!important;border:none!important;background:#f9f7ff!important;border-radius:0!important} .dynamic-add__field__input>input{background:#f9f7ff} .dynamic-add__field__input>input::placeholder{line-height:22px;font-size:14px;font-weight:400;color:#9ea1aa} .dynamic-add__field__input--error{background:#ffdfe4!important} .dynamic-add__field__input--error>input{background:#ffdfe4}"], changeDetection: 0 }); }
120
130
  }
121
131
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrSelectAddItemComponent, [{
122
132
  type: Component,
123
- args: [{ selector: 'dr-select-add-item', changeDetection: ChangeDetectionStrategy.OnPush, 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 <p *ngIf=\"alertMsg && !isDynamicValueValid() && isDirty\"\n class=\"dynamic-add__field__alert\">{{ alertMsg }}</p>\n <dr-input\n #dynamicInputRef\n class=\"dynamic-add__field__input\"\n [class.dynamic-add__field__input--error]=\"!isDynamicValueValid() && isDirty\"\n [(ngModel)]=\"dynamicValue\"\n (keydown)=\"onDynamicAdd(dynamicValue, $event)\"\n placeholder=\"Type...\"></dr-input>\n <div class=\"dynamic-add__field__buttons\">\n <dr-button\n *ngIf=\"dynamicValue && isDynamicValueValid()\"\n theme=\"icon\"\n icon=\"dr-icon-approve\"\n iconSize=\"18px\"\n (click)=\"onDynamicAdd(dynamicValue)\"></dr-button>\n <dr-button theme=\"icon\" icon=\"dr-icon-exit\" iconSize=\"18px\" (click)=\"onDynamicAddingClose()\"></dr-button>\n </div>\n </div>\n</div>\n", 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;color:#6d6e6f}.dynamic-add__add-item .dr-icon-add{color:#6d6e6f}.dynamic-add__field{position:relative}.dynamic-add__field__buttons{position:absolute;top:0;right:0;bottom:0;display:flex;align-items:center}.dynamic-add__field__alert{font-size:12px;position:absolute;color:#bf1d30;z-index:100;right:30px}::ng-deep .ng-dropdown-panel .ng-dropdown-footer:has(.dynamic-add),::ng-deep .ng-dropdown-panel .ng-dropdown-header:has(.dynamic-add){padding:0;border:none}::ng-deep .ng-dropdown-panel .ng-dropdown-footer .dynamic-add__add-item{border-bottom: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"] }]
133
+ args: [{ selector: 'dr-select-add-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dr-select__dynamic-add dynamic-add\">\n <div *ngIf=\"!(showOnlyInput && isDynamicAdding)\" 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 <p *ngIf=\"alertMsg && !isDynamicValueValid() && isDirty\" class=\"dynamic-add__field__alert\">{{ alertMsg }}</p>\n <dr-input\n #dynamicInputRef\n class=\"dynamic-add__field__input\"\n [class.dynamic-add__field__input--error]=\"!isDynamicValueValid() && isDirty\"\n [(ngModel)]=\"dynamicValue\"\n (keydown)=\"onDynamicAdd(dynamicValue, $event)\"\n placeholder=\"Type...\"></dr-input>\n <div class=\"dynamic-add__field__buttons\">\n <dr-button\n *ngIf=\"dynamicValue && isDynamicValueValid()\"\n theme=\"icon\"\n icon=\"dr-icon-approve\"\n iconSize=\"18px\"\n (click)=\"onDynamicAdd(dynamicValue)\"></dr-button>\n <dr-button theme=\"icon\" icon=\"dr-icon-exit\" iconSize=\"18px\" (click)=\"onDynamicAddingClose()\"></dr-button>\n </div>\n </div>\n</div>\n", 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;color:#6d6e6f}.dynamic-add__add-item .dr-icon-add{color:#6d6e6f}.dynamic-add__field{position:relative}.dynamic-add__field__buttons{position:absolute;top:0;right:0;bottom:0;display:flex;align-items:center}.dynamic-add__field__alert{font-size:12px;position:absolute;color:#bf1d30;z-index:100;right:30px}::ng-deep .ng-dropdown-panel .ng-dropdown-footer:has(.dynamic-add),::ng-deep .ng-dropdown-panel .ng-dropdown-header:has(.dynamic-add){padding:0;border:none}::ng-deep .ng-dropdown-panel .ng-dropdown-footer .dynamic-add__add-item{border-bottom: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"] }]
124
134
  }], function () { return [{ type: i1.DrSelectComponent }]; }, { dynamicAddLabel: [{
125
135
  type: Input
126
136
  }], bindValue: [{
@@ -129,10 +139,12 @@ export class DrSelectAddItemComponent {
129
139
  type: Input
130
140
  }], alertMsg: [{
131
141
  type: Input
142
+ }], showOnlyInput: [{
143
+ type: Input
132
144
  }], dynamicValueAdded: [{
133
145
  type: Output
134
146
  }], inputRef: [{
135
147
  type: ViewChild,
136
148
  args: ['dynamicInputRef']
137
149
  }] }); })();
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select-add-item.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { DrSelectComponent } from '../dr-select/dr-select.component';\nimport { reduce as _reduce } from 'lodash';\nimport { DrInputComponent } from '../dr-input/dr-input.component';\n\n@Component({\n    selector: 'dr-select-add-item',\n    templateUrl: './dr-select-add-item.component.html',\n    styleUrls: ['./dr-select-add-item.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrSelectAddItemComponent implements OnInit, OnChanges {\n    public isDynamicAdding: boolean;\n    public dynamicValue: string;\n    public currentValues: any[] = [];\n    public isDirty: boolean;\n\n    @Input() public dynamicAddLabel = 'Add new';\n    @Input() public bindValue: string;\n    @Input() private values: any[] = [];\n    @Input() public alertMsg: string;\n    @Output() private dynamicValueAdded: EventEmitter<any> = new EventEmitter<any>();\n\n    @ViewChild('dynamicInputRef') set inputRef(input: DrInputComponent) {\n        if (!input) return;\n        input.focus();\n    }\n\n    constructor(private drSelect: DrSelectComponent) {}\n\n    public ngOnChanges(changes: SimpleChanges) {\n        this.calculateCurrentValues();\n    }\n\n    public ngOnInit(): void {\n        this.calculateCurrentValues();\n    }\n\n    public onDynamicAdding(): void {\n        this.isDynamicAdding = true;\n    }\n\n    public onDynamicAddingClose(): void {\n        this.isDynamicAdding = false;\n        this.dynamicValue = '';\n    }\n\n    public isDynamicValueValid(): boolean {\n        const trimmedValue = this.dynamicValue?.trim();\n        if (!trimmedValue) return false;\n        return !this.currentValues.includes(trimmedValue);\n    }\n\n    public onDynamicAdd(value: string, keydownEvent?: KeyboardEvent): void {\n        this.isDirty = true;\n        if (!this.isDynamicValueValid()) return;\n        if (keydownEvent && keydownEvent.key !== 'Enter') return;\n\n        this.onDynamicAddingClose();\n        this.drSelect.close();\n        this.dynamicValueAdded.emit(value?.trim());\n    }\n\n    private calculateCurrentValues(): void {\n        this.currentValues = this.bindValue\n            ? _reduce(\n                  this.values,\n                  (acc, curr) => {\n                      acc.push(curr[this.bindValue]);\n                      return acc;\n                  },\n                  [],\n              )\n            : this.values;\n    }\n}\n","<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        <p *ngIf=\"alertMsg && !isDynamicValueValid() && isDirty\"\n              class=\"dynamic-add__field__alert\">{{ alertMsg }}</p>\n        <dr-input\n            #dynamicInputRef\n            class=\"dynamic-add__field__input\"\n            [class.dynamic-add__field__input--error]=\"!isDynamicValueValid() && isDirty\"\n            [(ngModel)]=\"dynamicValue\"\n            (keydown)=\"onDynamicAdd(dynamicValue, $event)\"\n            placeholder=\"Type...\"></dr-input>\n        <div class=\"dynamic-add__field__buttons\">\n            <dr-button\n                *ngIf=\"dynamicValue && isDynamicValueValid()\"\n                theme=\"icon\"\n                icon=\"dr-icon-approve\"\n                iconSize=\"18px\"\n                (click)=\"onDynamicAdd(dynamicValue)\"></dr-button>\n            <dr-button theme=\"icon\" icon=\"dr-icon-exit\" iconSize=\"18px\" (click)=\"onDynamicAddingClose()\"></dr-button>\n        </div>\n    </div>\n</div>\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select-add-item.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { DrSelectComponent } from '../dr-select/dr-select.component';\nimport { reduce as _reduce } from 'lodash';\nimport { DrInputComponent } from '../dr-input/dr-input.component';\n\n@Component({\n    selector: 'dr-select-add-item',\n    templateUrl: './dr-select-add-item.component.html',\n    styleUrls: ['./dr-select-add-item.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrSelectAddItemComponent implements OnInit, OnChanges {\n    public isDynamicAdding: boolean;\n    public dynamicValue: string;\n    public currentValues: any[] = [];\n    public isDirty: boolean;\n\n    @Input() public dynamicAddLabel = 'Add new';\n    @Input() public bindValue: string;\n    @Input() private values: any[] = [];\n    @Input() public alertMsg: string;\n    @Input() public showOnlyInput: boolean = false;\n    @Output() private dynamicValueAdded: EventEmitter<any> = new EventEmitter<any>();\n\n    @ViewChild('dynamicInputRef') set inputRef(input: DrInputComponent) {\n        if (!input) return;\n        input.focus();\n    }\n\n    constructor(private drSelect: DrSelectComponent) {}\n\n    public ngOnChanges(changes: SimpleChanges) {\n        this.calculateCurrentValues();\n    }\n\n    public ngOnInit(): void {\n        this.calculateCurrentValues();\n    }\n\n    public onDynamicAdding(): void {\n        this.isDynamicAdding = true;\n    }\n\n    public onDynamicAddingClose(): void {\n        this.isDynamicAdding = false;\n        this.dynamicValue = '';\n    }\n\n    public isDynamicValueValid(): boolean {\n        const trimmedValue = this.dynamicValue?.trim();\n        if (!trimmedValue) return false;\n        return !this.currentValues.includes(trimmedValue);\n    }\n\n    public onDynamicAdd(value: string, keydownEvent?: KeyboardEvent): void {\n        this.isDirty = true;\n        if (!this.isDynamicValueValid()) return;\n        if (keydownEvent && keydownEvent.key !== 'Enter') return;\n\n        this.onDynamicAddingClose();\n        this.drSelect.close();\n        this.dynamicValueAdded.emit(value?.trim());\n    }\n\n    private calculateCurrentValues(): void {\n        this.currentValues = this.bindValue\n            ? _reduce(\n                  this.values,\n                  (acc, curr) => {\n                      acc.push(curr[this.bindValue]);\n                      return acc;\n                  },\n                  [],\n              )\n            : this.values;\n    }\n}\n","<div class=\"dr-select__dynamic-add dynamic-add\">\n    <div *ngIf=\"!(showOnlyInput && isDynamicAdding)\" 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        <p *ngIf=\"alertMsg && !isDynamicValueValid() && isDirty\" class=\"dynamic-add__field__alert\">{{ alertMsg }}</p>\n        <dr-input\n            #dynamicInputRef\n            class=\"dynamic-add__field__input\"\n            [class.dynamic-add__field__input--error]=\"!isDynamicValueValid() && isDirty\"\n            [(ngModel)]=\"dynamicValue\"\n            (keydown)=\"onDynamicAdd(dynamicValue, $event)\"\n            placeholder=\"Type...\"></dr-input>\n        <div class=\"dynamic-add__field__buttons\">\n            <dr-button\n                *ngIf=\"dynamicValue && isDynamicValueValid()\"\n                theme=\"icon\"\n                icon=\"dr-icon-approve\"\n                iconSize=\"18px\"\n                (click)=\"onDynamicAdd(dynamicValue)\"></dr-button>\n            <dr-button theme=\"icon\" icon=\"dr-icon-exit\" iconSize=\"18px\" (click)=\"onDynamicAddingClose()\"></dr-button>\n        </div>\n    </div>\n</div>\n"]}