@design-factory/design-factory 18.1.1 → 19.0.0

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 (139) hide show
  1. package/README.md +4 -4
  2. package/design-factory-initial-branding.css +1 -1
  3. package/design-factory.css +1 -1
  4. package/fesm2022/design-factory.mjs +748 -921
  5. package/fesm2022/design-factory.mjs.map +1 -1
  6. package/lib/angular/accessibility/components/skip-links-container/skip-links-container.component.d.ts +3 -9
  7. package/lib/angular/accessibility/directives/skip-link.directive.d.ts +3 -9
  8. package/lib/angular/card/manage-card-selection.directive.d.ts +5 -5
  9. package/lib/angular/datepicker/datepicker-range.directive.d.ts +5 -6
  10. package/lib/angular/datepicker/datepicker.module.d.ts +3 -5
  11. package/lib/angular/inputs/icon/inputicon.directive.d.ts +5 -6
  12. package/lib/angular/mediaqueries/ifMedia.directive.d.ts +8 -9
  13. package/lib/angular/modal/modal.service.d.ts +4 -0
  14. package/lib/angular/progressbar/progressbar.component.d.ts +18 -28
  15. package/lib/angular/progressindicator/default/default-spinner.component.d.ts +4 -4
  16. package/lib/angular/progressindicator/progressindicator-backdrop.component.d.ts +4 -4
  17. package/lib/angular/progressindicator/progressindicator-container.component.d.ts +5 -7
  18. package/lib/angular/progressindicator/progressindicator.directive.d.ts +9 -11
  19. package/lib/angular/selects/events/manage-badge-events.directive.d.ts +4 -5
  20. package/lib/angular/selects/option-highlight.directive.d.ts +7 -12
  21. package/lib/angular/sidenav/dfSideNavCollapse.d.ts +16 -18
  22. package/lib/angular/sidenav/excludeTrap.directive.d.ts +9 -10
  23. package/lib/angular/sidenav/sidenav.component.d.ts +7 -8
  24. package/lib/angular/sidenav/sidenavlist.component.d.ts +8 -8
  25. package/lib/angular/slider/direction/sliderdirection.directive.d.ts +5 -7
  26. package/lib/angular/slider/lib/slider-element.directive.d.ts +2 -1
  27. package/lib/angular/slider/lib/slider-handle.directive.d.ts +1 -1
  28. package/lib/angular/slider/lib/slider-label.directive.d.ts +1 -1
  29. package/lib/angular/slider/lib/slider.component.d.ts +1 -1
  30. package/lib/angular/slider/lib/tooltip-wrapper.component.d.ts +1 -1
  31. package/lib/angular/slider/slider.module.d.ts +1 -1
  32. package/lib/angular/stepper/stepper.component.d.ts +7 -8
  33. package/lib/angular/utils/titleTruncate.directive.d.ts +2 -3
  34. package/lib/angular/waves-of-progress/waves.directive.d.ts +4 -3
  35. package/lib/index.d.ts +0 -1
  36. package/package.json +14 -16
  37. package/schematics/ng-add/index.js +1 -1
  38. package/styles/scss/agnosui/_variables.scss +9 -3
  39. package/styles/scss/bootstrap/_variables.scss +54 -12
  40. package/styles/scss/components/accordion/_accordion.scss +67 -6
  41. package/styles/scss/components/accordion/_accordion.variables.scss +2 -0
  42. package/styles/scss/components/alert/_alert.scss +3 -2
  43. package/styles/scss/components/badge/_badge.scss +13 -3
  44. package/styles/scss/components/badge/_badge.variables.scss +1 -0
  45. package/styles/scss/components/button/_button.scss +5 -0
  46. package/styles/scss/components/form/_form.scss +4 -0
  47. package/styles/scss/components/sidenav/_sidenav.scss +5 -2
  48. package/styles/scss/df-styles-namespace.scss +3 -1
  49. package/styles/scss/df-styles.scss +3 -1
  50. package/styles/scss/themes/brand2023/_variables.scss +80 -28
  51. package/esm2022/design-factory.mjs +0 -5
  52. package/esm2022/environment.mjs +0 -5
  53. package/esm2022/index.mjs +0 -5
  54. package/esm2022/lib/angular/accessibility/accessibility.module.mjs +0 -19
  55. package/esm2022/lib/angular/accessibility/components/skip-links-container/skip-links-container.component.mjs +0 -32
  56. package/esm2022/lib/angular/accessibility/directives/skip-link.directive.mjs +0 -64
  57. package/esm2022/lib/angular/alert/alert.module.mjs +0 -17
  58. package/esm2022/lib/angular/animation/ngbTransition.mjs +0 -76
  59. package/esm2022/lib/angular/animation/util.mjs +0 -30
  60. package/esm2022/lib/angular/card/card-advanced.module.mjs +0 -17
  61. package/esm2022/lib/angular/card/manage-card-selection.directive.mjs +0 -47
  62. package/esm2022/lib/angular/datepicker/closedatepicker.directive.mjs +0 -38
  63. package/esm2022/lib/angular/datepicker/datepicker-keyboard-nav.service.mjs +0 -39
  64. package/esm2022/lib/angular/datepicker/datepicker-range.directive.mjs +0 -101
  65. package/esm2022/lib/angular/datepicker/datepicker-range.service.mjs +0 -97
  66. package/esm2022/lib/angular/datepicker/datepicker.module.mjs +0 -42
  67. package/esm2022/lib/angular/df.module.mjs +0 -102
  68. package/esm2022/lib/angular/footer/footer.module.mjs +0 -17
  69. package/esm2022/lib/angular/icon/amadeus-icon.mjs +0 -79
  70. package/esm2022/lib/angular/icon/icon.module.mjs +0 -17
  71. package/esm2022/lib/angular/icon/insert/insert-icon.directive.mjs +0 -47
  72. package/esm2022/lib/angular/icon/insert/insert-icon.module.mjs +0 -17
  73. package/esm2022/lib/angular/inputs/click/trigger-click.directive.mjs +0 -28
  74. package/esm2022/lib/angular/inputs/icon/inputicon.directive.mjs +0 -95
  75. package/esm2022/lib/angular/inputs/input-advanced.module.mjs +0 -19
  76. package/esm2022/lib/angular/mediaqueries/ifMedia.directive.mjs +0 -52
  77. package/esm2022/lib/angular/mediaqueries/media.module.mjs +0 -17
  78. package/esm2022/lib/angular/mediaqueries/media.service.mjs +0 -46
  79. package/esm2022/lib/angular/mediaqueries/mediaUtils.service.mjs +0 -185
  80. package/esm2022/lib/angular/modal/modal.service.mjs +0 -36
  81. package/esm2022/lib/angular/popover/config/popover.config.mjs +0 -15
  82. package/esm2022/lib/angular/popover/popover.module.mjs +0 -17
  83. package/esm2022/lib/angular/progressbar/progressbar.component.mjs +0 -156
  84. package/esm2022/lib/angular/progressbar/progressbar.module.mjs +0 -18
  85. package/esm2022/lib/angular/progressindicator/default/default-spinner.component.mjs +0 -23
  86. package/esm2022/lib/angular/progressindicator/progressindicator-backdrop.component.mjs +0 -29
  87. package/esm2022/lib/angular/progressindicator/progressindicator-config.mjs +0 -25
  88. package/esm2022/lib/angular/progressindicator/progressindicator-container.component.mjs +0 -52
  89. package/esm2022/lib/angular/progressindicator/progressindicator-ref.mjs +0 -8
  90. package/esm2022/lib/angular/progressindicator/progressindicator.directive.mjs +0 -39
  91. package/esm2022/lib/angular/progressindicator/progressindicator.module.mjs +0 -45
  92. package/esm2022/lib/angular/progressindicator/progressindicator.service.mjs +0 -170
  93. package/esm2022/lib/angular/right-to-left/directionDetection.service.mjs +0 -32
  94. package/esm2022/lib/angular/selects/events/manage-badge-events.directive.mjs +0 -65
  95. package/esm2022/lib/angular/selects/nav/manage-nav-select.directive.mjs +0 -108
  96. package/esm2022/lib/angular/selects/option-highlight.directive.mjs +0 -59
  97. package/esm2022/lib/angular/selects/select.model.mjs +0 -2
  98. package/esm2022/lib/angular/selects/select.module.mjs +0 -22
  99. package/esm2022/lib/angular/sidenav/dfSideNavAnimation.mjs +0 -73
  100. package/esm2022/lib/angular/sidenav/dfSideNavCollapse.mjs +0 -94
  101. package/esm2022/lib/angular/sidenav/dfSideNavCollapse.module.mjs +0 -18
  102. package/esm2022/lib/angular/sidenav/dfSideNavCollapse.service.mjs +0 -37
  103. package/esm2022/lib/angular/sidenav/dfSideNavCollapseConfig.mjs +0 -27
  104. package/esm2022/lib/angular/sidenav/excludeTrap.directive.mjs +0 -55
  105. package/esm2022/lib/angular/sidenav/manage-sidenav.directive.mjs +0 -26
  106. package/esm2022/lib/angular/sidenav/sidenav-config.mjs +0 -25
  107. package/esm2022/lib/angular/sidenav/sidenav.component.mjs +0 -86
  108. package/esm2022/lib/angular/sidenav/sidenav.module.mjs +0 -52
  109. package/esm2022/lib/angular/sidenav/sidenav.service.mjs +0 -316
  110. package/esm2022/lib/angular/sidenav/sidenavlist.component.mjs +0 -59
  111. package/esm2022/lib/angular/slider/direction/sliderdirection.directive.mjs +0 -36
  112. package/esm2022/lib/angular/slider/lib/change-context.mjs +0 -3
  113. package/esm2022/lib/angular/slider/lib/compatibility-helper.mjs +0 -15
  114. package/esm2022/lib/angular/slider/lib/event-listener-helper.mjs +0 -77
  115. package/esm2022/lib/angular/slider/lib/event-listener.mjs +0 -3
  116. package/esm2022/lib/angular/slider/lib/math-helper.mjs +0 -15
  117. package/esm2022/lib/angular/slider/lib/options.mjs +0 -123
  118. package/esm2022/lib/angular/slider/lib/pointer-type.mjs +0 -9
  119. package/esm2022/lib/angular/slider/lib/slider-element.directive.mjs +0 -190
  120. package/esm2022/lib/angular/slider/lib/slider-handle.directive.mjs +0 -65
  121. package/esm2022/lib/angular/slider/lib/slider-label.directive.mjs +0 -41
  122. package/esm2022/lib/angular/slider/lib/slider.component.mjs +0 -1998
  123. package/esm2022/lib/angular/slider/lib/tooltip-wrapper.component.mjs +0 -23
  124. package/esm2022/lib/angular/slider/lib/value-helper.mjs +0 -50
  125. package/esm2022/lib/angular/slider/slider.module.mjs +0 -37
  126. package/esm2022/lib/angular/stepper/stepper.component.mjs +0 -65
  127. package/esm2022/lib/angular/stepper/stepper.directive.mjs +0 -174
  128. package/esm2022/lib/angular/stepper/stepper.module.mjs +0 -17
  129. package/esm2022/lib/angular/stepper/stepper.service.mjs +0 -213
  130. package/esm2022/lib/angular/toast/toast.module.mjs +0 -17
  131. package/esm2022/lib/angular/tooltip/tooltip.module.mjs +0 -18
  132. package/esm2022/lib/angular/tooltip/truncate/tooltipTruncate.directive.mjs +0 -31
  133. package/esm2022/lib/angular/utils/html-element-helper.mjs +0 -8
  134. package/esm2022/lib/angular/utils/scrollbar.service.mjs +0 -79
  135. package/esm2022/lib/angular/utils/titleTruncate.directive.mjs +0 -39
  136. package/esm2022/lib/angular/waves-of-progress/waves.directive.mjs +0 -86
  137. package/esm2022/lib/angular/waves-of-progress/waves.module.mjs +0 -16
  138. package/esm2022/lib/index.mjs +0 -93
  139. package/lib/angular/datepicker/closedatepicker.directive.d.ts +0 -10
