@datarailsshared/datarailsshared 1.4.194-rocket → 1.4.201-rocket

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (113) hide show
  1. package/datarailsshared-datarailsshared-1.4.201-rocket.tgz +0 -0
  2. package/esm2022/lib/date-tags/any-tag.component.mjs +7 -8
  3. package/esm2022/lib/date-tags/date-tag.component.mjs +10 -11
  4. package/esm2022/lib/date-tags/date-tag.module.mjs +6 -6
  5. package/esm2022/lib/date-tags/day-tag/day-tag.component.mjs +6 -7
  6. package/esm2022/lib/date-tags/forecast-tag/forecast-tag.component.mjs +22 -24
  7. package/esm2022/lib/date-tags/month-tag/month-tag.component.mjs +6 -7
  8. package/esm2022/lib/date-tags/quarter-tag/quarter-tag.component.mjs +7 -7
  9. package/esm2022/lib/date-tags/week-tag/week-tag.component.mjs +6 -7
  10. package/esm2022/lib/date-tags/year-tag/year-tag.component.mjs +6 -7
  11. package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +8 -10
  12. package/esm2022/lib/directives/click-outside/click-outside.module.mjs +4 -4
  13. package/esm2022/lib/dr-accordion/accordion-item-body.component.mjs +7 -8
  14. package/esm2022/lib/dr-accordion/accordion-item-header.component.mjs +7 -8
  15. package/esm2022/lib/dr-accordion/accordion-item.component.mjs +15 -19
  16. package/esm2022/lib/dr-accordion/accordion.component.mjs +7 -6
  17. package/esm2022/lib/dr-accordion/accordion.module.mjs +5 -5
  18. package/esm2022/lib/dr-avatar/dr-avatar.component.mjs +7 -7
  19. package/esm2022/lib/dr-avatar/dr-avatar.module.mjs +6 -6
  20. package/esm2022/lib/dr-avatar/dr-avatar.pipe.mjs +3 -3
  21. package/esm2022/lib/dr-badge-status/dr-badge-status.component.mjs +4 -7
  22. package/esm2022/lib/dr-badge-status/dr-badge-status.module.mjs +6 -6
  23. package/esm2022/lib/dr-chat/chat.component.mjs +18 -27
  24. package/esm2022/lib/dr-chat/chat.module.mjs +6 -6
  25. package/esm2022/lib/dr-chat/dr-chat-form/chat-form.component.mjs +52 -53
  26. package/esm2022/lib/dr-chat/dr-chat-message/chat-message.component.mjs +8 -27
  27. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.directive.mjs +5 -7
  28. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.service.mjs +6 -4
  29. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-file/chat-message-file.component.mjs +5 -13
  30. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-text/chat-message-text.component.mjs +3 -9
  31. package/esm2022/lib/dr-chat/dr-chat-suggestions/chat-suggestions.component.mjs +17 -18
  32. package/esm2022/lib/dr-chat/dr-dot-flashing/dr-dot-flashing.component.mjs +3 -3
  33. package/esm2022/lib/dr-details-list/dr-details-list.component.mjs +10 -9
  34. package/esm2022/lib/dr-details-list/dr-details-list.module.mjs +4 -4
  35. package/esm2022/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.mjs +12 -15
  36. package/esm2022/lib/dr-dialog/components/dialog-wrapper/dialog-wrapper.component.mjs +13 -18
  37. package/esm2022/lib/dr-dialog/dialog.module.mjs +6 -6
  38. package/esm2022/lib/dr-dialog/services/dialog.service.mjs +4 -5
  39. package/esm2022/lib/dr-dropdown/dr-dropdown-item-show.pipe.mjs +3 -3
  40. package/esm2022/lib/dr-dropdown/dr-dropdown-position.directive.mjs +5 -9
  41. package/esm2022/lib/dr-dropdown/dr-dropdown.component.mjs +7 -15
  42. package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +7 -15
  43. package/esm2022/lib/dr-dropdown/dr-dropdown.module.mjs +6 -6
  44. package/esm2022/lib/dr-dropdown/dr-dropdown.service.mjs +4 -5
  45. package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.component.mjs +10 -17
  46. package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.module.mjs +6 -6
  47. package/esm2022/lib/dr-error/dr-error.component.mjs +8 -10
  48. package/esm2022/lib/dr-error/dr-error.module.mjs +6 -6
  49. package/esm2022/lib/dr-inputs/button/button.component.mjs +10 -14
  50. package/esm2022/lib/dr-inputs/checkbox/checkbox.component.mjs +13 -15
  51. package/esm2022/lib/dr-inputs/date-pickers/directives/dr-date-picker-format.directive.mjs +5 -8
  52. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.mjs +31 -38
  53. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +21 -25
  54. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.mjs +59 -62
  55. package/esm2022/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.mjs +3 -3
  56. package/esm2022/lib/dr-inputs/date-pickers/services/dr-date-picker.service.mjs +29 -30
  57. package/esm2022/lib/dr-inputs/dr-input/dr-input.component.mjs +33 -47
  58. package/esm2022/lib/dr-inputs/dr-inputs.module.mjs +6 -6
  59. package/esm2022/lib/dr-inputs/dr-model-debounce-change.directive.mjs +6 -7
  60. package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +19 -42
  61. package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +9 -12
  62. package/esm2022/lib/dr-inputs/dr-toggle/dr-toggle.component.mjs +12 -17
  63. package/esm2022/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.mjs +16 -19
  64. package/esm2022/lib/dr-inputs/radio-button/radio-button.component.mjs +11 -15
  65. package/esm2022/lib/dr-inputs/radio-button/radio-group.component.mjs +13 -20
  66. package/esm2022/lib/dr-layout/dr-layout-body.component.mjs +3 -3
  67. package/esm2022/lib/dr-layout/dr-layout-header.component.mjs +4 -4
  68. package/esm2022/lib/dr-layout/dr-layout.component.mjs +3 -3
  69. package/esm2022/lib/dr-layout/dr-layout.module.mjs +5 -5
  70. package/esm2022/lib/dr-popover/dr-popover-ref.mjs +7 -10
  71. package/esm2022/lib/dr-popover/dr-popover.component.mjs +10 -25
  72. package/esm2022/lib/dr-popover/dr-popover.directive.mjs +16 -21
  73. package/esm2022/lib/dr-popover/dr-popover.module.mjs +5 -5
  74. package/esm2022/lib/dr-popover/dr-popover.service.mjs +4 -7
  75. package/esm2022/lib/dr-scenario/components/dr-scenario-configuration/dr-scenario-configuration.component.mjs +9 -14
  76. package/esm2022/lib/dr-scenario/components/dr-scenario-tag-configuration/dr-scenario-tag-configuration.component.mjs +14 -16
  77. package/esm2022/lib/dr-scenario/dr-scenario.module.mjs +6 -6
  78. package/esm2022/lib/dr-scenario/services/scenario.service.mjs +6 -7
  79. package/esm2022/lib/dr-spinner/dr-spinner.component.mjs +3 -4
  80. package/esm2022/lib/dr-spinner/dr-spinner.directive.mjs +6 -13
  81. package/esm2022/lib/dr-spinner/dr-spinner.module.mjs +4 -4
  82. package/esm2022/lib/dr-tabs/dr-tab.component.mjs +4 -9
  83. package/esm2022/lib/dr-tabs/dr-tabs.component.mjs +9 -13
  84. package/esm2022/lib/dr-tabs/dr-tabs.module.mjs +6 -6
  85. package/esm2022/lib/dr-tags/dr-tag.component.mjs +12 -25
  86. package/esm2022/lib/dr-tags/dr-tag.module.mjs +6 -6
  87. package/esm2022/lib/dr-tooltip/components/tooltip-info/tooltip-info.component.mjs +3 -5
  88. package/esm2022/lib/dr-tooltip/components/tooltip-info-simple/tooltip-info-simple.component.mjs +3 -4
  89. package/esm2022/lib/dr-tooltip/components/tooltip-no-body/tooltip-no-body.component.mjs +3 -4
  90. package/esm2022/lib/dr-tooltip/components/tooltip-process-default/tooltip-process-default.component.mjs +4 -5
  91. package/esm2022/lib/dr-tooltip/dr-tooltip.component.mjs +6 -11
  92. package/esm2022/lib/dr-tooltip/dr-tooltip.directive.mjs +11 -20
  93. package/esm2022/lib/dr-tooltip/dr-tooltip.module.mjs +5 -5
  94. package/esm2022/lib/dr-treeview/components/treeview/treeview.component.mjs +10 -19
  95. package/esm2022/lib/dr-treeview/components/treeview-item/treeview-item.component.mjs +17 -19
  96. package/esm2022/lib/dr-treeview/dr-tree-view.module.mjs +6 -6
  97. package/esm2022/lib/dr-treeview/helpers/treeview-event-parser.mjs +14 -11
  98. package/esm2022/lib/dr-treeview/models/treeview-config.mjs +10 -8
  99. package/esm2022/lib/dr-treeview/models/treeview-i18n.mjs +5 -5
  100. package/esm2022/lib/dr-treeview/models/treeview-item.mjs +4 -7
  101. package/esm2022/lib/dr-treeview/pipes/treeview.pipe.mjs +3 -3
  102. package/esm2022/lib/list-tags/list-tag.component.mjs +5 -8
  103. package/esm2022/lib/list-tags/list-tag.module.mjs +6 -6
  104. package/esm2022/lib/models/chat.mjs +1 -14
  105. package/esm2022/lib/models/datePicker.mjs +14 -12
  106. package/esm2022/lib/stepper/stepper.component.mjs +9 -12
  107. package/esm2022/lib/stepper/stepper.module.mjs +6 -6
  108. package/esm2022/lib/utils/dr-shared-utils.mjs +2 -2
  109. package/fesm2022/datarailsshared-datarailsshared.mjs +895 -1219
  110. package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
  111. package/lib/dr-dialog/components/dialog-wrapper/dialog-wrapper.component.d.ts +1 -1
  112. package/package.json +1 -1
  113. package/datarailsshared-datarailsshared-1.4.194-rocket.tgz +0 -0
