@ethlete/core 1.9.1 → 1.10.1

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 (155) hide show
  1. package/esm2022/lib/components/structured-data/structured-data.component.mjs +38 -0
  2. package/esm2022/lib/directives/animatable/animatable.directive.mjs +116 -0
  3. package/esm2022/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +116 -0
  4. package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +38 -0
  5. package/esm2022/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +148 -0
  6. package/esm2022/lib/directives/delayable/delayable.directive.mjs +56 -0
  7. package/esm2022/lib/directives/let/let.directive.mjs +41 -0
  8. package/esm2022/lib/directives/observe-content/observe-content.directive.mjs +69 -0
  9. package/esm2022/lib/directives/observe-resize/observe-resize.directive.mjs +69 -0
  10. package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +177 -0
  11. package/esm2022/lib/directives/repeat/repeat.directive.mjs +37 -0
  12. package/esm2022/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +32 -0
  13. package/esm2022/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +19 -0
  14. package/esm2022/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +35 -0
  15. package/esm2022/lib/directives/seo/seo.directive.mjs +167 -0
  16. package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +16 -0
  17. package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +16 -0
  18. package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +16 -0
  19. package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +16 -0
  20. package/esm2022/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +16 -0
  21. package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +16 -0
  22. package/esm2022/lib/services/click-observer.service.mjs +75 -0
  23. package/esm2022/lib/services/content-observer.service.mjs +81 -0
  24. package/esm2022/lib/services/destroy.service.mjs +24 -0
  25. package/esm2022/lib/services/focus-visible.service.mjs +35 -0
  26. package/esm2022/lib/services/resize-observer.service.mjs +77 -0
  27. package/esm2022/lib/services/router-state.service.mjs +116 -0
  28. package/esm2022/lib/services/viewport.service.mjs +169 -0
  29. package/esm2022/lib/types/angular.types.mjs +15 -0
  30. package/esm2022/lib/utils/scrollable.utils.mjs +85 -0
  31. package/{fesm2020 → fesm2022}/ethlete-core.mjs +119 -140
  32. package/{fesm2020 → fesm2022}/ethlete-core.mjs.map +1 -1
  33. package/lib/components/structured-data/structured-data.component.d.ts +1 -1
  34. package/lib/directives/animatable/animatable.directive.d.ts +1 -1
  35. package/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.d.ts +1 -1
  36. package/lib/directives/let/let.directive.d.ts +1 -1
  37. package/lib/directives/observe-content/observe-content.directive.d.ts +1 -1
  38. package/lib/directives/observe-resize/observe-resize.directive.d.ts +1 -1
  39. package/lib/directives/observe-scroll-state/observe-scroll-state.directive.d.ts +1 -1
  40. package/lib/directives/repeat/repeat.directive.d.ts +1 -1
  41. package/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.d.ts +1 -1
  42. package/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.d.ts +1 -1
  43. package/lib/types/angular.types.d.ts +6 -8
  44. package/package.json +13 -19
  45. package/esm2020/lib/components/structured-data/structured-data.component.mjs +0 -37
  46. package/esm2020/lib/directives/animatable/animatable.directive.mjs +0 -115
  47. package/esm2020/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +0 -115
  48. package/esm2020/lib/directives/click-outside/click-outside.directive.mjs +0 -37
  49. package/esm2020/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +0 -147
  50. package/esm2020/lib/directives/delayable/delayable.directive.mjs +0 -55
  51. package/esm2020/lib/directives/let/let.directive.mjs +0 -40
  52. package/esm2020/lib/directives/observe-content/observe-content.directive.mjs +0 -68
  53. package/esm2020/lib/directives/observe-resize/observe-resize.directive.mjs +0 -68
  54. package/esm2020/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +0 -176
  55. package/esm2020/lib/directives/repeat/repeat.directive.mjs +0 -36
  56. package/esm2020/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +0 -31
  57. package/esm2020/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +0 -18
  58. package/esm2020/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +0 -34
  59. package/esm2020/lib/directives/seo/seo.directive.mjs +0 -166
  60. package/esm2020/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +0 -15
  61. package/esm2020/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +0 -15
  62. package/esm2020/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +0 -15
  63. package/esm2020/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +0 -15
  64. package/esm2020/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +0 -15
  65. package/esm2020/lib/pipes/to-array/to-array.pipe.mjs +0 -15
  66. package/esm2020/lib/services/click-observer.service.mjs +0 -73
  67. package/esm2020/lib/services/content-observer.service.mjs +0 -79
  68. package/esm2020/lib/services/destroy.service.mjs +0 -23
  69. package/esm2020/lib/services/focus-visible.service.mjs +0 -34
  70. package/esm2020/lib/services/resize-observer.service.mjs +0 -75
  71. package/esm2020/lib/services/router-state.service.mjs +0 -115
  72. package/esm2020/lib/services/viewport.service.mjs +0 -168
  73. package/esm2020/lib/types/angular.types.mjs +0 -36
  74. package/esm2020/lib/utils/scrollable.utils.mjs +0 -85
  75. package/fesm2015/ethlete-core.mjs +0 -2787
  76. package/fesm2015/ethlete-core.mjs.map +0 -1
  77. /package/{esm2020 → esm2022}/ethlete-core.mjs +0 -0
  78. /package/{esm2020 → esm2022}/index.mjs +0 -0
  79. /package/{esm2020 → esm2022}/lib/components/public-api.mjs +0 -0
  80. /package/{esm2020 → esm2022}/lib/components/structured-data/public-api.mjs +0 -0
  81. /package/{esm2020 → esm2022}/lib/constants/index.mjs +0 -0
  82. /package/{esm2020 → esm2022}/lib/constants/public-api.mjs +0 -0
  83. /package/{esm2020 → esm2022}/lib/constants/viewport.constants.mjs +0 -0
  84. /package/{esm2020 → esm2022}/lib/decorators/index.mjs +0 -0
  85. /package/{esm2020 → esm2022}/lib/decorators/memo/memo.decorator.mjs +0 -0
  86. /package/{esm2020 → esm2022}/lib/decorators/memo/public-api.mjs +0 -0
  87. /package/{esm2020 → esm2022}/lib/decorators/public-api.mjs +0 -0
  88. /package/{esm2020 → esm2022}/lib/directives/animatable/index.mjs +0 -0
  89. /package/{esm2020 → esm2022}/lib/directives/animatable/public-api.mjs +0 -0
  90. /package/{esm2020 → esm2022}/lib/directives/animated-lifecycle/public-api.mjs +0 -0
  91. /package/{esm2020 → esm2022}/lib/directives/click-outside/public-api.mjs +0 -0
  92. /package/{esm2020 → esm2022}/lib/directives/cursor-drag-scroll/cursor-drag-scroll.constants.mjs +0 -0
  93. /package/{esm2020 → esm2022}/lib/directives/cursor-drag-scroll/public-api.mjs +0 -0
  94. /package/{esm2020 → esm2022}/lib/directives/delayable/public-api.mjs +0 -0
  95. /package/{esm2020 → esm2022}/lib/directives/let/let.types.mjs +0 -0
  96. /package/{esm2020 → esm2022}/lib/directives/let/public-api.mjs +0 -0
  97. /package/{esm2020 → esm2022}/lib/directives/observe-content/public-api.mjs +0 -0
  98. /package/{esm2020 → esm2022}/lib/directives/observe-resize/public-api.mjs +0 -0
  99. /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/observe-scroll-state.constants.mjs +0 -0
  100. /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/observe-scroll-state.types.mjs +0 -0
  101. /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/public-api.mjs +0 -0
  102. /package/{esm2020 → esm2022}/lib/directives/public-api.mjs +0 -0
  103. /package/{esm2020 → esm2022}/lib/directives/repeat/public-api.mjs +0 -0
  104. /package/{esm2020 → esm2022}/lib/directives/scroll-observer-first-element/index.mjs +0 -0
  105. /package/{esm2020 → esm2022}/lib/directives/scroll-observer-first-element/public-api.mjs +0 -0
  106. /package/{esm2020 → esm2022}/lib/directives/scroll-observer-ignore-target/index.mjs +0 -0
  107. /package/{esm2020 → esm2022}/lib/directives/scroll-observer-ignore-target/public-api.mjs +0 -0
  108. /package/{esm2020 → esm2022}/lib/directives/scroll-observer-last-element/index.mjs +0 -0
  109. /package/{esm2020 → esm2022}/lib/directives/scroll-observer-last-element/public-api.mjs +0 -0
  110. /package/{esm2020 → esm2022}/lib/directives/seo/public-api.mjs +0 -0
  111. /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.constants.mjs +0 -0
  112. /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.types.mjs +0 -0
  113. /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.utils.mjs +0 -0
  114. /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/normalize-game-result-type.types.mjs +0 -0
  115. /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/normalize-game-result-type.util.mjs +0 -0
  116. /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/public-api.mjs +0 -0
  117. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/normalize-match-participants.types.mjs +0 -0
  118. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/normalize-match-participants.util.mjs +0 -0
  119. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/public-api.mjs +0 -0
  120. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/normalize-match-score.types.mjs +0 -0
  121. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/normalize-match-score.util.mjs +0 -0
  122. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/public-api.mjs +0 -0
  123. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/index.mjs +0 -0
  124. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/normalize-match-state.constants.mjs +0 -0
  125. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/normalize-match-state.util.mjs +0 -0
  126. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/public-api.mjs +0 -0
  127. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-type/normalize-match-type.util.mjs +0 -0
  128. /package/{esm2020 → esm2022}/lib/pipes/normalize-match-type/public-api.mjs +0 -0
  129. /package/{esm2020 → esm2022}/lib/pipes/public-api.mjs +0 -0
  130. /package/{esm2020 → esm2022}/lib/pipes/to-array/public-api.mjs +0 -0
  131. /package/{esm2020 → esm2022}/lib/pipes/to-array/to-array.util.mjs +0 -0
  132. /package/{esm2020 → esm2022}/lib/public-api.mjs +0 -0
  133. /package/{esm2020 → esm2022}/lib/services/index.mjs +0 -0
  134. /package/{esm2020 → esm2022}/lib/services/public-api.mjs +0 -0
  135. /package/{esm2020 → esm2022}/lib/services/viewport.types.mjs +0 -0
  136. /package/{esm2020 → esm2022}/lib/types/i18n.types.mjs +0 -0
  137. /package/{esm2020 → esm2022}/lib/types/index.mjs +0 -0
  138. /package/{esm2020 → esm2022}/lib/types/public-api.mjs +0 -0
  139. /package/{esm2020 → esm2022}/lib/types/viewport.types.mjs +0 -0
  140. /package/{esm2020 → esm2022}/lib/utils/animation.utils.mjs +0 -0
  141. /package/{esm2020 → esm2022}/lib/utils/clamp.util.mjs +0 -0
  142. /package/{esm2020 → esm2022}/lib/utils/clone.util.mjs +0 -0
  143. /package/{esm2020 → esm2022}/lib/utils/cookie.util.mjs +0 -0
  144. /package/{esm2020 → esm2022}/lib/utils/equal.util.mjs +0 -0
  145. /package/{esm2020 → esm2022}/lib/utils/index.mjs +0 -0
  146. /package/{esm2020 → esm2022}/lib/utils/media-query-observable.util.mjs +0 -0
  147. /package/{esm2020 → esm2022}/lib/utils/public-api.mjs +0 -0
  148. /package/{esm2020 → esm2022}/lib/utils/reactive-binding.util.mjs +0 -0
  149. /package/{esm2020 → esm2022}/lib/utils/rxjs.utils.mjs +0 -0
  150. /package/{esm2020 → esm2022}/lib/utils/smart-block-scroll-strategy.utils.mjs +0 -0
  151. /package/{esm2020 → esm2022}/lib/utils/viewport.util.mjs +0 -0
  152. /package/{esm2020 → esm2022}/lib/validators/is-array-not-empty.validator.mjs +0 -0
  153. /package/{esm2020 → esm2022}/lib/validators/is-email.validator.mjs +0 -0
  154. /package/{esm2020 → esm2022}/lib/validators/must-match.validator.mjs +0 -0
  155. /package/{esm2020 → esm2022}/lib/validators/public-api.mjs +0 -0