@@ -1,77 +0,0 @@
1
- import { Subject } from 'rxjs';
2
- import { throttleTime, tap } from 'rxjs/operators';
3
- import { EventListener } from './event-listener';
4
- import { ValueHelper } from './value-helper';
5
- const w = typeof window !== 'undefined' ? window : { screen: {}, navigator: {} };
6
- let passiveOptionAccessed = false;
7
- const options = {
8
- get passive() {
9
- return (passiveOptionAccessed = true);
10
- }
11
- };
12
- const noop = () => { };
13
- w.addEventListener && w.addEventListener('p', noop, options);
14
- w.removeEventListener && w.removeEventListener('p', noop, false);
15
- export const supportsPassiveEvents = passiveOptionAccessed;
16
- /**
17
- * Helper class to attach event listeners to DOM elements with debounce support using rxjs
18
- */
19
- export class EventListenerHelper {
20
- constructor(renderer) {
21
- this.renderer = renderer;
22
- }
23
- attachPassiveEventListener(nativeElement, eventName, callback, throttleInterval) {
24
- // Only use passive event listeners if the browser supports it
25
- if (supportsPassiveEvents !== true) {
26
- return this.attachEventListener(nativeElement, eventName, callback, throttleInterval);
27
- }
28
- // Angular doesn't support passive event handlers (yet), so we need to roll our own code using native functions
29
- const listener = new EventListener();
30
- listener.eventName = eventName;
31
- listener.events = new Subject();
32
- const observerCallback = (event) => {
33
- listener.events?.next(event);
34
- };
35
- nativeElement.addEventListener(eventName, observerCallback, { passive: true, capture: false });
36
- listener.teardownCallback = () => {
37
- nativeElement.removeEventListener(eventName, observerCallback, { passive: true, capture: false });
38
- };
39
- listener.eventsSubscription = listener.events
40
- .pipe((!ValueHelper.isNullOrUndefined(throttleInterval))
41
- ? throttleTime(throttleInterval, undefined, { leading: true, trailing: true })
42
- : tap(() => { }) // no-op
43
- )
44
- .subscribe((event) => {
45
- callback(event);
46
- });
47
- return listener;
48
- }
49
- detachEventListener(eventListener) {
50
- if (!ValueHelper.isNullOrUndefined(eventListener.eventsSubscription)) {
51
- eventListener.eventsSubscription?.unsubscribe();
52
- }
53
- if (!ValueHelper.isNullOrUndefined(eventListener.events)) {
54
- eventListener.events?.complete();
55
- }
56
- if (!ValueHelper.isNullOrUndefined(eventListener.teardownCallback)) {
57
- eventListener.teardownCallback?.();
58
- }
59
- }
60
- attachEventListener(nativeElement, eventName, callback, throttleInterval) {
61
- const listener = new EventListener();
62
- listener.eventName = eventName;
63
- listener.events = new Subject();
64
- const observerCallback = (event) => {
65
- listener.events?.next(event);
66
- };
67
- listener.teardownCallback = this.renderer.listen(nativeElement, eventName, observerCallback);
68
- listener.eventsSubscription = listener.events
69
- .pipe((!ValueHelper.isNullOrUndefined(throttleInterval))
70
- ? throttleTime(throttleInterval, undefined, { leading: true, trailing: true })
71
- : tap(() => { }) // no-op
72
- )
73
- .subscribe((event) => { callback(event); });
74
- return listener;
75
- }
76
- }
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-listener-helper.js","sourceRoot":"","sources":["../../../../../../../projects/design-factory/src/lib/angular/slider/lib/event-listener-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { Renderer2 } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { throttleTime, tap } from 'rxjs/operators';\nimport { EventListener } from './event-listener';\nimport { ValueHelper } from './value-helper';\n\nconst w: Window | any =\n  typeof window !== 'undefined' ? window : { screen: {}, navigator: {} };\n\nlet passiveOptionAccessed = false;\nconst options = {\n  get passive() {\n    return (passiveOptionAccessed = true);\n  }\n};\nconst noop = () => {};\nw.addEventListener && w.addEventListener('p', noop, options);\nw.removeEventListener && w.removeEventListener('p', noop, false);\n\nexport const supportsPassiveEvents: boolean = passiveOptionAccessed;\n\n/**\n * Helper class to attach event listeners to DOM elements with debounce support using rxjs\n */\nexport class EventListenerHelper {\n  constructor(private renderer: Renderer2) {\n  }\n\n  public attachPassiveEventListener(nativeElement: any, eventName: string, callback: (event: any) => void,\n      throttleInterval?: number): EventListener {\n    // Only use passive event listeners if the browser supports it\n    if (supportsPassiveEvents !== true) {\n      return this.attachEventListener(nativeElement, eventName, callback, throttleInterval);\n    }\n\n    // Angular doesn't support passive event handlers (yet), so we need to roll our own code using native functions\n    const listener: EventListener = new EventListener();\n    listener.eventName = eventName;\n    listener.events = new Subject<Event>();\n\n    const observerCallback: (event: Event) => void = (event: Event): void => {\n      listener.events?.next(event);\n    };\n    nativeElement.addEventListener(eventName, observerCallback, {passive: true, capture: false});\n\n    listener.teardownCallback = (): void => {\n      nativeElement.removeEventListener(eventName, observerCallback, {passive: true, capture: false});\n    };\n\n    listener.eventsSubscription = listener.events\n      .pipe((!ValueHelper.isNullOrUndefined(throttleInterval))\n        ? throttleTime(throttleInterval!, undefined, { leading: true, trailing: true})\n        : tap(() => {}) // no-op\n      )\n      .subscribe((event: Event) => {\n        callback(event);\n      });\n\n    return listener;\n  }\n\n  public detachEventListener(eventListener: EventListener): void {\n    if (!ValueHelper.isNullOrUndefined(eventListener.eventsSubscription)) {\n      eventListener.eventsSubscription?.unsubscribe();\n    }\n\n    if (!ValueHelper.isNullOrUndefined(eventListener.events)) {\n      eventListener.events?.complete();\n    }\n\n    if (!ValueHelper.isNullOrUndefined(eventListener.teardownCallback)) {\n      eventListener.teardownCallback?.();\n    }\n  }\n\n  public attachEventListener(nativeElement: any, eventName: string, callback: (event: any) => void,\n      throttleInterval?: number): EventListener {\n    const listener: EventListener = new EventListener();\n    listener.eventName = eventName;\n    listener.events = new Subject<Event>();\n\n    const observerCallback: (event: Event) => void = (event: Event): void => {\n      listener.events?.next(event);\n    };\n\n    listener.teardownCallback = this.renderer.listen(nativeElement, eventName, observerCallback);\n\n    listener.eventsSubscription = listener.events\n      .pipe((!ValueHelper.isNullOrUndefined(throttleInterval))\n          ? throttleTime(throttleInterval!, undefined, { leading: true, trailing: true})\n          : tap(() => {}) // no-op\n      )\n      .subscribe((event: Event) => { callback(event); });\n\n    return listener;\n  }\n}"]}
@@ -1,3 +0,0 @@
1
- export class EventListener {
2
- }
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtbGlzdGVuZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tZmFjdG9yeS9zcmMvbGliL2FuZ3VsYXIvc2xpZGVyL2xpYi9ldmVudC1saXN0ZW5lci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sYUFBYTtDQUt6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN1YmplY3QsIFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgY2xhc3MgRXZlbnRMaXN0ZW5lciB7XG4gIGV2ZW50TmFtZT86IHN0cmluZztcbiAgZXZlbnRzPzogU3ViamVjdDxFdmVudD47XG4gIGV2ZW50c1N1YnNjcmlwdGlvbj86IFN1YnNjcmlwdGlvbjtcbiAgdGVhcmRvd25DYWxsYmFjaz86ICgpID0+IHZvaWQ7XG59Il19
@@ -1,15 +0,0 @@
1
- /** Helper with mathematical functions */
2
- export class MathHelper {
3
- /* Round numbers to a given number of significant digits */
4
- static roundToPrecisionLimit(value, precisionLimit) {
5
- return +(value.toPrecision(precisionLimit));
6
- }
7
- static isModuloWithinPrecisionLimit(value, modulo, precisionLimit) {
8
- const limit = Math.pow(10, -precisionLimit);
9
- return Math.abs(value % modulo) <= limit || Math.abs(Math.abs(value % modulo) - modulo) <= limit;
10
- }
11
- static clampToRange(value, floor, ceil) {
12
- return Math.min(Math.max(value, floor), ceil);
13
- }
14
- }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0aC1oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tZmFjdG9yeS9zcmMvbGliL2FuZ3VsYXIvc2xpZGVyL2xpYi9tYXRoLWhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx5Q0FBeUM7QUFDekMsTUFBTSxPQUFPLFVBQVU7SUFDckIsMkRBQTJEO0lBQzNELE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxLQUFhLEVBQUUsY0FBc0I7UUFDaEUsT0FBTyxDQUFDLENBQUUsS0FBSyxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUMsQ0FBRSxDQUFDO0lBQ2hELENBQUM7SUFFRCxNQUFNLENBQUMsNEJBQTRCLENBQUMsS0FBYSxFQUFFLE1BQWMsRUFBRSxjQUFzQjtRQUN2RixNQUFNLEtBQUssR0FBVyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBRSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3BELE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLElBQUksS0FBSyxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLEdBQUcsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDO0lBQ25HLENBQUM7SUFFRCxNQUFNLENBQUMsWUFBWSxDQUFDLEtBQWEsRUFBRSxLQUFhLEVBQUUsSUFBWTtRQUM1RCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDaEQsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEhlbHBlciB3aXRoIG1hdGhlbWF0aWNhbCBmdW5jdGlvbnMgKi9cbmV4cG9ydCBjbGFzcyBNYXRoSGVscGVyIHtcbiAgLyogUm91bmQgbnVtYmVycyB0byBhIGdpdmVuIG51bWJlciBvZiBzaWduaWZpY2FudCBkaWdpdHMgKi9cbiAgc3RhdGljIHJvdW5kVG9QcmVjaXNpb25MaW1pdCh2YWx1ZTogbnVtYmVyLCBwcmVjaXNpb25MaW1pdDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICByZXR1cm4gKyggdmFsdWUudG9QcmVjaXNpb24ocHJlY2lzaW9uTGltaXQpICk7XG4gIH1cblxuICBzdGF0aWMgaXNNb2R1bG9XaXRoaW5QcmVjaXNpb25MaW1pdCh2YWx1ZTogbnVtYmVyLCBtb2R1bG86IG51bWJlciwgcHJlY2lzaW9uTGltaXQ6IG51bWJlcik6IGJvb2xlYW4ge1xuICAgIGNvbnN0IGxpbWl0OiBudW1iZXIgPSBNYXRoLnBvdygxMCwgLXByZWNpc2lvbkxpbWl0KTtcbiAgICByZXR1cm4gTWF0aC5hYnModmFsdWUgJSBtb2R1bG8pIDw9IGxpbWl0IHx8IE1hdGguYWJzKE1hdGguYWJzKHZhbHVlICUgbW9kdWxvKSAtIG1vZHVsbykgPD0gbGltaXQ7XG4gIH1cblxuICBzdGF0aWMgY2xhbXBUb1JhbmdlKHZhbHVlOiBudW1iZXIsIGZsb29yOiBudW1iZXIsIGNlaWw6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIE1hdGgubWluKE1hdGgubWF4KHZhbHVlLCBmbG9vciksIGNlaWwpO1xuICB9XG59Il19
@@ -1,123 +0,0 @@
1
- /** Label type */
2
- export var LabelType;
3
- (function (LabelType) {
4
- /** Label above low pointer */
5
- LabelType[LabelType["Low"] = 0] = "Low";
6
- /** Label above high pointer */
7
- LabelType[LabelType["High"] = 1] = "High";
8
- /** Label for minimum slider value */
9
- LabelType[LabelType["Floor"] = 2] = "Floor";
10
- /** Label for maximum slider value */
11
- LabelType[LabelType["Ceil"] = 3] = "Ceil";
12
- /** Label below legend tick */
13
- LabelType[LabelType["TickValue"] = 4] = "TickValue";
14
- })(LabelType || (LabelType = {}));
15
- /** Slider options */
16
- export class Options {
17
- constructor() {
18
- /** Minimum value for a slider.
19
- Not applicable when using stepsArray. */
20
- this.floor = 0;
21
- /** Step between each value.
22
- Not applicable when using stepsArray. */
23
- this.step = 1;
24
- /** Set to true to have a push behavior. When the min handle goes above the max,
25
- the max is moved as well (and vice-versa). The range between min and max is
26
- defined by the step option (defaults to 1) and can also be overriden by
27
- the minRange option. Applies to range slider only. */
28
- this.pushRange = false;
29
- /** Set to true to bind the index of the selected item to value model and valueHigh model. */
30
- this.bindIndexForStepsArray = false;
31
- /** When set to true and using a range slider, the range can be dragged by the selection bar.
32
- Applies to range slider only. */
33
- this.draggableRange = false;
34
- /** Same as draggableRange but the slider range can't be changed.
35
- Applies to range slider only. */
36
- this.draggableRangeOnly = false;
37
- /** Set to true to always show the selection bar before the slider handle. */
38
- this.showSelectionBar = false;
39
- /** Set to true to always show the selection bar after the slider handle. */
40
- this.showSelectionBarEnd = false;
41
- /** Only for range slider. Set to true to visualize in different colour the areas
42
- on the left/right (top/bottom for vertical range slider) of selection bar between the handles. */
43
- this.showOuterSelectionBars = false;
44
- /** Set to true to hide pointer labels */
45
- this.hidePointerLabels = false;
46
- /** Set to true to hide min / max labels */
47
- this.hideLimitLabels = false;
48
- /** Set to false to disable the auto-hiding behavior of the limit labels. */
49
- this.autoHideLimitLabels = true;
50
- /** Set to true to make the slider read-only. */
51
- this.readOnly = false;
52
- /** Set to true to disable the slider. */
53
- this.disabled = false;
54
- /** Set to true to display a tick for each step of the slider. */
55
- this.showTicks = false;
56
- /** Set to true to display a tick and the step value for each step of the slider.. */
57
- this.showTicksValues = false;
58
- /** Set to true to display the slider vertically.
59
- The slider will take the full height of its parent.
60
- Changing this value at runtime is not currently supported. */
61
- this.vertical = false;
62
- /** Handles are focusable (on click or with tab) and can be modified using the following keyboard controls:
63
- Left/bottom arrows: -1
64
- Right/top arrows: +1
65
- Page-down: -10%
66
- Page-up: +10%
67
- Home: minimum value
68
- End: maximum value
69
- */
70
- this.keyboardSupport = true;
71
- /** If you display the slider in an element that uses transform: scale(0.5), set the scale value to 2
72
- so that the slider is rendered properly and the events are handled correctly. */
73
- this.scale = 1;
74
- /** If you display the slider in an element that uses transform: rotate(90deg), set the rotate value to 90
75
- so that the slider is rendered properly and the events are handled correctly. Value is in degrees. */
76
- this.rotate = 0;
77
- /** Set to true to force the value(s) to be rounded to the step, even when modified from the outside.
78
- When set to false, if the model values are modified from outside the slider, they are not rounded
79
- and can be between two steps. */
80
- this.enforceStep = true;
81
- /** Set to true to force the value(s) to be normalised to allowed range (floor to ceil), even when modified from the outside.
82
- When set to false, if the model values are modified from outside the slider, and they are outside allowed range,
83
- the slider may be rendered incorrectly. However, setting this to false may be useful if you want to perform custom normalisation. */
84
- this.enforceRange = true;
85
- /** Set to true to force the value(s) to be rounded to the nearest step value, even when modified from the outside.
86
- When set to false, if the model values are modified from outside the slider, and they are outside allowed range,
87
- the slider may be rendered incorrectly. However, setting this to false may be useful if you want to perform custom normalisation. */
88
- this.enforceStepsArray = true;
89
- /** Set to true to prevent to user from switching the min and max handles. Applies to range slider only. */
90
- this.noSwitching = false;
91
- /** Set to true to only bind events on slider handles. */
92
- this.onlyBindHandles = false;
93
- /** Set to true to show graphs right to left.
94
- If vertical is true it will be from top to bottom and left / right arrow functions reversed. */
95
- this.rightToLeft = false;
96
- /** Set to true to reverse keyboard navigation:
97
- Right/top arrows: -1
98
- Left/bottom arrows: +1
99
- Page-up: -10%
100
- Page-down: +10%
101
- End: minimum value
102
- Home: maximum value
103
- */
104
- this.reversedControls = false;
105
- /** Set to true to keep the slider labels inside the slider bounds. */
106
- this.boundPointerLabels = true;
107
- /** Set to true to use a logarithmic scale to display the slider. */
108
- this.logScale = false;
109
- /** Precision limit for calculated values.
110
- Values used in calculations will be rounded to this number of significant digits
111
- to prevent accumulating small floating-point errors. */
112
- this.precisionLimit = 12;
113
- /** Use to add a label directly to the slider for accessibility. Adds the aria-label attribute. */
114
- this.ariaLabel = 'ngx-slider';
115
- /** Use to add a label directly to the slider range for accessibility. Adds the aria-label attribute. */
116
- this.ariaLabelHigh = 'ngx-slider-max';
117
- /** Enable/disable CSS animations */
118
- this.animate = true;
119
- /** Enable/disable CSS animations while moving the slider */
120
- this.animateOnMove = false;
121
- }
122
- }
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.js","sourceRoot":"","sources":["../../../../../../../projects/design-factory/src/lib/angular/slider/lib/options.ts"],"names":[],"mappings":"AAEA,iBAAiB;AACjB,MAAM,CAAN,IAAY,SAWX;AAXD,WAAY,SAAS;IACnB,8BAA8B;IAC9B,uCAAG,CAAA;IACH,+BAA+B;IAC/B,yCAAI,CAAA;IACJ,qCAAqC;IACrC,2CAAK,CAAA;IACL,qCAAqC;IACrC,yCAAI,CAAA;IACJ,8BAA8B;IAC9B,mDAAS,CAAA;AACX,CAAC,EAXW,SAAS,KAAT,SAAS,QAWpB;AA4BD,qBAAqB;AACrB,MAAM,OAAO,OAAO;IAApB;QACE;kDAC0C;QAC1C,UAAK,GAAY,CAAC,CAAC;QAMnB;kDAC0C;QAC1C,SAAI,GAAY,CAAC,CAAC;QAYlB;;;+DAGuD;QACvD,cAAS,GAAa,KAAK,CAAC;QA0C5B,6FAA6F;QAC7F,2BAAsB,GAAa,KAAK,CAAC;QAEzC;0CACkC;QAClC,mBAAc,GAAa,KAAK,CAAC;QAEjC;0CACkC;QAClC,uBAAkB,GAAa,KAAK,CAAC;QAErC,6EAA6E;QAC7E,qBAAgB,GAAa,KAAK,CAAC;QAEnC,4EAA4E;QAC5E,wBAAmB,GAAa,KAAK,CAAC;QAMtC;2GACmG;QACnG,2BAAsB,GAAa,KAAK,CAAC;QAEzC,yCAAyC;QACzC,sBAAiB,GAAa,KAAK,CAAC;QAEpC,4CAA4C;QAC5C,oBAAe,GAAa,KAAK,CAAC;QAElC,4EAA4E;QAC5E,wBAAmB,GAAa,IAAI,CAAC;QAErC,gDAAgD;QAChD,aAAQ,GAAa,KAAK,CAAC;QAE3B,yCAAyC;QACzC,aAAQ,GAAa,KAAK,CAAC;QAE3B,iEAAiE;QACjE,cAAS,GAAa,KAAK,CAAC;QAE5B,qFAAqF;QACrF,oBAAe,GAAa,KAAK,CAAC;QAsBlC;;uEAE+D;QAC/D,aAAQ,GAAa,KAAK,CAAC;QAsB3B;;;;;;;WAOG;QACH,oBAAe,GAAa,IAAI,CAAC;QAEjC;0FACkF;QAClF,UAAK,GAAY,CAAC,CAAC;QAEnB;8GACsG;QACtG,WAAM,GAAY,CAAC,CAAC;QAEpB;;0CAEkC;QAClC,gBAAW,GAAa,IAAI,CAAC;QAE7B;;8IAEsI;QACtI,iBAAY,GAAa,IAAI,CAAC;QAE9B;;8IAEsI;QACtI,sBAAiB,GAAa,IAAI,CAAC;QAEnC,2GAA2G;QAC3G,gBAAW,GAAa,KAAK,CAAC;QAE9B,yDAAyD;QACzD,oBAAe,GAAa,KAAK,CAAC;QAElC;yGACiG;QACjG,gBAAW,GAAa,KAAK,CAAC;QAE9B;;;;;;;WAOG;QACH,qBAAgB,GAAa,KAAK,CAAC;QAEnC,sEAAsE;QACtE,uBAAkB,GAAa,IAAI,CAAC;QAEpC,qEAAqE;QACrE,aAAQ,GAAa,KAAK,CAAC;QAY3B;;iEAEyD;QACzD,mBAAc,GAAY,EAAE,CAAC;QAM7B,kGAAkG;QAClG,cAAS,GAAY,YAAY,CAAC;QAMlC,wGAAwG;QACxG,kBAAa,GAAY,gBAAgB,CAAC;QAY1C,oCAAoC;QACpC,YAAO,GAAa,IAAI,CAAC;QAEzB,4DAA4D;QAC5D,kBAAa,GAAa,KAAK,CAAC;IAClC,CAAC;CAAA","sourcesContent":["import { PointerType } from './pointer-type';\n\n/** Label type */\nexport enum LabelType {\n  /** Label above low pointer */\n  Low,\n  /** Label above high pointer */\n  High,\n  /** Label for minimum slider value */\n  Floor,\n  /** Label for maximum slider value */\n  Ceil,\n  /** Label below legend tick */\n  TickValue\n}\n\n/** Function to translate label value into text */\nexport type TranslateFunction = (value: number, label: LabelType) => string;\n/** Function to combind */\nexport type CombineLabelsFunction = (minLabel: string, maxLabel: string) => string;\n/** Function to provide legend  */\nexport type GetLegendFunction = (value: number) => string;\nexport type GetStepLegendFunction = (step: CustomStepDefinition) => string;\n\n/** Function converting slider value to slider position */\nexport type ValueToPositionFunction = (val: number, minVal: number, maxVal: number) => number;\n\n/** Function converting slider position to slider value */\nexport type PositionToValueFunction = (percent: number, minVal: number, maxVal: number) => number;\n\n/**\n * Custom step definition\n *\n * This can be used to specify custom values and legend values for slider ticks\n */\nexport interface CustomStepDefinition {\n  /** Value */\n  value: number;\n  /** Legend (label for the value) */\n  legend?: string;\n}\n\n/** Slider options */\nexport class Options {\n  /** Minimum value for a slider.\n    Not applicable when using stepsArray. */\n  floor?: number = 0;\n\n  /** Maximum value for a slider.\n    Not applicable when using stepsArray. */\n  ceil?: number;\n\n  /** Step between each value.\n    Not applicable when using stepsArray. */\n  step?: number = 1;\n\n  /** The minimum range authorized on the slider.\n    Applies to range slider only.\n    When using stepsArray, expressed as index into stepsArray. */\n  minRange?: number;\n\n  /** The maximum range authorized on the slider.\n    Applies to range slider only.\n    When using stepsArray, expressed as index into stepsArray. */\n  maxRange?: number;\n\n  /** Set to true to have a push behavior. When the min handle goes above the max,\n    the max is moved as well (and vice-versa). The range between min and max is\n    defined by the step option (defaults to 1) and can also be overriden by\n    the minRange option. Applies to range slider only. */\n  pushRange?: boolean = false;\n\n  /** The minimum value authorized on the slider.\n    When using stepsArray, expressed as index into stepsArray. */\n  minLimit?: number;\n\n  /** The maximum value authorized on the slider.\n    When using stepsArray, expressed as index into stepsArray. */\n  maxLimit?: number;\n\n  /** Custom translate function. Use this if you want to translate values displayed\n      on the slider. */\n  translate?: TranslateFunction;\n\n  /** Custom function for combining overlapping labels in range slider.\n      It takes the min and max values (already translated with translate fuction)\n      and should return how these two values should be combined.\n      If not provided, the default function will join the two values with\n      ' - ' as separator. */\n  combineLabels?: CombineLabelsFunction;\n\n  /** Use to display legend under ticks (thus, it needs to be used along with\n     showTicks or showTicksValues). The function will be called with each tick\n     value and returned content will be displayed under the tick as a legend.\n     If the returned value is null, then no legend is displayed under\n     the corresponding tick.You can also directly provide the legend values\n     in the stepsArray option. */\n  getLegend?: GetLegendFunction;\n\n   /** Use to display a custom legend of a stepItem from stepsArray.\n    It will be the same as getLegend but for stepsArray. */\n  getStepLegend?: GetStepLegendFunction;\n\n  /** If you want to display a slider with non linear/number steps.\n     Just pass an array with each slider value and that's it; the floor, ceil and step settings\n     of the slider will be computed automatically.\n     By default, the value model and valueHigh model values will be the value of the selected item\n     in the stepsArray.\n     They can also be bound to the index of the selected item by setting the bindIndexForStepsArray\n     option to true. */\n  stepsArray?: CustomStepDefinition[];\n\n  /** Set to true to bind the index of the selected item to value model and valueHigh model. */\n  bindIndexForStepsArray?: boolean = false;\n\n  /** When set to true and using a range slider, the range can be dragged by the selection bar.\n    Applies to range slider only. */\n  draggableRange?: boolean = false;\n\n  /** Same as draggableRange but the slider range can't be changed.\n    Applies to range slider only. */\n  draggableRangeOnly?: boolean = false;\n\n  /** Set to true to always show the selection bar before the slider handle. */\n  showSelectionBar?: boolean = false;\n\n  /** Set to true to always show the selection bar after the slider handle. */\n  showSelectionBarEnd?: boolean = false;\n\n  /**  Set a number to draw the selection bar between this value and the slider handle.\n    When using stepsArray, expressed as index into stepsArray. */\n  showSelectionBarFromValue?: number;\n\n  /**  Only for range slider. Set to true to visualize in different colour the areas\n    on the left/right (top/bottom for vertical range slider) of selection bar between the handles. */\n  showOuterSelectionBars?: boolean = false;\n\n  /** Set to true to hide pointer labels */\n  hidePointerLabels?: boolean = false;\n\n  /** Set to true to hide min / max labels  */\n  hideLimitLabels?: boolean = false;\n\n  /** Set to false to disable the auto-hiding behavior of the limit labels. */\n  autoHideLimitLabels?: boolean = true;\n\n  /** Set to true to make the slider read-only. */\n  readOnly?: boolean = false;\n\n  /** Set to true to disable the slider. */\n  disabled?: boolean = false;\n\n  /** Set to true to display a tick for each step of the slider. */\n  showTicks?: boolean = false;\n\n  /** Set to true to display a tick and the step value for each step of the slider.. */\n  showTicksValues?: boolean = false;\n\n  /* The step between each tick to display. If not set, the step value is used.\n    Not used when ticksArray is specified. */\n  tickStep?: number;\n\n  /* The step between displaying each tick step value.\n    If not set, then tickStep or step is used, depending on which one is set. */\n  tickValueStep?: number;\n\n  /** Use to display ticks at specific positions.\n    The array contains the index of the ticks that should be displayed.\n    For example, [0, 1, 5] will display a tick for the first, second and sixth values. */\n  ticksArray?: number[];\n\n  /** Used to display a tooltip when a tick is hovered.\n    Set to a function that returns the tooltip content for a given value. */\n  ticksTooltip?: (value: number) => string;\n\n  /** Same as ticksTooltip but for ticks values. */\n  ticksValuesTooltip?: (value: number) => string;\n\n  /** Set to true to display the slider vertically.\n    The slider will take the full height of its parent.\n    Changing this value at runtime is not currently supported. */\n  vertical?: boolean = false;\n\n  /** Function that returns the current color of the selection bar.\n    If your color won't change, don't use this option but set it through CSS.\n    If the returned color depends on a model value (either value or valueHigh),\n    you should use the argument passed to the function.\n    Indeed, when the function is called, there is no certainty that the model\n    has already been updated.*/\n  getSelectionBarColor?: (minValue: number, maxValue?: number) => string;\n\n  /** Function that returns the color of a tick. showTicks must be enabled. */\n  getTickColor?: (value: number) => string;\n\n  /** Function that returns the current color of a pointer.\n    If your color won't change, don't use this option but set it through CSS.\n    If the returned color depends on a model value (either value or valueHigh),\n    you should use the argument passed to the function.\n    Indeed, when the function is called, there is no certainty that the model has already been updated.\n    To handle range slider pointers independently, you should evaluate pointerType within the given\n    function where \"min\" stands for value model and \"max\" for valueHigh model values. */\n  getPointerColor?: (value: number, pointerType: PointerType) => string;\n\n  /** Handles are focusable (on click or with tab) and can be modified using the following keyboard controls:\n    Left/bottom arrows: -1\n    Right/top arrows: +1\n    Page-down: -10%\n    Page-up: +10%\n    Home: minimum value\n    End: maximum value\n   */\n  keyboardSupport?: boolean = true;\n\n  /** If you display the slider in an element that uses transform: scale(0.5), set the scale value to 2\n    so that the slider is rendered properly and the events are handled correctly. */\n  scale?: number = 1;\n\n  /** If you display the slider in an element that uses transform: rotate(90deg), set the rotate value to 90\n   so that the slider is rendered properly and the events are handled correctly. Value is in degrees. */\n  rotate?: number = 0;\n\n  /** Set to true to force the value(s) to be rounded to the step, even when modified from the outside.\n    When set to false, if the model values are modified from outside the slider, they are not rounded\n    and can be between two steps. */\n  enforceStep?: boolean = true;\n\n  /** Set to true to force the value(s) to be normalised to allowed range (floor to ceil), even when modified from the outside.\n    When set to false, if the model values are modified from outside the slider, and they are outside allowed range,\n    the slider may be rendered incorrectly. However, setting this to false may be useful if you want to perform custom normalisation. */\n  enforceRange?: boolean = true;\n\n  /** Set to true to force the value(s) to be rounded to the nearest step value, even when modified from the outside.\n    When set to false, if the model values are modified from outside the slider, and they are outside allowed range,\n    the slider may be rendered incorrectly. However, setting this to false may be useful if you want to perform custom normalisation. */\n  enforceStepsArray?: boolean = true;\n\n  /** Set to true to prevent to user from switching the min and max handles. Applies to range slider only. */\n  noSwitching?: boolean = false;\n\n  /** Set to true to only bind events on slider handles. */\n  onlyBindHandles?: boolean = false;\n\n  /** Set to true to show graphs right to left.\n    If vertical is true it will be from top to bottom and left / right arrow functions reversed. */\n  rightToLeft?: boolean = false;\n\n  /** Set to true to reverse keyboard navigation:\n    Right/top arrows: -1\n    Left/bottom arrows: +1\n    Page-up: -10%\n    Page-down: +10%\n    End: minimum value\n    Home: maximum value\n   */\n  reversedControls?: boolean = false;\n\n  /** Set to true to keep the slider labels inside the slider bounds. */\n  boundPointerLabels?: boolean = true;\n\n  /** Set to true to use a logarithmic scale to display the slider.  */\n  logScale?: boolean = false;\n\n  /** Function that returns the position on the slider for a given value.\n    The position must be a percentage between 0 and 1.\n    The function should be monotonically increasing or decreasing; otherwise the slider may behave incorrectly. */\n  customValueToPosition?: ValueToPositionFunction;\n\n  /** Function that returns the value for a given position on the slider.\n    The position is a percentage between 0 and 1.\n    The function should be monotonically increasing or decreasing; otherwise the slider may behave incorrectly. */\n  customPositionToValue?: PositionToValueFunction;\n\n  /** Precision limit for calculated values.\n    Values used in calculations will be rounded to this number of significant digits\n    to prevent accumulating small floating-point errors. */\n  precisionLimit?: number = 12;\n\n  /** Use to display the selection bar as a gradient.\n    The given object must contain from and to properties which are colors. */\n  selectionBarGradient?: {from: string, to: string};\n\n  /** Use to add a label directly to the slider for accessibility. Adds the aria-label attribute. */\n  ariaLabel?: string = 'ngx-slider';\n\n  /** Use instead of ariaLabel to reference the id of an element which will be used to label the slider.\n    Adds the aria-labelledby attribute. */\n  ariaLabelledBy?: string;\n\n  /** Use to add a label directly to the slider range for accessibility. Adds the aria-label attribute. */\n  ariaLabelHigh?: string = 'ngx-slider-max';\n\n  /** Use instead of ariaLabelHigh to reference the id of an element which will be used to label the slider range.\n    Adds the aria-labelledby attribute. */\n  ariaLabelledByHigh?: string;\n\n  /** Use to increase rendering performance. If the value is not provided, the slider calculates the with/height of the handle */\n  handleDimension?: number;\n\n  /** Use to increase rendering performance. If the value is not provided, the slider calculates the with/height of the bar */\n  barDimension?: number;\n\n  /** Enable/disable CSS animations */\n  animate?: boolean = true;\n\n  /** Enable/disable CSS animations while moving the slider */\n  animateOnMove?: boolean = false;\n}"]}
@@ -1,9 +0,0 @@
1
- /** Pointer type */
2
- export var PointerType;
3
- (function (PointerType) {
4
- /** Low pointer */
5
- PointerType[PointerType["Min"] = 0] = "Min";
6
- /** High pointer */
7
- PointerType[PointerType["Max"] = 1] = "Max";
8
- })(PointerType || (PointerType = {}));
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9pbnRlci10eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWZhY3Rvcnkvc3JjL2xpYi9hbmd1bGFyL3NsaWRlci9saWIvcG9pbnRlci10eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG1CQUFtQjtBQUNuQixNQUFNLENBQU4sSUFBWSxXQUtYO0FBTEQsV0FBWSxXQUFXO0lBQ3JCLGtCQUFrQjtJQUNsQiwyQ0FBRyxDQUFBO0lBQ0gsbUJBQW1CO0lBQ25CLDJDQUFHLENBQUE7QUFDTCxDQUFDLEVBTFcsV0FBVyxLQUFYLFdBQVcsUUFLdEIiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogUG9pbnRlciB0eXBlICovXG5leHBvcnQgZW51bSBQb2ludGVyVHlwZSB7XG4gIC8qKiBMb3cgcG9pbnRlciAqL1xuICBNaW4sXG4gIC8qKiBIaWdoIHBvaW50ZXIgKi9cbiAgTWF4XG59Il19
@@ -1,190 +0,0 @@
1
- import { Directive, HostBinding } from '@angular/core';
2
- import { EventListenerHelper } from './event-listener-helper';
3
- import { ValueHelper } from './value-helper';
4
- import * as i0 from "@angular/core";
5
- /**
6
- * @deprecated SliderElementDirective is deprecated. Use {@link https://design-factory-int.app.net6.paas.westeurope.rnd.az.amadeus.net/#/components/slider/agnosui AgnosUI Slider} instead.
7
- */
8
- export class SliderElementDirective {
9
- get position() {
10
- return this._position;
11
- }
12
- get dimension() {
13
- return this._dimension;
14
- }
15
- get alwaysHide() {
16
- return this._alwaysHide;
17
- }
18
- get vertical() {
19
- return this._vertical;
20
- }
21
- get scale() {
22
- return this._scale;
23
- }
24
- get rotate() {
25
- return this._rotate;
26
- }
27
- constructor(elemRef, renderer, changeDetectionRef) {
28
- this.elemRef = elemRef;
29
- this.renderer = renderer;
30
- this.changeDetectionRef = changeDetectionRef;
31
- this._position = 0;
32
- this._dimension = 0;
33
- this._alwaysHide = false;
34
- this._vertical = false;
35
- this._scale = 1;
36
- this._rotate = 0;
37
- this.opacity = 1;
38
- this.visibility = 'visible';
39
- this.left = '';
40
- this.bottom = '';
41
- this.height = '';
42
- this.width = '';
43
- this.transform = '';
44
- this.eventListeners = [];
45
- this.eventListenerHelper = new EventListenerHelper(this.renderer);
46
- }
47
- setAlwaysHide(hide) {
48
- this._alwaysHide = hide;
49
- if (hide) {
50
- this.visibility = 'hidden';
51
- }
52
- else {
53
- this.visibility = 'visible';
54
- }
55
- }
56
- hide() {
57
- this.opacity = 0;
58
- }
59
- show() {
60
- if (this.alwaysHide) {
61
- return;
62
- }
63
- this.opacity = 1;
64
- }
65
- isVisible() {
66
- if (this.alwaysHide) {
67
- return false;
68
- }
69
- return this.opacity !== 0;
70
- }
71
- setVertical(vertical) {
72
- this._vertical = vertical;
73
- if (this._vertical) {
74
- this.left = '';
75
- this.width = '';
76
- }
77
- else {
78
- this.bottom = '';
79
- this.height = '';
80
- }
81
- }
82
- setScale(scale) {
83
- this._scale = scale;
84
- }
85
- setRotate(rotate) {
86
- this._rotate = rotate;
87
- this.transform = 'rotate(' + rotate + 'deg)';
88
- }
89
- getRotate() {
90
- return this._rotate;
91
- }
92
- // Set element left/top position depending on whether slider is horizontal or vertical
93
- setPosition(pos) {
94
- if (this._position !== pos && !this.isRefDestroyed()) {
95
- this.changeDetectionRef.markForCheck();
96
- }
97
- this._position = pos;
98
- if (this._vertical) {
99
- this.bottom = Math.round(pos) + 'px';
100
- }
101
- else {
102
- this.left = Math.round(pos) + 'px';
103
- }
104
- }
105
- // Calculate element's width/height depending on whether slider is horizontal or vertical
106
- calculateDimension() {
107
- const val = this.getBoundingClientRect();
108
- if (this.vertical) {
109
- this._dimension = (val.bottom - val.top) * this.scale;
110
- }
111
- else {
112
- this._dimension = (val.right - val.left) * this.scale;
113
- }
114
- }
115
- // Set element width/height depending on whether slider is horizontal or vertical
116
- setDimension(dim) {
117
- if (this._dimension !== dim && !this.isRefDestroyed()) {
118
- this.changeDetectionRef.markForCheck();
119
- }
120
- this._dimension = dim;
121
- if (this._vertical) {
122
- this.height = Math.round(dim) + 'px';
123
- }
124
- else {
125
- this.width = Math.round(dim) + 'px';
126
- }
127
- }
128
- getBoundingClientRect() {
129
- return this.elemRef.nativeElement.getBoundingClientRect();
130
- }
131
- on(eventName, callback, debounceInterval) {
132
- const listener = this.eventListenerHelper.attachEventListener(this.elemRef.nativeElement, eventName, callback, debounceInterval);
133
- this.eventListeners.push(listener);
134
- }
135
- onPassive(eventName, callback, debounceInterval) {
136
- const listener = this.eventListenerHelper.attachPassiveEventListener(this.elemRef.nativeElement, eventName, callback, debounceInterval);
137
- this.eventListeners.push(listener);
138
- }
139
- off(eventName) {
140
- let listenersToKeep;
141
- let listenersToRemove;
142
- if (!ValueHelper.isNullOrUndefined(eventName)) {
143
- listenersToKeep = this.eventListeners.filter((event) => event.eventName !== eventName);
144
- listenersToRemove = this.eventListeners.filter((event) => event.eventName === eventName);
145
- }
146
- else {
147
- listenersToKeep = [];
148
- listenersToRemove = this.eventListeners;
149
- }
150
- for (const listener of listenersToRemove) {
151
- this.eventListenerHelper.detachEventListener(listener);
152
- }
153
- this.eventListeners = listenersToKeep;
154
- }
155
- isRefDestroyed() {
156
- return (ValueHelper.isNullOrUndefined(this.changeDetectionRef) || this.changeDetectionRef['destroyed']);
157
- }
158
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderElementDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
159
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: SliderElementDirective, isStandalone: true, selector: "[ngxSliderElement]", host: { properties: { "style.opacity": "this.opacity", "style.visibility": "this.visibility", "style.left": "this.left", "style.bottom": "this.bottom", "style.height": "this.height", "style.width": "this.width", "style.transform": "this.transform" } }, ngImport: i0 }); }
160
- }
161
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderElementDirective, decorators: [{
162
- type: Directive,
163
- args: [{
164
- // eslint-disable-next-line @angular-eslint/directive-selector
165
- selector: '[ngxSliderElement]',
166
- standalone: true
167
- }]
168
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], propDecorators: { opacity: [{
169
- type: HostBinding,
170
- args: ['style.opacity']
171
- }], visibility: [{
172
- type: HostBinding,
173
- args: ['style.visibility']
174
- }], left: [{
175
- type: HostBinding,
176
- args: ['style.left']
177
- }], bottom: [{
178
- type: HostBinding,
179
- args: ['style.bottom']
180
- }], height: [{
181
- type: HostBinding,
182
- args: ['style.height']
183
- }], width: [{
184
- type: HostBinding,
185
- args: ['style.width']
186
- }], transform: [{
187
- type: HostBinding,
188
- args: ['style.transform']
189
- }] } });
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-element.directive.js","sourceRoot":"","sources":["../../../../../../../projects/design-factory/src/lib/angular/slider/lib/slider-element.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAyB,WAAW,EAAqB,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;;AAE7C;;GAEG;AAMH,MAAM,OAAO,sBAAsB;IAEjC,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAGD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAGD,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAGD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAGD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAGD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IA0BD,YACY,OAAmB,EACnB,QAAmB,EACnB,kBAAqC;QAFrC,YAAO,GAAP,OAAO,CAAY;QACnB,aAAQ,GAAR,QAAQ,CAAW;QACnB,uBAAkB,GAAlB,kBAAkB,CAAmB;QAzDzC,cAAS,GAAW,CAAC,CAAC;QAKtB,eAAU,GAAW,CAAC,CAAC;QAKvB,gBAAW,GAAY,KAAK,CAAC;QAK7B,cAAS,GAAY,KAAK,CAAC;QAK3B,WAAM,GAAW,CAAC,CAAC;QAKnB,YAAO,GAAW,CAAC,CAAC;QAM5B,YAAO,GAAW,CAAC,CAAC;QAGpB,eAAU,GAAW,SAAS,CAAC;QAG/B,SAAI,GAAW,EAAE,CAAC;QAGlB,WAAM,GAAW,EAAE,CAAC;QAGpB,WAAM,GAAW,EAAE,CAAC;QAGpB,UAAK,GAAW,EAAE,CAAC;QAGnB,cAAS,GAAW,EAAE,CAAC;QAGf,mBAAc,GAAoB,EAAE,CAAC;QAO3C,IAAI,CAAC,mBAAmB,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACpE,CAAC;IAED,aAAa,CAAC,IAAa;QACzB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,IAAI;QACF,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,SAAS;QACP,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,WAAW,CAAC,QAAiB;QAC3B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAClB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACnB,CAAC;IACH,CAAC;IAED,QAAQ,CAAC,KAAa;QACpB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,SAAS,CAAC,MAAc;QACtB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,SAAS,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,CAAC;IAC/C,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,sFAAsF;IACtF,WAAW,CAAC,GAAW;QACrB,IAAI,IAAI,CAAC,SAAS,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YACrD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QACzC,CAAC;QAED,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACrB,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACvC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACrC,CAAC;IACH,CAAC;IAED,yFAAyF;IACzF,kBAAkB;QAChB,MAAM,GAAG,GAAe,IAAI,CAAC,qBAAqB,EAAE,CAAC;QACrD,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG,CAAC,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QACxD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QACxD,CAAC;IACH,CAAC;IAED,iFAAiF;IACjF,YAAY,CAAC,GAAW;QACtB,IAAI,IAAI,CAAC,UAAU,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YACtD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QACzC,CAAC;QAED,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QACtB,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACvC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACtC,CAAC;IACH,CAAC;IAED,qBAAqB;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;IAC5D,CAAC;IAED,EAAE,CAAC,SAAiB,EAAE,QAA8B,EAAE,gBAAyB;QAC7E,MAAM,QAAQ,GAAkB,IAAI,CAAC,mBAAmB,CAAC,mBAAmB,CAC1E,IAAI,CAAC,OAAO,CAAC,aAAa,EAC1B,SAAS,EACT,QAAQ,EACR,gBAAgB,CACjB,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED,SAAS,CAAC,SAAiB,EAAE,QAA8B,EAAE,gBAAyB;QACpF,MAAM,QAAQ,GAAkB,IAAI,CAAC,mBAAmB,CAAC,0BAA0B,CACjF,IAAI,CAAC,OAAO,CAAC,aAAa,EAC1B,SAAS,EACT,QAAQ,EACR,gBAAgB,CACjB,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED,GAAG,CAAC,SAAkB;QACpB,IAAI,eAAgC,CAAC;QACrC,IAAI,iBAAkC,CAAC;QACvC,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,SAAS,CAAC,EAAE,CAAC;YAC9C,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,KAAoB,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;YACtG,iBAAiB,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,KAAoB,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;QAC1G,CAAC;aAAM,CAAC;YACN,eAAe,GAAG,EAAE,CAAC;YACrB,iBAAiB,GAAG,IAAI,CAAC,cAAc,CAAC;QAC1C,CAAC;QAED,KAAK,MAAM,QAAQ,IAAI,iBAAiB,EAAE,CAAC;YACzC,IAAI,CAAC,mBAAmB,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QACzD,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,eAAe,CAAC;IACxC,CAAC;IAEO,cAAc;QACpB,OAAO,CACL,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAK,IAAI,CAAC,kBAAqC,CAAC,WAAW,CAAC,CACnH,CAAC;IACJ,CAAC;8GAvMU,sBAAsB;kGAAtB,sBAAsB;;2FAAtB,sBAAsB;kBALlC,SAAS;mBAAC;oBACT,8DAA8D;oBAC9D,QAAQ,EAAE,oBAAoB;oBAC9B,UAAU,EAAE,IAAI;iBACjB;uIAiCC,OAAO;sBADN,WAAW;uBAAC,eAAe;gBAI5B,UAAU;sBADT,WAAW;uBAAC,kBAAkB;gBAI/B,IAAI;sBADH,WAAW;uBAAC,YAAY;gBAIzB,MAAM;sBADL,WAAW;uBAAC,cAAc;gBAI3B,MAAM;sBADL,WAAW;uBAAC,cAAc;gBAI3B,KAAK;sBADJ,WAAW;uBAAC,aAAa;gBAI1B,SAAS;sBADR,WAAW;uBAAC,iBAAiB","sourcesContent":["import { Directive, ElementRef, Renderer2, HostBinding, ChangeDetectorRef } from '@angular/core';\nimport { EventListenerHelper } from './event-listener-helper';\nimport { EventListener } from './event-listener';\nimport { ValueHelper } from './value-helper';\n\n/**\n * @deprecated SliderElementDirective is deprecated. Use {@link https://design-factory-int.app.net6.paas.westeurope.rnd.az.amadeus.net/#/components/slider/agnosui  AgnosUI Slider} instead.\n */\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: '[ngxSliderElement]',\n  standalone: true\n})\nexport class SliderElementDirective {\n  private _position: number = 0;\n  get position(): number {\n    return this._position;\n  }\n\n  private _dimension: number = 0;\n  get dimension(): number {\n    return this._dimension;\n  }\n\n  private _alwaysHide: boolean = false;\n  get alwaysHide(): boolean {\n    return this._alwaysHide;\n  }\n\n  private _vertical: boolean = false;\n  get vertical(): boolean {\n    return this._vertical;\n  }\n\n  private _scale: number = 1;\n  get scale(): number {\n    return this._scale;\n  }\n\n  private _rotate: number = 0;\n  get rotate(): number {\n    return this._rotate;\n  }\n\n  @HostBinding('style.opacity')\n  opacity: number = 1;\n\n  @HostBinding('style.visibility')\n  visibility: string = 'visible';\n\n  @HostBinding('style.left')\n  left: string = '';\n\n  @HostBinding('style.bottom')\n  bottom: string = '';\n\n  @HostBinding('style.height')\n  height: string = '';\n\n  @HostBinding('style.width')\n  width: string = '';\n\n  @HostBinding('style.transform')\n  transform: string = '';\n\n  private eventListenerHelper: EventListenerHelper;\n  private eventListeners: EventListener[] = [];\n\n  constructor(\n    protected elemRef: ElementRef,\n    protected renderer: Renderer2,\n    protected changeDetectionRef: ChangeDetectorRef\n  ) {\n    this.eventListenerHelper = new EventListenerHelper(this.renderer);\n  }\n\n  setAlwaysHide(hide: boolean): void {\n    this._alwaysHide = hide;\n    if (hide) {\n      this.visibility = 'hidden';\n    } else {\n      this.visibility = 'visible';\n    }\n  }\n\n  hide(): void {\n    this.opacity = 0;\n  }\n\n  show(): void {\n    if (this.alwaysHide) {\n      return;\n    }\n\n    this.opacity = 1;\n  }\n\n  isVisible(): boolean {\n    if (this.alwaysHide) {\n      return false;\n    }\n    return this.opacity !== 0;\n  }\n\n  setVertical(vertical: boolean): void {\n    this._vertical = vertical;\n    if (this._vertical) {\n      this.left = '';\n      this.width = '';\n    } else {\n      this.bottom = '';\n      this.height = '';\n    }\n  }\n\n  setScale(scale: number): void {\n    this._scale = scale;\n  }\n\n  setRotate(rotate: number): void {\n    this._rotate = rotate;\n    this.transform = 'rotate(' + rotate + 'deg)';\n  }\n\n  getRotate(): number {\n    return this._rotate;\n  }\n\n  // Set element left/top position depending on whether slider is horizontal or vertical\n  setPosition(pos: number): void {\n    if (this._position !== pos && !this.isRefDestroyed()) {\n      this.changeDetectionRef.markForCheck();\n    }\n\n    this._position = pos;\n    if (this._vertical) {\n      this.bottom = Math.round(pos) + 'px';\n    } else {\n      this.left = Math.round(pos) + 'px';\n    }\n  }\n\n  // Calculate element's width/height depending on whether slider is horizontal or vertical\n  calculateDimension(): void {\n    const val: ClientRect = this.getBoundingClientRect();\n    if (this.vertical) {\n      this._dimension = (val.bottom - val.top) * this.scale;\n    } else {\n      this._dimension = (val.right - val.left) * this.scale;\n    }\n  }\n\n  // Set element width/height depending on whether slider is horizontal or vertical\n  setDimension(dim: number): void {\n    if (this._dimension !== dim && !this.isRefDestroyed()) {\n      this.changeDetectionRef.markForCheck();\n    }\n\n    this._dimension = dim;\n    if (this._vertical) {\n      this.height = Math.round(dim) + 'px';\n    } else {\n      this.width = Math.round(dim) + 'px';\n    }\n  }\n\n  getBoundingClientRect(): ClientRect {\n    return this.elemRef.nativeElement.getBoundingClientRect();\n  }\n\n  on(eventName: string, callback: (event: any) => void, debounceInterval?: number): void {\n    const listener: EventListener = this.eventListenerHelper.attachEventListener(\n      this.elemRef.nativeElement,\n      eventName,\n      callback,\n      debounceInterval\n    );\n    this.eventListeners.push(listener);\n  }\n\n  onPassive(eventName: string, callback: (event: any) => void, debounceInterval?: number): void {\n    const listener: EventListener = this.eventListenerHelper.attachPassiveEventListener(\n      this.elemRef.nativeElement,\n      eventName,\n      callback,\n      debounceInterval\n    );\n    this.eventListeners.push(listener);\n  }\n\n  off(eventName?: string): void {\n    let listenersToKeep: EventListener[];\n    let listenersToRemove: EventListener[];\n    if (!ValueHelper.isNullOrUndefined(eventName)) {\n      listenersToKeep = this.eventListeners.filter((event: EventListener) => event.eventName !== eventName);\n      listenersToRemove = this.eventListeners.filter((event: EventListener) => event.eventName === eventName);\n    } else {\n      listenersToKeep = [];\n      listenersToRemove = this.eventListeners;\n    }\n\n    for (const listener of listenersToRemove) {\n      this.eventListenerHelper.detachEventListener(listener);\n    }\n\n    this.eventListeners = listenersToKeep;\n  }\n\n  private isRefDestroyed(): boolean {\n    return (\n      ValueHelper.isNullOrUndefined(this.changeDetectionRef) || (this.changeDetectionRef as unknown as any)['destroyed']\n    );\n  }\n}\n"]}
@@ -1,65 +0,0 @@
1
- import { Directive, HostBinding } from '@angular/core';
2
- import { SliderElementDirective } from './slider-element.directive';
3
- import * as i0 from "@angular/core";
4
- /**
5
- * @deprecated SliderHandleDirective is deprecated. Use {@link https://design-factory-int.app.net6.paas.westeurope.rnd.az.amadeus.net/#/components/slider/agnosui AgnosUI Slider} instead.
6
- */
7
- export class SliderHandleDirective extends SliderElementDirective {
8
- constructor(elemRef, renderer, changeDetectionRef) {
9
- super(elemRef, renderer, changeDetectionRef);
10
- this.active = false;
11
- this.role = '';
12
- this.tabindex = '';
13
- this.ariaOrientation = '';
14
- this.ariaLabel = '';
15
- this.ariaLabelledBy = '';
16
- this.ariaValueNow = '';
17
- this.ariaValueText = '';
18
- this.ariaValueMin = '';
19
- this.ariaValueMax = '';
20
- }
21
- focus() {
22
- this.elemRef.nativeElement.focus();
23
- }
24
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderHandleDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
25
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: SliderHandleDirective, isStandalone: true, selector: "[ngxSliderHandle]", host: { properties: { "class.ngx-slider-active": "this.active", "attr.role": "this.role", "attr.tabindex": "this.tabindex", "attr.aria-orientation": "this.ariaOrientation", "attr.aria-label": "this.ariaLabel", "attr.aria-labelledby": "this.ariaLabelledBy", "attr.aria-valuenow": "this.ariaValueNow", "attr.aria-valuetext": "this.ariaValueText", "attr.aria-valuemin": "this.ariaValueMin", "attr.aria-valuemax": "this.ariaValueMax" } }, usesInheritance: true, ngImport: i0 }); }
26
- }
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderHandleDirective, decorators: [{
28
- type: Directive,
29
- args: [{
30
- // eslint-disable-next-line @angular-eslint/directive-selector
31
- selector: '[ngxSliderHandle]',
32
- standalone: true
33
- }]
34
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], propDecorators: { active: [{
35
- type: HostBinding,
36
- args: ['class.ngx-slider-active']
37
- }], role: [{
38
- type: HostBinding,
39
- args: ['attr.role']
40
- }], tabindex: [{
41
- type: HostBinding,
42
- args: ['attr.tabindex']
43
- }], ariaOrientation: [{
44
- type: HostBinding,
45
- args: ['attr.aria-orientation']
46
- }], ariaLabel: [{
47
- type: HostBinding,
48
- args: ['attr.aria-label']
49
- }], ariaLabelledBy: [{
50
- type: HostBinding,
51
- args: ['attr.aria-labelledby']
52
- }], ariaValueNow: [{
53
- type: HostBinding,
54
- args: ['attr.aria-valuenow']
55
- }], ariaValueText: [{
56
- type: HostBinding,
57
- args: ['attr.aria-valuetext']
58
- }], ariaValueMin: [{
59
- type: HostBinding,
60
- args: ['attr.aria-valuemin']
61
- }], ariaValueMax: [{
62
- type: HostBinding,
63
- args: ['attr.aria-valuemax']
64
- }] } });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLWhhbmRsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tZmFjdG9yeS9zcmMvbGliL2FuZ3VsYXIvc2xpZGVyL2xpYi9zbGlkZXItaGFuZGxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUF5QixXQUFXLEVBQXFCLE1BQU0sZUFBZSxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQUVwRTs7R0FFRztBQU1ILE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxzQkFBc0I7SUErQi9ELFlBQVksT0FBbUIsRUFBRSxRQUFtQixFQUFFLGtCQUFxQztRQUN6RixLQUFLLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO1FBOUIvQyxXQUFNLEdBQVksS0FBSyxDQUFDO1FBR3hCLFNBQUksR0FBVyxFQUFFLENBQUM7UUFHbEIsYUFBUSxHQUFXLEVBQUUsQ0FBQztRQUd0QixvQkFBZSxHQUFXLEVBQUUsQ0FBQztRQUc3QixjQUFTLEdBQVcsRUFBRSxDQUFDO1FBR3ZCLG1CQUFjLEdBQVcsRUFBRSxDQUFDO1FBRzVCLGlCQUFZLEdBQVcsRUFBRSxDQUFDO1FBRzFCLGtCQUFhLEdBQVcsRUFBRSxDQUFDO1FBRzNCLGlCQUFZLEdBQVcsRUFBRSxDQUFDO1FBRzFCLGlCQUFZLEdBQVcsRUFBRSxDQUFDO0lBSTFCLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckMsQ0FBQzs4R0FyQ1UscUJBQXFCO2tHQUFyQixxQkFBcUI7OzJGQUFyQixxQkFBcUI7a0JBTGpDLFNBQVM7bUJBQUM7b0JBQ1QsOERBQThEO29CQUM5RCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7dUlBR0MsTUFBTTtzQkFETCxXQUFXO3VCQUFDLHlCQUF5QjtnQkFJdEMsSUFBSTtzQkFESCxXQUFXO3VCQUFDLFdBQVc7Z0JBSXhCLFFBQVE7c0JBRFAsV0FBVzt1QkFBQyxlQUFlO2dCQUk1QixlQUFlO3NCQURkLFdBQVc7dUJBQUMsdUJBQXVCO2dCQUlwQyxTQUFTO3NCQURSLFdBQVc7dUJBQUMsaUJBQWlCO2dCQUk5QixjQUFjO3NCQURiLFdBQVc7dUJBQUMsc0JBQXNCO2dCQUluQyxZQUFZO3NCQURYLFdBQVc7dUJBQUMsb0JBQW9CO2dCQUlqQyxhQUFhO3NCQURaLFdBQVc7dUJBQUMscUJBQXFCO2dCQUlsQyxZQUFZO3NCQURYLFdBQVc7dUJBQUMsb0JBQW9CO2dCQUlqQyxZQUFZO3NCQURYLFdBQVc7dUJBQUMsb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBSZW5kZXJlcjIsIEhvc3RCaW5kaW5nLCBDaGFuZ2VEZXRlY3RvclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2xpZGVyRWxlbWVudERpcmVjdGl2ZSB9IGZyb20gJy4vc2xpZGVyLWVsZW1lbnQuZGlyZWN0aXZlJztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBTbGlkZXJIYW5kbGVEaXJlY3RpdmUgaXMgZGVwcmVjYXRlZC4gVXNlIHtAbGluayBodHRwczovL2Rlc2lnbi1mYWN0b3J5LWludC5hcHAubmV0Ni5wYWFzLndlc3RldXJvcGUucm5kLmF6LmFtYWRldXMubmV0LyMvY29tcG9uZW50cy9zbGlkZXIvYWdub3N1aSAgQWdub3NVSSBTbGlkZXJ9IGluc3RlYWQuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2RpcmVjdGl2ZS1zZWxlY3RvclxuICBzZWxlY3RvcjogJ1tuZ3hTbGlkZXJIYW5kbGVdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBTbGlkZXJIYW5kbGVEaXJlY3RpdmUgZXh0ZW5kcyBTbGlkZXJFbGVtZW50RGlyZWN0aXZlIHtcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5uZ3gtc2xpZGVyLWFjdGl2ZScpXG4gIGFjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIEBIb3N0QmluZGluZygnYXR0ci5yb2xlJylcbiAgcm9sZTogc3RyaW5nID0gJyc7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLnRhYmluZGV4JylcbiAgdGFiaW5kZXg6IHN0cmluZyA9ICcnO1xuXG4gIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLW9yaWVudGF0aW9uJylcbiAgYXJpYU9yaWVudGF0aW9uOiBzdHJpbmcgPSAnJztcblxuICBASG9zdEJpbmRpbmcoJ2F0dHIuYXJpYS1sYWJlbCcpXG4gIGFyaWFMYWJlbDogc3RyaW5nID0gJyc7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtbGFiZWxsZWRieScpXG4gIGFyaWFMYWJlbGxlZEJ5OiBzdHJpbmcgPSAnJztcblxuICBASG9zdEJpbmRpbmcoJ2F0dHIuYXJpYS12YWx1ZW5vdycpXG4gIGFyaWFWYWx1ZU5vdzogc3RyaW5nID0gJyc7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtdmFsdWV0ZXh0JylcbiAgYXJpYVZhbHVlVGV4dDogc3RyaW5nID0gJyc7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtdmFsdWVtaW4nKVxuICBhcmlhVmFsdWVNaW46IHN0cmluZyA9ICcnO1xuXG4gIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLXZhbHVlbWF4JylcbiAgYXJpYVZhbHVlTWF4OiBzdHJpbmcgPSAnJztcblxuICBjb25zdHJ1Y3RvcihlbGVtUmVmOiBFbGVtZW50UmVmLCByZW5kZXJlcjogUmVuZGVyZXIyLCBjaGFuZ2VEZXRlY3Rpb25SZWY6IENoYW5nZURldGVjdG9yUmVmKSB7XG4gICAgc3VwZXIoZWxlbVJlZiwgcmVuZGVyZXIsIGNoYW5nZURldGVjdGlvblJlZik7XG4gIH1cblxuICBmb2N1cygpOiB2b2lkIHtcbiAgICB0aGlzLmVsZW1SZWYubmF0aXZlRWxlbWVudC5mb2N1cygpO1xuICB9XG59XG4iXX0=
@@ -1,41 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { SliderElementDirective } from './slider-element.directive';
3
- import { ValueHelper } from './value-helper';
4
- import * as i0 from "@angular/core";
5
- /**
6
- * @deprecated SliderLabelDirective is deprecated. Use {@link https://design-factory-int.app.net6.paas.westeurope.rnd.az.amadeus.net/#/components/slider/agnosui AgnosUI Slider} instead.
7
- */
8
- export class SliderLabelDirective extends SliderElementDirective {
9
- get value() {
10
- return this._value || '';
11
- }
12
- constructor(elemRef, renderer, changeDetectionRef) {
13
- super(elemRef, renderer, changeDetectionRef);
14
- }
15
- setValue(value) {
16
- let recalculateDimension = false;
17
- if (!this.alwaysHide &&
18
- (ValueHelper.isNullOrUndefined(this.value) ||
19
- this.value.length !== value.length ||
20
- (this.value.length > 0 && this.dimension === 0))) {
21
- recalculateDimension = true;
22
- }
23
- this._value = value;
24
- this.elemRef.nativeElement.innerHTML = value;
25
- // Update dimension only when length of the label have changed
26
- if (recalculateDimension) {
27
- this.calculateDimension();
28
- }
29
- }
30
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderLabelDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
31
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: SliderLabelDirective, isStandalone: true, selector: "[ngxSliderLabel]", usesInheritance: true, ngImport: i0 }); }
32
- }
33
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderLabelDirective, decorators: [{
34
- type: Directive,
35
- args: [{
36
- // eslint-disable-next-line @angular-eslint/directive-selector
37
- selector: '[ngxSliderLabel]',
38
- standalone: true
39
- }]
40
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }] });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLWxhYmVsLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1mYWN0b3J5L3NyYy9saWIvYW5ndWxhci9zbGlkZXIvbGliL3NsaWRlci1sYWJlbC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixTQUFTLEVBQXlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFFN0M7O0dBRUc7QUFNSCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsc0JBQXNCO0lBRTlELElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFlBQVksT0FBbUIsRUFBRSxRQUFtQixFQUFFLGtCQUFxQztRQUN6RixLQUFLLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRCxRQUFRLENBQUMsS0FBYTtRQUNwQixJQUFJLG9CQUFvQixHQUFZLEtBQUssQ0FBQztRQUUxQyxJQUNFLENBQUMsSUFBSSxDQUFDLFVBQVU7WUFDaEIsQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQztnQkFDeEMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssS0FBSyxDQUFDLE1BQU07Z0JBQ2xDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxJQUFJLElBQUksQ0FBQyxTQUFTLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFDbEQsQ0FBQztZQUNELG9CQUFvQixHQUFHLElBQUksQ0FBQztRQUM5QixDQUFDO1FBRUQsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUU3Qyw4REFBOEQ7UUFDOUQsSUFBSSxvQkFBb0IsRUFBRSxDQUFDO1lBQ3pCLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQzVCLENBQUM7SUFDSCxDQUFDOzhHQTdCVSxvQkFBb0I7a0dBQXBCLG9CQUFvQjs7MkZBQXBCLG9CQUFvQjtrQkFMaEMsU0FBUzttQkFBQztvQkFDVCw4REFBOEQ7b0JBQzlELFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2xpZGVyRWxlbWVudERpcmVjdGl2ZSB9IGZyb20gJy4vc2xpZGVyLWVsZW1lbnQuZGlyZWN0aXZlJztcbmltcG9ydCB7IFZhbHVlSGVscGVyIH0gZnJvbSAnLi92YWx1ZS1oZWxwZXInO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIFNsaWRlckxhYmVsRGlyZWN0aXZlIGlzIGRlcHJlY2F0ZWQuIFVzZSB7QGxpbmsgaHR0cHM6Ly9kZXNpZ24tZmFjdG9yeS1pbnQuYXBwLm5ldDYucGFhcy53ZXN0ZXVyb3BlLnJuZC5hei5hbWFkZXVzLm5ldC8jL2NvbXBvbmVudHMvc2xpZGVyL2Fnbm9zdWkgIEFnbm9zVUkgU2xpZGVyfSBpbnN0ZWFkLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9kaXJlY3RpdmUtc2VsZWN0b3JcbiAgc2VsZWN0b3I6ICdbbmd4U2xpZGVyTGFiZWxdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBTbGlkZXJMYWJlbERpcmVjdGl2ZSBleHRlbmRzIFNsaWRlckVsZW1lbnREaXJlY3RpdmUge1xuICBwcml2YXRlIF92YWx1ZT86IHN0cmluZztcbiAgZ2V0IHZhbHVlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3ZhbHVlIHx8ICcnO1xuICB9XG5cbiAgY29uc3RydWN0b3IoZWxlbVJlZjogRWxlbWVudFJlZiwgcmVuZGVyZXI6IFJlbmRlcmVyMiwgY2hhbmdlRGV0ZWN0aW9uUmVmOiBDaGFuZ2VEZXRlY3RvclJlZikge1xuICAgIHN1cGVyKGVsZW1SZWYsIHJlbmRlcmVyLCBjaGFuZ2VEZXRlY3Rpb25SZWYpO1xuICB9XG5cbiAgc2V0VmFsdWUodmFsdWU6IHN0cmluZyk6IHZvaWQge1xuICAgIGxldCByZWNhbGN1bGF0ZURpbWVuc2lvbjogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgaWYgKFxuICAgICAgIXRoaXMuYWx3YXlzSGlkZSAmJlxuICAgICAgKFZhbHVlSGVscGVyLmlzTnVsbE9yVW5kZWZpbmVkKHRoaXMudmFsdWUpIHx8XG4gICAgICAgIHRoaXMudmFsdWUubGVuZ3RoICE9PSB2YWx1ZS5sZW5ndGggfHxcbiAgICAgICAgKHRoaXMudmFsdWUubGVuZ3RoID4gMCAmJiB0aGlzLmRpbWVuc2lvbiA9PT0gMCkpXG4gICAgKSB7XG4gICAgICByZWNhbGN1bGF0ZURpbWVuc2lvbiA9IHRydWU7XG4gICAgfVxuXG4gICAgdGhpcy5fdmFsdWUgPSB2YWx1ZTtcbiAgICB0aGlzLmVsZW1SZWYubmF0aXZlRWxlbWVudC5pbm5lckhUTUwgPSB2YWx1ZTtcblxuICAgIC8vIFVwZGF0ZSBkaW1lbnNpb24gb25seSB3aGVuIGxlbmd0aCBvZiB0aGUgbGFiZWwgaGF2ZSBjaGFuZ2VkXG4gICAgaWYgKHJlY2FsY3VsYXRlRGltZW5zaW9uKSB7XG4gICAgICB0aGlzLmNhbGN1bGF0ZURpbWVuc2lvbigpO1xuICAgIH1cbiAgfVxufVxuIl19