@@ -1,14 +1,10 @@
1
- import { Directive, Input } from '@angular/core';
1
+ import { Directive, ElementRef, Input, Renderer2 } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class DrDropdownPositionDirective {
4
- el;
5
- renderer;
6
- drDropdownPosition;
7
- position = 'left';
8
- widthMoreRight;
9
4
  constructor(el, renderer) {
10
5
  this.el = el;
11
6
  this.renderer = renderer;
7
+ this.position = 'left';
12
8
  }
13
9
  ngOnInit() {
14
10
  setTimeout(this.calculatePosition.bind(this), 1);
@@ -91,8 +87,8 @@ export class DrDropdownPositionDirective {
91
87
  this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');
92
88
  }
93
89
  }
94
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownPositionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
95
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: DrDropdownPositionDirective, selector: "[drDropdownPosition]", inputs: { drDropdownPosition: "drDropdownPosition", position: "position" }, exportAs: ["dropdownPosition"], ngImport: i0 });
90
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownPositionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
91
+ /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: DrDropdownPositionDirective, selector: "[drDropdownPosition]", inputs: { drDropdownPosition: "drDropdownPosition", position: "position" }, exportAs: ["dropdownPosition"], ngImport: i0 }); }
96
92
  }
97
93
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownPositionDirective, decorators: [{
98
94
  type: Directive,
@@ -105,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
105
101
  }], position: [{
106
102
  type: Input
107
103
  }] } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown-position.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown-position.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnInit, Renderer2 } from '@angular/core';\nimport { ElPosition, IDropdownCoordinate } from '../models/dropdown';\n\n@Directive({\n    selector: '[drDropdownPosition]',\n    exportAs: 'dropdownPosition'\n})\nexport class DrDropdownPositionDirective implements OnInit {\n\n    @Input() drDropdownPosition;\n    @Input() position: ElPosition | IDropdownCoordinate = 'left';\n\n    widthMoreRight: boolean;\n\n    constructor(private el: ElementRef, private renderer: Renderer2) {\n    }\n\n    ngOnInit(): void {\n        setTimeout(this.calculatePosition.bind(this), 1);\n    }\n\n    calculatePosition() {\n        let xDifference = 0;\n        let defaultDelta = 10;\n        let defaultPadding = 0;\n        const originalPosition = this.position;\n\n        if (this.position === 'child') {\n            defaultDelta = 0;\n            defaultPadding = 10;\n            xDifference = this.el.nativeElement.parentElement.parentElement.offsetWidth - this.el.nativeElement.offsetWidth;\n            const parentRect = this.el.nativeElement.parentElement.parentElement.getBoundingClientRect();\n\n            this.position = {\n                x: this.el.nativeElement.offsetWidth,\n                y: this.el.nativeElement.parentElement.parentElement.offsetTop - 9,\n                clientX: parentRect.x + this.el.nativeElement.parentElement.parentElement.offsetWidth,\n                clientY: parentRect.y\n            };\n        }\n\n        if (typeof this.position === 'string') {\n            this.renderer.setStyle(this.el.nativeElement, 'top',\n                this.position === 'bottom' ?\n                    this.drDropdownPosition.y - this.drDropdownPosition.height + 'px' :\n                    this.drDropdownPosition.y + 'px');\n            this.renderer.setStyle(this.el.nativeElement, 'left',\n                this.position === 'right' ?\n                    this.drDropdownPosition.x + this.drDropdownPosition.width + 'px' :\n                    this.drDropdownPosition.x + 'px');\n            const menuHeight = this.el.nativeElement.offsetHeight;\n            const heightMoreWindowBottom = menuHeight + this.drDropdownPosition.y > window.innerHeight;\n            const heightMoreWindowTop = menuHeight - this.drDropdownPosition.y + this.drDropdownPosition.height / 2 > 48; // header height;\n            const widthMoreWindowRight = this.drDropdownPosition.x + 250 > window.innerWidth;\n\n            const spaceBetweenElAndRightBorder = window.innerWidth - (this.drDropdownPosition.x + this.el.nativeElement.offsetWidth);\n            this.widthMoreRight = this.drDropdownPosition.x < spaceBetweenElAndRightBorder;\n\n            if (heightMoreWindowBottom) {\n                this.position = 'top';\n            }\n            if (heightMoreWindowBottom && widthMoreWindowRight && !heightMoreWindowTop || this.position === 'top-left') {\n                this.position = 'top-left';\n                const translateX = `calc(-100% + ${ this.drDropdownPosition.width }px)`;\n                const translateY = 'calc(-100% - 8px)';\n                this.renderer.setStyle(this.el.nativeElement, 'transform', `translate(${ translateX }, ${ translateY })`);\n            }\n            if (heightMoreWindowTop && heightMoreWindowBottom) {\n                this.position = 'left-center';\n            }\n            if (this.position === 'bottom-left') {\n                this.renderer.setStyle(\n                    this.el.nativeElement,\n                    'transform',\n                    `translate(calc(-100% + ${ this.drDropdownPosition.width }px), ${ this.drDropdownPosition.height + 8 }px)`\n                );\n            }\n            const className = this.position === 'top' ? 'content-top'\n                : this.position === 'top-left' ? 'content-top-left'\n                    : this.position === 'bottom' ? 'content-bottom'\n                        : this.position === 'bottom-left' ? 'content-bottom-left'\n                            : this.position === 'left' ? 'content-left'\n                                : this.position === 'left-center' ? 'content-left-center'\n                                    : this.position === 'right' ? 'content-right'\n                                        : this.position === 'bottom-right' ? 'content-bottom-right' : '';\n            this.renderer.addClass(this.el.nativeElement, className);\n            this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');\n        } else {\n            const defaultChildPadding = 3;\n            const widthMoreWindowRight = originalPosition !== 'child'\n                ? window.innerWidth - (this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding)\n                : window.innerWidth - this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding;\n\n            const widthMoreWindowBottom = originalPosition !== 'child'\n                ? window.innerHeight - (this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding)\n                : window.innerHeight - this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding;\n\n            const spaceRightAmount = window.innerWidth - (this.position.clientX + this.el.nativeElement.offsetWidth + defaultPadding);\n            this.widthMoreRight = !(widthMoreWindowRight < 0);\n\n            let calculatedHorizantallyPos = widthMoreWindowRight < 0\n                ? -this.position.x + -defaultChildPadding\n                : this.position.x + defaultChildPadding + xDifference;\n\n            if (spaceRightAmount <= 0 && originalPosition !== 'child') {\n                calculatedHorizantallyPos -= this.el.nativeElement.offsetWidth;\n            }\n\n            const deltaHeight = widthMoreWindowBottom < 0 ? widthMoreWindowBottom : defaultDelta;\n\n            this.renderer.setStyle(this.el.nativeElement, 'top', (this.position.y + deltaHeight) + 'px');\n            this.renderer.setStyle(this.el.nativeElement, 'left', (calculatedHorizantallyPos) + 'px');\n            this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');\n        }\n    }\n}\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown-position.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown-position.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnInit, Renderer2 } from '@angular/core';\nimport { ElPosition, IDropdownCoordinate } from '../models/dropdown';\n\n@Directive({\n    selector: '[drDropdownPosition]',\n    exportAs: 'dropdownPosition'\n})\nexport class DrDropdownPositionDirective implements OnInit {\n\n    @Input() drDropdownPosition;\n    @Input() position: ElPosition | IDropdownCoordinate = 'left';\n\n    widthMoreRight: boolean;\n\n    constructor(private el: ElementRef, private renderer: Renderer2) {\n    }\n\n    ngOnInit(): void {\n        setTimeout(this.calculatePosition.bind(this), 1);\n    }\n\n    calculatePosition() {\n        let xDifference = 0;\n        let defaultDelta = 10;\n        let defaultPadding = 0;\n        const originalPosition = this.position;\n\n        if (this.position === 'child') {\n            defaultDelta = 0;\n            defaultPadding = 10;\n            xDifference = this.el.nativeElement.parentElement.parentElement.offsetWidth - this.el.nativeElement.offsetWidth;\n            const parentRect = this.el.nativeElement.parentElement.parentElement.getBoundingClientRect();\n\n            this.position = {\n                x: this.el.nativeElement.offsetWidth,\n                y: this.el.nativeElement.parentElement.parentElement.offsetTop - 9,\n                clientX: parentRect.x + this.el.nativeElement.parentElement.parentElement.offsetWidth,\n                clientY: parentRect.y\n            };\n        }\n\n        if (typeof this.position === 'string') {\n            this.renderer.setStyle(this.el.nativeElement, 'top',\n                this.position === 'bottom' ?\n                    this.drDropdownPosition.y - this.drDropdownPosition.height + 'px' :\n                    this.drDropdownPosition.y + 'px');\n            this.renderer.setStyle(this.el.nativeElement, 'left',\n                this.position === 'right' ?\n                    this.drDropdownPosition.x + this.drDropdownPosition.width + 'px' :\n                    this.drDropdownPosition.x + 'px');\n            const menuHeight = this.el.nativeElement.offsetHeight;\n            const heightMoreWindowBottom = menuHeight + this.drDropdownPosition.y > window.innerHeight;\n            const heightMoreWindowTop = menuHeight - this.drDropdownPosition.y + this.drDropdownPosition.height / 2 > 48; // header height;\n            const widthMoreWindowRight = this.drDropdownPosition.x + 250 > window.innerWidth;\n\n            const spaceBetweenElAndRightBorder = window.innerWidth - (this.drDropdownPosition.x + this.el.nativeElement.offsetWidth);\n            this.widthMoreRight = this.drDropdownPosition.x < spaceBetweenElAndRightBorder;\n\n            if (heightMoreWindowBottom) {\n                this.position = 'top';\n            }\n            if (heightMoreWindowBottom && widthMoreWindowRight && !heightMoreWindowTop || this.position === 'top-left') {\n                this.position = 'top-left';\n                const translateX = `calc(-100% + ${ this.drDropdownPosition.width }px)`;\n                const translateY = 'calc(-100% - 8px)';\n                this.renderer.setStyle(this.el.nativeElement, 'transform', `translate(${ translateX }, ${ translateY })`);\n            }\n            if (heightMoreWindowTop && heightMoreWindowBottom) {\n                this.position = 'left-center';\n            }\n            if (this.position === 'bottom-left') {\n                this.renderer.setStyle(\n                    this.el.nativeElement,\n                    'transform',\n                    `translate(calc(-100% + ${ this.drDropdownPosition.width }px), ${ this.drDropdownPosition.height + 8 }px)`\n                );\n            }\n            const className = this.position === 'top' ? 'content-top'\n                : this.position === 'top-left' ? 'content-top-left'\n                    : this.position === 'bottom' ? 'content-bottom'\n                        : this.position === 'bottom-left' ? 'content-bottom-left'\n                            : this.position === 'left' ? 'content-left'\n                                : this.position === 'left-center' ? 'content-left-center'\n                                    : this.position === 'right' ? 'content-right'\n                                        : this.position === 'bottom-right' ? 'content-bottom-right' : '';\n            this.renderer.addClass(this.el.nativeElement, className);\n            this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');\n        } else {\n            const defaultChildPadding = 3;\n            const widthMoreWindowRight = originalPosition !== 'child'\n                ? window.innerWidth - (this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding)\n                : window.innerWidth - this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding;\n\n            const widthMoreWindowBottom = originalPosition !== 'child'\n                ? window.innerHeight - (this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding)\n                : window.innerHeight - this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding;\n\n            const spaceRightAmount = window.innerWidth - (this.position.clientX + this.el.nativeElement.offsetWidth + defaultPadding);\n            this.widthMoreRight = !(widthMoreWindowRight < 0);\n\n            let calculatedHorizantallyPos = widthMoreWindowRight < 0\n                ? -this.position.x + -defaultChildPadding\n                : this.position.x + defaultChildPadding + xDifference;\n\n            if (spaceRightAmount <= 0 && originalPosition !== 'child') {\n                calculatedHorizantallyPos -= this.el.nativeElement.offsetWidth;\n            }\n\n            const deltaHeight = widthMoreWindowBottom < 0 ? widthMoreWindowBottom : defaultDelta;\n\n            this.renderer.setStyle(this.el.nativeElement, 'top', (this.position.y + deltaHeight) + 'px');\n            this.renderer.setStyle(this.el.nativeElement, 'left', (calculatedHorizantallyPos) + 'px');\n            this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');\n        }\n    }\n}\n"]}
@@ -1,4 +1,5 @@
1
- import { ChangeDetectionStrategy, Component, Input, ViewChild } from '@angular/core';
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';
2
+ import { DrDropdownService } from './dr-dropdown.service';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "./dr-dropdown.service";
4
5
  import * as i2 from "@angular/common";
@@ -6,20 +7,11 @@ import * as i3 from "../dr-tooltip/dr-tooltip.directive";
6
7
  import * as i4 from "./dr-dropdown-position.directive";
7
8
  import * as i5 from "./dr-dropdown-item-show.pipe";
8
9
  export class DrDropdownComponent {
9
- menuService;
10
- cdr;
11
- viewMenu;
12
- menuContainer;
13
- option;
14
- position = 'left';
15
- drDropdownInHover;
16
- list;
17
- containerClass;
18
- wasHovered = false;
19
- firstInit;
20
10
  constructor(menuService, cdr) {
21
11
  this.menuService = menuService;
22
12
  this.cdr = cdr;
13
+ this.position = 'left';
14
+ this.wasHovered = false;
23
15
  }
24
16
  set options(data) {
25
17
  if (data) {
@@ -106,8 +98,8 @@ export class DrDropdownComponent {
106
98
  this.hide();
107
99
  }
108
100
  }
109
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownComponent, deps: [{ token: i1.DrDropdownService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
110
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: DrDropdownComponent, selector: "dr-dropdown", inputs: { options: "options" }, viewQueries: [{ propertyName: "viewMenu", first: true, predicate: ["listMenu"], descendants: true }, { propertyName: "menuContainer", first: true, predicate: ["menuContainer"], descendants: true }], ngImport: i0, template: "<div #menuContainer\n (mouseleave)=\"onMouseLeave()\"\n (mouseenter)=\"onMouseEnter()\"\n (clickOutside)=\"onClickedOutside()\"\n [drDropdownPosition]=\"option\"\n #dropdownPosition=\"dropdownPosition\"\n [position]=\"position\"\n [class]=\"containerClass\"\n class=\"dr-dropdown\">\n <div class=\"dr-dropdown__container\">\n <div *ngFor=\"let act of list | drDropdownItemShowPipe\"\n (click)=\"action(act)\"\n [drTooltip]=\"tooltipToShow(act)\"\n [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\n [drTooltipOptions]=\"{ withoutArrow: true }\"\n [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n class=\"dr-dropdown__container__item\"\n [class.item-disabled]=\"disabled(act)\"\n [class.item-selected]=\"selected(act)\"\n [class.separate-line]=\"act.separateLine\">\n <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n <span class=\"dr-dropdown__container__item__text\">{{act.title}}</span>\n <i *ngFor=\"let actionIcon of act.actionIcons\"\n [class]=\"actionIcon.icon\"\n [class.showOnHover]=\"actionIcon.showOnHover\"\n (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\n <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .dr-dropdown__container__item .dr-dropdown{visibility:hidden;transition-delay:.2s}::ng-deep .dr-dropdown__container__item:hover>*>.dr-dropdown{visibility:visible;transition-delay:0s}::ng-deep .dr-dropdown__tooltip>.default-content{max-width:300px;white-space:normal!important}.dr-dropdown{position:absolute;z-index:-1;top:0;left:0;width:auto}.dr-dropdown__container{display:flex;flex-direction:column;background:#fff;border-radius:4px;box-shadow:0 4px 8px 1px #00000040;padding:8px 0;overflow-y:auto;max-height:60vh}.dr-dropdown__container__item{display:flex;align-items:center;justify-content:flex-start;cursor:pointer;min-width:15rem;font-style:normal;font-weight:400;font-size:14px;line-height:24px;clear:both;width:100%;white-space:nowrap;padding:0 12px;height:36px;flex-shrink:0}.dr-dropdown__container__item.separate-line{border-top:1px solid #bcbcbc}.dr-dropdown__container__item:hover{background-color:#f9faff}.dr-dropdown__container__item:hover .showOnHover{visibility:visible}.dr-dropdown__container__item.item-selected{background:#f3f7ff}.dr-dropdown__container__item.item-disabled,.dr-dropdown__container__item.item-disabled i,.dr-dropdown__container__item.item-disabled .dr-dropdown__container__item__text{color:#bcbcbc}.dr-dropdown__container__item i:first-child{margin-right:8px}.dr-dropdown__container__item__text{margin-right:auto;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dr-dropdown__container__item i,.dr-dropdown__container__item__text{color:#151b3f}.dr-dropdown__container__item i{color:#4e566c}.dr-dropdown__container__item i:hover{color:#4646ce}.dr-dropdown__container__item .showOnHover{visibility:hidden}.dr-dropdown.content-top{transform:translate(-50%,-100%)}.dr-dropdown.content-top-left{transform:translate(-100%,-100%)}.dr-dropdown.content-bottom{transform:translate(-50%,50%)}.dr-dropdown.content-bottom-left{transform:translate(-90%,35%)}.dr-dropdown.content-bottom-right{transform:translateY(15%)}.dr-dropdown.content-left{transform:translate(-100%)}.dr-dropdown.content-left-center{transform:translate(-100%,-50%)}.dr-dropdown.content-right{transform:translate(5%)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DrTooltipDirective, selector: "[drTooltip]", inputs: ["drTooltip", "drTooltipContext", "drTooltipPosition", "drTooltipClass", "drTooltipMousleaveTimeout", "drTooltipOptions", "drTooltipShow"] }, { kind: "directive", type: i4.DrDropdownPositionDirective, selector: "[drDropdownPosition]", inputs: ["drDropdownPosition", "position"], exportAs: ["dropdownPosition"] }, { kind: "component", type: DrDropdownComponent, selector: "dr-dropdown", inputs: ["options"] }, { kind: "pipe", type: i5.DrDropdownItemShowPipe, name: "drDropdownItemShowPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
101
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownComponent, deps: [{ token: i1.DrDropdownService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
102
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: DrDropdownComponent, selector: "dr-dropdown", inputs: { options: "options" }, viewQueries: [{ propertyName: "viewMenu", first: true, predicate: ["listMenu"], descendants: true }, { propertyName: "menuContainer", first: true, predicate: ["menuContainer"], descendants: true }], ngImport: i0, template: "<div #menuContainer\n (mouseleave)=\"onMouseLeave()\"\n (mouseenter)=\"onMouseEnter()\"\n (clickOutside)=\"onClickedOutside()\"\n [drDropdownPosition]=\"option\"\n #dropdownPosition=\"dropdownPosition\"\n [position]=\"position\"\n [class]=\"containerClass\"\n class=\"dr-dropdown\">\n <div class=\"dr-dropdown__container\">\n <div *ngFor=\"let act of list | drDropdownItemShowPipe\"\n (click)=\"action(act)\"\n [drTooltip]=\"tooltipToShow(act)\"\n [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\n [drTooltipOptions]=\"{ withoutArrow: true }\"\n [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n class=\"dr-dropdown__container__item\"\n [class.item-disabled]=\"disabled(act)\"\n [class.item-selected]=\"selected(act)\"\n [class.separate-line]=\"act.separateLine\">\n <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n <span class=\"dr-dropdown__container__item__text\">{{act.title}}</span>\n <i *ngFor=\"let actionIcon of act.actionIcons\"\n [class]=\"actionIcon.icon\"\n [class.showOnHover]=\"actionIcon.showOnHover\"\n (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\n <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .dr-dropdown__container__item .dr-dropdown{visibility:hidden;transition-delay:.2s}::ng-deep .dr-dropdown__container__item:hover>*>.dr-dropdown{visibility:visible;transition-delay:0s}::ng-deep .dr-dropdown__tooltip>.default-content{max-width:300px;white-space:normal!important}.dr-dropdown{position:absolute;z-index:-1;top:0;left:0;width:auto}.dr-dropdown__container{display:flex;flex-direction:column;background:#fff;border-radius:4px;box-shadow:0 4px 8px 1px #00000040;padding:8px 0;overflow-y:auto;max-height:60vh}.dr-dropdown__container__item{display:flex;align-items:center;justify-content:flex-start;cursor:pointer;min-width:15rem;font-style:normal;font-weight:400;font-size:14px;line-height:24px;clear:both;width:100%;white-space:nowrap;padding:0 12px;height:36px;flex-shrink:0}.dr-dropdown__container__item.separate-line{border-top:1px solid #bcbcbc}.dr-dropdown__container__item:hover{background-color:#f9faff}.dr-dropdown__container__item:hover .showOnHover{visibility:visible}.dr-dropdown__container__item.item-selected{background:#f3f7ff}.dr-dropdown__container__item.item-disabled,.dr-dropdown__container__item.item-disabled i,.dr-dropdown__container__item.item-disabled .dr-dropdown__container__item__text{color:#bcbcbc}.dr-dropdown__container__item i:first-child{margin-right:8px}.dr-dropdown__container__item__text{margin-right:auto;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dr-dropdown__container__item i,.dr-dropdown__container__item__text{color:#151b3f}.dr-dropdown__container__item i{color:#4e566c}.dr-dropdown__container__item i:hover{color:#4646ce}.dr-dropdown__container__item .showOnHover{visibility:hidden}.dr-dropdown.content-top{transform:translate(-50%,-100%)}.dr-dropdown.content-top-left{transform:translate(-100%,-100%)}.dr-dropdown.content-bottom{transform:translate(-50%,50%)}.dr-dropdown.content-bottom-left{transform:translate(-90%,35%)}.dr-dropdown.content-bottom-right{transform:translateY(15%)}.dr-dropdown.content-left{transform:translate(-100%)}.dr-dropdown.content-left-center{transform:translate(-100%,-50%)}.dr-dropdown.content-right{transform:translate(5%)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DrTooltipDirective, selector: "[drTooltip]", inputs: ["drTooltip", "drTooltipContext", "drTooltipPosition", "drTooltipClass", "drTooltipMousleaveTimeout", "drTooltipOptions", "drTooltipShow"] }, { kind: "directive", type: i4.DrDropdownPositionDirective, selector: "[drDropdownPosition]", inputs: ["drDropdownPosition", "position"], exportAs: ["dropdownPosition"] }, { kind: "component", type: DrDropdownComponent, selector: "dr-dropdown", inputs: ["options"] }, { kind: "pipe", type: i5.DrDropdownItemShowPipe, name: "drDropdownItemShowPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
111
103
  }
112
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownComponent, decorators: [{
113
105
  type: Component,
@@ -121,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
121
113
  }], options: [{
122
114
  type: Input
123
115
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';\nimport { ElPosition, IDropdown, IDropdownActionIcon, IDropdownCoordinate, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService } from './dr-dropdown.service';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DrDropdownComponent {\n\n    @ViewChild('listMenu') viewMenu: HTMLElement;\n    @ViewChild('menuContainer') menuContainer: HTMLElement;\n    option: any;\n    position: ElPosition | IDropdownCoordinate = 'left';\n    drDropdownInHover: boolean;\n    list: IDropdownItem<unknown>[];\n    containerClass: string;\n    public wasHovered = false;\n    private firstInit: boolean;\n\n    constructor(protected menuService: DrDropdownService, private cdr: ChangeDetectorRef) {\n    }\n\n    @Input() set options(data: IDropdown<IDropdownItem<any>>) {\n        if (data) {\n            this.option = data.option;\n            this.position = data.position;\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.list = data.list || [];\n            this.list.forEach(item => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        list: item.children,\n                        class: item?.childOptions?.class || '',\n                        position: 'child'\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n        }\n    }\n\n    onMouseEnter(): void {\n        this.wasHovered = true;\n    }\n\n    onMouseLeave(): void {\n        if (this.drDropdownInHover) this.menuService.destroy();\n    }\n\n    onClickedOutside(): void {\n        if (this.firstInit) {\n            this.menuService.destroy();\n        } else {\n            this.firstInit = true;\n        }\n    }\n\n    hide(): void {\n        this.menuService.destroy();\n    }\n\n    disabled(act: IDropdownItem<unknown> | IDropdownActionIcon<any>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    tooltipToShow(act: IDropdownItem<unknown>): string {\n        if (act.toolTipIfDisabled && !this.disabled(act)) return '';\n        return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;\n    }\n\n    tooltipPosition(widthMoreRight: boolean) {\n        return widthMoreRight ? 'right' : 'left';\n    }\n\n    action(act: IDropdownItem<any>) {\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                this.menuService.actionItem.next({ event: act.event || act.title || 'default', data: act.data });\n            }\n            this.hide();\n        }\n    }\n\n    onActionIconClick($event, actionIcon: IDropdownActionIcon<any>, data: any) {\n        $event.stopPropagation();\n        if (!this.disabled(actionIcon)) {\n            actionIcon.action(data);\n            this.hide();\n        }\n    }\n}\n\n","<div #menuContainer\n     (mouseleave)=\"onMouseLeave()\"\n     (mouseenter)=\"onMouseEnter()\"\n     (clickOutside)=\"onClickedOutside()\"\n     [drDropdownPosition]=\"option\"\n     #dropdownPosition=\"dropdownPosition\"\n     [position]=\"position\"\n     [class]=\"containerClass\"\n     class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\">\n        <div *ngFor=\"let act of list | drDropdownItemShowPipe\"\n             (click)=\"action(act)\"\n             [drTooltip]=\"tooltipToShow(act)\"\n             [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\n             [drTooltipOptions]=\"{ withoutArrow: true }\"\n             [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n             class=\"dr-dropdown__container__item\"\n             [class.item-disabled]=\"disabled(act)\"\n             [class.item-selected]=\"selected(act)\"\n             [class.separate-line]=\"act.separateLine\">\n            <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n            <span class=\"dr-dropdown__container__item__text\">{{act.title}}</span>\n            <i *ngFor=\"let actionIcon of act.actionIcons\"\n               [class]=\"actionIcon.icon\"\n               [class.showOnHover]=\"actionIcon.showOnHover\"\n               (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n            <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\n            <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\n        </div>\n    </div>\n</div>\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';\nimport { ElPosition, IDropdown, IDropdownActionIcon, IDropdownCoordinate, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService } from './dr-dropdown.service';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DrDropdownComponent {\n\n    @ViewChild('listMenu') viewMenu: HTMLElement;\n    @ViewChild('menuContainer') menuContainer: HTMLElement;\n    option: any;\n    position: ElPosition | IDropdownCoordinate = 'left';\n    drDropdownInHover: boolean;\n    list: IDropdownItem<unknown>[];\n    containerClass: string;\n    public wasHovered = false;\n    private firstInit: boolean;\n\n    constructor(protected menuService: DrDropdownService, private cdr: ChangeDetectorRef) {\n    }\n\n    @Input() set options(data: IDropdown<IDropdownItem<any>>) {\n        if (data) {\n            this.option = data.option;\n            this.position = data.position;\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.list = data.list || [];\n            this.list.forEach(item => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        list: item.children,\n                        class: item?.childOptions?.class || '',\n                        position: 'child'\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n        }\n    }\n\n    onMouseEnter(): void {\n        this.wasHovered = true;\n    }\n\n    onMouseLeave(): void {\n        if (this.drDropdownInHover) this.menuService.destroy();\n    }\n\n    onClickedOutside(): void {\n        if (this.firstInit) {\n            this.menuService.destroy();\n        } else {\n            this.firstInit = true;\n        }\n    }\n\n    hide(): void {\n        this.menuService.destroy();\n    }\n\n    disabled(act: IDropdownItem<unknown> | IDropdownActionIcon<any>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    tooltipToShow(act: IDropdownItem<unknown>): string {\n        if (act.toolTipIfDisabled && !this.disabled(act)) return '';\n        return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;\n    }\n\n    tooltipPosition(widthMoreRight: boolean) {\n        return widthMoreRight ? 'right' : 'left';\n    }\n\n    action(act: IDropdownItem<any>) {\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                this.menuService.actionItem.next({ event: act.event || act.title || 'default', data: act.data });\n            }\n            this.hide();\n        }\n    }\n\n    onActionIconClick($event, actionIcon: IDropdownActionIcon<any>, data: any) {\n        $event.stopPropagation();\n        if (!this.disabled(actionIcon)) {\n            actionIcon.action(data);\n            this.hide();\n        }\n    }\n}\n\n","<div #menuContainer\n     (mouseleave)=\"onMouseLeave()\"\n     (mouseenter)=\"onMouseEnter()\"\n     (clickOutside)=\"onClickedOutside()\"\n     [drDropdownPosition]=\"option\"\n     #dropdownPosition=\"dropdownPosition\"\n     [position]=\"position\"\n     [class]=\"containerClass\"\n     class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\">\n        <div *ngFor=\"let act of list | drDropdownItemShowPipe\"\n             (click)=\"action(act)\"\n             [drTooltip]=\"tooltipToShow(act)\"\n             [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\n             [drTooltipOptions]=\"{ withoutArrow: true }\"\n             [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n             class=\"dr-dropdown__container__item\"\n             [class.item-disabled]=\"disabled(act)\"\n             [class.item-selected]=\"selected(act)\"\n             [class.separate-line]=\"act.separateLine\">\n            <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n            <span class=\"dr-dropdown__container__item__text\">{{act.title}}</span>\n            <i *ngFor=\"let actionIcon of act.actionIcons\"\n               [class]=\"actionIcon.icon\"\n               [class.showOnHover]=\"actionIcon.showOnHover\"\n               (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n            <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\n            <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\n        </div>\n    </div>\n</div>\n"]}
@@ -1,26 +1,18 @@
1
- import { Directive, HostListener, Inject, Input, ViewChild, ViewContainerRef } from '@angular/core';
1
+ import { ComponentFactoryResolver, Directive, ElementRef, HostListener, Inject, Input, ViewChild, ViewContainerRef } from '@angular/core';
2
2
  import { DOCUMENT } from '@angular/common';
3
3
  import { DrDropdownComponent } from './dr-dropdown.component';
4
+ import { DrDropdownService } from './dr-dropdown.service';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "./dr-dropdown.service";
6
7
  export class DrDropdownDirective {
7
- componentFactoryResolver;
8
- viewContainerRef;
9
- service;
10
- el;
11
- _document;
12
- position = 'left';
13
- drDropdown;
14
- drDropdownClass;
15
- drDropdownInHover;
16
- contentCmpRef;
17
- mouseleaveTimeout = 200;
18
8
  constructor(componentFactoryResolver, viewContainerRef, service, el, _document) {
19
9
  this.componentFactoryResolver = componentFactoryResolver;
20
10
  this.viewContainerRef = viewContainerRef;
21
11
  this.service = service;
22
12
  this.el = el;
23
13
  this._document = _document;
14
+ this.position = 'left';
15
+ this.mouseleaveTimeout = 200;
24
16
  }
25
17
  elementHover() {
26
18
  if (!this.drDropdownInHover)
@@ -87,8 +79,8 @@ export class DrDropdownDirective {
87
79
  this.contentCmpRef.destroy();
88
80
  }
89
81
  }
90
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownDirective, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }, { token: i1.DrDropdownService }, { token: i0.ElementRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive });
91
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: DrDropdownDirective, selector: "[drDropdown]", inputs: { position: "position", drDropdown: "drDropdown", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover" }, host: { listeners: { "mouseenter": "elementHover()", "click": "elementClick()", "mouseleave": "leaveDropdownTriggerElement()", "document:mouseup": "documentClick($event)" } }, viewQueries: [{ propertyName: "contentCmpRef", first: true, predicate: DrDropdownComponent, descendants: true, read: ViewContainerRef, static: true }], ngImport: i0 });
82
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownDirective, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }, { token: i1.DrDropdownService }, { token: i0.ElementRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive }); }
83
+ /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: DrDropdownDirective, selector: "[drDropdown]", inputs: { position: "position", drDropdown: "drDropdown", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover" }, host: { listeners: { "mouseenter": "elementHover()", "click": "elementClick()", "mouseleave": "leaveDropdownTriggerElement()", "document:mouseup": "documentClick($event)" } }, viewQueries: [{ propertyName: "contentCmpRef", first: true, predicate: DrDropdownComponent, descendants: true, read: ViewContainerRef, static: true }], ngImport: i0 }); }
92
84
  }
93
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownDirective, decorators: [{
94
86
  type: Directive,
@@ -122,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
122
114
  type: HostListener,
123
115
  args: ['document:mouseup', ['$event']]
124
116
  }] } });
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentFactory,\n    ComponentFactoryResolver,\n    Directive,\n    ElementRef,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { ElPosition, IDropdown, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrDropdownService } from './dr-dropdown.service';\n\n@Directive({\n    selector: '[drDropdown]'\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n\n    @Input() position: ElPosition = 'left';\n    @Input() drDropdown: IDropdownItem<T>[];\n    @Input() drDropdownClass: string;\n    @Input() drDropdownInHover: boolean;\n    @ViewChild(DrDropdownComponent, { static: true, read: ViewContainerRef }) contentCmpRef;\n\n    private readonly mouseleaveTimeout = 200;\n\n    constructor(private componentFactoryResolver: ComponentFactoryResolver,\n                private viewContainerRef: ViewContainerRef,\n                private service: DrDropdownService,\n                private el: ElementRef,\n                @Inject(DOCUMENT) private _document: any) {\n    }\n\n    @HostListener('mouseenter') elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click') elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave') leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout(_ => {\n                if (this.contentCmpRef && !this.contentCmpRef.instance.wasHovered) {\n                    this.contentCmpRef.destroy();\n                    this.contentCmpRef = null;\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup', ['$event']) documentClick(e) {\n        this.closeDropdown(e);\n    }\n\n    private openDropdown(): void {\n        const option = this.el.nativeElement.getBoundingClientRect();\n        this._document.querySelectorAll('dr-dropdown').forEach(item => item.remove());\n        if (this.contentCmpRef && this.contentCmpRef.destroyCbs) {\n            this.contentCmpRef.destroy();\n            this.contentCmpRef = null;\n        } else {\n            this.service.destroy();\n            this.showMenu({\n                option,\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.position,\n                list: this.drDropdown,\n                class: this.drDropdownClass\n            });\n        }\n    }\n\n    private closeDropdown(e): void {\n\n        if (!this.contentCmpRef) {\n            return;\n        }\n\n        const clickTarget = e.target;\n        const triggerElement = this.el.nativeElement;\n        const dropdownElement = this.contentCmpRef.location.nativeElement;\n        const isClickTriggerElement = triggerElement.contains(clickTarget) || triggerElement === clickTarget;\n        const isClickDropdownContents = dropdownElement.contains(clickTarget);\n\n        if (!isClickTriggerElement && !isClickDropdownContents) {\n            const elems = this._document.querySelectorAll('dr-dropdown');\n            setTimeout(() => elems.forEach(item => item.remove()), 100);\n        }\n    }\n\n    private showMenu(options: IDropdown<T>) {\n        const componentFactory: ComponentFactory<DrDropdownComponent> = this.componentFactoryResolver.resolveComponentFactory(DrDropdownComponent);\n        this.contentCmpRef = this.viewContainerRef.createComponent(componentFactory);\n        this.service.addMenu = this.contentCmpRef;\n        this._document.querySelector('dr-layout').appendChild(this.contentCmpRef.location.nativeElement);\n        this.contentCmpRef.instance.options = options;\n    }\n\n    public ngOnDestroy() {\n        if (this.contentCmpRef) {\n            this.contentCmpRef.destroy();\n        }\n    }\n}\n"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,wBAAwB,EACxB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,SAAS,EACT,gBAAgB,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;;;AAK1D,MAAM,OAAO,mBAAmB;IAU5B,YAAoB,wBAAkD,EAClD,gBAAkC,EAClC,OAA0B,EAC1B,EAAc,EACI,SAAc;QAJhC,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,YAAO,GAAP,OAAO,CAAmB;QAC1B,OAAE,GAAF,EAAE,CAAY;QACI,cAAS,GAAT,SAAS,CAAK;QAZ3C,aAAQ,GAAe,MAAM,CAAC;QAMtB,sBAAiB,GAAG,GAAG,CAAC;IAOzC,CAAC;IAE2B,YAAY;QACpC,IAAI,CAAC,IAAI,CAAC,iBAAiB;YAAE,OAAO;QACpC,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAEsB,YAAY;QAC/B,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAE2B,2BAA2B;QACnD,IAAI,IAAI,CAAC,iBAAiB,EAAE;YACxB,UAAU,CAAC,CAAC,CAAC,EAAE;gBACX,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,UAAU,EAAE;oBAC/D,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;oBAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;iBAC7B;YACL,CAAC,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;SAC9B;IACL,CAAC;IAE6C,aAAa,CAAC,CAAC;QACzD,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAEO,YAAY;QAChB,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;QAC7D,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAC9E,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE;YACrD,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;aAAM;YACH,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,CAAC;gBACV,MAAM;gBACN,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;gBACzC,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,IAAI,EAAE,IAAI,CAAC,UAAU;gBACrB,KAAK,EAAE,IAAI,CAAC,eAAe;aAC9B,CAAC,CAAC;SACN;IACL,CAAC;IAEO,aAAa,CAAC,CAAC;QAEnB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,OAAO;SACV;QAED,MAAM,WAAW,GAAG,CAAC,CAAC,MAAM,CAAC;QAC7B,MAAM,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;QAC7C,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC;QAClE,MAAM,qBAAqB,GAAG,cAAc,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,cAAc,KAAK,WAAW,CAAC;QACrG,MAAM,uBAAuB,GAAG,eAAe,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QAEtE,IAAI,CAAC,qBAAqB,IAAI,CAAC,uBAAuB,EAAE;YACpD,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;YAC7D,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;SAC/D;IACL,CAAC;IAEO,QAAQ,CAAC,OAAqB;QAClC,MAAM,gBAAgB,GAA0C,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,mBAAmB,CAAC,CAAC;QAC3I,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;QAC7E,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC;QAC1C,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QACjG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,OAAO,GAAG,OAAO,CAAC;IAClD,CAAC;IAEM,WAAW;QACd,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;SAChC;IACL,CAAC;iIAzFQ,mBAAmB,qJAcR,QAAQ;qHAdnB,mBAAmB,2ZAMjB,mBAAmB,2BAAwB,gBAAgB;;2FAN7D,mBAAmB;kBAH/B,SAAS;mBAAC;oBACP,QAAQ,EAAE,cAAc;iBAC3B;;0BAegB,MAAM;2BAAC,QAAQ;4CAZnB,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACoE,aAAa;sBAAtF,SAAS;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,gBAAgB,EAAE;gBAW5C,YAAY;sBAAvC,YAAY;uBAAC,YAAY;gBAKH,YAAY;sBAAlC,YAAY;uBAAC,OAAO;gBAIO,2BAA2B;sBAAtD,YAAY;uBAAC,YAAY;gBAWoB,aAAa;sBAA1D,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n    ComponentFactory,\n    ComponentFactoryResolver,\n    Directive,\n    ElementRef,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { ElPosition, IDropdown, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrDropdownService } from './dr-dropdown.service';\n\n@Directive({\n    selector: '[drDropdown]'\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n\n    @Input() position: ElPosition = 'left';\n    @Input() drDropdown: IDropdownItem<T>[];\n    @Input() drDropdownClass: string;\n    @Input() drDropdownInHover: boolean;\n    @ViewChild(DrDropdownComponent, { static: true, read: ViewContainerRef }) contentCmpRef;\n\n    private readonly mouseleaveTimeout = 200;\n\n    constructor(private componentFactoryResolver: ComponentFactoryResolver,\n                private viewContainerRef: ViewContainerRef,\n                private service: DrDropdownService,\n                private el: ElementRef,\n                @Inject(DOCUMENT) private _document: any) {\n    }\n\n    @HostListener('mouseenter') elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click') elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave') leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout(_ => {\n                if (this.contentCmpRef && !this.contentCmpRef.instance.wasHovered) {\n                    this.contentCmpRef.destroy();\n                    this.contentCmpRef = null;\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup', ['$event']) documentClick(e) {\n        this.closeDropdown(e);\n    }\n\n    private openDropdown(): void {\n        const option = this.el.nativeElement.getBoundingClientRect();\n        this._document.querySelectorAll('dr-dropdown').forEach(item => item.remove());\n        if (this.contentCmpRef && this.contentCmpRef.destroyCbs) {\n            this.contentCmpRef.destroy();\n            this.contentCmpRef = null;\n        } else {\n            this.service.destroy();\n            this.showMenu({\n                option,\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.position,\n                list: this.drDropdown,\n                class: this.drDropdownClass\n            });\n        }\n    }\n\n    private closeDropdown(e): void {\n\n        if (!this.contentCmpRef) {\n            return;\n        }\n\n        const clickTarget = e.target;\n        const triggerElement = this.el.nativeElement;\n        const dropdownElement = this.contentCmpRef.location.nativeElement;\n        const isClickTriggerElement = triggerElement.contains(clickTarget) || triggerElement === clickTarget;\n        const isClickDropdownContents = dropdownElement.contains(clickTarget);\n\n        if (!isClickTriggerElement && !isClickDropdownContents) {\n            const elems = this._document.querySelectorAll('dr-dropdown');\n            setTimeout(() => elems.forEach(item => item.remove()), 100);\n        }\n    }\n\n    private showMenu(options: IDropdown<T>) {\n        const componentFactory: ComponentFactory<DrDropdownComponent> = this.componentFactoryResolver.resolveComponentFactory(DrDropdownComponent);\n        this.contentCmpRef = this.viewContainerRef.createComponent(componentFactory);\n        this.service.addMenu = this.contentCmpRef;\n        this._document.querySelector('dr-layout').appendChild(this.contentCmpRef.location.nativeElement);\n        this.contentCmpRef.instance.options = options;\n    }\n\n    public ngOnDestroy() {\n        if (this.contentCmpRef) {\n            this.contentCmpRef.destroy();\n        }\n    }\n}\n"]}
@@ -8,19 +8,19 @@ import { DrDropdownItemShowPipe } from './dr-dropdown-item-show.pipe';
8
8
  import { DrDropdownService } from './dr-dropdown.service';
9
9
  import * as i0 from "@angular/core";
10
10
  export class DrDropdownModule {
11
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownModule, declarations: [DrDropdownDirective,
11
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
12
+ /** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownModule, declarations: [DrDropdownDirective,
13
13
  DrDropdownPositionDirective,
14
14
  DrDropdownComponent,
15
15
  DrDropdownItemShowPipe], imports: [CommonModule,
16
16
  DrTooltipModule], exports: [DrDropdownDirective,
17
17
  DrDropdownPositionDirective,
18
18
  DrDropdownComponent,
19
- DrDropdownItemShowPipe] });
20
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownModule, providers: [
19
+ DrDropdownItemShowPipe] }); }
20
+ /** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownModule, providers: [
21
21
  DrDropdownService,
22
22
  ], imports: [CommonModule,
23
- DrTooltipModule] });
23
+ DrTooltipModule] }); }
24
24
  }
25
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownModule, decorators: [{
26
26
  type: NgModule,
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
46
46
  ],
47
47
  }]
48
48
  }] });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHJvcGRvd24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZHJvcGRvd24vZHItZHJvcGRvd24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDL0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUF3QjFELE1BQU0sT0FBTyxnQkFBZ0I7dUdBQWhCLGdCQUFnQjt3R0FBaEIsZ0JBQWdCLGlCQWhCckIsbUJBQW1CO1lBQ25CLDJCQUEyQjtZQUMzQixtQkFBbUI7WUFDbkIsc0JBQXNCLGFBUHRCLFlBQVk7WUFDWixlQUFlLGFBU2YsbUJBQW1CO1lBQ25CLDJCQUEyQjtZQUMzQixtQkFBbUI7WUFDbkIsc0JBQXNCO3dHQU9qQixnQkFBZ0IsYUFMZDtZQUNQLGlCQUFpQjtTQUNwQixZQWpCRyxZQUFZO1lBQ1osZUFBZTs7MkZBbUJWLGdCQUFnQjtrQkF0QjVCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osZUFBZTtxQkFDbEI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNWLG1CQUFtQjt3QkFDbkIsMkJBQTJCO3dCQUMzQixtQkFBbUI7d0JBQ25CLHNCQUFzQjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLG1CQUFtQjt3QkFDbkIsMkJBQTJCO3dCQUMzQixtQkFBbUI7d0JBQ25CLHNCQUFzQjtxQkFDekI7b0JBQ0QsU0FBUyxFQUFFO3dCQUNQLGlCQUFpQjtxQkFDcEI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJEcm9wZG93blBvc2l0aW9uRGlyZWN0aXZlIH0gZnJvbSAnLi9kci1kcm9wZG93bi1wb3NpdGlvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gJy4vZHItZHJvcGRvd24uZGlyZWN0aXZlJztcbmltcG9ydCB7IERyRHJvcGRvd25Db21wb25lbnQgfSBmcm9tICcuL2RyLWRyb3Bkb3duLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRHJUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi4vZHItdG9vbHRpcC9kci10b29sdGlwLm1vZHVsZSc7XG5pbXBvcnQgeyBEckRyb3Bkb3duSXRlbVNob3dQaXBlIH0gZnJvbSAnLi9kci1kcm9wZG93bi1pdGVtLXNob3cucGlwZSc7XG5pbXBvcnQgeyBEckRyb3Bkb3duU2VydmljZSB9IGZyb20gJy4vZHItZHJvcGRvd24uc2VydmljZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIERyVG9vbHRpcE1vZHVsZSxcbiAgICBdLFxuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBEckRyb3Bkb3duRGlyZWN0aXZlLFxuICAgICAgICBEckRyb3Bkb3duUG9zaXRpb25EaXJlY3RpdmUsXG4gICAgICAgIERyRHJvcGRvd25Db21wb25lbnQsXG4gICAgICAgIERyRHJvcGRvd25JdGVtU2hvd1BpcGUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIERyRHJvcGRvd25EaXJlY3RpdmUsXG4gICAgICAgIERyRHJvcGRvd25Qb3NpdGlvbkRpcmVjdGl2ZSxcbiAgICAgICAgRHJEcm9wZG93bkNvbXBvbmVudCxcbiAgICAgICAgRHJEcm9wZG93bkl0ZW1TaG93UGlwZSxcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICBEckRyb3Bkb3duU2VydmljZSxcbiAgICBdLFxufSlcblxuZXhwb3J0IGNsYXNzIERyRHJvcGRvd25Nb2R1bGUge1xufVxuIl19
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHJvcGRvd24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZHJvcGRvd24vZHItZHJvcGRvd24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDL0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUF3QjFELE1BQU0sT0FBTyxnQkFBZ0I7aUlBQWhCLGdCQUFnQjtrSUFBaEIsZ0JBQWdCLGlCQWhCckIsbUJBQW1CO1lBQ25CLDJCQUEyQjtZQUMzQixtQkFBbUI7WUFDbkIsc0JBQXNCLGFBUHRCLFlBQVk7WUFDWixlQUFlLGFBU2YsbUJBQW1CO1lBQ25CLDJCQUEyQjtZQUMzQixtQkFBbUI7WUFDbkIsc0JBQXNCO2tJQU9qQixnQkFBZ0IsYUFMZDtZQUNQLGlCQUFpQjtTQUNwQixZQWpCRyxZQUFZO1lBQ1osZUFBZTs7MkZBbUJWLGdCQUFnQjtrQkF0QjVCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osZUFBZTtxQkFDbEI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNWLG1CQUFtQjt3QkFDbkIsMkJBQTJCO3dCQUMzQixtQkFBbUI7d0JBQ25CLHNCQUFzQjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLG1CQUFtQjt3QkFDbkIsMkJBQTJCO3dCQUMzQixtQkFBbUI7d0JBQ25CLHNCQUFzQjtxQkFDekI7b0JBQ0QsU0FBUyxFQUFFO3dCQUNQLGlCQUFpQjtxQkFDcEI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJEcm9wZG93blBvc2l0aW9uRGlyZWN0aXZlIH0gZnJvbSAnLi9kci1kcm9wZG93bi1wb3NpdGlvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gJy4vZHItZHJvcGRvd24uZGlyZWN0aXZlJztcbmltcG9ydCB7IERyRHJvcGRvd25Db21wb25lbnQgfSBmcm9tICcuL2RyLWRyb3Bkb3duLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRHJUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi4vZHItdG9vbHRpcC9kci10b29sdGlwLm1vZHVsZSc7XG5pbXBvcnQgeyBEckRyb3Bkb3duSXRlbVNob3dQaXBlIH0gZnJvbSAnLi9kci1kcm9wZG93bi1pdGVtLXNob3cucGlwZSc7XG5pbXBvcnQgeyBEckRyb3Bkb3duU2VydmljZSB9IGZyb20gJy4vZHItZHJvcGRvd24uc2VydmljZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIERyVG9vbHRpcE1vZHVsZSxcbiAgICBdLFxuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBEckRyb3Bkb3duRGlyZWN0aXZlLFxuICAgICAgICBEckRyb3Bkb3duUG9zaXRpb25EaXJlY3RpdmUsXG4gICAgICAgIERyRHJvcGRvd25Db21wb25lbnQsXG4gICAgICAgIERyRHJvcGRvd25JdGVtU2hvd1BpcGUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIERyRHJvcGRvd25EaXJlY3RpdmUsXG4gICAgICAgIERyRHJvcGRvd25Qb3NpdGlvbkRpcmVjdGl2ZSxcbiAgICAgICAgRHJEcm9wZG93bkNvbXBvbmVudCxcbiAgICAgICAgRHJEcm9wZG93bkl0ZW1TaG93UGlwZSxcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICBEckRyb3Bkb3duU2VydmljZSxcbiAgICBdLFxufSlcblxuZXhwb3J0IGNsYXNzIERyRHJvcGRvd25Nb2R1bGUge1xufVxuIl19
@@ -2,9 +2,8 @@ import { Injectable } from '@angular/core';
2
2
  import { Subject } from 'rxjs';
3
3
  import * as i0 from "@angular/core";
4
4
  export class DrDropdownService {
5
- actionItem = new Subject();
6
- menuInView;
7
5
  constructor() {
6
+ this.actionItem = new Subject();
8
7
  }
9
8
  set addMenu(item) {
10
9
  this.menuInView = item;
@@ -14,8 +13,8 @@ export class DrDropdownService {
14
13
  this.menuInView.destroy();
15
14
  }
16
15
  }
17
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
18
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownService, providedIn: 'root' });
16
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
17
+ /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownService, providedIn: 'root' }); }
19
18
  }
20
19
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDropdownService, decorators: [{
21
20
  type: Injectable,
@@ -23,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
23
22
  providedIn: 'root'
24
23
  }]
25
24
  }], ctorParameters: function () { return []; } });
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHJvcGRvd24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWRyb3Bkb3duL2RyLWRyb3Bkb3duLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFPL0IsTUFBTSxPQUFPLGlCQUFpQjtJQUUxQixVQUFVLEdBQUcsSUFBSSxPQUFPLEVBQTRCLENBQUM7SUFDM0MsVUFBVSxDQUFvQztJQUV4RDtJQUNBLENBQUM7SUFFRCxJQUFJLE9BQU8sQ0FBQyxJQUF1QztRQUMvQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztJQUMzQixDQUFDO0lBRUQsT0FBTztRQUNILElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNqQixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQzdCO0lBQ0wsQ0FBQzt1R0FoQlEsaUJBQWlCOzJHQUFqQixpQkFBaUIsY0FGZCxNQUFNOzsyRkFFVCxpQkFBaUI7a0JBSDdCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50UmVmLCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEckRyb3Bkb3duQ29tcG9uZW50IH0gZnJvbSAnLi9kci1kcm9wZG93bi5jb21wb25lbnQnO1xuaW1wb3J0IHsgSURyb3Bkb3duQWN0aW9uIH0gZnJvbSAnLi4vbW9kZWxzL2Ryb3Bkb3duJztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEckRyb3Bkb3duU2VydmljZSB7XG5cbiAgICBhY3Rpb25JdGVtID0gbmV3IFN1YmplY3Q8SURyb3Bkb3duQWN0aW9uPHVua25vd24+PigpO1xuICAgIHByb3RlY3RlZCBtZW51SW5WaWV3OiBDb21wb25lbnRSZWY8RHJEcm9wZG93bkNvbXBvbmVudD47XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICB9XG5cbiAgICBzZXQgYWRkTWVudShpdGVtOiBDb21wb25lbnRSZWY8RHJEcm9wZG93bkNvbXBvbmVudD4pIHtcbiAgICAgICAgdGhpcy5tZW51SW5WaWV3ID0gaXRlbTtcbiAgICB9XG5cbiAgICBkZXN0cm95KCkge1xuICAgICAgICBpZiAodGhpcy5tZW51SW5WaWV3KSB7XG4gICAgICAgICAgICB0aGlzLm1lbnVJblZpZXcuZGVzdHJveSgpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHJvcGRvd24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWRyb3Bkb3duL2RyLWRyb3Bkb3duLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFPL0IsTUFBTSxPQUFPLGlCQUFpQjtJQUsxQjtRQUhBLGVBQVUsR0FBRyxJQUFJLE9BQU8sRUFBNEIsQ0FBQztJQUlyRCxDQUFDO0lBRUQsSUFBSSxPQUFPLENBQUMsSUFBdUM7UUFDL0MsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7SUFDM0IsQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDakIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztTQUM3QjtJQUNMLENBQUM7aUlBaEJRLGlCQUFpQjtxSUFBakIsaUJBQWlCLGNBRmQsTUFBTTs7MkZBRVQsaUJBQWlCO2tCQUg3QixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudFJlZiwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRHJEcm9wZG93bkNvbXBvbmVudCB9IGZyb20gJy4vZHItZHJvcGRvd24uY29tcG9uZW50JztcbmltcG9ydCB7IElEcm9wZG93bkFjdGlvbiB9IGZyb20gJy4uL21vZGVscy9kcm9wZG93bic7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgRHJEcm9wZG93blNlcnZpY2Uge1xuXG4gICAgYWN0aW9uSXRlbSA9IG5ldyBTdWJqZWN0PElEcm9wZG93bkFjdGlvbjx1bmtub3duPj4oKTtcbiAgICBwcm90ZWN0ZWQgbWVudUluVmlldzogQ29tcG9uZW50UmVmPERyRHJvcGRvd25Db21wb25lbnQ+O1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgfVxuXG4gICAgc2V0IGFkZE1lbnUoaXRlbTogQ29tcG9uZW50UmVmPERyRHJvcGRvd25Db21wb25lbnQ+KSB7XG4gICAgICAgIHRoaXMubWVudUluVmlldyA9IGl0ZW07XG4gICAgfVxuXG4gICAgZGVzdHJveSgpIHtcbiAgICAgICAgaWYgKHRoaXMubWVudUluVmlldykge1xuICAgICAgICAgICAgdGhpcy5tZW51SW5WaWV3LmRlc3Ryb3koKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
@@ -1,24 +1,17 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { find as _find, isNumber as _isNumber, isObject as _isObject, isNil as _isNil, map as _map } from 'lodash';
3
- import * as moment from 'moment';
3
+ import moment from 'moment';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
6
6
  import * as i2 from "../dr-inputs/dr-select/dr-select.component";
7
7
  import * as i3 from "../dr-inputs/dr-select-add-item/dr-select-add-item.component";
8
8
  import * as i4 from "@angular/forms";
9
9
  export class DrDynamicTagComponent {
10
- values;
11
- tagConfig;
12
- selectedTag;
13
- lockedTags = [];
14
- connectedTags;
15
- isDynamicTagAddEnabled;
16
- disabled;
17
- tagChange = new EventEmitter();
18
- tagAdd = new EventEmitter();
19
- selectedDynamicTag;
20
- currentValues;
21
- isLockedTagSelected;
10
+ constructor() {
11
+ this.lockedTags = [];
12
+ this.tagChange = new EventEmitter();
13
+ this.tagAdd = new EventEmitter();
14
+ }
22
15
  get isPrimitiveDataSource() {
23
16
  const values = Object.values(this.values) || [];
24
17
  return !_isObject(values[0]);
@@ -91,12 +84,12 @@ export class DrDynamicTagComponent {
91
84
  }
92
85
  return connectedTags.value;
93
86
  }
94
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
95
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: DrDynamicTagComponent, selector: "dr-dynamic-tag", inputs: { values: "values", tagConfig: "tagConfig", selectedTag: "selectedTag", lockedTags: "lockedTags", connectedTags: "connectedTags", isDynamicTagAddEnabled: "isDynamicTagAddEnabled", disabled: "disabled" }, outputs: { tagChange: "tagChange", tagAdd: "tagAdd" }, usesOnChanges: true, ngImport: i0, template: "<p class=\"dynamic-tag__label\">{{ tagConfig.name }}</p>\n<dr-select [(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 bindValue=\"value\"\n [values]=\"currentValues\"\n [dynamicAddLabel]=\"' Add new ' + tagConfig.name\"\n (dynamicValueAdded)=\"onDynamicValueAdd($event)\"></dr-select-add-item>\n </ng-template>\n <ng-template #labelTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--label\">\n <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n <ng-template #optionTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--option\"\n [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: [".dynamic-tag__label{margin:0 0 4px;color:#0c142b;font-size:14px;font-weight:400;line-height:22px}.dynamic-tag__field,.dynamic-tag__field--label,.dynamic-tag__field--option{cursor:pointer;height:24px}.dynamic-tag__field--option{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{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"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DrSelectComponent, selector: "dr-select", inputs: ["className", "items", "addTag", "appendTo", "bindLabel", "bindValue", "clearable", "searchable", "searchFn", "multiple", "hideSelected", "placeholder", "loading", "readonly", "disabled", "groupBy", "optionWithDescription", "id", "keyDownFn", "selectedItem", "dropdownClass", "closeOnSelect", "textView", "autofocus", "isOpen"], outputs: ["change", "open"] }, { kind: "component", type: i3.DrSelectAddItemComponent, selector: "dr-select-add-item", inputs: ["dynamicAddLabel", "bindValue", "values"], outputs: ["dynamicValueAdded"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
87
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
88
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: DrDynamicTagComponent, selector: "dr-dynamic-tag", inputs: { values: "values", tagConfig: "tagConfig", selectedTag: "selectedTag", lockedTags: "lockedTags", connectedTags: "connectedTags", isDynamicTagAddEnabled: "isDynamicTagAddEnabled", disabled: "disabled" }, outputs: { tagChange: "tagChange", tagAdd: "tagAdd" }, usesOnChanges: true, ngImport: i0, template: "<p class=\"dynamic-tag__label\">{{ tagConfig.name }}</p>\n<dr-select [(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 bindValue=\"value\"\n [values]=\"currentValues\"\n [dynamicAddLabel]=\"' Add new ' + tagConfig.name\"\n (dynamicValueAdded)=\"onDynamicValueAdd($event)\"></dr-select-add-item>\n </ng-template>\n <ng-template #labelTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--label\">\n <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n <ng-template #optionTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--option\"\n [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: [".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"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DrSelectComponent, selector: "dr-select", inputs: ["className", "items", "addTag", "appendTo", "bindLabel", "bindValue", "clearable", "searchable", "searchFn", "multiple", "hideSelected", "placeholder", "loading", "readonly", "disabled", "groupBy", "optionWithDescription", "id", "keyDownFn", "selectedItem", "dropdownClass", "closeOnSelect", "textView", "autofocus", "isOpen"], outputs: ["change", "open"] }, { kind: "component", type: i3.DrSelectAddItemComponent, selector: "dr-select-add-item", inputs: ["dynamicAddLabel", "bindValue", "values"], outputs: ["dynamicValueAdded"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
96
89
  }
97
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagComponent, decorators: [{
98
91
  type: Component,
99
- args: [{ selector: 'dr-dynamic-tag', template: "<p class=\"dynamic-tag__label\">{{ tagConfig.name }}</p>\n<dr-select [(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 bindValue=\"value\"\n [values]=\"currentValues\"\n [dynamicAddLabel]=\"' Add new ' + tagConfig.name\"\n (dynamicValueAdded)=\"onDynamicValueAdd($event)\"></dr-select-add-item>\n </ng-template>\n <ng-template #labelTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--label\">\n <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n <ng-template #optionTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--option\"\n [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: [".dynamic-tag__label{margin:0 0 4px;color:#0c142b;font-size:14px;font-weight:400;line-height:22px}.dynamic-tag__field,.dynamic-tag__field--label,.dynamic-tag__field--option{cursor:pointer;height:24px}.dynamic-tag__field--option{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{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"] }]
92
+ args: [{ selector: 'dr-dynamic-tag', template: "<p class=\"dynamic-tag__label\">{{ tagConfig.name }}</p>\n<dr-select [(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 bindValue=\"value\"\n [values]=\"currentValues\"\n [dynamicAddLabel]=\"' Add new ' + tagConfig.name\"\n (dynamicValueAdded)=\"onDynamicValueAdd($event)\"></dr-select-add-item>\n </ng-template>\n <ng-template #labelTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--label\">\n <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n </div>\n </ng-template>\n <ng-template #optionTemplate let-item=\"item\">\n <div class=\"dynamic-tag__field--option\"\n [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: [".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"] }]
100
93
  }], propDecorators: { values: [{
101
94
  type: Input
102
95
  }], tagConfig: [{
@@ -116,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
116
109
  }], tagAdd: [{
117
110
  type: Output
118
111
  }] } });
119
- //# 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 {\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChanges\n} from '@angular/core';\nimport { find as _find, isNumber as _isNumber, isObject as _isObject, isNil as _isNil, map as _map } from 'lodash';\nimport { IDynamicTag, ITag, ITagForServer, TDynamicTag, TDynamicTagValue } from '../models/serverTags';\nimport * as moment from 'moment';\n\n@Component({\n    selector: 'dr-dynamic-tag',\n    templateUrl: './dr-dynamic-tag.component.html',\n    styleUrls: ['./dr-dynamic-tag.component.scss']\n})\nexport class DrDynamicTagComponent implements OnChanges {\n\n    @Input() public values: TDynamicTag;\n    @Input() public tagConfig: ITag;\n    @Input() public selectedTag: ITagForServer;\n\n    @Input() public lockedTags: any[] = [];\n    @Input() public connectedTags: ITagForServer[];\n    @Input() public isDynamicTagAddEnabled: boolean;\n    @Input() public disabled: 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    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, this.tryToParseParentValue).join('__');\n    }\n\n    private tryToParseParentValue(connectedTags: ITagForServer) {\n        if (_isNumber(connectedTags.value)) {\n            const momentData = moment.unix(connectedTags.value);\n            const convertedParentValue = momentData.get('year'); // TODO: add input prop (selectedTimeDimension) or Format\n\n            if (momentData.isValid() && convertedParentValue) {\n                return convertedParentValue;\n            }\n        }\n\n        return connectedTags.value;\n    }\n}\n","<p class=\"dynamic-tag__label\">{{ tagConfig.name }}</p>\n<dr-select [(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 bindValue=\"value\"\n                            [values]=\"currentValues\"\n                            [dynamicAddLabel]=\"' Add new ' + tagConfig.name\"\n                            (dynamicValueAdded)=\"onDynamicValueAdd($event)\"></dr-select-add-item>\n    </ng-template>\n    <ng-template #labelTemplate let-item=\"item\">\n        <div class=\"dynamic-tag__field--label\">\n            <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n            <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n        </div>\n    </ng-template>\n    <ng-template #optionTemplate let-item=\"item\">\n        <div class=\"dynamic-tag__field--option\"\n             [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"]}
112
+ //# 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 {\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChanges\n} from '@angular/core';\nimport { find as _find, isNumber as _isNumber, isObject as _isObject, isNil as _isNil, map as _map } from 'lodash';\nimport { IDynamicTag, ITag, ITagForServer, TDynamicTag, TDynamicTagValue } from '../models/serverTags';\nimport moment from 'moment';\n\n@Component({\n    selector: 'dr-dynamic-tag',\n    templateUrl: './dr-dynamic-tag.component.html',\n    styleUrls: ['./dr-dynamic-tag.component.scss']\n})\nexport class DrDynamicTagComponent implements OnChanges {\n\n    @Input() public values: TDynamicTag;\n    @Input() public tagConfig: ITag;\n    @Input() public selectedTag: ITagForServer;\n\n    @Input() public lockedTags: any[] = [];\n    @Input() public connectedTags: ITagForServer[];\n    @Input() public isDynamicTagAddEnabled: boolean;\n    @Input() public disabled: 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    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, this.tryToParseParentValue).join('__');\n    }\n\n    private tryToParseParentValue(connectedTags: ITagForServer) {\n        if (_isNumber(connectedTags.value)) {\n            const momentData = moment.unix(connectedTags.value);\n            const convertedParentValue = momentData.get('year'); // TODO: add input prop (selectedTimeDimension) or Format\n\n            if (momentData.isValid() && convertedParentValue) {\n                return convertedParentValue;\n            }\n        }\n\n        return connectedTags.value;\n    }\n}\n","<p class=\"dynamic-tag__label\">{{ tagConfig.name }}</p>\n<dr-select [(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 bindValue=\"value\"\n                            [values]=\"currentValues\"\n                            [dynamicAddLabel]=\"' Add new ' + tagConfig.name\"\n                            (dynamicValueAdded)=\"onDynamicValueAdd($event)\"></dr-select-add-item>\n    </ng-template>\n    <ng-template #labelTemplate let-item=\"item\">\n        <div class=\"dynamic-tag__field--label\">\n            <p class=\"dynamic-tag__field__text\">{{ item?.value || item }}</p>\n            <i *ngIf=\"item?.is_favorite\" class=\"dynamic-tag__field__icon dr-icon-star-fill\"></i>\n        </div>\n    </ng-template>\n    <ng-template #optionTemplate let-item=\"item\">\n        <div class=\"dynamic-tag__field--option\"\n             [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"]}
@@ -5,13 +5,13 @@ import { DrInputsModule } from '../dr-inputs/dr-inputs.module';
5
5
  import { FormsModule } from '@angular/forms';
6
6
  import * as i0 from "@angular/core";
7
7
  export class DrDynamicTagModule {
8
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagModule, declarations: [DrDynamicTagComponent], imports: [CommonModule,
8
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
+ /** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagModule, declarations: [DrDynamicTagComponent], imports: [CommonModule,
10
10
  DrInputsModule,
11
- FormsModule], exports: [DrDynamicTagComponent] });
12
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagModule, imports: [CommonModule,
11
+ FormsModule], exports: [DrDynamicTagComponent] }); }
12
+ /** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagModule, imports: [CommonModule,
13
13
  DrInputsModule,
14
- FormsModule] });
14
+ FormsModule] }); }
15
15
  }
16
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DrDynamicTagModule, decorators: [{
17
17
  type: NgModule,
@@ -25,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
25
25
  exports: [DrDynamicTagComponent]
26
26
  }]
27
27
  }] });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHluYW1pYy10YWcubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZHluYW1pYy10YWcvZHItZHluYW1pYy10YWcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ25FLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBVzdDLE1BQU0sT0FBTyxrQkFBa0I7dUdBQWxCLGtCQUFrQjt3R0FBbEIsa0JBQWtCLGlCQVJaLHFCQUFxQixhQUVoQyxZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVcsYUFFTCxxQkFBcUI7d0dBRXRCLGtCQUFrQixZQU52QixZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVc7OzJGQUlOLGtCQUFrQjtrQkFUOUIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDckMsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxXQUFXO3FCQUNkO29CQUNELE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRHJEeW5hbWljVGFnQ29tcG9uZW50IH0gZnJvbSAnLi9kci1keW5hbWljLXRhZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJJbnB1dHNNb2R1bGUgfSBmcm9tICcuLi9kci1pbnB1dHMvZHItaW5wdXRzLm1vZHVsZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtEckR5bmFtaWNUYWdDb21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBEcklucHV0c01vZHVsZSxcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbRHJEeW5hbWljVGFnQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBEckR5bmFtaWNUYWdNb2R1bGUge1xufVxuIl19
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHluYW1pYy10YWcubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZHluYW1pYy10YWcvZHItZHluYW1pYy10YWcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ25FLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBVzdDLE1BQU0sT0FBTyxrQkFBa0I7aUlBQWxCLGtCQUFrQjtrSUFBbEIsa0JBQWtCLGlCQVJaLHFCQUFxQixhQUVoQyxZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVcsYUFFTCxxQkFBcUI7a0lBRXRCLGtCQUFrQixZQU52QixZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVc7OzJGQUlOLGtCQUFrQjtrQkFUOUIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDckMsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxXQUFXO3FCQUNkO29CQUNELE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRHJEeW5hbWljVGFnQ29tcG9uZW50IH0gZnJvbSAnLi9kci1keW5hbWljLXRhZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJJbnB1dHNNb2R1bGUgfSBmcm9tICcuLi9kci1pbnB1dHMvZHItaW5wdXRzLm1vZHVsZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtEckR5bmFtaWNUYWdDb21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBEcklucHV0c01vZHVsZSxcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbRHJEeW5hbWljVGFnQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBEckR5bmFtaWNUYWdNb2R1bGUge1xufVxuIl19