@@ -0,0 +1,38 @@
1
+ import { ChangeDetectionStrategy, Component, HostBinding, inject, Input, ViewEncapsulation } from '@angular/core';
2
+ import { DomSanitizer } from '@angular/platform-browser';
3
+ import * as i0 from "@angular/core";
4
+ class StructuredDataComponent {
5
+ constructor() {
6
+ this._sanitizer = inject(DomSanitizer);
7
+ }
8
+ set data(currentValue) {
9
+ this.jsonLD = this.getSafeHTML(currentValue);
10
+ }
11
+ getSafeHTML(value) {
12
+ const json = value ? JSON.stringify(value, null, 2).replace(/<\/script>/g, '<\\/script>') : '';
13
+ const html = `<script type="application/ld+json">${json}</script>`;
14
+ return this._sanitizer.bypassSecurityTrustHtml(html);
15
+ }
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: StructuredDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
17
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: StructuredDataComponent, isStandalone: true, selector: "et-structured-data", inputs: { data: "data" }, host: { properties: { "innerHTML": "this.jsonLD" }, styleAttribute: "display: none" }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
18
+ }
19
+ export { StructuredDataComponent };
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: StructuredDataComponent, decorators: [{
21
+ type: Component,
22
+ args: [{
23
+ selector: 'et-structured-data',
24
+ standalone: true,
25
+ template: '',
26
+ changeDetection: ChangeDetectionStrategy.OnPush,
27
+ encapsulation: ViewEncapsulation.None,
28
+ host: {
29
+ style: 'display: none',
30
+ },
31
+ }]
32
+ }], propDecorators: { data: [{
33
+ type: Input
34
+ }], jsonLD: [{
35
+ type: HostBinding,
36
+ args: ['innerHTML']
37
+ }] } });
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlZC1kYXRhLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc3RydWN0dXJlZC1kYXRhL3N0cnVjdHVyZWQtZGF0YS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsSCxPQUFPLEVBQUUsWUFBWSxFQUFZLE1BQU0sMkJBQTJCLENBQUM7O0FBR25FLE1BVWEsdUJBQXVCO0lBVnBDO1FBV21CLGVBQVUsR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7S0FlcEQ7SUFiQyxJQUNJLElBQUksQ0FBQyxZQUFnRjtRQUN2RixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUtELFdBQVcsQ0FBQyxLQUF5RTtRQUNuRixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDL0YsTUFBTSxJQUFJLEdBQUcsc0NBQXNDLElBQUksV0FBVyxDQUFDO1FBQ25FLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2RCxDQUFDOzhHQWZVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLCtMQVB4QixFQUFFOztTQU9ELHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQVZuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsRUFBRTtvQkFDWixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsZUFBZTtxQkFDdkI7aUJBQ0Y7OEJBS0ssSUFBSTtzQkFEUCxLQUFLO2dCQU1OLE1BQU07c0JBREwsV0FBVzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIGluamVjdCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVIdG1sIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5pbXBvcnQgeyBKc29uTEQgfSBmcm9tICdAZXRobGV0ZS90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2V0LXN0cnVjdHVyZWQtZGF0YScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHRlbXBsYXRlOiAnJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGhvc3Q6IHtcbiAgICBzdHlsZTogJ2Rpc3BsYXk6IG5vbmUnLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBTdHJ1Y3R1cmVkRGF0YUNvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX3Nhbml0aXplciA9IGluamVjdChEb21TYW5pdGl6ZXIpO1xuXG4gIEBJbnB1dCgpXG4gIHNldCBkYXRhKGN1cnJlbnRWYWx1ZTogSnNvbkxELldpdGhDb250ZXh0PEpzb25MRC5UaGluZz4gfCBKc29uTEQuR3JhcGggfCBudWxsIHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy5qc29uTEQgPSB0aGlzLmdldFNhZmVIVE1MKGN1cnJlbnRWYWx1ZSk7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ2lubmVySFRNTCcpXG4gIGpzb25MRD86IFNhZmVIdG1sO1xuXG4gIGdldFNhZmVIVE1MKHZhbHVlOiBKc29uTEQuV2l0aENvbnRleHQ8SnNvbkxELlRoaW5nPiB8IEpzb25MRC5HcmFwaCB8IG51bGwgfCB1bmRlZmluZWQpIHtcbiAgICBjb25zdCBqc29uID0gdmFsdWUgPyBKU09OLnN0cmluZ2lmeSh2YWx1ZSwgbnVsbCwgMikucmVwbGFjZSgvPFxcL3NjcmlwdD4vZywgJzxcXFxcL3NjcmlwdD4nKSA6ICcnO1xuICAgIGNvbnN0IGh0bWwgPSBgPHNjcmlwdCB0eXBlPVwiYXBwbGljYXRpb24vbGQranNvblwiPiR7anNvbn08L3NjcmlwdD5gO1xuICAgIHJldHVybiB0aGlzLl9zYW5pdGl6ZXIuYnlwYXNzU2VjdXJpdHlUcnVzdEh0bWwoaHRtbCk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,116 @@
1
+ import { Directive, ElementRef, inject, InjectionToken, Input, isDevMode } from '@angular/core';
2
+ import { BehaviorSubject, debounceTime, filter, fromEvent, map, merge, skip, Subject, takeUntil, tap, } from 'rxjs';
3
+ import { DestroyService } from '../../services';
4
+ import * as i0 from "@angular/core";
5
+ export const ANIMATABLE_TOKEN = new InjectionToken('ANIMATABLE_DIRECTIVE_TOKEN');
6
+ class AnimatableDirective {
7
+ constructor() {
8
+ this._didEmitStart = false;
9
+ this._parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });
10
+ this._destroy$ = inject(DestroyService, { host: true }).destroy$;
11
+ this._elementRef = inject(ElementRef);
12
+ this._animationStart$ = new Subject();
13
+ this._animationEnd$ = new Subject();
14
+ this._animatedElement$ = new BehaviorSubject(this._elementRef.nativeElement);
15
+ this.animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));
16
+ this.animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));
17
+ this._hostActiveAnimationCount$ = new BehaviorSubject(0);
18
+ this._totalActiveAnimationCount$ = new BehaviorSubject(0);
19
+ this.isAnimating$ = this._totalActiveAnimationCount$.pipe(map((count) => count > 0), debounceTime(0));
20
+ }
21
+ set animatedElement(value) {
22
+ let newElement = null;
23
+ if (value === null || value === undefined) {
24
+ newElement = this._elementRef.nativeElement;
25
+ }
26
+ else if (typeof value === 'string') {
27
+ const el = document.querySelector(value);
28
+ if (el) {
29
+ newElement = el;
30
+ }
31
+ else {
32
+ if (isDevMode()) {
33
+ console.warn(`Element with selector ${value} not found. Animatable directive will use host element.`);
34
+ }
35
+ newElement = this._elementRef.nativeElement;
36
+ }
37
+ }
38
+ else {
39
+ newElement = value;
40
+ }
41
+ if (this._animatedElement$.value !== newElement) {
42
+ this._animatedElement$.next(newElement);
43
+ }
44
+ }
45
+ ngOnInit() {
46
+ this._animatedElement$
47
+ .pipe(tap((el) => {
48
+ this._totalActiveAnimationCount$.next(this._totalActiveAnimationCount$.value - this._hostActiveAnimationCount$.value);
49
+ this._hostActiveAnimationCount$.next(0);
50
+ merge(fromEvent(el, 'animationstart'), fromEvent(el, 'transitionstart'))
51
+ .pipe(filter((e) => e.target === el), // skip events from children
52
+ tap(() => {
53
+ const count = this._hostActiveAnimationCount$.value + 1;
54
+ this._hostActiveAnimationCount$.next(count);
55
+ this._totalActiveAnimationCount$.next(count);
56
+ }), takeUntil(this._destroy$), takeUntil(this._animatedElement$.pipe(skip(1))))
57
+ .subscribe();
58
+ merge(fromEvent(el, 'animationend'), fromEvent(el, 'animationcancel'), fromEvent(el, 'transitionend'), fromEvent(el, 'transitioncancel'))
59
+ .pipe(filter((e) => e.target === el), // skip events from children
60
+ tap(() => {
61
+ const count = this._hostActiveAnimationCount$.value - 1;
62
+ this._hostActiveAnimationCount$.next(count);
63
+ this._totalActiveAnimationCount$.next(count);
64
+ }), takeUntil(this._destroy$), takeUntil(this._animatedElement$.pipe(skip(1))))
65
+ .subscribe();
66
+ }), takeUntil(this._destroy$))
67
+ .subscribe();
68
+ this._totalActiveAnimationCount$
69
+ .pipe(tap((count) => {
70
+ if (count > 0 && !this._didEmitStart) {
71
+ this._animationStart$.next();
72
+ this._didEmitStart = true;
73
+ }
74
+ else if (count === 0) {
75
+ this._animationEnd$.next();
76
+ this._didEmitStart = false;
77
+ }
78
+ }), takeUntil(this._destroy$))
79
+ .subscribe();
80
+ if (this._parent) {
81
+ this._parent._hostActiveAnimationCount$
82
+ .pipe(takeUntil(this._destroy$), tap((count) => {
83
+ this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);
84
+ }))
85
+ .subscribe();
86
+ }
87
+ }
88
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
89
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AnimatableDirective, isStandalone: true, selector: "[etAnimatable]", inputs: { animatedElement: ["etAnimatable", "animatedElement"] }, providers: [
90
+ {
91
+ provide: ANIMATABLE_TOKEN,
92
+ useExisting: AnimatableDirective,
93
+ },
94
+ DestroyService,
95
+ ], exportAs: ["etAnimatable"], ngImport: i0 }); }
96
+ }
97
+ export { AnimatableDirective };
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatableDirective, decorators: [{
99
+ type: Directive,
100
+ args: [{
101
+ selector: '[etAnimatable]',
102
+ exportAs: 'etAnimatable',
103
+ standalone: true,
104
+ providers: [
105
+ {
106
+ provide: ANIMATABLE_TOKEN,
107
+ useExisting: AnimatableDirective,
108
+ },
109
+ DestroyService,
110
+ ],
111
+ }]
112
+ }], propDecorators: { animatedElement: [{
113
+ type: Input,
114
+ args: ['etAnimatable']
115
+ }] } });
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animatable.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animatable/animatable.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AACxG,OAAO,EACL,eAAe,EACf,YAAY,EACZ,MAAM,EACN,SAAS,EACT,GAAG,EACH,KAAK,EAEL,IAAI,EACJ,OAAO,EACP,SAAS,EACT,GAAG,GACJ,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;;AAEhD,MAAM,CAAC,MAAM,gBAAgB,GAAG,IAAI,cAAc,CAAsB,4BAA4B,CAAC,CAAC;AAEtG,MAYa,mBAAmB;IAZhC;QAaU,kBAAa,GAAG,KAAK,CAAC;QAEb,YAAO,GAAG,MAAM,CAAC,gBAAgB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACvE,cAAS,GAAG,MAAM,CAAC,cAAc,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC;QAC5D,gBAAW,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;QAE1D,qBAAgB,GAAG,IAAI,OAAO,EAAQ,CAAC;QACvC,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QA2B9C,sBAAiB,GAAG,IAAI,eAAe,CAAc,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAEpF,oBAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,kBAAa,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;QAEjE,+BAA0B,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QAC5D,gCAA2B,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QAErE,iBAAY,GAAwB,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAChF,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC,EACzB,YAAY,CAAC,CAAC,CAAC,CAChB,CAAC;KAwEH;IA5GC,IACI,eAAe,CAAC,KAA8C;QAChE,IAAI,UAAU,GAAuB,IAAI,CAAC;QAC1C,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;YACzC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;SAC7C;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YACpC,MAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAgB,CAAC;YAExD,IAAI,EAAE,EAAE;gBACN,UAAU,GAAG,EAAE,CAAC;aACjB;iBAAM;gBACL,IAAI,SAAS,EAAE,EAAE;oBACf,OAAO,CAAC,IAAI,CAAC,yBAAyB,KAAK,yDAAyD,CAAC,CAAC;iBACvG;gBAED,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;aAC7C;SACF;aAAM;YACL,UAAU,GAAG,KAAK,CAAC;SACpB;QAED,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,KAAK,UAAU,EAAE;YAC/C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACzC;IACH,CAAC;IAcD,QAAQ;QACN,IAAI,CAAC,iBAAiB;aACnB,IAAI,CACH,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE;YACT,IAAI,CAAC,2BAA2B,CAAC,IAAI,CACnC,IAAI,CAAC,2BAA2B,CAAC,KAAK,GAAG,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAC/E,CAAC;YACF,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAExC,KAAK,CAAC,SAAS,CAAiB,EAAE,EAAE,gBAAgB,CAAC,EAAE,SAAS,CAAkB,EAAE,EAAE,iBAAiB,CAAC,CAAC;iBACtG,IAAI,CACH,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,EAAE,CAAC,EAAE,4BAA4B;YAC5D,GAAG,CAAC,GAAG,EAAE;gBACP,MAAM,KAAK,GAAG,IAAI,CAAC,0BAA0B,CAAC,KAAK,GAAG,CAAC,CAAC;gBACxD,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC5C,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/C,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAChD;iBACA,SAAS,EAAE,CAAC;YAEf,KAAK,CACH,SAAS,CAAiB,EAAE,EAAE,cAAc,CAAC,EAC7C,SAAS,CAAiB,EAAE,EAAE,iBAAiB,CAAC,EAChD,SAAS,CAAkB,EAAE,EAAE,eAAe,CAAC,EAC/C,SAAS,CAAkB,EAAE,EAAE,kBAAkB,CAAC,CACnD;iBACE,IAAI,CACH,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,EAAE,CAAC,EAAE,4BAA4B;YAC5D,GAAG,CAAC,GAAG,EAAE;gBACP,MAAM,KAAK,GAAG,IAAI,CAAC,0BAA0B,CAAC,KAAK,GAAG,CAAC,CAAC;gBACxD,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC5C,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/C,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAChD;iBACA,SAAS,EAAE,CAAC;QACjB,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,EAAE,CAAC;QAEf,IAAI,CAAC,2BAA2B;aAC7B,IAAI,CACH,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;gBACpC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;gBAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;aAC3B;iBAAM,IAAI,KAAK,KAAK,CAAC,EAAE;gBACtB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;gBAC3B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;aAC5B;QACH,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,EAAE,CAAC;QAEf,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,0BAA0B;iBACpC,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;gBACZ,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;YACvF,CAAC,CAAC,CACH;iBACA,SAAS,EAAE,CAAC;SAChB;IACH,CAAC;8GArHU,mBAAmB;kGAAnB,mBAAmB,+HARnB;YACT;gBACE,OAAO,EAAE,gBAAgB;gBACzB,WAAW,EAAE,mBAAmB;aACjC;YACD,cAAc;SACf;;SAEU,mBAAmB;2FAAnB,mBAAmB;kBAZ/B,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,cAAc;oBACxB,UAAU,EAAE,IAAI;oBAChB,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,gBAAgB;4BACzB,WAAW,qBAAqB;yBACjC;wBACD,cAAc;qBACf;iBACF;8BAYK,eAAe;sBADlB,KAAK;uBAAC,cAAc","sourcesContent":["import { Directive, ElementRef, inject, InjectionToken, Input, isDevMode, OnInit } from '@angular/core';\nimport {\n  BehaviorSubject,\n  debounceTime,\n  filter,\n  fromEvent,\n  map,\n  merge,\n  Observable,\n  skip,\n  Subject,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport { DestroyService } from '../../services';\n\nexport const ANIMATABLE_TOKEN = new InjectionToken<AnimatableDirective>('ANIMATABLE_DIRECTIVE_TOKEN');\n\n@Directive({\n  selector: '[etAnimatable]',\n  exportAs: 'etAnimatable',\n  standalone: true,\n  providers: [\n    {\n      provide: ANIMATABLE_TOKEN,\n      useExisting: AnimatableDirective,\n    },\n    DestroyService,\n  ],\n})\nexport class AnimatableDirective implements OnInit {\n  private _didEmitStart = false;\n\n  private readonly _parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });\n  private readonly _destroy$ = inject(DestroyService, { host: true }).destroy$;\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _animationStart$ = new Subject<void>();\n  private readonly _animationEnd$ = new Subject<void>();\n\n  @Input('etAnimatable')\n  set animatedElement(value: string | HTMLElement | null | undefined) {\n    let newElement: HTMLElement | null = null;\n    if (value === null || value === undefined) {\n      newElement = this._elementRef.nativeElement;\n    } else if (typeof value === 'string') {\n      const el = document.querySelector(value) as HTMLElement;\n\n      if (el) {\n        newElement = el;\n      } else {\n        if (isDevMode()) {\n          console.warn(`Element with selector ${value} not found. Animatable directive will use host element.`);\n        }\n\n        newElement = this._elementRef.nativeElement;\n      }\n    } else {\n      newElement = value;\n    }\n\n    if (this._animatedElement$.value !== newElement) {\n      this._animatedElement$.next(newElement);\n    }\n  }\n  private _animatedElement$ = new BehaviorSubject<HTMLElement>(this._elementRef.nativeElement);\n\n  readonly animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));\n  readonly animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));\n\n  private readonly _hostActiveAnimationCount$ = new BehaviorSubject<number>(0);\n  private readonly _totalActiveAnimationCount$ = new BehaviorSubject<number>(0);\n\n  readonly isAnimating$: Observable<boolean> = this._totalActiveAnimationCount$.pipe(\n    map((count) => count > 0),\n    debounceTime(0),\n  );\n\n  ngOnInit(): void {\n    this._animatedElement$\n      .pipe(\n        tap((el) => {\n          this._totalActiveAnimationCount$.next(\n            this._totalActiveAnimationCount$.value - this._hostActiveAnimationCount$.value,\n          );\n          this._hostActiveAnimationCount$.next(0);\n\n          merge(fromEvent<AnimationEvent>(el, 'animationstart'), fromEvent<TransitionEvent>(el, 'transitionstart'))\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value + 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n\n          merge(\n            fromEvent<AnimationEvent>(el, 'animationend'),\n            fromEvent<AnimationEvent>(el, 'animationcancel'),\n            fromEvent<TransitionEvent>(el, 'transitionend'),\n            fromEvent<TransitionEvent>(el, 'transitioncancel'),\n          )\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value - 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._totalActiveAnimationCount$\n      .pipe(\n        tap((count) => {\n          if (count > 0 && !this._didEmitStart) {\n            this._animationStart$.next();\n            this._didEmitStart = true;\n          } else if (count === 0) {\n            this._animationEnd$.next();\n            this._didEmitStart = false;\n          }\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    if (this._parent) {\n      this._parent._hostActiveAnimationCount$\n        .pipe(\n          takeUntil(this._destroy$),\n          tap((count) => {\n            this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);\n          }),\n        )\n        .subscribe();\n    }\n  }\n}\n"]}
@@ -0,0 +1,116 @@
1
+ import { Directive, ElementRef, inject, InjectionToken, isDevMode } from '@angular/core';
2
+ import { BehaviorSubject, map, switchMap, take, takeUntil, tap } from 'rxjs';
3
+ import { DestroyService } from '../../services';
4
+ import { createReactiveBindings, forceReflow, fromNextFrame } from '../../utils';
5
+ import { AnimatableDirective, ANIMATABLE_TOKEN } from '../animatable';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../animatable/animatable.directive";
8
+ export const ANIMATED_LIFECYCLE_TOKEN = new InjectionToken('ANIMATED_LIFECYCLE_DIRECTIVE_TOKEN');
9
+ const ANIMATION_CLASSES = {
10
+ enterFrom: 'et-animation-enter-from',
11
+ enterActive: 'et-animation-enter-active',
12
+ enterTo: 'et-animation-enter-to',
13
+ leaveFrom: 'et-animation-leave-from',
14
+ leaveActive: 'et-animation-leave-active',
15
+ leaveTo: 'et-animation-leave-to',
16
+ };
17
+ class AnimatedLifecycleDirective {
18
+ constructor() {
19
+ this._destroy$ = inject(DestroyService, { host: true }).destroy$;
20
+ this._elementRef = inject(ElementRef);
21
+ this._animatable = inject(ANIMATABLE_TOKEN);
22
+ this._classList = this._elementRef.nativeElement.classList;
23
+ this._state$ = new BehaviorSubject('init');
24
+ this.state$ = this._state$.asObservable();
25
+ this._bindings = createReactiveBindings({
26
+ attribute: 'class.et-force-invisible',
27
+ observable: this._state$.pipe(map((state) => state === 'init')),
28
+ });
29
+ }
30
+ get state() {
31
+ return this._state$.value;
32
+ }
33
+ enter(config) {
34
+ if (this.state !== 'init' && this.state !== 'left' && isDevMode()) {
35
+ console.warn('Tried to enter but the element is not in the initial state. This may result in unexpected behavior.', this);
36
+ }
37
+ this._state$.next('entering');
38
+ if (!config?.onlyTransition) {
39
+ this._classList.add(ANIMATION_CLASSES.enterFrom);
40
+ }
41
+ forceReflow();
42
+ this._classList.add(ANIMATION_CLASSES.enterActive);
43
+ fromNextFrame()
44
+ .pipe(tap(() => {
45
+ if (!config?.onlyTransition) {
46
+ this._classList.remove(ANIMATION_CLASSES.enterFrom);
47
+ this._classList.add(ANIMATION_CLASSES.enterTo);
48
+ }
49
+ }), switchMap(() => this._animatable.animationEnd$), tap(() => {
50
+ this._state$.next('entered');
51
+ this._classList.remove(ANIMATION_CLASSES.enterActive);
52
+ if (!config?.onlyTransition) {
53
+ this._classList.remove(ANIMATION_CLASSES.enterTo);
54
+ }
55
+ }), takeUntil(this._destroy$), take(1))
56
+ .subscribe();
57
+ }
58
+ leave(config) {
59
+ if (this.state !== 'entered' && this.state !== 'entering' && isDevMode()) {
60
+ console.warn('Tried to leave while already leaving or left. This may result in unexpected behavior.', this);
61
+ }
62
+ if (this._classList.contains(ANIMATION_CLASSES.enterFrom) ||
63
+ this._classList.contains(ANIMATION_CLASSES.enterActive) ||
64
+ this._classList.contains(ANIMATION_CLASSES.enterTo)) {
65
+ this._classList.remove(ANIMATION_CLASSES.enterFrom);
66
+ this._classList.remove(ANIMATION_CLASSES.enterActive);
67
+ this._classList.remove(ANIMATION_CLASSES.enterTo);
68
+ }
69
+ this._state$.next('leaving');
70
+ if (!config?.onlyTransition) {
71
+ this._classList.add(ANIMATION_CLASSES.leaveFrom);
72
+ }
73
+ forceReflow();
74
+ this._classList.add(ANIMATION_CLASSES.leaveActive);
75
+ fromNextFrame()
76
+ .pipe(tap(() => {
77
+ if (!config?.onlyTransition) {
78
+ this._classList.remove(ANIMATION_CLASSES.leaveFrom);
79
+ this._classList.add(ANIMATION_CLASSES.leaveTo);
80
+ }
81
+ }), switchMap(() => this._animatable.animationEnd$), tap(() => {
82
+ this._state$.next('left');
83
+ this._classList.remove(ANIMATION_CLASSES.leaveActive);
84
+ if (!config?.onlyTransition) {
85
+ this._classList.remove(ANIMATION_CLASSES.leaveTo);
86
+ }
87
+ }), takeUntil(this._destroy$), take(1))
88
+ .subscribe();
89
+ }
90
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedLifecycleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
91
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AnimatedLifecycleDirective, isStandalone: true, selector: "[etAnimatedLifecycle]", providers: [
92
+ {
93
+ provide: ANIMATED_LIFECYCLE_TOKEN,
94
+ useExisting: AnimatedLifecycleDirective,
95
+ },
96
+ DestroyService,
97
+ ], exportAs: ["etAnimatedLifecycle"], hostDirectives: [{ directive: i1.AnimatableDirective }], ngImport: i0 }); }
98
+ }
99
+ export { AnimatedLifecycleDirective };
100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedLifecycleDirective, decorators: [{
101
+ type: Directive,
102
+ args: [{
103
+ selector: '[etAnimatedLifecycle]',
104
+ exportAs: 'etAnimatedLifecycle',
105
+ standalone: true,
106
+ providers: [
107
+ {
108
+ provide: ANIMATED_LIFECYCLE_TOKEN,
109
+ useExisting: AnimatedLifecycleDirective,
110
+ },
111
+ DestroyService,
112
+ ],
113
+ hostDirectives: [AnimatableDirective],
114
+ }]
115
+ }] });
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-lifecycle.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-lifecycle/animated-lifecycle.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, inject, InjectionToken, isDevMode } from '@angular/core';\nimport { BehaviorSubject, map, switchMap, take, takeUntil, tap } from 'rxjs';\nimport { DestroyService } from '../../services';\nimport { createReactiveBindings, forceReflow, fromNextFrame } from '../../utils';\nimport { AnimatableDirective, ANIMATABLE_TOKEN } from '../animatable';\n\nexport const ANIMATED_LIFECYCLE_TOKEN = new InjectionToken<AnimatedLifecycleDirective>(\n  'ANIMATED_LIFECYCLE_DIRECTIVE_TOKEN',\n);\n\nconst ANIMATION_CLASSES = {\n  enterFrom: 'et-animation-enter-from',\n  enterActive: 'et-animation-enter-active',\n  enterTo: 'et-animation-enter-to',\n  leaveFrom: 'et-animation-leave-from',\n  leaveActive: 'et-animation-leave-active',\n  leaveTo: 'et-animation-leave-to',\n} as const;\n\n@Directive({\n  selector: '[etAnimatedLifecycle]',\n  exportAs: 'etAnimatedLifecycle',\n  standalone: true,\n  providers: [\n    {\n      provide: ANIMATED_LIFECYCLE_TOKEN,\n      useExisting: AnimatedLifecycleDirective,\n    },\n    DestroyService,\n  ],\n  hostDirectives: [AnimatableDirective],\n})\nexport class AnimatedLifecycleDirective {\n  private readonly _destroy$ = inject(DestroyService, { host: true }).destroy$;\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _animatable = inject(ANIMATABLE_TOKEN);\n  private readonly _classList = this._elementRef.nativeElement.classList;\n\n  private _state$ = new BehaviorSubject<'entering' | 'entered' | 'leaving' | 'left' | 'init'>('init');\n  readonly state$ = this._state$.asObservable();\n\n  get state() {\n    return this._state$.value;\n  }\n\n  private readonly _bindings = createReactiveBindings({\n    attribute: 'class.et-force-invisible',\n    observable: this._state$.pipe(map((state) => state === 'init')),\n  });\n\n  enter(config?: { onlyTransition?: boolean }) {\n    if (this.state !== 'init' && this.state !== 'left' && isDevMode()) {\n      console.warn(\n        'Tried to enter but the element is not in the initial state. This may result in unexpected behavior.',\n        this,\n      );\n    }\n\n    this._state$.next('entering');\n\n    if (!config?.onlyTransition) {\n      this._classList.add(ANIMATION_CLASSES.enterFrom);\n    }\n\n    forceReflow();\n    this._classList.add(ANIMATION_CLASSES.enterActive);\n\n    fromNextFrame()\n      .pipe(\n        tap(() => {\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.enterFrom);\n            this._classList.add(ANIMATION_CLASSES.enterTo);\n          }\n        }),\n        switchMap(() => this._animatable.animationEnd$),\n        tap(() => {\n          this._state$.next('entered');\n          this._classList.remove(ANIMATION_CLASSES.enterActive);\n\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.enterTo);\n          }\n        }),\n        takeUntil(this._destroy$),\n        take(1),\n      )\n      .subscribe();\n  }\n\n  leave(config?: { onlyTransition?: boolean }) {\n    if (this.state !== 'entered' && this.state !== 'entering' && isDevMode()) {\n      console.warn('Tried to leave while already leaving or left. This may result in unexpected behavior.', this);\n    }\n\n    if (\n      this._classList.contains(ANIMATION_CLASSES.enterFrom) ||\n      this._classList.contains(ANIMATION_CLASSES.enterActive) ||\n      this._classList.contains(ANIMATION_CLASSES.enterTo)\n    ) {\n      this._classList.remove(ANIMATION_CLASSES.enterFrom);\n      this._classList.remove(ANIMATION_CLASSES.enterActive);\n      this._classList.remove(ANIMATION_CLASSES.enterTo);\n    }\n\n    this._state$.next('leaving');\n\n    if (!config?.onlyTransition) {\n      this._classList.add(ANIMATION_CLASSES.leaveFrom);\n    }\n\n    forceReflow();\n    this._classList.add(ANIMATION_CLASSES.leaveActive);\n\n    fromNextFrame()\n      .pipe(\n        tap(() => {\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.leaveFrom);\n            this._classList.add(ANIMATION_CLASSES.leaveTo);\n          }\n        }),\n        switchMap(() => this._animatable.animationEnd$),\n        tap(() => {\n          this._state$.next('left');\n          this._classList.remove(ANIMATION_CLASSES.leaveActive);\n\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.leaveTo);\n          }\n        }),\n        takeUntil(this._destroy$),\n        take(1),\n      )\n      .subscribe();\n  }\n}\n"]}
@@ -0,0 +1,38 @@
1
+ import { Directive, ElementRef, EventEmitter, inject, Output } from '@angular/core';
2
+ import { ClickObserverService } from '../../services';
3
+ import * as i0 from "@angular/core";
4
+ class ClickOutsideDirective {
5
+ constructor() {
6
+ this._elementRef = inject(ElementRef);
7
+ this._clickObserverService = inject(ClickObserverService);
8
+ this._subscription = null;
9
+ this.etClickOutside = new EventEmitter();
10
+ }
11
+ ngOnInit() {
12
+ setTimeout(() => {
13
+ this._subscription = this._clickObserverService.observe(this._elementRef.nativeElement).subscribe((event) => {
14
+ const activeElement = event.target;
15
+ const isInside = this._elementRef.nativeElement.contains(activeElement);
16
+ if (!isInside) {
17
+ this.etClickOutside.emit(event);
18
+ }
19
+ });
20
+ });
21
+ }
22
+ ngOnDestroy() {
23
+ this._subscription?.unsubscribe();
24
+ }
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ClickOutsideDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
26
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: ClickOutsideDirective, isStandalone: true, selector: "[etClickOutside]", outputs: { etClickOutside: "etClickOutside" }, ngImport: i0 }); }
27
+ }
28
+ export { ClickOutsideDirective };
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ClickOutsideDirective, decorators: [{
30
+ type: Directive,
31
+ args: [{
32
+ selector: '[etClickOutside]',
33
+ standalone: true,
34
+ }]
35
+ }], propDecorators: { etClickOutside: [{
36
+ type: Output
37
+ }] } });
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL2NsaWNrLW91dHNpZGUvY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBcUIsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQUV0RCxNQUlhLHFCQUFxQjtJQUpsQztRQUtVLGdCQUFXLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2pDLDBCQUFxQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBRXJELGtCQUFhLEdBQXdCLElBQUksQ0FBQztRQUdsRCxtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFjLENBQUM7S0FrQmpEO0lBaEJDLFFBQVE7UUFDTixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQzFHLE1BQU0sYUFBYSxHQUFHLEtBQUssQ0FBQyxNQUFxQixDQUFDO2dCQUNsRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7Z0JBRXhFLElBQUksQ0FBQyxRQUFRLEVBQUU7b0JBQ2IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7aUJBQ2pDO1lBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGFBQWEsRUFBRSxXQUFXLEVBQUUsQ0FBQztJQUNwQyxDQUFDOzhHQXhCVSxxQkFBcUI7a0dBQXJCLHFCQUFxQjs7U0FBckIscUJBQXFCOzJGQUFyQixxQkFBcUI7a0JBSmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQVFDLGNBQWM7c0JBRGIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBpbmplY3QsIE9uRGVzdHJveSwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ2xpY2tPYnNlcnZlclNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tldENsaWNrT3V0c2lkZV0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBDbGlja091dHNpZGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgX2VsZW1lbnRSZWYgPSBpbmplY3QoRWxlbWVudFJlZik7XG4gIHByaXZhdGUgX2NsaWNrT2JzZXJ2ZXJTZXJ2aWNlID0gaW5qZWN0KENsaWNrT2JzZXJ2ZXJTZXJ2aWNlKTtcblxuICBwcml2YXRlIF9zdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbiB8IG51bGwgPSBudWxsO1xuXG4gIEBPdXRwdXQoKVxuICBldENsaWNrT3V0c2lkZSA9IG5ldyBFdmVudEVtaXR0ZXI8TW91c2VFdmVudD4oKTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHRoaXMuX3N1YnNjcmlwdGlvbiA9IHRoaXMuX2NsaWNrT2JzZXJ2ZXJTZXJ2aWNlLm9ic2VydmUodGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50KS5zdWJzY3JpYmUoKGV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IGFjdGl2ZUVsZW1lbnQgPSBldmVudC50YXJnZXQgYXMgSFRNTEVsZW1lbnQ7XG4gICAgICAgIGNvbnN0IGlzSW5zaWRlID0gdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmNvbnRhaW5zKGFjdGl2ZUVsZW1lbnQpO1xuXG4gICAgICAgIGlmICghaXNJbnNpZGUpIHtcbiAgICAgICAgICB0aGlzLmV0Q2xpY2tPdXRzaWRlLmVtaXQoZXZlbnQpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX3N1YnNjcmlwdGlvbj8udW5zdWJzY3JpYmUoKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,148 @@
1
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
+ import { Directive, ElementRef, inject, Input } from '@angular/core';
3
+ import { combineLatest, debounceTime, fromEvent, startWith, Subject, take, takeUntil, tap } from 'rxjs';
4
+ import { ContentObserverService, DestroyService, ResizeObserverService } from '../../services';
5
+ import { elementCanScroll } from '../../utils';
6
+ import { CURSOR_DRAG_SCROLLING_CLASS, CURSOR_DRAG_SCROLLING_PREPARED_CLASS } from './cursor-drag-scroll.constants';
7
+ import * as i0 from "@angular/core";
8
+ class CursorDragScrollDirective {
9
+ constructor() {
10
+ this._subscriptions = [];
11
+ this._destroy$ = inject(DestroyService, { host: true }).destroy$;
12
+ this._elementRef = inject(ElementRef);
13
+ this._contentObserverService = inject(ContentObserverService);
14
+ this._resizeObserverService = inject(ResizeObserverService);
15
+ this._bufferUntilScroll = 5;
16
+ this._mouseUp$ = new Subject();
17
+ this._isScrolling = false;
18
+ this._canScroll = false;
19
+ this._currentScrollState = {
20
+ top: 0,
21
+ left: 0,
22
+ x: 0,
23
+ y: 0,
24
+ };
25
+ this._enabled = false;
26
+ }
27
+ get enabled() {
28
+ return this._enabled;
29
+ }
30
+ set enabled(value) {
31
+ this._enabled = coerceBooleanProperty(value);
32
+ if (this._enabled) {
33
+ this._enableCursorDragScroll();
34
+ }
35
+ else {
36
+ this._disableCursorDragScroll();
37
+ }
38
+ }
39
+ ngAfterViewInit() {
40
+ if (this.enabled) {
41
+ this._enableCursorDragScroll();
42
+ }
43
+ else {
44
+ this._disableCursorDragScroll();
45
+ }
46
+ }
47
+ _enableCursorDragScroll() {
48
+ const contentResizeSub = combineLatest([
49
+ this._contentObserverService.observe(this._elementRef.nativeElement).pipe(startWith(null)),
50
+ this._resizeObserverService.observe(this._elementRef.nativeElement).pipe(startWith(null)),
51
+ ])
52
+ .pipe(debounceTime(25), tap(() => this._updateCanScrollState()), takeUntil(this._destroy$))
53
+ .subscribe();
54
+ const mousedownSub = fromEvent(this._elementRef.nativeElement, 'mousedown')
55
+ .pipe(tap((e) => this._onMouseDown(e)), takeUntil(this._destroy$))
56
+ .subscribe();
57
+ this._subscriptions.push(contentResizeSub, mousedownSub);
58
+ this._updateCanScrollState();
59
+ }
60
+ _disableCursorDragScroll() {
61
+ this._subscriptions.forEach((sub) => sub.unsubscribe());
62
+ this._subscriptions.length = 0;
63
+ this._elementRef.nativeElement.style.cursor = 'default';
64
+ }
65
+ _onMouseDown(e) {
66
+ if (!this._elementRef?.nativeElement || !this._canScroll) {
67
+ return;
68
+ }
69
+ const element = this._elementRef.nativeElement;
70
+ element.classList.add(CURSOR_DRAG_SCROLLING_PREPARED_CLASS);
71
+ this._elementRef.nativeElement.style.scrollSnapType = 'none';
72
+ this._elementRef.nativeElement.style.scrollBehavior = 'unset';
73
+ this._currentScrollState = {
74
+ left: this._elementRef.nativeElement.scrollLeft,
75
+ top: this._elementRef.nativeElement.scrollTop,
76
+ x: e.clientX,
77
+ y: e.clientY,
78
+ };
79
+ fromEvent(document, 'mousemove')
80
+ .pipe(tap((e) => this._mouseMoveHandler(e)), takeUntil(this._mouseUp$), takeUntil(this._destroy$))
81
+ .subscribe();
82
+ fromEvent(document, 'mouseup')
83
+ .pipe(tap(() => this._mouseUpHandler()), take(1), takeUntil(this._destroy$))
84
+ .subscribe();
85
+ }
86
+ _mouseMoveHandler(e) {
87
+ e.preventDefault();
88
+ if (!this._elementRef?.nativeElement) {
89
+ return;
90
+ }
91
+ const dx = e.clientX - this._currentScrollState.x;
92
+ const dy = e.clientY - this._currentScrollState.y;
93
+ if (Math.abs(dx) > this._bufferUntilScroll || Math.abs(dy) > this._bufferUntilScroll) {
94
+ const element = this._elementRef.nativeElement;
95
+ if (!this._isScrolling) {
96
+ this._isScrolling = true;
97
+ element.style.cursor = 'grabbing';
98
+ element.classList.add(CURSOR_DRAG_SCROLLING_CLASS);
99
+ element.scroll({
100
+ top: this._currentScrollState.top - dy,
101
+ left: this._currentScrollState.left - dx,
102
+ behavior: 'smooth',
103
+ });
104
+ }
105
+ else {
106
+ element.scrollTop = this._currentScrollState.top - dy;
107
+ element.scrollLeft = this._currentScrollState.left - dx;
108
+ }
109
+ }
110
+ }
111
+ _mouseUpHandler() {
112
+ this._mouseUp$.next(true);
113
+ this._isScrolling = false;
114
+ if (!this._elementRef?.nativeElement) {
115
+ return;
116
+ }
117
+ this._elementRef.nativeElement.style.scrollSnapType = '';
118
+ this._elementRef.nativeElement.style.scrollBehavior = '';
119
+ this._elementRef.nativeElement.style.cursor = 'grab';
120
+ this._elementRef.nativeElement.classList.remove(CURSOR_DRAG_SCROLLING_CLASS);
121
+ this._elementRef.nativeElement.classList.remove(CURSOR_DRAG_SCROLLING_PREPARED_CLASS);
122
+ }
123
+ _updateCanScrollState() {
124
+ this._canScroll = elementCanScroll(this._elementRef.nativeElement);
125
+ if (this._canScroll) {
126
+ this._elementRef.nativeElement.style.cursor = 'grab';
127
+ }
128
+ else {
129
+ this._elementRef.nativeElement.style.cursor = 'default';
130
+ }
131
+ }
132
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: CursorDragScrollDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
133
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: CursorDragScrollDirective, isStandalone: true, selector: "[etCursorDragScroll]", inputs: { enabled: ["etCursorDragScroll", "enabled"] }, providers: [DestroyService], exportAs: ["etCursorDragScroll"], ngImport: i0 }); }
134
+ }
135
+ export { CursorDragScrollDirective };
136
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: CursorDragScrollDirective, decorators: [{
137
+ type: Directive,
138
+ args: [{
139
+ selector: '[etCursorDragScroll]',
140
+ exportAs: 'etCursorDragScroll',
141
+ standalone: true,
142
+ providers: [DestroyService],
143
+ }]
144
+ }], propDecorators: { enabled: [{
145
+ type: Input,
146
+ args: ['etCursorDragScroll']
147
+ }] } });
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cursor-drag-scroll.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { AfterViewInit, Directive, ElementRef, inject, Input } from '@angular/core';\nimport { combineLatest, debounceTime, fromEvent, startWith, Subject, Subscription, take, takeUntil, tap } from 'rxjs';\nimport { ContentObserverService, DestroyService, ResizeObserverService } from '../../services';\nimport { elementCanScroll } from '../../utils';\nimport { CURSOR_DRAG_SCROLLING_CLASS, CURSOR_DRAG_SCROLLING_PREPARED_CLASS } from './cursor-drag-scroll.constants';\n\n@Directive({\n  selector: '[etCursorDragScroll]',\n  exportAs: 'etCursorDragScroll',\n  standalone: true,\n  providers: [DestroyService],\n})\nexport class CursorDragScrollDirective implements AfterViewInit {\n  private readonly _subscriptions: Subscription[] = [];\n  private readonly _destroy$ = inject(DestroyService, { host: true }).destroy$;\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _contentObserverService = inject(ContentObserverService);\n  private readonly _resizeObserverService = inject(ResizeObserverService);\n\n  private readonly _bufferUntilScroll = 5;\n  private readonly _mouseUp$ = new Subject<boolean>();\n\n  private _isScrolling = false;\n  private _canScroll = false;\n\n  private _currentScrollState = {\n    top: 0,\n    left: 0,\n    x: 0,\n    y: 0,\n  };\n\n  @Input('etCursorDragScroll')\n  get enabled(): boolean {\n    return this._enabled;\n  }\n  set enabled(value: BooleanInput) {\n    this._enabled = coerceBooleanProperty(value);\n\n    if (this._enabled) {\n      this._enableCursorDragScroll();\n    } else {\n      this._disableCursorDragScroll();\n    }\n  }\n  private _enabled = false;\n\n  ngAfterViewInit(): void {\n    if (this.enabled) {\n      this._enableCursorDragScroll();\n    } else {\n      this._disableCursorDragScroll();\n    }\n  }\n\n  private _enableCursorDragScroll() {\n    const contentResizeSub = combineLatest([\n      this._contentObserverService.observe(this._elementRef.nativeElement).pipe(startWith(null)),\n      this._resizeObserverService.observe(this._elementRef.nativeElement).pipe(startWith(null)),\n    ])\n      .pipe(\n        debounceTime(25),\n        tap(() => this._updateCanScrollState()),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    const mousedownSub = fromEvent<MouseEvent>(this._elementRef.nativeElement, 'mousedown')\n      .pipe(\n        tap((e) => this._onMouseDown(e)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._subscriptions.push(contentResizeSub, mousedownSub);\n\n    this._updateCanScrollState();\n  }\n\n  private _disableCursorDragScroll() {\n    this._subscriptions.forEach((sub) => sub.unsubscribe());\n    this._subscriptions.length = 0;\n    this._elementRef.nativeElement.style.cursor = 'default';\n  }\n\n  private _onMouseDown(e: MouseEvent) {\n    if (!this._elementRef?.nativeElement || !this._canScroll) {\n      return;\n    }\n\n    const element = this._elementRef.nativeElement;\n\n    element.classList.add(CURSOR_DRAG_SCROLLING_PREPARED_CLASS);\n\n    this._elementRef.nativeElement.style.scrollSnapType = 'none';\n    this._elementRef.nativeElement.style.scrollBehavior = 'unset';\n\n    this._currentScrollState = {\n      left: this._elementRef.nativeElement.scrollLeft,\n      top: this._elementRef.nativeElement.scrollTop,\n      x: e.clientX,\n      y: e.clientY,\n    };\n\n    fromEvent<MouseEvent>(document, 'mousemove')\n      .pipe(\n        tap((e) => this._mouseMoveHandler(e)),\n        takeUntil(this._mouseUp$),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    fromEvent<MouseEvent>(document, 'mouseup')\n      .pipe(\n        tap(() => this._mouseUpHandler()),\n        take(1),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  private _mouseMoveHandler(e: MouseEvent) {\n    e.preventDefault();\n\n    if (!this._elementRef?.nativeElement) {\n      return;\n    }\n\n    const dx = e.clientX - this._currentScrollState.x;\n    const dy = e.clientY - this._currentScrollState.y;\n\n    if (Math.abs(dx) > this._bufferUntilScroll || Math.abs(dy) > this._bufferUntilScroll) {\n      const element = this._elementRef.nativeElement;\n\n      if (!this._isScrolling) {\n        this._isScrolling = true;\n\n        element.style.cursor = 'grabbing';\n        element.classList.add(CURSOR_DRAG_SCROLLING_CLASS);\n        element.scroll({\n          top: this._currentScrollState.top - dy,\n          left: this._currentScrollState.left - dx,\n          behavior: 'smooth',\n        });\n      } else {\n        element.scrollTop = this._currentScrollState.top - dy;\n        element.scrollLeft = this._currentScrollState.left - dx;\n      }\n    }\n  }\n\n  private _mouseUpHandler() {\n    this._mouseUp$.next(true);\n    this._isScrolling = false;\n\n    if (!this._elementRef?.nativeElement) {\n      return;\n    }\n\n    this._elementRef.nativeElement.style.scrollSnapType = '';\n    this._elementRef.nativeElement.style.scrollBehavior = '';\n\n    this._elementRef.nativeElement.style.cursor = 'grab';\n    this._elementRef.nativeElement.classList.remove(CURSOR_DRAG_SCROLLING_CLASS);\n    this._elementRef.nativeElement.classList.remove(CURSOR_DRAG_SCROLLING_PREPARED_CLASS);\n  }\n\n  private _updateCanScrollState() {\n    this._canScroll = elementCanScroll(this._elementRef.nativeElement);\n\n    if (this._canScroll) {\n      this._elementRef.nativeElement.style.cursor = 'grab';\n    } else {\n      this._elementRef.nativeElement.style.cursor = 'default';\n    }\n  }\n}\n"]}
@@ -0,0 +1,56 @@
1
+ import { Directive, InjectionToken } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export const DELAYABLE_TOKEN = new InjectionToken('DELAYABLE_DIRECTIVE_TOKEN');
5
+ class DelayableDirective {
6
+ constructor() {
7
+ this._isDelayed$ = new BehaviorSubject(false);
8
+ }
9
+ get isDelayed$() {
10
+ return this._isDelayed$.asObservable();
11
+ }
12
+ get isDelayed() {
13
+ return this._isDelayed$.value;
14
+ }
15
+ enableDelayed() {
16
+ if (this._isDelayed$.value) {
17
+ return;
18
+ }
19
+ this._isDelayed$.next(true);
20
+ }
21
+ disableDelayed() {
22
+ if (!this._isDelayed$.value) {
23
+ return;
24
+ }
25
+ this._isDelayed$.next(false);
26
+ }
27
+ setDelayed(val) {
28
+ if (this._isDelayed$.value === val) {
29
+ return;
30
+ }
31
+ this._isDelayed$.next(val);
32
+ }
33
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: DelayableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
34
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: DelayableDirective, isStandalone: true, selector: "[etDelayable]", providers: [
35
+ {
36
+ provide: DELAYABLE_TOKEN,
37
+ useExisting: DelayableDirective,
38
+ },
39
+ ], exportAs: ["etDelayable"], ngImport: i0 }); }
40
+ }
41
+ export { DelayableDirective };
42
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: DelayableDirective, decorators: [{
43
+ type: Directive,
44
+ args: [{
45
+ selector: '[etDelayable]',
46
+ exportAs: 'etDelayable',
47
+ standalone: true,
48
+ providers: [
49
+ {
50
+ provide: DELAYABLE_TOKEN,
51
+ useExisting: DelayableDirective,
52
+ },
53
+ ],
54
+ }]
55
+ }] });
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVsYXlhYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvZGVsYXlhYmxlL2RlbGF5YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFFdkMsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLElBQUksY0FBYyxDQUFxQiwyQkFBMkIsQ0FBQyxDQUFDO0FBRW5HLE1BV2Esa0JBQWtCO0lBWC9CO1FBWW1CLGdCQUFXLEdBQUcsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7S0FpQzNEO0lBL0JDLElBQUksVUFBVTtRQUNaLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQztJQUNoQyxDQUFDO0lBRUQsYUFBYTtRQUNYLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUU7WUFDMUIsT0FBTztTQUNSO1FBRUQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVELGNBQWM7UUFDWixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUU7WUFDM0IsT0FBTztTQUNSO1FBRUQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELFVBQVUsQ0FBQyxHQUFZO1FBQ3JCLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEtBQUssR0FBRyxFQUFFO1lBQ2xDLE9BQU87U0FDUjtRQUVELElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdCLENBQUM7OEdBakNVLGtCQUFrQjtrR0FBbEIsa0JBQWtCLDREQVBsQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxlQUFlO2dCQUN4QixXQUFXLEVBQUUsa0JBQWtCO2FBQ2hDO1NBQ0Y7O1NBRVUsa0JBQWtCOzJGQUFsQixrQkFBa0I7a0JBWDlCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFFBQVEsRUFBRSxhQUFhO29CQUN2QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxlQUFlOzRCQUN4QixXQUFXLG9CQUFvQjt5QkFDaEM7cUJBQ0Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IGNvbnN0IERFTEFZQUJMRV9UT0tFTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxEZWxheWFibGVEaXJlY3RpdmU+KCdERUxBWUFCTEVfRElSRUNUSVZFX1RPS0VOJyk7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tldERlbGF5YWJsZV0nLFxuICBleHBvcnRBczogJ2V0RGVsYXlhYmxlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogREVMQVlBQkxFX1RPS0VOLFxuICAgICAgdXNlRXhpc3Rpbmc6IERlbGF5YWJsZURpcmVjdGl2ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBEZWxheWFibGVEaXJlY3RpdmUge1xuICBwcml2YXRlIHJlYWRvbmx5IF9pc0RlbGF5ZWQkID0gbmV3IEJlaGF2aW9yU3ViamVjdChmYWxzZSk7XG5cbiAgZ2V0IGlzRGVsYXllZCQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2lzRGVsYXllZCQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBnZXQgaXNEZWxheWVkKCkge1xuICAgIHJldHVybiB0aGlzLl9pc0RlbGF5ZWQkLnZhbHVlO1xuICB9XG5cbiAgZW5hYmxlRGVsYXllZCgpIHtcbiAgICBpZiAodGhpcy5faXNEZWxheWVkJC52YWx1ZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMuX2lzRGVsYXllZCQubmV4dCh0cnVlKTtcbiAgfVxuXG4gIGRpc2FibGVEZWxheWVkKCkge1xuICAgIGlmICghdGhpcy5faXNEZWxheWVkJC52YWx1ZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMuX2lzRGVsYXllZCQubmV4dChmYWxzZSk7XG4gIH1cblxuICBzZXREZWxheWVkKHZhbDogYm9vbGVhbikge1xuICAgIGlmICh0aGlzLl9pc0RlbGF5ZWQkLnZhbHVlID09PSB2YWwpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLl9pc0RlbGF5ZWQkLm5leHQodmFsKTtcbiAgfVxufVxuIl19