@datarailsshared/datarailsshared 1.6.115 → 1.6.119

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.
@@ -34,9 +34,10 @@ function DrChatFormDropdownComponent_i_14_Template(rf, ctx) { if (rf & 1) {
34
34
  function DrChatFormDropdownComponent_dr_dot_flashing_15_Template(rf, ctx) { if (rf & 1) {
35
35
  i0.ɵɵelement(0, "dr-dot-flashing", 15);
36
36
  } }
37
- const _c2 = function (a0) { return { "message-row_loading": a0 }; };
38
- const _c3 = function (a0, a1) { return { "message-row__input--focused": a0, "message-row__input--filled": a1 }; };
39
- const _c4 = ["*"];
37
+ const _c2 = ["*", [["", "dropItem", ""]]];
38
+ const _c3 = function (a0) { return { "message-row_loading": a0 }; };
39
+ const _c4 = function (a0, a1) { return { "message-row__input--focused": a0, "message-row__input--filled": a1 }; };
40
+ const _c5 = ["*", "[dropItem]"];
40
41
  export class DrChatFormDropdownComponent {
41
42
  constructor(cdr, domSanitizer) {
42
43
  this.cdr = cdr;
@@ -204,8 +205,8 @@ export class DrChatFormDropdownComponent {
204
205
  i0.ɵɵlistener("drop", function DrChatFormDropdownComponent_drop_HostBindingHandler($event) { return ctx.onDrop($event); })("dragover", function DrChatFormDropdownComponent_dragover_HostBindingHandler($event) { return ctx.onDragOver($event); })("dragleave", function DrChatFormDropdownComponent_dragleave_HostBindingHandler($event) { return ctx.onDragLeave($event); });
205
206
  } if (rf & 2) {
206
207
  i0.ɵɵclassProp("file-over", ctx.fileOver);
207
- } }, inputs: { isUploadingFiles: "isUploadingFiles", message: "message", messagePlaceholder: "messagePlaceholder", dropFiles: "dropFiles", dropFilePlaceholder: "dropFilePlaceholder", waitForReply: "waitForReply", showDotFlashing: "showDotFlashing" }, outputs: { send: "send", uploadFiles: "uploadFiles", abort: "abort", inputChange: "inputChange" }, ngContentSelectors: _c4, decls: 16, vars: 20, consts: [[1, "message-row", 3, "ngClass"], [1, "message-row__input", 3, "ngClass"], [3, "files", "isRemovable", "maxLengthText", "removeFileEvent", 4, "ngIf"], [1, "message-row__input-textarea-wrap"], ["type", "text", 3, "ngModel", "rows", "placeholder", "focus", "blur", "mouseenter", "mouseleave", "ngModelChange", "keydown.enter"], ["textAreaElement", ""], [1, "message-row__btns"], ["type", "file", "hidden", "", "multiple", "", 3, "change"], ["fileInput", ""], ["class", "dr-icon-send-arrow-up send-button", 3, "click", 4, "ngIf"], ["class", "dr-icon-stop abort-button", 3, "click", 4, "ngIf"], ["class", "wait-reply-dot-flashing", 4, "ngIf"], [3, "files", "isRemovable", "maxLengthText", "removeFileEvent"], [1, "dr-icon-send-arrow-up", "send-button", 3, "click"], [1, "dr-icon-stop", "abort-button", 3, "click"], [1, "wait-reply-dot-flashing"]], template: function DrChatFormDropdownComponent_Template(rf, ctx) { if (rf & 1) {
208
- i0.ɵɵprojectionDef();
208
+ } }, inputs: { isUploadingFiles: "isUploadingFiles", message: "message", messagePlaceholder: "messagePlaceholder", dropFiles: "dropFiles", dropFilePlaceholder: "dropFilePlaceholder", waitForReply: "waitForReply", showDotFlashing: "showDotFlashing" }, outputs: { send: "send", uploadFiles: "uploadFiles", abort: "abort", inputChange: "inputChange" }, ngContentSelectors: _c5, decls: 17, vars: 20, consts: [[1, "message-row", 3, "ngClass"], [1, "message-row__input", 3, "ngClass"], [3, "files", "isRemovable", "maxLengthText", "removeFileEvent", 4, "ngIf"], [1, "message-row__input-textarea-wrap"], ["type", "text", 3, "ngModel", "rows", "placeholder", "focus", "blur", "mouseenter", "mouseleave", "ngModelChange", "keydown.enter"], ["textAreaElement", ""], [1, "message-row__btns"], ["type", "file", "hidden", "", "multiple", "", 3, "change"], ["fileInput", ""], ["class", "dr-icon-send-arrow-up send-button", 3, "click", 4, "ngIf"], ["class", "dr-icon-stop abort-button", 3, "click", 4, "ngIf"], ["class", "wait-reply-dot-flashing", 4, "ngIf"], [3, "files", "isRemovable", "maxLengthText", "removeFileEvent"], [1, "dr-icon-send-arrow-up", "send-button", 3, "click"], [1, "dr-icon-stop", "abort-button", 3, "click"], [1, "wait-reply-dot-flashing"]], template: function DrChatFormDropdownComponent_Template(rf, ctx) { if (rf & 1) {
209
+ i0.ɵɵprojectionDef(_c2);
209
210
  i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
210
211
  i0.ɵɵpipe(2, "async");
211
212
  i0.ɵɵtemplate(3, DrChatFormDropdownComponent_dr_chat_dropped_files_3_Template, 2, 5, "dr-chat-dropped-files", 2);
@@ -222,13 +223,15 @@ export class DrChatFormDropdownComponent {
222
223
  i0.ɵɵtemplate(13, DrChatFormDropdownComponent_i_13_Template, 1, 0, "i", 9);
223
224
  i0.ɵɵtemplate(14, DrChatFormDropdownComponent_i_14_Template, 1, 0, "i", 10);
224
225
  i0.ɵɵtemplate(15, DrChatFormDropdownComponent_dr_dot_flashing_15_Template, 1, 0, "dr-dot-flashing", 11);
225
- i0.ɵɵelementEnd()()();
226
+ i0.ɵɵelementEnd();
227
+ i0.ɵɵprojection(16, 1);
228
+ i0.ɵɵelementEnd()();
226
229
  } if (rf & 2) {
227
230
  const _r1 = i0.ɵɵreference(7);
228
231
  let tmp_1_0;
229
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(15, _c2, ctx.isUploadingFiles));
232
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(15, _c3, ctx.isUploadingFiles));
230
233
  i0.ɵɵadvance(1);
231
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(17, _c3, ctx.inputFocus, !!(ctx.message == null ? null : (tmp_1_0 = ctx.message.trim()) == null ? null : tmp_1_0.length) || !!i0.ɵɵpipeBind1(2, 11, ctx.droppedFiles$).length));
234
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(17, _c4, ctx.inputFocus, !!(ctx.message == null ? null : (tmp_1_0 = ctx.message.trim()) == null ? null : tmp_1_0.length) || !!i0.ɵɵpipeBind1(2, 11, ctx.droppedFiles$).length));
232
235
  i0.ɵɵadvance(2);
233
236
  i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(4, 13, ctx.droppedFiles$).length);
234
237
  i0.ɵɵadvance(3);
@@ -241,11 +244,11 @@ export class DrChatFormDropdownComponent {
241
244
  i0.ɵɵproperty("ngIf", ctx.waitForReply && !ctx.showDotFlashing);
242
245
  i0.ɵɵadvance(1);
243
246
  i0.ɵɵproperty("ngIf", ctx.waitForReply && ctx.showDotFlashing);
244
- } }, dependencies: [i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.NgClass, i3.NgIf, i4.DrDotFlashingComponent, i5.DrChatDroppedFilesComponent, i3.AsyncPipe], styles: ["[_nghost-%COMP%] {--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}[_nghost-%COMP%] .message-row{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}[_nghost-%COMP%] .message-row__input{flex-direction:column;background-color:#fff;position:relative;display:flex;align-items:center;flex-grow:1;padding:14px 8px 8px 15px;height:auto;overflow:visible;min-width:265px;border-radius:24px;border:1.5px solid transparent;box-shadow:0 2px 16px -10px #603cff29;transition:.35s ease}[_nghost-%COMP%] .message-row__input .abort-button, [_nghost-%COMP%] .message-row__input .send-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;border-radius:100px;color:#fff;transition:.15s ease-in-out;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box}[_nghost-%COMP%] .message-row__input .send-button, [_nghost-%COMP%] .message-row__input .abort-button{background:var(--disabled-bg);pointer-events:none}[_nghost-%COMP%] .message-row__input--focused{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;height:auto!important;background:#fff}[_nghost-%COMP%] .message-row__input--filled{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}[_nghost-%COMP%] .message-row__input--filled .send-button{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}[_nghost-%COMP%] .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:32px}[_nghost-%COMP%] .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}[_nghost-%COMP%] .message-row__input textarea{color:#333;width:100%;outline:none;min-height:30px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px;font-family:Poppins,sans-serif;font-size:14px;line-height:22px}[_nghost-%COMP%] .message-row__input textarea:focus{border:none}[_nghost-%COMP%] .message-row__input textarea::placeholder{color:#9ea1aa}[_nghost-%COMP%] .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}[_nghost-%COMP%] .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}[_nghost-%COMP%] dr-chat-dropped-files{margin-right:auto}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files{padding:0}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files__item{margin:0}[_nghost-%COMP%] .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}[_nghost-%COMP%] .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}"], changeDetection: 0 }); }
247
+ } }, dependencies: [i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.NgClass, i3.NgIf, i4.DrDotFlashingComponent, i5.DrChatDroppedFilesComponent, i3.AsyncPipe], styles: ["[_nghost-%COMP%] {--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}[_nghost-%COMP%] .message-row{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}[_nghost-%COMP%] .message-row__input{flex-direction:column;background-color:#fff;position:relative;display:flex;align-items:center;flex-grow:1;padding:14px 8px 8px 15px;height:auto;overflow:visible;min-width:265px;border-radius:24px;border:1.5px solid transparent;box-shadow:0 2px 16px -10px #603cff29;transition:.35s ease;will-change:box-shadow}[_nghost-%COMP%] .message-row__input .abort-button, [_nghost-%COMP%] .message-row__input .send-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;border-radius:100px;color:#fff;transition:.15s ease-in-out;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box}[_nghost-%COMP%] .message-row__input .send-button, [_nghost-%COMP%] .message-row__input .abort-button{background:var(--disabled-bg);pointer-events:none}[_nghost-%COMP%] .message-row__input--focused{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;height:auto!important;background:#fff}[_nghost-%COMP%] .message-row__input--filled{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}[_nghost-%COMP%] .message-row__input--filled .send-button{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}[_nghost-%COMP%] .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:32px}[_nghost-%COMP%] .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}[_nghost-%COMP%] .message-row__input textarea{color:#333;width:100%;outline:none;min-height:30px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px;font-family:Poppins,sans-serif;font-size:14px;line-height:22px}[_nghost-%COMP%] .message-row__input textarea:focus{border:none}[_nghost-%COMP%] .message-row__input textarea::placeholder{color:#9ea1aa}[_nghost-%COMP%] .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}[_nghost-%COMP%] .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}[_nghost-%COMP%] dr-chat-dropped-files{margin-right:auto}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files{padding:0}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files__item{margin:0}[_nghost-%COMP%] .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}[_nghost-%COMP%] .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}"], changeDetection: 0 }); }
245
248
  }
