@datarailsshared/datarailsshared 1.3.49 → 1.3.51

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 (133) hide show
  1. package/_datarailsshared.styles.css +3 -3
  2. package/assets/styles/_styles.scss +2 -2
  3. package/assets/styles/img/default-avatar.svg +5 -5
  4. package/bundles/datarailsshared-datarailsshared.umd.js +3984 -3995
  5. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  6. package/datarailsshared-datarailsshared-1.3.51.tgz +0 -0
  7. package/datarailsshared-datarailsshared.d.ts +9 -9
  8. package/datarailsshared-datarailsshared.metadata.json +1 -1
  9. package/esm2015/datarailsshared-datarailsshared.js +9 -9
  10. package/esm2015/lib/date-tags/date-tag.component.js +70 -70
  11. package/esm2015/lib/date-tags/date-tag.module.js +50 -50
  12. package/esm2015/lib/date-tags/day-tag/day-tag.component.js +81 -81
  13. package/esm2015/lib/date-tags/forecast-tag/forecast-tag.component.js +143 -143
  14. package/esm2015/lib/date-tags/month-tag/month-tag.component.js +87 -87
  15. package/esm2015/lib/date-tags/quarter-tag/quarter-tag.component.js +101 -101
  16. package/esm2015/lib/date-tags/week-tag/week-tag.component.js +124 -124
  17. package/esm2015/lib/date-tags/year-tag/year-tag.component.js +93 -93
  18. package/esm2015/lib/dr-accordion/accordion-item-body.component.js +57 -57
  19. package/esm2015/lib/dr-accordion/accordion-item-header.component.js +79 -79
  20. package/esm2015/lib/dr-accordion/accordion-item.component.js +123 -123
  21. package/esm2015/lib/dr-accordion/accordion.component.js +43 -43
  22. package/esm2015/lib/dr-accordion/accordion.module.js +23 -23
  23. package/esm2015/lib/dr-avatar/dr-avatar.component.js +42 -42
  24. package/esm2015/lib/dr-avatar/dr-avatar.module.js +26 -26
  25. package/esm2015/lib/dr-avatar/dr-avatar.pipe.js +15 -15
  26. package/esm2015/lib/dr-dropdown/dr-dropdown-item-show.pipe.js +12 -12
  27. package/esm2015/lib/dr-dropdown/dr-dropdown-position.directive.js +97 -97
  28. package/esm2015/lib/dr-dropdown/dr-dropdown.component.js +110 -110
  29. package/esm2015/lib/dr-dropdown/dr-dropdown.directive.js +89 -89
  30. package/esm2015/lib/dr-dropdown/dr-dropdown.module.js +34 -34
  31. package/esm2015/lib/dr-dropdown/dr-dropdown.service.js +24 -24
  32. package/esm2015/lib/dr-inputs/button/button.component.js +80 -80
  33. package/esm2015/lib/dr-inputs/checkbox/checkbox.component.js +63 -63
  34. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.js +47 -47
  35. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.component.js +183 -186
  36. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.service.js +41 -41
  37. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.js +129 -129
  38. package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +185 -185
  39. package/esm2015/lib/dr-inputs/dr-inputs.module.js +51 -51
  40. package/esm2015/lib/dr-inputs/dr-model-debounce-change.directive.js +31 -31
  41. package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +90 -90
  42. package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +64 -64
  43. package/esm2015/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.js +56 -56
  44. package/esm2015/lib/dr-inputs/radio-button/radio-button.component.js +64 -64
  45. package/esm2015/lib/dr-inputs/radio-button/radio-group.component.js +164 -164
  46. package/esm2015/lib/dr-popover/dr-popover-ref.js +20 -20
  47. package/esm2015/lib/dr-popover/dr-popover.component.js +77 -77
  48. package/esm2015/lib/dr-popover/dr-popover.directive.js +72 -72
  49. package/esm2015/lib/dr-popover/dr-popover.module.js +23 -23
  50. package/esm2015/lib/dr-popover/dr-popover.service.js +102 -102
  51. package/esm2015/lib/dr-spinner/dr-spinner.component.js +29 -29
  52. package/esm2015/lib/dr-spinner/dr-spinner.directive.js +53 -53
  53. package/esm2015/lib/dr-spinner/dr-spinner.module.js +18 -18
  54. package/esm2015/lib/dr-tabs/dr-tab.component.js +23 -23
  55. package/esm2015/lib/dr-tabs/dr-tabs.component.js +28 -28
  56. package/esm2015/lib/dr-tabs/dr-tabs.module.js +30 -30
  57. package/esm2015/lib/dr-tags/dr-tag.component.js +54 -54
  58. package/esm2015/lib/dr-tags/dr-tag.module.js +22 -22
  59. package/esm2015/lib/dr-tooltip/dr-tooltip.component.js +30 -30
  60. package/esm2015/lib/dr-tooltip/dr-tooltip.directive.js +102 -102
  61. package/esm2015/lib/dr-tooltip/dr-tooltip.module.js +23 -23
  62. package/esm2015/lib/list-tags/list-tag.component.js +41 -41
  63. package/esm2015/lib/list-tags/list-tag.module.js +29 -29
  64. package/esm2015/lib/models/constants.js +97 -97
  65. package/esm2015/lib/models/datePicker.js +40 -40
  66. package/esm2015/lib/models/dropdown.js +2 -2
  67. package/esm2015/lib/models/popover.js +27 -27
  68. package/esm2015/lib/models/serverTags.js +2 -2
  69. package/esm2015/public-api.js +57 -57
  70. package/fesm2015/datarailsshared-datarailsshared.js +3365 -3368
  71. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  72. package/lib/date-tags/date-tag.component.d.ts +27 -27
  73. package/lib/date-tags/date-tag.module.d.ts +4 -4
  74. package/lib/date-tags/day-tag/day-tag.component.d.ts +12 -12
  75. package/lib/date-tags/forecast-tag/forecast-tag.component.d.ts +21 -21
  76. package/lib/date-tags/month-tag/month-tag.component.d.ts +14 -14
  77. package/lib/date-tags/quarter-tag/quarter-tag.component.d.ts +17 -17
  78. package/lib/date-tags/week-tag/week-tag.component.d.ts +19 -19
  79. package/lib/date-tags/year-tag/year-tag.component.d.ts +14 -14
  80. package/lib/dr-accordion/accordion-item-body.component.d.ts +11 -11
  81. package/lib/dr-accordion/accordion-item-header.component.d.ts +16 -16
  82. package/lib/dr-accordion/accordion-item.component.d.ts +53 -53
  83. package/lib/dr-accordion/accordion.component.d.ts +19 -19
  84. package/lib/dr-accordion/accordion.module.d.ts +2 -2
  85. package/lib/dr-avatar/dr-avatar.component.d.ts +10 -10
  86. package/lib/dr-avatar/dr-avatar.module.d.ts +2 -2
  87. package/lib/dr-avatar/dr-avatar.pipe.d.ts +4 -4
  88. package/lib/dr-dropdown/dr-dropdown-item-show.pipe.d.ts +5 -5
  89. package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +12 -12
  90. package/lib/dr-dropdown/dr-dropdown.component.d.ts +26 -26
  91. package/lib/dr-dropdown/dr-dropdown.directive.d.ts +23 -23
  92. package/lib/dr-dropdown/dr-dropdown.module.d.ts +2 -2
  93. package/lib/dr-dropdown/dr-dropdown.service.d.ts +11 -11
  94. package/lib/dr-inputs/button/button.component.d.ts +21 -21
  95. package/lib/dr-inputs/checkbox/checkbox.component.d.ts +20 -20
  96. package/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.d.ts +10 -10
  97. package/lib/dr-inputs/dr-date-picker/dr-date-picker.component.d.ts +54 -54
  98. package/lib/dr-inputs/dr-date-picker/dr-date-picker.service.d.ts +12 -12
  99. package/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +41 -41
  100. package/lib/dr-inputs/dr-input/dr-input.component.d.ts +58 -58
  101. package/lib/dr-inputs/dr-inputs.module.d.ts +2 -2
  102. package/lib/dr-inputs/dr-model-debounce-change.directive.d.ts +11 -11
  103. package/lib/dr-inputs/dr-select/dr-select.component.d.ts +38 -38
  104. package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +23 -23
  105. package/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.d.ts +19 -19
  106. package/lib/dr-inputs/radio-button/radio-button.component.d.ts +21 -21
  107. package/lib/dr-inputs/radio-button/radio-group.component.d.ts +39 -39
  108. package/lib/dr-popover/dr-popover-ref.d.ts +16 -16
  109. package/lib/dr-popover/dr-popover.component.d.ts +26 -26
  110. package/lib/dr-popover/dr-popover.directive.d.ts +26 -26
  111. package/lib/dr-popover/dr-popover.module.d.ts +2 -2
  112. package/lib/dr-popover/dr-popover.service.d.ts +17 -17
  113. package/lib/dr-spinner/dr-spinner.component.d.ts +10 -10
  114. package/lib/dr-spinner/dr-spinner.directive.d.ts +15 -15
  115. package/lib/dr-spinner/dr-spinner.module.d.ts +2 -2
  116. package/lib/dr-tabs/dr-tab.component.d.ts +8 -8
  117. package/lib/dr-tabs/dr-tabs.component.d.ts +11 -11
  118. package/lib/dr-tabs/dr-tabs.module.d.ts +2 -2
  119. package/lib/dr-tags/dr-tag.component.d.ts +15 -15
  120. package/lib/dr-tags/dr-tag.module.d.ts +2 -2
  121. package/lib/dr-tooltip/dr-tooltip.component.d.ts +16 -16
  122. package/lib/dr-tooltip/dr-tooltip.directive.d.ts +23 -23
  123. package/lib/dr-tooltip/dr-tooltip.module.d.ts +2 -2
  124. package/lib/list-tags/list-tag.component.d.ts +14 -14
  125. package/lib/list-tags/list-tag.module.d.ts +2 -2
  126. package/lib/models/constants.d.ts +87 -87
  127. package/lib/models/datePicker.d.ts +25 -25
  128. package/lib/models/dropdown.d.ts +48 -48
  129. package/lib/models/popover.d.ts +32 -32
  130. package/lib/models/serverTags.d.ts +28 -28
  131. package/package.json +1 -1
  132. package/public-api.d.ts +55 -55
  133. package/datarailsshared-datarailsshared-1.3.49.tgz +0 -0
