@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.
- package/datarailsshared-datarailsshared-1.6.210.tgz +0 -0
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.mjs +6 -3
- package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +56 -38
- package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +47 -35
- package/fesm2022/datarailsshared-datarailsshared.mjs +106 -73
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.d.ts +2 -2
- package/lib/dr-inputs/dr-select/dr-select.component.d.ts +2 -1
- package/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.d.ts +2 -1
- package/package.json +1 -1
- package/datarailsshared-datarailsshared-1.6.208.tgz +0 -0
|
@@ -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
|
|
13
|
-
i0.ɵɵ
|
|
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
|
|
30
|
+
const ctx_r4 = i0.ɵɵnextContext(2);
|
|
18
31
|
i0.ɵɵadvance(1);
|
|
19
|
-
i0.ɵɵtextInterpolate(
|
|
32
|
+
i0.ɵɵtextInterpolate(ctx_r4.alertMsg);
|
|
20
33
|
} }
|
|
21
|
-
function
|
|
22
|
-
const
|
|
23
|
-
i0.ɵɵelementStart(0, "dr-button",
|
|
24
|
-
i0.ɵɵlistener("click", function
|
|
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
|
|
28
|
-
const
|
|
29
|
-
i0.ɵɵelementStart(0, "div",
|
|
30
|
-
i0.ɵɵtemplate(1,
|
|
31
|
-
i0.ɵɵelementStart(2, "dr-input",
|
|
32
|
-
i0.ɵɵlistener("ngModelChange", function
|
|
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",
|
|
35
|
-
i0.ɵɵtemplate(5,
|
|
36
|
-
i0.ɵɵelementStart(6, "dr-button",
|
|
37
|
-
i0.ɵɵlistener("click", function
|
|
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
|
|
53
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
41
54
|
i0.ɵɵadvance(1);
|
|
42
|
-
i0.ɵɵproperty("ngIf",
|
|
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", !
|
|
45
|
-
i0.ɵɵproperty("ngModel",
|
|
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",
|
|
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:
|
|
106
|
-
i0.ɵɵelementStart(0, "div", 0)
|
|
107
|
-
i0.ɵɵ
|
|
108
|
-
i0.ɵɵ
|
|
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(
|
|
116
|
-
i0.ɵɵ
|
|
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\"
|
|
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,
|
|
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"]}
|