246
249
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrChatFormDropdownComponent, [{
247
250
  type: Component,
248
- args: [{ selector: 'dr-chat-form-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"message-row\" [ngClass]=\"{ 'message-row_loading': isUploadingFiles }\">\n <div\n class=\"message-row__input\"\n [ngClass]=\"{\n 'message-row__input--focused': inputFocus,\n 'message-row__input--filled': !!message?.trim()?.length || !!(droppedFiles$ | async).length,\n }\">\n <dr-chat-dropped-files\n *ngIf=\"(droppedFiles$ | async).length\"\n [files]=\"droppedFiles$ | async\"\n [isRemovable]=\"true\"\n [maxLengthText]=\"15\"\n (removeFileEvent)=\"removeFile($event)\"></dr-chat-dropped-files>\n\n <div class=\"message-row__input-textarea-wrap\">\n <textarea\n #textAreaElement\n (focus)=\"inputFocus = true\"\n (blur)=\"inputFocus = false\"\n (mouseenter)=\"inputHover = true\"\n (mouseleave)=\"inputHover = false\"\n [(ngModel)]=\"message\"\n [rows]=\"1\"\n [style]=\"getTextAreaHeight(textAreaElement)\"\n (ngModelChange)=\"onModelChange($event)\"\n type=\"text\"\n placeholder=\"{{ fileOver ? dropFilePlaceholder : messagePlaceholder }}\"\n (keydown.enter)=\"sendMessage($event)\">\n </textarea>\n </div>\n <div class=\"message-row__btns\">\n <ng-content></ng-content>\n <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n <i *ngIf=\"!waitForReply\" (click)=\"sendMessage($event)\" class=\"dr-icon-send-arrow-up send-button\"></i>\n\n <i *ngIf=\"waitForReply && !showDotFlashing\" class=\"dr-icon-stop abort-button\" (click)=\"abortMessage()\"></i>\n <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n </div>\n </div>\n</div>\n", styles: [":host::ng-deep{--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}:host::ng-deep .message-row{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}:host::ng-deep .message-row__input{flex-direction:column;background-color:#fff;position:relative;display:flex;align-items:center;flex-grow:1;padding:14px 8px 8px 15px;height:auto;overflow:visible;min-width:265px;border-radius:24px;border:1.5px solid transparent;box-shadow:0 2px 16px -10px #603cff29;transition:.35s ease}:host::ng-deep .message-row__input .abort-button,:host::ng-deep .message-row__input .send-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;border-radius:100px;color:#fff;transition:.15s ease-in-out;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box}:host::ng-deep .message-row__input .send-button,:host::ng-deep .message-row__input .abort-button{background:var(--disabled-bg);pointer-events:none}:host::ng-deep .message-row__input--focused{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;height:auto!important;background:#fff}:host::ng-deep .message-row__input--filled{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}:host::ng-deep .message-row__input--filled .send-button{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}:host::ng-deep .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:32px}:host::ng-deep .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}:host::ng-deep .message-row__input textarea{color:#333;width:100%;outline:none;min-height:30px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px;font-family:Poppins,sans-serif;font-size:14px;line-height:22px}:host::ng-deep .message-row__input textarea:focus{border:none}:host::ng-deep .message-row__input textarea::placeholder{color:#9ea1aa}:host::ng-deep .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}:host::ng-deep .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}:host::ng-deep dr-chat-dropped-files{margin-right:auto}:host::ng-deep dr-chat-dropped-files .dropped-files{padding:0}:host::ng-deep dr-chat-dropped-files .dropped-files__item{margin:0}:host::ng-deep .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}:host::ng-deep .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}\n"] }]
251
+ args: [{ selector: 'dr-chat-form-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"message-row\" [ngClass]=\"{ 'message-row_loading': isUploadingFiles }\">\n <div\n class=\"message-row__input\"\n [ngClass]=\"{\n 'message-row__input--focused': inputFocus,\n 'message-row__input--filled': !!message?.trim()?.length || !!(droppedFiles$ | async).length,\n }\">\n <dr-chat-dropped-files\n *ngIf=\"(droppedFiles$ | async).length\"\n [files]=\"droppedFiles$ | async\"\n [isRemovable]=\"true\"\n [maxLengthText]=\"15\"\n (removeFileEvent)=\"removeFile($event)\"></dr-chat-dropped-files>\n\n <div class=\"message-row__input-textarea-wrap\">\n <textarea\n #textAreaElement\n (focus)=\"inputFocus = true\"\n (blur)=\"inputFocus = false\"\n (mouseenter)=\"inputHover = true\"\n (mouseleave)=\"inputHover = false\"\n [(ngModel)]=\"message\"\n [rows]=\"1\"\n [style]=\"getTextAreaHeight(textAreaElement)\"\n (ngModelChange)=\"onModelChange($event)\"\n type=\"text\"\n placeholder=\"{{ fileOver ? dropFilePlaceholder : messagePlaceholder }}\"\n (keydown.enter)=\"sendMessage($event)\">\n </textarea>\n </div>\n <div class=\"message-row__btns\">\n <ng-content></ng-content>\n <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n <i *ngIf=\"!waitForReply\" (click)=\"sendMessage($event)\" class=\"dr-icon-send-arrow-up send-button\"></i>\n\n <i *ngIf=\"waitForReply && !showDotFlashing\" class=\"dr-icon-stop abort-button\" (click)=\"abortMessage()\"></i>\n <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n </div>\n <ng-content select=\"[dropItem]\"></ng-content>\n </div>\n</div>\n", styles: [":host::ng-deep{--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}:host::ng-deep .message-row{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}:host::ng-deep .message-row__input{flex-direction:column;background-color:#fff;position:relative;display:flex;align-items:center;flex-grow:1;padding:14px 8px 8px 15px;height:auto;overflow:visible;min-width:265px;border-radius:24px;border:1.5px solid transparent;box-shadow:0 2px 16px -10px #603cff29;transition:.35s ease;will-change:box-shadow}:host::ng-deep .message-row__input .abort-button,:host::ng-deep .message-row__input .send-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;border-radius:100px;color:#fff;transition:.15s ease-in-out;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box}:host::ng-deep .message-row__input .send-button,:host::ng-deep .message-row__input .abort-button{background:var(--disabled-bg);pointer-events:none}:host::ng-deep .message-row__input--focused{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;height:auto!important;background:#fff}:host::ng-deep .message-row__input--filled{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}:host::ng-deep .message-row__input--filled .send-button{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}:host::ng-deep .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:32px}:host::ng-deep .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}:host::ng-deep .message-row__input textarea{color:#333;width:100%;outline:none;min-height:30px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px;font-family:Poppins,sans-serif;font-size:14px;line-height:22px}:host::ng-deep .message-row__input textarea:focus{border:none}:host::ng-deep .message-row__input textarea::placeholder{color:#9ea1aa}:host::ng-deep .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}:host::ng-deep .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}:host::ng-deep dr-chat-dropped-files{margin-right:auto}:host::ng-deep dr-chat-dropped-files .dropped-files{padding:0}:host::ng-deep dr-chat-dropped-files .dropped-files__item{margin:0}:host::ng-deep .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}:host::ng-deep .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}\n"] }]
249
252
  }], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }]; }, { textAreaElementRef: [{
250
253
  type: ViewChild,
251
254
  args: ['textAreaElement']
@@ -287,4 +290,4 @@ export class DrChatFormDropdownComponent {
287
290
  type: HostListener,
288
291
  args: ['dragleave', ['$event']]
289
292
  }] }); })();