@@ -1,15 +1,15 @@
1
- import { Pipe } from '@angular/core';
2
- export class DrAvatarPipe {
3
- transform(item, type = 'full') {
4
- if (type === 'initials') {
5
- return (item.first_name && item.last_name ? (item.first_name[0] + item.last_name[0]) : item.email[0]).toUpperCase();
6
- }
7
- return item.first_name && item.last_name ? (item.first_name + ' ' + item.last_name) : item.email;
8
- }
9
- }
10
- DrAvatarPipe.decorators = [
11
- { type: Pipe, args: [{
12
- name: 'drAvatar'
13
- },] }
14
- ];
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItYXZhdGFyLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1hdmF0YXIvZHItYXZhdGFyLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFLcEQsTUFBTSxPQUFPLFlBQVk7SUFFdkIsU0FBUyxDQUFDLElBQVMsRUFBRSxPQUFlLE1BQU07UUFDeEMsSUFBSSxJQUFJLEtBQUssVUFBVSxFQUFFO1lBQ3ZCLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNySDtRQUVELE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQztJQUNuRyxDQUFDOzs7WUFYRixJQUFJLFNBQUM7Z0JBQ0osSUFBSSxFQUFFLFVBQVU7YUFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AUGlwZSh7XHJcbiAgbmFtZTogJ2RyQXZhdGFyJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgRHJBdmF0YXJQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcblxyXG4gIHRyYW5zZm9ybShpdGVtOiBhbnksIHR5cGU6IHN0cmluZyA9ICdmdWxsJyk6IHN0cmluZyB7XHJcbiAgICBpZiAodHlwZSA9PT0gJ2luaXRpYWxzJykge1xyXG4gICAgICByZXR1cm4gKGl0ZW0uZmlyc3RfbmFtZSAmJiBpdGVtLmxhc3RfbmFtZSA/IChpdGVtLmZpcnN0X25hbWVbMF0gKyBpdGVtLmxhc3RfbmFtZVswXSkgOiBpdGVtLmVtYWlsWzBdKS50b1VwcGVyQ2FzZSgpO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBpdGVtLmZpcnN0X25hbWUgJiYgaXRlbS5sYXN0X25hbWUgPyAoaXRlbS5maXJzdF9uYW1lICsgJyAnICsgaXRlbS5sYXN0X25hbWUpIDogaXRlbS5lbWFpbDtcclxuICB9XHJcbn1cclxuIl19
1
+ import { Pipe } from '@angular/core';
2
+ export class DrAvatarPipe {
3
+ transform(item, type = 'full') {
4
+ if (type === 'initials') {
5
+ return (item.first_name && item.last_name ? (item.first_name[0] + item.last_name[0]) : item.email[0]).toUpperCase();
6
+ }
7
+ return item.first_name && item.last_name ? (item.first_name + ' ' + item.last_name) : item.email;
8
+ }
9
+ }
10
+ DrAvatarPipe.decorators = [
11
+ { type: Pipe, args: [{
12
+ name: 'drAvatar'
13
+ },] }
14
+ ];
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItYXZhdGFyLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1hdmF0YXIvZHItYXZhdGFyLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFLcEQsTUFBTSxPQUFPLFlBQVk7SUFFdkIsU0FBUyxDQUFDLElBQVMsRUFBRSxPQUFlLE1BQU07UUFDeEMsSUFBSSxJQUFJLEtBQUssVUFBVSxFQUFFO1lBQ3ZCLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNySDtRQUVELE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQztJQUNuRyxDQUFDOzs7WUFYRixJQUFJLFNBQUM7Z0JBQ0osSUFBSSxFQUFFLFVBQVU7YUFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ2RyQXZhdGFyJ1xufSlcbmV4cG9ydCBjbGFzcyBEckF2YXRhclBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcblxuICB0cmFuc2Zvcm0oaXRlbTogYW55LCB0eXBlOiBzdHJpbmcgPSAnZnVsbCcpOiBzdHJpbmcge1xuICAgIGlmICh0eXBlID09PSAnaW5pdGlhbHMnKSB7XG4gICAgICByZXR1cm4gKGl0ZW0uZmlyc3RfbmFtZSAmJiBpdGVtLmxhc3RfbmFtZSA/IChpdGVtLmZpcnN0X25hbWVbMF0gKyBpdGVtLmxhc3RfbmFtZVswXSkgOiBpdGVtLmVtYWlsWzBdKS50b1VwcGVyQ2FzZSgpO1xuICAgIH1cblxuICAgIHJldHVybiBpdGVtLmZpcnN0X25hbWUgJiYgaXRlbS5sYXN0X25hbWUgPyAoaXRlbS5maXJzdF9uYW1lICsgJyAnICsgaXRlbS5sYXN0X25hbWUpIDogaXRlbS5lbWFpbDtcbiAgfVxufVxuIl19
@@ -1,12 +1,12 @@
1
- import { Pipe } from '@angular/core';
2
- export class DrDropdownItemShowPipe {
3
- transform(arr) {
4
- return arr.filter(item => item.show ? item.show(item.data) : true);
5
- }
6
- }
7
- DrDropdownItemShowPipe.decorators = [
8
- { type: Pipe, args: [{
9
- name: 'drDropdownItemShowPipe'
10
- },] }
11
- ];
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHJvcGRvd24taXRlbS1zaG93LnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1kcm9wZG93bi9kci1kcm9wZG93bi1pdGVtLXNob3cucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQU1wRCxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLFNBQVMsQ0FBQyxHQUF1QjtRQUMvQixPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDckUsQ0FBQzs7O1lBTkYsSUFBSSxTQUFDO2dCQUNKLElBQUksRUFBRSx3QkFBd0I7YUFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IElEcm9wZG93bkl0ZW0gfSBmcm9tICcuLi9tb2RlbHMvZHJvcGRvd24nO1xyXG5cclxuQFBpcGUoe1xyXG4gIG5hbWU6ICdkckRyb3Bkb3duSXRlbVNob3dQaXBlJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgRHJEcm9wZG93bkl0ZW1TaG93UGlwZTxUPiBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gIHRyYW5zZm9ybShhcnI6IElEcm9wZG93bkl0ZW08VD5bXSk6IElEcm9wZG93bkl0ZW08VD5bXSB7XHJcbiAgICByZXR1cm4gYXJyLmZpbHRlcihpdGVtID0+IGl0ZW0uc2hvdyA/IGl0ZW0uc2hvdyhpdGVtLmRhdGEpIDogdHJ1ZSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
1
+ import { Pipe } from '@angular/core';
2
+ export class DrDropdownItemShowPipe {
3
+ transform(arr) {
4
+ return arr.filter(item => item.show ? item.show(item.data) : true);
5
+ }
6
+ }
7
+ DrDropdownItemShowPipe.decorators = [
8
+ { type: Pipe, args: [{
9
+ name: 'drDropdownItemShowPipe'
10
+ },] }
11
+ ];
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZHJvcGRvd24taXRlbS1zaG93LnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1kcm9wZG93bi9kci1kcm9wZG93bi1pdGVtLXNob3cucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQU1wRCxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLFNBQVMsQ0FBQyxHQUF1QjtRQUMvQixPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDckUsQ0FBQzs7O1lBTkYsSUFBSSxTQUFDO2dCQUNKLElBQUksRUFBRSx3QkFBd0I7YUFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJRHJvcGRvd25JdGVtIH0gZnJvbSAnLi4vbW9kZWxzL2Ryb3Bkb3duJztcblxuQFBpcGUoe1xuICBuYW1lOiAnZHJEcm9wZG93bkl0ZW1TaG93UGlwZSdcbn0pXG5leHBvcnQgY2xhc3MgRHJEcm9wZG93bkl0ZW1TaG93UGlwZTxUPiBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oYXJyOiBJRHJvcGRvd25JdGVtPFQ+W10pOiBJRHJvcGRvd25JdGVtPFQ+W10ge1xuICAgIHJldHVybiBhcnIuZmlsdGVyKGl0ZW0gPT4gaXRlbS5zaG93ID8gaXRlbS5zaG93KGl0ZW0uZGF0YSkgOiB0cnVlKTtcbiAgfVxufVxuIl19
@@ -1,97 +1,97 @@
1
- import { Directive, ElementRef, Input, Renderer2 } from '@angular/core';
2
- export class DrDropdownPositionDirective {
3
- constructor(el, renderer) {
4
- this.el = el;
5
- this.renderer = renderer;
6
- this.position = 'left';
7
- }
8
- ngOnInit() {
9
- setTimeout(this.calculatePosition.bind(this), 1);
10
- }
11
- calculatePosition() {
12
- let xDifference = 0;
13
- let defaultDelta = 10;
14
- let defaultPadding = 0;
15
- if (this.position === 'child') {
16
- defaultDelta = 0;
17
- defaultPadding = 10;
18
- xDifference = this.el.nativeElement.parentElement.parentElement.offsetWidth - this.el.nativeElement.offsetWidth;
19
- const parentRect = this.el.nativeElement.parentElement.parentElement.getBoundingClientRect();
20
- this.position = {
21
- x: this.el.nativeElement.offsetWidth,
22
- y: this.el.nativeElement.parentElement.parentElement.offsetTop - 9,
23
- clientX: parentRect.x + this.el.nativeElement.parentElement.parentElement.offsetWidth,
24
- clientY: parentRect.y
25
- };
26
- }
27
- if (typeof this.position === 'string') {
28
- this.renderer.setStyle(this.el.nativeElement, 'top', this.position === 'bottom' ?
29
- this.drDropdownPosition.y - this.drDropdownPosition.height + 'px' :
30
- this.drDropdownPosition.y + 'px');
31
- this.renderer.setStyle(this.el.nativeElement, 'left', this.position === 'right' ?
32
- this.drDropdownPosition.x + this.drDropdownPosition.width + 'px' :
33
- this.drDropdownPosition.x + 'px');
34
- const menuHeight = this.el.nativeElement.offsetHeight;
35
- const heightMoreWindowBottom = menuHeight + this.drDropdownPosition.y > window.innerHeight;
36
- const heightMoreWindowTop = menuHeight - this.drDropdownPosition.y + this.drDropdownPosition.height / 2 > 48; // header height;
37
- const widthMoreWindowRight = this.drDropdownPosition.x + 250 > window.innerWidth;
38
- const spaceBetweenElAndRightBorder = window.innerWidth - (this.drDropdownPosition.x + this.el.nativeElement.offsetWidth);
39
- this.widthMoreRight = this.drDropdownPosition.x < spaceBetweenElAndRightBorder;
40
- if (heightMoreWindowBottom) {
41
- this.position = 'top';
42
- }
43
- if (heightMoreWindowBottom && widthMoreWindowRight && !heightMoreWindowTop || this.position === 'top-left') {
44
- this.position = 'top-left';
45
- this.renderer.setStyle(this.el.nativeElement, 'transform', 'translate(-100%, calc(-100% + ' + this.drDropdownPosition.height + 'px))');
46
- }
47
- if (heightMoreWindowTop && heightMoreWindowBottom) {
48
- this.position = 'left-center';
49
- }
50
- if (this.position === 'bottom-left') {
51
- this.renderer.setStyle(this.el.nativeElement, 'transform', `translate(calc(-100% + ${this.drDropdownPosition.width}px), ${this.drDropdownPosition.height + 8}px)`);
52
- }
53
- const className = this.position === 'top' ? 'content-top'
54
- : this.position === 'top-left' ? 'content-top-left'
55
- : this.position === 'bottom' ? 'content-bottom'
56
- : this.position === 'bottom-left' ? 'content-bottom-left'
57
- : this.position === 'left' ? 'content-left'
58
- : this.position === 'left-center' ? 'content-left-center'
59
- : this.position === 'right' ? 'content-right'
60
- : this.position === 'bottom-right' ? 'content-bottom-right' : '';
61
- this.renderer.addClass(this.el.nativeElement, className);
62
- this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');
63
- }
64
- else {
65
- const defaultChildPadding = 3;
66
- const widthMoreWindowRight = window.innerWidth - (this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding);
67
- const widthMoreWindowBottom = window.innerHeight - (this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding);
68
- const spaceRightAmount = window.innerWidth - (this.position.clientX + this.el.nativeElement.offsetWidth + defaultPadding);
69
- this.widthMoreRight = !(widthMoreWindowRight < 0);
70
- let calculatedHorizantallyPos = widthMoreWindowRight < 0
71
- ? -this.position.x + -defaultChildPadding
72
- : this.position.x + defaultChildPadding + xDifference;
73
- if (spaceRightAmount <= 0) {
74
- calculatedHorizantallyPos -= this.el.nativeElement.offsetWidth;
75
- }
76
- const deltaHeight = widthMoreWindowBottom < 0 ? widthMoreWindowBottom : defaultDelta;
77
- this.renderer.setStyle(this.el.nativeElement, 'top', (this.position.y + deltaHeight) + 'px');
78
- this.renderer.setStyle(this.el.nativeElement, 'left', (calculatedHorizantallyPos) + 'px');
79
- this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');
80
- }
81
- }
82
- }
83
- DrDropdownPositionDirective.decorators = [
84
- { type: Directive, args: [{
85
- selector: '[drDropdownPosition]',
86
- exportAs: 'dropdownPosition'
87
- },] }
88
- ];
89
- DrDropdownPositionDirective.ctorParameters = () => [
90
- { type: ElementRef },
91
- { type: Renderer2 }
92
- ];
93
- DrDropdownPositionDirective.propDecorators = {
94
- drDropdownPosition: [{ type: Input }],
95
- position: [{ type: Input }]
96
- };
97
- //# 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';\r\nimport { IDropdownCoordinate, ElPosition } from '../models/dropdown';\r\n\r\n@Directive({\r\n    selector: '[drDropdownPosition]',\r\n    exportAs: 'dropdownPosition'\r\n})\r\nexport class DrDropdownPositionDirective implements OnInit {\r\n\r\n    @Input() drDropdownPosition;\r\n    @Input() position: ElPosition | IDropdownCoordinate = 'left';\r\n\r\n    widthMoreRight: boolean;\r\n\r\n    constructor(private el: ElementRef, private renderer: Renderer2) {\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        setTimeout(this.calculatePosition.bind(this), 1);\r\n    }\r\n\r\n    calculatePosition() {\r\n        let xDifference = 0;\r\n        let defaultDelta = 10;\r\n        let defaultPadding = 0;\r\n\r\n        if (this.position === 'child') {\r\n            defaultDelta = 0;\r\n            defaultPadding = 10;\r\n            xDifference = this.el.nativeElement.parentElement.parentElement.offsetWidth - this.el.nativeElement.offsetWidth;\r\n            const parentRect = this.el.nativeElement.parentElement.parentElement.getBoundingClientRect();\r\n\r\n            this.position = {\r\n                x: this.el.nativeElement.offsetWidth,\r\n                y: this.el.nativeElement.parentElement.parentElement.offsetTop - 9,\r\n                clientX: parentRect.x + this.el.nativeElement.parentElement.parentElement.offsetWidth,\r\n                clientY: parentRect.y\r\n            };\r\n        }\r\n\r\n        if (typeof this.position === 'string') {\r\n            this.renderer.setStyle(this.el.nativeElement, 'top',\r\n              this.position === 'bottom' ?\r\n                this.drDropdownPosition.y - this.drDropdownPosition.height + 'px' :\r\n                this.drDropdownPosition.y + 'px');\r\n            this.renderer.setStyle(this.el.nativeElement, 'left',\r\n              this.position === 'right' ?\r\n                this.drDropdownPosition.x + this.drDropdownPosition.width + 'px' :\r\n                this.drDropdownPosition.x + 'px');\r\n            const menuHeight = this.el.nativeElement.offsetHeight;\r\n            const heightMoreWindowBottom = menuHeight + this.drDropdownPosition.y > window.innerHeight;\r\n            const heightMoreWindowTop = menuHeight - this.drDropdownPosition.y + this.drDropdownPosition.height / 2 > 48; // header height;\r\n            const widthMoreWindowRight = this.drDropdownPosition.x + 250 > window.innerWidth;\r\n\r\n            const spaceBetweenElAndRightBorder = window.innerWidth - (this.drDropdownPosition.x + this.el.nativeElement.offsetWidth);\r\n            this.widthMoreRight = this.drDropdownPosition.x < spaceBetweenElAndRightBorder;\r\n\r\n            if (heightMoreWindowBottom) {\r\n                this.position = 'top';\r\n            }\r\n            if (heightMoreWindowBottom && widthMoreWindowRight && !heightMoreWindowTop || this.position === 'top-left') {\r\n                this.position = 'top-left';\r\n                this.renderer.setStyle(this.el.nativeElement, 'transform',\r\n                  'translate(-100%, calc(-100% + ' + this.drDropdownPosition.height + 'px))');\r\n            }\r\n            if (heightMoreWindowTop && heightMoreWindowBottom) {\r\n                this.position = 'left-center';\r\n            }\r\n            if (this.position === 'bottom-left') {\r\n                this.renderer.setStyle(this.el.nativeElement, 'transform', `translate(calc(-100% + ${ this.drDropdownPosition.width }px), ${ this.drDropdownPosition.height + 8 }px)`);\r\n            }\r\n            const className = this.position === 'top' ? 'content-top'\r\n              : this.position === 'top-left' ? 'content-top-left'\r\n                : this.position === 'bottom' ? 'content-bottom'\r\n                  : this.position === 'bottom-left' ? 'content-bottom-left'\r\n                    : this.position === 'left' ? 'content-left'\r\n                      : this.position === 'left-center' ? 'content-left-center'\r\n                        : this.position === 'right' ? 'content-right'\r\n                          : this.position === 'bottom-right' ? 'content-bottom-right' : '';\r\n            this.renderer.addClass(this.el.nativeElement, className);\r\n            this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');\r\n        } else {\r\n            const defaultChildPadding = 3;\r\n            const widthMoreWindowRight = window.innerWidth - (this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding);\r\n            const widthMoreWindowBottom = window.innerHeight - (this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding);\r\n            const spaceRightAmount = window.innerWidth - (this.position.clientX + this.el.nativeElement.offsetWidth + defaultPadding);\r\n            this.widthMoreRight = !(widthMoreWindowRight < 0);\r\n\r\n            let calculatedHorizantallyPos = widthMoreWindowRight < 0\r\n              ? -this.position.x + -defaultChildPadding\r\n              : this.position.x + defaultChildPadding + xDifference;\r\n\r\n            if (spaceRightAmount <= 0) {\r\n              calculatedHorizantallyPos -= this.el.nativeElement.offsetWidth;\r\n            }\r\n\r\n            const deltaHeight = widthMoreWindowBottom < 0 ? widthMoreWindowBottom : defaultDelta;\r\n\r\n            this.renderer.setStyle(this.el.nativeElement, 'top', (this.position.y + deltaHeight) + 'px');\r\n            this.renderer.setStyle(this.el.nativeElement, 'left', (calculatedHorizantallyPos) + 'px');\r\n            this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');\r\n        }\r\n    }\r\n}\r\n"]}
1
+ import { Directive, ElementRef, Input, Renderer2 } from '@angular/core';
2
+ export class DrDropdownPositionDirective {
3
+ constructor(el, renderer) {
4
+ this.el = el;
5
+ this.renderer = renderer;
6
+ this.position = 'left';
7
+ }
8
+ ngOnInit() {
9
+ setTimeout(this.calculatePosition.bind(this), 1);
10
+ }
11
+ calculatePosition() {
12
+ let xDifference = 0;
13
+ let defaultDelta = 10;
14
+ let defaultPadding = 0;
15
+ if (this.position === 'child') {
16
+ defaultDelta = 0;
17
+ defaultPadding = 10;
18
+ xDifference = this.el.nativeElement.parentElement.parentElement.offsetWidth - this.el.nativeElement.offsetWidth;
19
+ const parentRect = this.el.nativeElement.parentElement.parentElement.getBoundingClientRect();
20
+ this.position = {
21
+ x: this.el.nativeElement.offsetWidth,
22
+ y: this.el.nativeElement.parentElement.parentElement.offsetTop - 9,
23
+ clientX: parentRect.x + this.el.nativeElement.parentElement.parentElement.offsetWidth,
24
+ clientY: parentRect.y
25
+ };
26
+ }
27
+ if (typeof this.position === 'string') {
28
+ this.renderer.setStyle(this.el.nativeElement, 'top', this.position === 'bottom' ?
29
+ this.drDropdownPosition.y - this.drDropdownPosition.height + 'px' :
30
+ this.drDropdownPosition.y + 'px');
31
+ this.renderer.setStyle(this.el.nativeElement, 'left', this.position === 'right' ?
32
+ this.drDropdownPosition.x + this.drDropdownPosition.width + 'px' :
33
+ this.drDropdownPosition.x + 'px');
34
+ const menuHeight = this.el.nativeElement.offsetHeight;
35
+ const heightMoreWindowBottom = menuHeight + this.drDropdownPosition.y > window.innerHeight;
36
+ const heightMoreWindowTop = menuHeight - this.drDropdownPosition.y + this.drDropdownPosition.height / 2 > 48; // header height;
37
+ const widthMoreWindowRight = this.drDropdownPosition.x + 250 > window.innerWidth;
38
+ const spaceBetweenElAndRightBorder = window.innerWidth - (this.drDropdownPosition.x + this.el.nativeElement.offsetWidth);
39
+ this.widthMoreRight = this.drDropdownPosition.x < spaceBetweenElAndRightBorder;
40
+ if (heightMoreWindowBottom) {
41
+ this.position = 'top';
42
+ }
43
+ if (heightMoreWindowBottom && widthMoreWindowRight && !heightMoreWindowTop || this.position === 'top-left') {
44
+ this.position = 'top-left';
45
+ this.renderer.setStyle(this.el.nativeElement, 'transform', 'translate(-100%, calc(-100% + ' + this.drDropdownPosition.height + 'px))');
46
+ }
47
+ if (heightMoreWindowTop && heightMoreWindowBottom) {
48
+ this.position = 'left-center';
49
+ }
50
+ if (this.position === 'bottom-left') {
51
+ this.renderer.setStyle(this.el.nativeElement, 'transform', `translate(calc(-100% + ${this.drDropdownPosition.width}px), ${this.drDropdownPosition.height + 8}px)`);
52
+ }
53
+ const className = this.position === 'top' ? 'content-top'
54
+ : this.position === 'top-left' ? 'content-top-left'
55
+ : this.position === 'bottom' ? 'content-bottom'
56
+ : this.position === 'bottom-left' ? 'content-bottom-left'
57
+ : this.position === 'left' ? 'content-left'
58
+ : this.position === 'left-center' ? 'content-left-center'
59
+ : this.position === 'right' ? 'content-right'
60
+ : this.position === 'bottom-right' ? 'content-bottom-right' : '';
61
+ this.renderer.addClass(this.el.nativeElement, className);
62
+ this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');
63
+ }
64
+ else {
65
+ const defaultChildPadding = 3;
66
+ const widthMoreWindowRight = window.innerWidth - (this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding);
67
+ const widthMoreWindowBottom = window.innerHeight - (this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding);
68
+ const spaceRightAmount = window.innerWidth - (this.position.clientX + this.el.nativeElement.offsetWidth + defaultPadding);
69
+ this.widthMoreRight = !(widthMoreWindowRight < 0);
70
+ let calculatedHorizantallyPos = widthMoreWindowRight < 0
71
+ ? -this.position.x + -defaultChildPadding
72
+ : this.position.x + defaultChildPadding + xDifference;
73
+ if (spaceRightAmount <= 0) {
74
+ calculatedHorizantallyPos -= this.el.nativeElement.offsetWidth;
75
+ }
76
+ const deltaHeight = widthMoreWindowBottom < 0 ? widthMoreWindowBottom : defaultDelta;
77
+ this.renderer.setStyle(this.el.nativeElement, 'top', (this.position.y + deltaHeight) + 'px');
78
+ this.renderer.setStyle(this.el.nativeElement, 'left', (calculatedHorizantallyPos) + 'px');
79
+ this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');
80
+ }
81
+ }
82
+ }
83
+ DrDropdownPositionDirective.decorators = [
84
+ { type: Directive, args: [{
85
+ selector: '[drDropdownPosition]',
86
+ exportAs: 'dropdownPosition'
87
+ },] }
88
+ ];
89
+ DrDropdownPositionDirective.ctorParameters = () => [
90
+ { type: ElementRef },
91
+ { type: Renderer2 }
92
+ ];
93
+ DrDropdownPositionDirective.propDecorators = {
94
+ drDropdownPosition: [{ type: Input }],
95
+ position: [{ type: Input }]
96
+ };
97
+ //# 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 { IDropdownCoordinate, ElPosition } 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\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                this.renderer.setStyle(this.el.nativeElement, 'transform',\n                  'translate(-100%, calc(-100% + ' + this.drDropdownPosition.height + 'px))');\n            }\n            if (heightMoreWindowTop && heightMoreWindowBottom) {\n                this.position = 'left-center';\n            }\n            if (this.position === 'bottom-left') {\n                this.renderer.setStyle(this.el.nativeElement, 'transform', `translate(calc(-100% + ${ this.drDropdownPosition.width }px), ${ this.drDropdownPosition.height + 8 }px)`);\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 = window.innerWidth - (this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding);\n            const widthMoreWindowBottom = window.innerHeight - (this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding);\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) {\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,110 +1,110 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';
2
- import { DrDropdownService } from './dr-dropdown.service';
3
- export class DrDropdownComponent {
4
- constructor(menuService, cdr) {
5
- this.menuService = menuService;
6
- this.cdr = cdr;
7
- this.position = 'left';
8
- }
9
- set options(data) {
10
- if (data) {
11
- this.option = data.option;
12
- this.position = data.position;
13
- this.drDropdownInHover = data.drDropdownInHover;
14
- this.containerClass = data.class;
15
- this.list = data.list || [];
16
- this.list.forEach(item => {
17
- var _a, _b;
18
- if ((_a = item.children) === null || _a === void 0 ? void 0 : _a.length) {
19
- item.childOptions = {
20
- list: item.children,
21
- class: ((_b = item === null || item === void 0 ? void 0 : item.childOptions) === null || _b === void 0 ? void 0 : _b.class) || '',
22
- position: 'child'
23
- };
24
- }
25
- });
26
- this.cdr.markForCheck();
27
- }
28
- }
29
- onMouseLeave() {
30
- if (this.drDropdownInHover)
31
- this.menuService.destroy();
32
- }
33
- onClickedOutside() {
34
- if (this.firstInit) {
35
- this.menuService.destroy();
36
- }
37
- else {
38
- this.firstInit = true;
39
- }
40
- }
41
- hide() {
42
- this.menuService.destroy();
43
- }
44
- disabled(act) {
45
- if (!act.disabled) {
46
- return false;
47
- }
48
- if (typeof act.disabled === 'boolean') {
49
- return act.disabled;
50
- }
51
- else {
52
- return act.disabled(act.data);
53
- }
54
- }
55
- selected(act) {
56
- if (!act.selected) {
57
- return false;
58
- }
59
- if (typeof act.selected === 'boolean') {
60
- return act.selected;
61
- }
62
- else {
63
- return act.selected(act.data);
64
- }
65
- }
66
- tooltipToShow(act) {
67
- if (act.toolTipIfDisabled && !this.disabled(act))
68
- return '';
69
- return act.toolTip;
70
- }
71
- tooltipPosition(widthMoreRight) {
72
- return widthMoreRight ? 'right' : 'left';
73
- }
74
- action(act) {
75
- if (!this.disabled(act)) {
76
- if (act.action) {
77
- act.action(act.data);
78
- }
79
- else {
80
- this.menuService.actionItem.next({ event: act.event || act.title || 'default', data: act.data });
81
- }
82
- this.hide();
83
- }
84
- }
85
- onActionIconClick($event, actionIcon, data) {
86
- $event.stopPropagation();
87
- if (!this.disabled(actionIcon)) {
88
- actionIcon.action(data);
89
- this.hide();
90
- }
91
- }
92
- }
93
- DrDropdownComponent.decorators = [
94
- { type: Component, args: [{
95
- selector: 'dr-dropdown',
96
- template: "<div #menuContainer\r\n (mouseleave)=\"onMouseLeave()\"\r\n (clickOutside)=\"onClickedOutside()\"\r\n [drDropdownPosition]=\"option\"\r\n #dropdownPosition=\"dropdownPosition\"\r\n [position]=\"position\"\r\n [class]=\"containerClass\"\r\n class=\"dr-dropdown\">\r\n <div class=\"dr-dropdown__container\">\r\n <div *ngFor=\"let act of list | drDropdownItemShowPipe\"\r\n (click)=\"action(act)\"\r\n [drTooltip]=\"tooltipToShow(act)\"\r\n [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\r\n [drTooltipOptions]=\"{ withoutArrow: true }\"\r\n [drTooltipClass]=\"'dr-dropdown__tooltip'\"\r\n class=\"dr-dropdown__container__item\"\r\n [class.item-disabled]=\"disabled(act)\"\r\n [class.item-selected]=\"selected(act)\">\r\n <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\r\n <span class=\"dr-dropdown__container__item__text\">{{act.title}}</span>\r\n <i *ngFor=\"let actionIcon of act.actionIcons\"\r\n [class]=\"actionIcon.icon\"\r\n [class.showOnHover]=\"actionIcon.showOnHover\"\r\n (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\r\n <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\r\n <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\r\n </div>\r\n </div>\r\n</div>\r\n",
97
- changeDetection: ChangeDetectionStrategy.OnPush,
98
- styles: ["::ng-deep .dr-dropdown__container__item .dr-dropdown{visibility:hidden}::ng-deep .dr-dropdown__container__item:hover>*>.dr-dropdown{visibility:visible}::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: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"]
99
- },] }
100
- ];
101
- DrDropdownComponent.ctorParameters = () => [
102
- { type: DrDropdownService },
103
- { type: ChangeDetectorRef }
104
- ];
105
- DrDropdownComponent.propDecorators = {
106
- viewMenu: [{ type: ViewChild, args: ['listMenu',] }],
107
- menuContainer: [{ type: ViewChild, args: ['menuContainer',] }],
108
- options: [{ type: Input }]
109
- };
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';\r\nimport { IDropdownItem, ElPosition, IDropdownActionIcon, IDropdown, IDropdownCoordinate } from '../models/dropdown';\r\nimport { DrDropdownService } from './dr-dropdown.service';\r\n\r\n@Component({\r\n  selector: 'dr-dropdown',\r\n  templateUrl: './dr-dropdown.component.html',\r\n  styleUrls: ['./dr-dropdown.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DrDropdownComponent {\r\n\r\n  @ViewChild('listMenu') viewMenu: HTMLElement;\r\n  @ViewChild('menuContainer') menuContainer: HTMLElement;\r\n  option: any;\r\n  position: ElPosition | IDropdownCoordinate = 'left';\r\n  drDropdownInHover: boolean;\r\n  list: IDropdownItem<unknown>[];\r\n  containerClass: string;\r\n  private firstInit: boolean;\r\n\r\n  constructor(protected menuService: DrDropdownService, private cdr: ChangeDetectorRef) {\r\n  }\r\n\r\n  @Input() set options(data: IDropdown<IDropdownItem<any>>) {\r\n    if (data) {\r\n      this.option = data.option;\r\n      this.position = data.position;\r\n      this.drDropdownInHover = data.drDropdownInHover;\r\n      this.containerClass = data.class;\r\n      this.list = data.list || [];\r\n      this.list.forEach(item => {\r\n        if (item.children?.length) {\r\n          item.childOptions = {\r\n            list: item.children,\r\n            class: item?.childOptions?.class || '',\r\n            position: 'child'\r\n          };\r\n        }\r\n      });\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  onMouseLeave(): void {\r\n    if (this.drDropdownInHover) this.menuService.destroy();\r\n  }\r\n\r\n  onClickedOutside(): void {\r\n    if (this.firstInit) {\r\n      this.menuService.destroy();\r\n    } else {\r\n      this.firstInit = true;\r\n    }\r\n  }\r\n\r\n  hide(): void {\r\n    this.menuService.destroy();\r\n  }\r\n\r\n  disabled(act: IDropdownItem<unknown> | IDropdownActionIcon<any>): boolean {\r\n    if (!act.disabled) {\r\n      return false;\r\n    }\r\n    if (typeof act.disabled === 'boolean') {\r\n      return act.disabled;\r\n    } else {\r\n      return act.disabled(act.data);\r\n    }\r\n  }\r\n\r\n  selected(act: IDropdownItem<unknown>): boolean {\r\n    if (!act.selected) {\r\n      return false;\r\n    }\r\n    if (typeof act.selected === 'boolean') {\r\n      return act.selected;\r\n    } else {\r\n      return act.selected(act.data);\r\n    }\r\n  }\r\n\r\n  tooltipToShow(act: IDropdownItem<unknown>): string {\r\n    if (act.toolTipIfDisabled && !this.disabled(act)) return '';\r\n    return act.toolTip;\r\n  }\r\n\r\n  tooltipPosition(widthMoreRight: boolean) {\r\n    return widthMoreRight ? 'right' : 'left';\r\n  }\r\n\r\n  action(act: IDropdownItem<any>) {\r\n    if (!this.disabled(act)) {\r\n      if (act.action) {\r\n        act.action(act.data);\r\n      } else {\r\n        this.menuService.actionItem.next({event: act.event || act.title || 'default', data: act.data});\r\n      }\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  onActionIconClick($event, actionIcon: IDropdownActionIcon<any>, data: any) {\r\n    $event.stopPropagation();\r\n    if (!this.disabled(actionIcon)) {\r\n      actionIcon.action(data);\r\n      this.hide();\r\n    }\r\n  }\r\n}\r\n\r\n"]}
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';
2
+ import { DrDropdownService } from './dr-dropdown.service';
3
+ export class DrDropdownComponent {
4
+ constructor(menuService, cdr) {
5
+ this.menuService = menuService;
6
+ this.cdr = cdr;
7
+ this.position = 'left';
8
+ }
9
+ set options(data) {
10
+ if (data) {
11
+ this.option = data.option;
12
+ this.position = data.position;
13
+ this.drDropdownInHover = data.drDropdownInHover;
14
+ this.containerClass = data.class;
15
+ this.list = data.list || [];
16
+ this.list.forEach(item => {
17
+ var _a, _b;
18
+ if ((_a = item.children) === null || _a === void 0 ? void 0 : _a.length) {
19
+ item.childOptions = {
20
+ list: item.children,
21
+ class: ((_b = item === null || item === void 0 ? void 0 : item.childOptions) === null || _b === void 0 ? void 0 : _b.class) || '',
22
+ position: 'child'
23
+ };
24
+ }
25
+ });
26
+ this.cdr.markForCheck();
27
+ }
28
+ }
29
+ onMouseLeave() {
30
+ if (this.drDropdownInHover)
31
+ this.menuService.destroy();
32
+ }
33
+ onClickedOutside() {
34
+ if (this.firstInit) {
35
+ this.menuService.destroy();
36
+ }
37
+ else {
38
+ this.firstInit = true;
39
+ }
40
+ }
41
+ hide() {
42
+ this.menuService.destroy();
43
+ }
44
+ disabled(act) {
45
+ if (!act.disabled) {
46
+ return false;
47
+ }
48
+ if (typeof act.disabled === 'boolean') {
49
+ return act.disabled;
50
+ }
51
+ else {
52
+ return act.disabled(act.data);
53
+ }
54
+ }
55
+ selected(act) {
56
+ if (!act.selected) {
57
+ return false;
58
+ }
59
+ if (typeof act.selected === 'boolean') {
60
+ return act.selected;
61
+ }
62
+ else {
63
+ return act.selected(act.data);
64
+ }
65
+ }
66
+ tooltipToShow(act) {
67
+ if (act.toolTipIfDisabled && !this.disabled(act))
68
+ return '';
69
+ return act.toolTip;
70
+ }
71
+ tooltipPosition(widthMoreRight) {
72
+ return widthMoreRight ? 'right' : 'left';
73
+ }
74
+ action(act) {
75
+ if (!this.disabled(act)) {
76
+ if (act.action) {
77
+ act.action(act.data);
78
+ }
79
+ else {
80
+ this.menuService.actionItem.next({ event: act.event || act.title || 'default', data: act.data });
81
+ }
82
+ this.hide();
83
+ }
84
+ }
85
+ onActionIconClick($event, actionIcon, data) {
86
+ $event.stopPropagation();
87
+ if (!this.disabled(actionIcon)) {
88
+ actionIcon.action(data);
89
+ this.hide();
90
+ }
91
+ }
92
+ }
93
+ DrDropdownComponent.decorators = [
94
+ { type: Component, args: [{
95
+ selector: 'dr-dropdown',
96
+ template: "<div #menuContainer\n (mouseleave)=\"onMouseLeave()\"\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 <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",
97
+ changeDetection: ChangeDetectionStrategy.OnPush,
98
+ styles: ["::ng-deep .dr-dropdown__container__item .dr-dropdown{visibility:hidden}::ng-deep .dr-dropdown__container__item:hover>*>.dr-dropdown{visibility:visible}::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: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"]
99
+ },] }
100
+ ];
101
+ DrDropdownComponent.ctorParameters = () => [
102
+ { type: DrDropdownService },
103
+ { type: ChangeDetectorRef }
104
+ ];
105
+ DrDropdownComponent.propDecorators = {
106
+ viewMenu: [{ type: ViewChild, args: ['listMenu',] }],
107
+ menuContainer: [{ type: ViewChild, args: ['menuContainer',] }],
108
+ options: [{ type: Input }]
109
+ };
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';\nimport { IDropdownItem, ElPosition, IDropdownActionIcon, IDropdown, IDropdownCoordinate } 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  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  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.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"]}