290
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-chat-form-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { IFIle } from '../../models/chat';\nimport { BehaviorSubject } from 'rxjs';\n\n@Component({\n    selector: 'dr-chat-form-dropdown',\n    templateUrl: './dr-chat-form-dropdown.component.html',\n    styleUrls: ['./dr-chat-form-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrChatFormDropdownComponent {\n    @ViewChild('textAreaElement') textAreaElementRef: ElementRef;\n    @ViewChild('fileInput') fileInput: ElementRef;\n    _textareaInitialHeight = true;\n    inputFocus = false;\n    inputHover = false;\n\n    droppedFiles$ = new BehaviorSubject<IFIle[]>([]);\n\n    @Input() isUploadingFiles = false;\n\n    /**\n     * Predefined message text\n     *\n     * @type {string}\n     */\n    @Input() message = '';\n\n    /**\n     * Message placeholder text\n     *\n     * @type {string}\n     */\n    @Input() messagePlaceholder = 'Type a message';\n\n    /**\n     * Show send button\n     *\n     * @type {boolean}\n     */\n    @Input() dropFiles = false;\n\n    /**\n     * File drop placeholder text\n     *\n     * @type {string}\n     */\n    @Input() dropFilePlaceholder = 'Drop file to send';\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() waitForReply = false;\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() showDotFlashing = false;\n\n    /**\n     *\n     * @type {EventEmitter<{ message: string, files: IFile[] }>}\n     */\n    @Output() send = new EventEmitter<{ message: string; files: IFIle[] }>();\n    @Output() uploadFiles = new EventEmitter<IFIle[]>();\n    @Output() abort = new EventEmitter<void>();\n\n    /**\n     * Emits when message input value has been changed\n     *\n     * @type {EventEmitter<string>}\n     */\n\n    @Output() inputChange = new EventEmitter<string>();\n\n    @HostBinding('class.file-over') fileOver = false;\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected domSanitizer: DomSanitizer,\n    ) {}\n\n    @HostListener('drop', ['$event'])\n    onDrop(event: any) {\n        if (this.dropFiles) {\n            event.preventDefault();\n            event.stopPropagation();\n\n            this.fileOver = false;\n            const files = event.dataTransfer?.files;\n            if (files) {\n                this.saveFiles(files);\n            }\n        }\n    }\n\n    removeFile(file: IFIle) {\n        const droppedFiles = this.droppedFiles$.value;\n        const index = droppedFiles.indexOf(file);\n        if (index >= 0) {\n            droppedFiles.splice(index, 1);\n            this.droppedFiles$.next(droppedFiles);\n        }\n    }\n\n    @HostListener('dragover', ['$event'])\n    onDragOver(event: DragEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.dropFiles) {\n            this.fileOver = true;\n        }\n    }\n\n    @HostListener('dragleave', ['$event'])\n    onDragLeave(event: DragEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.dropFiles) {\n            this.fileOver = false;\n        }\n    }\n\n    sendMessage($event: Event | KeyboardEvent) {\n        if (!$event || !($event as KeyboardEvent).shiftKey) {\n            $event?.preventDefault();\n            $event?.stopPropagation();\n            if (this.waitForReply || this.isUploadingFiles) {\n                return;\n            } else if (this.droppedFiles$.value.length || String(this.message).trim().length) {\n                this._textareaInitialHeight = true;\n                this.send.emit({ message: this.message, files: this.droppedFiles$.value });\n                this.message = '';\n                this.droppedFiles$.next([]);\n                this.cdr.markForCheck();\n            }\n        }\n    }\n\n    abortMessage() {\n        this.abort.emit();\n    }\n\n    onModelChange(value: string): void {\n        this._textareaInitialHeight = false;\n        this.inputChange.emit(value);\n    }\n\n    getTextAreaHeight(textAreaElement: HTMLTextAreaElement) {\n        if (this._textareaInitialHeight) {\n            textAreaElement.style.height = '30px';\n        } else {\n            textAreaElement.style.height = 'auto';\n            textAreaElement.style.height = textAreaElement.scrollHeight + 'px';\n        }\n\n        return `${textAreaElement.style.height}`;\n    }\n\n    onFileSelected(event: Event) {\n        const input = event.target as HTMLInputElement;\n        this.fileOver = false;\n        const files = input.files;\n        if (files && files.length) {\n            this.saveFiles(Array.from(files));\n        }\n        this.fileInput.nativeElement.value = '';\n    }\n\n    private async saveFiles(files: Array<File>) {\n        const uploadedFiles = [];\n        for (const file of files) {\n            let res = file as IFIle;\n            res.data = (await this.base64Convert(res)) as string;\n            this.droppedFiles$.next([...this.droppedFiles$.value, res]);\n            uploadedFiles.push(res);\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n        }\n        this.uploadFiles.emit(uploadedFiles.map((item) => ({ data: item.data, name: item.name })));\n    }\n\n    private base64Convert(file: any) {\n        return new Promise((resolve, reject) => {\n            const reader = new FileReader();\n            reader.onload = () => resolve(reader.result as string);\n            reader.onerror = (error) => reject(error);\n            reader.readAsDataURL(file);\n        });\n    }\n}\n","<div class=\"message-row\" [ngClass]=\"{ 'message-row_loading': isUploadingFiles }\">\n    <div\n        class=\"message-row__input\"\n        [ngClass]=\"{\n            'message-row__input--focused': inputFocus,\n            'message-row__input--filled': !!message?.trim()?.length || !!(droppedFiles$ | async).length,\n        }\">\n        <dr-chat-dropped-files\n            *ngIf=\"(droppedFiles$ | async).length\"\n            [files]=\"droppedFiles$ | async\"\n            [isRemovable]=\"true\"\n            [maxLengthText]=\"15\"\n            (removeFileEvent)=\"removeFile($event)\"></dr-chat-dropped-files>\n\n        <div class=\"message-row__input-textarea-wrap\">\n            <textarea\n                #textAreaElement\n                (focus)=\"inputFocus = true\"\n                (blur)=\"inputFocus = false\"\n                (mouseenter)=\"inputHover = true\"\n                (mouseleave)=\"inputHover = false\"\n                [(ngModel)]=\"message\"\n                [rows]=\"1\"\n                [style]=\"getTextAreaHeight(textAreaElement)\"\n                (ngModelChange)=\"onModelChange($event)\"\n                type=\"text\"\n                placeholder=\"{{ fileOver ? dropFilePlaceholder : messagePlaceholder }}\"\n                (keydown.enter)=\"sendMessage($event)\">\n            </textarea>\n        </div>\n        <div class=\"message-row__btns\">\n            <ng-content></ng-content>\n            <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n            <i *ngIf=\"!waitForReply\" (click)=\"sendMessage($event)\" class=\"dr-icon-send-arrow-up send-button\"></i>\n\n            <i *ngIf=\"waitForReply && !showDotFlashing\" class=\"dr-icon-stop abort-button\" (click)=\"abortMessage()\"></i>\n            <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n        </div>\n    </div>\n</div>\n"]}
293
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-chat-form-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { IFIle } from '../../models/chat';\nimport { BehaviorSubject } from 'rxjs';\n\n@Component({\n    selector: 'dr-chat-form-dropdown',\n    templateUrl: './dr-chat-form-dropdown.component.html',\n    styleUrls: ['./dr-chat-form-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrChatFormDropdownComponent {\n    @ViewChild('textAreaElement') textAreaElementRef: ElementRef;\n    @ViewChild('fileInput') fileInput: ElementRef;\n    _textareaInitialHeight = true;\n    inputFocus = false;\n    inputHover = false;\n\n    droppedFiles$ = new BehaviorSubject<IFIle[]>([]);\n\n    @Input() isUploadingFiles = false;\n\n    /**\n     * Predefined message text\n     *\n     * @type {string}\n     */\n    @Input() message = '';\n\n    /**\n     * Message placeholder text\n     *\n     * @type {string}\n     */\n    @Input() messagePlaceholder = 'Type a message';\n\n    /**\n     * Show send button\n     *\n     * @type {boolean}\n     */\n    @Input() dropFiles = false;\n\n    /**\n     * File drop placeholder text\n     *\n     * @type {string}\n     */\n    @Input() dropFilePlaceholder = 'Drop file to send';\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() waitForReply = false;\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() showDotFlashing = false;\n\n    /**\n     *\n     * @type {EventEmitter<{ message: string, files: IFile[] }>}\n     */\n    @Output() send = new EventEmitter<{ message: string; files: IFIle[] }>();\n    @Output() uploadFiles = new EventEmitter<IFIle[]>();\n    @Output() abort = new EventEmitter<void>();\n\n    /**\n     * Emits when message input value has been changed\n     *\n     * @type {EventEmitter<string>}\n     */\n\n    @Output() inputChange = new EventEmitter<string>();\n\n    @HostBinding('class.file-over') fileOver = false;\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected domSanitizer: DomSanitizer,\n    ) {}\n\n    @HostListener('drop', ['$event'])\n    onDrop(event: any) {\n        if (this.dropFiles) {\n            event.preventDefault();\n            event.stopPropagation();\n\n            this.fileOver = false;\n            const files = event.dataTransfer?.files;\n            if (files) {\n                this.saveFiles(files);\n            }\n        }\n    }\n\n    removeFile(file: IFIle) {\n        const droppedFiles = this.droppedFiles$.value;\n        const index = droppedFiles.indexOf(file);\n        if (index >= 0) {\n            droppedFiles.splice(index, 1);\n            this.droppedFiles$.next(droppedFiles);\n        }\n    }\n\n    @HostListener('dragover', ['$event'])\n    onDragOver(event: DragEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.dropFiles) {\n            this.fileOver = true;\n        }\n    }\n\n    @HostListener('dragleave', ['$event'])\n    onDragLeave(event: DragEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.dropFiles) {\n            this.fileOver = false;\n        }\n    }\n\n    sendMessage($event: Event | KeyboardEvent) {\n        if (!$event || !($event as KeyboardEvent).shiftKey) {\n            $event?.preventDefault();\n            $event?.stopPropagation();\n            if (this.waitForReply || this.isUploadingFiles) {\n                return;\n            } else if (this.droppedFiles$.value.length || String(this.message).trim().length) {\n                this._textareaInitialHeight = true;\n                this.send.emit({ message: this.message, files: this.droppedFiles$.value });\n                this.message = '';\n                this.droppedFiles$.next([]);\n                this.cdr.markForCheck();\n            }\n        }\n    }\n\n    abortMessage() {\n        this.abort.emit();\n    }\n\n    onModelChange(value: string): void {\n        this._textareaInitialHeight = false;\n        this.inputChange.emit(value);\n    }\n\n    getTextAreaHeight(textAreaElement: HTMLTextAreaElement) {\n        if (this._textareaInitialHeight) {\n            textAreaElement.style.height = '30px';\n        } else {\n            textAreaElement.style.height = 'auto';\n            textAreaElement.style.height = textAreaElement.scrollHeight + 'px';\n        }\n\n        return `${textAreaElement.style.height}`;\n    }\n\n    onFileSelected(event: Event) {\n        const input = event.target as HTMLInputElement;\n        this.fileOver = false;\n        const files = input.files;\n        if (files && files.length) {\n            this.saveFiles(Array.from(files));\n        }\n        this.fileInput.nativeElement.value = '';\n    }\n\n    private async saveFiles(files: Array<File>) {\n        const uploadedFiles = [];\n        for (const file of files) {\n            let res = file as IFIle;\n            res.data = (await this.base64Convert(res)) as string;\n            this.droppedFiles$.next([...this.droppedFiles$.value, res]);\n            uploadedFiles.push(res);\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n        }\n        this.uploadFiles.emit(uploadedFiles.map((item) => ({ data: item.data, name: item.name })));\n    }\n\n    private base64Convert(file: any) {\n        return new Promise((resolve, reject) => {\n            const reader = new FileReader();\n            reader.onload = () => resolve(reader.result as string);\n            reader.onerror = (error) => reject(error);\n            reader.readAsDataURL(file);\n        });\n    }\n}\n","<div class=\"message-row\" [ngClass]=\"{ 'message-row_loading': isUploadingFiles }\">\n    <div\n        class=\"message-row__input\"\n        [ngClass]=\"{\n            'message-row__input--focused': inputFocus,\n            'message-row__input--filled': !!message?.trim()?.length || !!(droppedFiles$ | async).length,\n        }\">\n        <dr-chat-dropped-files\n            *ngIf=\"(droppedFiles$ | async).length\"\n            [files]=\"droppedFiles$ | async\"\n            [isRemovable]=\"true\"\n            [maxLengthText]=\"15\"\n            (removeFileEvent)=\"removeFile($event)\"></dr-chat-dropped-files>\n\n        <div class=\"message-row__input-textarea-wrap\">\n            <textarea\n                #textAreaElement\n                (focus)=\"inputFocus = true\"\n                (blur)=\"inputFocus = false\"\n                (mouseenter)=\"inputHover = true\"\n                (mouseleave)=\"inputHover = false\"\n                [(ngModel)]=\"message\"\n                [rows]=\"1\"\n                [style]=\"getTextAreaHeight(textAreaElement)\"\n                (ngModelChange)=\"onModelChange($event)\"\n                type=\"text\"\n                placeholder=\"{{ fileOver ? dropFilePlaceholder : messagePlaceholder }}\"\n                (keydown.enter)=\"sendMessage($event)\">\n            </textarea>\n        </div>\n        <div class=\"message-row__btns\">\n            <ng-content></ng-content>\n            <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n            <i *ngIf=\"!waitForReply\" (click)=\"sendMessage($event)\" class=\"dr-icon-send-arrow-up send-button\"></i>\n\n            <i *ngIf=\"waitForReply && !showDotFlashing\" class=\"dr-icon-stop abort-button\" (click)=\"abortMessage()\"></i>\n            <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n        </div>\n        <ng-content select=\"[dropItem]\"></ng-content>\n    </div>\n</div>\n"]}
@@ -59,7 +59,7 @@ function DrDynamicTagComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
59
59
  } if (rf & 2) {
60
60
  const item_r12 = ctx.item;
61
61
  const ctx_r5 = i0.ɵɵnextContext();
62
- i0.ɵɵclassProp("disabled", ctx_r5.lockedTags.includes((item_r12 == null ? null : item_r12.value) || item_r12));
62
+ i0.ɵɵclassProp("disabled", ctx_r5.isLockedTag((item_r12 == null ? null : item_r12.value) || item_r12));
63
63
  i0.ɵɵadvance(2);
64
64
  i0.ɵɵtextInterpolate((item_r12 == null ? null : item_r12.value) || item_r12);
65
65
  i0.ɵɵadvance(1);
@@ -92,7 +92,7 @@ export class DrDynamicTagComponent {
92
92
  id: this.tagConfig.id,
93
93
  name: this.tagConfig.name,
94
94
  value: $event,
95
- locked: this.lockedTags.includes($event),
95
+ locked: this.isLockedTag($event),
96
96
  };
97
97
  if (!_isNil(this.selectedTag?.locked)) {
98
98
  resultEvent.locked = this.selectedTag.locked;
@@ -104,7 +104,7 @@ export class DrDynamicTagComponent {
104
104
  this.tagChange.emit(resultEvent);
105
105
  }
106
106
  onOptionClick($event, tagValue) {
107
- if (this.lockedTags.includes(tagValue)) {
107
+ if (this.isLockedTag(tagValue)) {
108
108
  $event.stopImmediatePropagation();
109
109
  }
110
110
  }
@@ -141,20 +141,33 @@ export class DrDynamicTagComponent {
141
141
  }
142
142
  getParentValueKey() {
143
143
  return _map(this.connectedTags, (connectedTag) => {
144
- if (_isNumber(connectedTag.value)) {
145
- const momentData = moment.unix(connectedTag.value);
146
- const convertedParentKey = this.parentKeyFormatterFn
147
- ? this.parentKeyFormatterFn(momentData)
148
- : momentData.format(this.parentKeyFormat);
149
- if (momentData.isValid() && convertedParentKey) {
150
- return convertedParentKey;
151
- }
152
- }
153
- return connectedTag.value;
144
+ return this.getSingleParentKey(connectedTag.value);
154
145
  }).join('__');
155
146
  }
147
+ isLockedTag(tagValue) {
148
+ if (!!this.lockedMultipleTags?.length) {
149
+ return this.hasLockedTagInMultiple(tagValue);
150
+ }
151
+ return this.lockedTags.includes(tagValue);
152
+ }
153
+ getSingleParentKey(value) {
154
+ if (_isNumber(value)) {
155
+ const momentData = moment.unix(value);
156
+ const convertedParentKey = this.parentKeyFormatterFn
157
+ ? this.parentKeyFormatterFn(momentData)
158
+ : momentData.format(this.parentKeyFormat);
159
+ if (momentData.isValid() && convertedParentKey) {
160
+ return convertedParentKey;
161
+ }
162
+ }
163
+ return value;
164
+ }
165
+ hasLockedTagInMultiple(selectedTagValue) {
166
+ const parentValueKey = this.getParentValueKey();
167
+ return this.lockedMultipleTags?.some((tag) => tag.value === selectedTagValue && this.getSingleParentKey(tag.parent_tag_value) === parentValueKey);
168
+ }
156
169
  /** @nocollapse */ static { this.ɵfac = function DrDynamicTagComponent_Factory(t) { return new (t || DrDynamicTagComponent)(); }; }
157
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDynamicTagComponent, selectors: [["dr-dynamic-tag"]], inputs: { values: "values", tagConfig: "tagConfig", selectedTag: "selectedTag", hideLabel: "hideLabel", lockedTags: "lockedTags", connectedTags: "connectedTags", isDynamicTagAddEnabled: "isDynamicTagAddEnabled", disabled: "disabled", fiscalYearStartsFrom: "fiscalYearStartsFrom", fiscalYearBack: "fiscalYearBack", parentKeyFormat: "parentKeyFormat", parentKeyFormatterFn: "parentKeyFormatterFn", label: "label", hideFavoriteStar: "hideFavoriteStar" }, outputs: { tagChange: "tagChange", tagAdd: "tagAdd" }, features: [i0.ɵɵNgOnChangesFeature], decls: 7, vars: 7, consts: [["class", "dynamic-tag__label", 4, "ngIf"], ["bindLabel", "value", "bindValue", "value", "dropdownClass", "dynamic-tag__select dr-tag__select", 3, "ngModel", "items", "disabled", "ngModelChange"], [4, "ngIf"], ["labelTemplate", ""], ["optionTemplate", ""], [1, "dynamic-tag__label"], ["optionHeaderTemplate", ""], ["bindValue", "value", 3, "values", "dynamicAddLabel", "dynamicValueAdded"], [1, "dynamic-tag__field--label"], [1, "dynamic-tag__field__text"], ["class", "dynamic-tag__field__icon dr-icon-star-fill", 4, "ngIf"], [1, "dynamic-tag__field__icon", "dr-icon-star-fill"], [1, "dynamic-tag__field--option", 3, "click"]], template: function DrDynamicTagComponent_Template(rf, ctx) { if (rf & 1) {
170
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDynamicTagComponent, selectors: [["dr-dynamic-tag"]], inputs: { values: "values", tagConfig: "tagConfig", selectedTag: "selectedTag", hideLabel: "hideLabel", lockedTags: "lockedTags", connectedTags: "connectedTags", isDynamicTagAddEnabled: "isDynamicTagAddEnabled", disabled: "disabled", lockedMultipleTags: "lockedMultipleTags", tagsConfig: "tagsConfig", fiscalYearStartsFrom: "fiscalYearStartsFrom", fiscalYearBack: "fiscalYearBack", parentKeyFormat: "parentKeyFormat", parentKeyFormatterFn: "parentKeyFormatterFn", label: "label", hideFavoriteStar: "hideFavoriteStar" }, outputs: { tagChange: "tagChange", tagAdd: "tagAdd" }, features: [i0.ɵɵNgOnChangesFeature], decls: 7, vars: 7, consts: [["class", "dynamic-tag__label", 4, "ngIf"], ["bindLabel", "value", "bindValue", "value", "dropdownClass", "dynamic-tag__select dr-tag__select", 3, "ngModel", "items", "disabled", "ngModelChange"], [4, "ngIf"], ["labelTemplate", ""], ["optionTemplate", ""], [1, "dynamic-tag__label"], ["optionHeaderTemplate", ""], ["bindValue", "value", 3, "values", "dynamicAddLabel", "dynamicValueAdded"], [1, "dynamic-tag__field--label"], [1, "dynamic-tag__field__text"], ["class", "dynamic-tag__field__icon dr-icon-star-fill", 4, "ngIf"], [1, "dynamic-tag__field__icon", "dr-icon-star-fill"], [1, "dynamic-tag__field--option", 3, "click"]], template: function DrDynamicTagComponent_Template(rf, ctx) { if (rf & 1) {
158
171
  i0.ɵɵtemplate(0, DrDynamicTagComponent_p_0_Template, 2, 1, "p", 0);
159
172
  i0.ɵɵelementStart(1, "dr-select", 1);
160
173
  i0.ɵɵlistener("ngModelChange", function DrDynamicTagComponent_Template_dr_select_ngModelChange_1_listener($event) { return ctx.selectedDynamicTag = $event; })("ngModelChange", function DrDynamicTagComponent_Template_dr_select_ngModelChange_1_listener($event) { return ctx.onTagChanged($event); });
@@ -173,7 +186,7 @@ export class DrDynamicTagComponent {
173
186
  }
174
187
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrDynamicTagComponent, [{
175
188
  type: Component,
176
- args: [{ selector: 'dr-dynamic-tag', template: "<p *ngIf=\"!hideLabel\" class=\"dynamic-tag__label\">{{ label || tagConfig.name }}</p>\n<dr-select\n [(ngModel)]=\"selectedDynamicTag\"\n [class.dynamic-tag__locked]=\"isLockedTagSelected\"\n bindLabel=\"value\"\n bindValue=\"value\"\n [items]=\"currentValues\"\n [disabled]=\"disabled\"\n dropdownClass=\"dynamic-tag__select dr-tag__select\"\n (ngModelChange)=\"onTagChanged($event)\">\n <ng-template #optionHeaderTemplate *ngIf=\"isDynamicTagAddEnabled\">\n <dr-select-add-item\n 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 && !hideFavoriteStar\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n <ng-template #optionTemplate let-item=\"item\">\n <div\n class=\"dynamic-tag__field--option\"\n [class.disabled]=\"lockedTags.includes(item?.value || item)\"\n (click)=\"onOptionClick($event, item?.value || item)\">\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", styles: [":host{flex-grow:1}.dynamic-tag__label{margin:0 0 4px;color:#0c142b;font-size:14px;font-weight:400;line-height:22px}.dynamic-tag__field{cursor:pointer;height:24px}.dynamic-tag__field--option{cursor:pointer;height:24px;padding:8px 12px;width:100%;display:flex;justify-content:space-between;align-items:center}.dynamic-tag__field--option.disabled{opacity:.5;box-sizing:content-box}.dynamic-tag__field--label{cursor:pointer;height:24px;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}::ng-deep dr-select.dynamic-tag__locked>ng-select>.ng-select-container{opacity:.4}::ng-deep .ng-option:has(.dynamic-tag__field--option){padding:0!important}\n"] }]
189
+ args: [{ selector: 'dr-dynamic-tag', template: "<p *ngIf=\"!hideLabel\" class=\"dynamic-tag__label\">{{ label || tagConfig.name }}</p>\n<dr-select\n [(ngModel)]=\"selectedDynamicTag\"\n [class.dynamic-tag__locked]=\"isLockedTagSelected\"\n bindLabel=\"value\"\n bindValue=\"value\"\n [items]=\"currentValues\"\n [disabled]=\"disabled\"\n dropdownClass=\"dynamic-tag__select dr-tag__select\"\n (ngModelChange)=\"onTagChanged($event)\">\n <ng-template #optionHeaderTemplate *ngIf=\"isDynamicTagAddEnabled\">\n <dr-select-add-item\n 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 && !hideFavoriteStar\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n <ng-template #optionTemplate let-item=\"item\">\n <div\n class=\"dynamic-tag__field--option\"\n [class.disabled]=\"isLockedTag(item?.value || item)\"\n (click)=\"onOptionClick($event, item?.value || item)\">\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", styles: [":host{flex-grow:1}.dynamic-tag__label{margin:0 0 4px;color:#0c142b;font-size:14px;font-weight:400;line-height:22px}.dynamic-tag__field{cursor:pointer;height:24px}.dynamic-tag__field--option{cursor:pointer;height:24px;padding:8px 12px;width:100%;display:flex;justify-content:space-between;align-items:center}.dynamic-tag__field--option.disabled{opacity:.5;box-sizing:content-box}.dynamic-tag__field--label{cursor:pointer;height:24px;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}::ng-deep dr-select.dynamic-tag__locked>ng-select>.ng-select-container{opacity:.4}::ng-deep .ng-option:has(.dynamic-tag__field--option){padding:0!important}\n"] }]
177
190
  }], null, { values: [{
178
191
  type: Input
179
192
  }], tagConfig: [{
@@ -190,6 +203,10 @@ export class DrDynamicTagComponent {
190
203
  type: Input
191
204
  }], disabled: [{
192
205
  type: Input
206
+ }], lockedMultipleTags: [{
207
+ type: Input
208
+ }], tagsConfig: [{
209
+ type: Input
193
210
  }], fiscalYearStartsFrom: [{
194
211
  type: Input
195
212
  }], fiscalYearBack: [{
@@ -207,4 +224,4 @@ export class DrDynamicTagComponent {
207
224
  }], tagAdd: [{
208
225
  type: Output
209
226
  }] }); })();
210
- //# 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","../../../../../projects/datarailsshared/src/lib/dr-dynamic-tag/dr-dynamic-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { find as _find, isNil as _isNil, isNumber as _isNumber, isObject as _isObject, map as _map } from 'lodash';\nimport { IDynamicTag, ITag, ITagForServer, TDynamicTag, TDynamicTagValue } from '../models/serverTags';\nimport 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    @Input() public values: TDynamicTag;\n    @Input() public tagConfig: ITag;\n    @Input() public selectedTag: ITagForServer;\n    @Input() public hideLabel: boolean = false;\n    @Input() public lockedTags: any[] = [];\n    @Input() public connectedTags: ITagForServer[];\n    @Input() public isDynamicTagAddEnabled: boolean;\n    @Input() public disabled: boolean;\n\n    @Input() fiscalYearStartsFrom: number;\n    @Input() fiscalYearBack: boolean;\n\n    @Input() set parentKeyFormat(format: string) {\n        this._parentKeyFormat = format || this.DEFAULT_PARENT_KEY_FORMAT;\n    }\n\n    @Input() parentKeyFormatterFn: (momentData) => string;\n\n    @Input() label: string;\n    @Input() hideFavoriteStar: 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    public isLockedTagSelected: boolean;\n\n    private readonly DEFAULT_PARENT_KEY_FORMAT = 'yyyy';\n    private _parentKeyFormat: string = this.DEFAULT_PARENT_KEY_FORMAT;\n\n    public get parentKeyFormat(): string {\n        return this._parentKeyFormat;\n    }\n\n    public get isPrimitiveDataSource(): boolean {\n        const values = Object.values(this.values) || [];\n        return !_isObject(values[0]);\n    }\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            locked: this.lockedTags.includes($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.isLockedTagSelected = resultEvent.locked;\n        this.tagChange.emit(resultEvent);\n    }\n\n    public onOptionClick($event: Event, tagValue: string | number): void {\n        if (this.lockedTags.includes(tagValue)) {\n            $event.stopImmediatePropagation();\n        }\n    }\n\n    public onDynamicValueAdd($event: string) {\n        const parentValueKey = this.getParentValueKey();\n        const parentValues = this.values[parentValueKey] || [];\n\n        if (this.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, (connectedTag) => {\n            if (_isNumber(connectedTag.value)) {\n                const momentData = moment.unix(connectedTag.value);\n\n                const convertedParentKey = this.parentKeyFormatterFn\n                    ? this.parentKeyFormatterFn(momentData)\n                    : momentData.format(this.parentKeyFormat);\n\n                if (momentData.isValid() && convertedParentKey) {\n                    return convertedParentKey;\n                }\n            }\n\n            return connectedTag.value;\n        }).join('__');\n    }\n}\n","<p *ngIf=\"!hideLabel\" class=\"dynamic-tag__label\">{{ label || tagConfig.name }}</p>\n<dr-select\n    [(ngModel)]=\"selectedDynamicTag\"\n    [class.dynamic-tag__locked]=\"isLockedTagSelected\"\n    bindLabel=\"value\"\n    bindValue=\"value\"\n    [items]=\"currentValues\"\n    [disabled]=\"disabled\"\n    dropdownClass=\"dynamic-tag__select dr-tag__select\"\n    (ngModelChange)=\"onTagChanged($event)\">\n    <ng-template #optionHeaderTemplate *ngIf=\"isDynamicTagAddEnabled\">\n        <dr-select-add-item\n            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 && !hideFavoriteStar\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n        </div>\n    </ng-template>\n    <ng-template #optionTemplate let-item=\"item\">\n        <div\n            class=\"dynamic-tag__field--option\"\n            [class.disabled]=\"lockedTags.includes(item?.value || item)\"\n            (click)=\"onOptionClick($event, item?.value || item)\">\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"]}
227
+ //# 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","../../../../../projects/datarailsshared/src/lib/dr-dynamic-tag/dr-dynamic-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { find as _find, isNil as _isNil, isNumber as _isNumber, isObject as _isObject, map as _map } from 'lodash';\nimport { IDynamicTag, ITag, ITagForServer, TDynamicTag, TDynamicTagValue } from '../models/serverTags';\nimport moment from 'moment';\nimport { IMultipleLockedTag } from '../dr-tags/dr-tag.types';\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    @Input() public values: TDynamicTag;\n    @Input() public tagConfig: ITag;\n    @Input() public selectedTag: ITagForServer;\n    @Input() public hideLabel: boolean = false;\n    @Input() public lockedTags: any[] = [];\n    @Input() public connectedTags: ITagForServer[];\n    @Input() public isDynamicTagAddEnabled: boolean;\n    @Input() public disabled: boolean;\n\n    @Input() public lockedMultipleTags: IMultipleLockedTag[];\n    @Input() public tagsConfig: ITag[];\n\n    @Input() fiscalYearStartsFrom: number;\n    @Input() fiscalYearBack: boolean;\n\n    @Input() set parentKeyFormat(format: string) {\n        this._parentKeyFormat = format || this.DEFAULT_PARENT_KEY_FORMAT;\n    }\n\n    @Input() parentKeyFormatterFn: (momentData) => string;\n\n    @Input() label: string;\n    @Input() hideFavoriteStar: 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    public isLockedTagSelected: boolean;\n\n    private readonly DEFAULT_PARENT_KEY_FORMAT = 'yyyy';\n    private _parentKeyFormat: string = this.DEFAULT_PARENT_KEY_FORMAT;\n\n    public get parentKeyFormat(): string {\n        return this._parentKeyFormat;\n    }\n\n    public get isPrimitiveDataSource(): boolean {\n        const values = Object.values(this.values) || [];\n        return !_isObject(values[0]);\n    }\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            locked: this.isLockedTag($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.isLockedTagSelected = resultEvent.locked;\n        this.tagChange.emit(resultEvent);\n    }\n\n    public onOptionClick($event: Event, tagValue: string | number): void {\n        if (this.isLockedTag(tagValue)) {\n            $event.stopImmediatePropagation();\n        }\n    }\n\n    public onDynamicValueAdd($event: string) {\n        const parentValueKey = this.getParentValueKey();\n        const parentValues = this.values[parentValueKey] || [];\n\n        if (this.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, (connectedTag) => {\n            return this.getSingleParentKey(connectedTag.value);\n        }).join('__');\n    }\n\n    isLockedTag(tagValue: string | number): boolean {\n        if (!!this.lockedMultipleTags?.length) {\n            return this.hasLockedTagInMultiple(tagValue);\n        }\n        return this.lockedTags.includes(tagValue);\n    }\n\n    private getSingleParentKey(value: string | number) {\n        if (_isNumber(value)) {\n            const momentData = moment.unix(value);\n\n            const convertedParentKey = this.parentKeyFormatterFn\n                ? this.parentKeyFormatterFn(momentData)\n                : momentData.format(this.parentKeyFormat);\n\n            if (momentData.isValid() && convertedParentKey) {\n                return convertedParentKey;\n            }\n        }\n\n        return value;\n    }\n\n    private hasLockedTagInMultiple(selectedTagValue: string | number): boolean {\n        const parentValueKey = this.getParentValueKey();\n        return this.lockedMultipleTags?.some(\n            (tag) => tag.value === selectedTagValue && this.getSingleParentKey(tag.parent_tag_value) === parentValueKey,\n        );\n    }\n}\n","<p *ngIf=\"!hideLabel\" class=\"dynamic-tag__label\">{{ label || tagConfig.name }}</p>\n<dr-select\n    [(ngModel)]=\"selectedDynamicTag\"\n    [class.dynamic-tag__locked]=\"isLockedTagSelected\"\n    bindLabel=\"value\"\n    bindValue=\"value\"\n    [items]=\"currentValues\"\n    [disabled]=\"disabled\"\n    dropdownClass=\"dynamic-tag__select dr-tag__select\"\n    (ngModelChange)=\"onTagChanged($event)\">\n    <ng-template #optionHeaderTemplate *ngIf=\"isDynamicTagAddEnabled\">\n        <dr-select-add-item\n            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 && !hideFavoriteStar\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n        </div>\n    </ng-template>\n    <ng-template #optionTemplate let-item=\"item\">\n        <div\n            class=\"dynamic-tag__field--option\"\n            [class.disabled]=\"isLockedTag(item?.value || item)\"\n            (click)=\"onOptionClick($event, item?.value || item)\">\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"]}