@design-factory/design-factory 15.2.3 → 16.0.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 (205) hide show
  1. package/README.md +17 -1
  2. package/assets/fonts/amadeus-neue/bold/AmadeusNeue-Bold.ttf +0 -0
  3. package/assets/fonts/amadeus-neue/bold/AmadeusNeue-Bold.woff +0 -0
  4. package/assets/fonts/amadeus-neue/bold/AmadeusNeue-Bold.woff2 +0 -0
  5. package/assets/fonts/amadeus-neue/bold/AmadeusNeue-BoldItalic.ttf +0 -0
  6. package/assets/fonts/amadeus-neue/bold/AmadeusNeue-BoldItalic.woff +0 -0
  7. package/assets/fonts/amadeus-neue/bold/AmadeusNeue-BoldItalic.woff2 +0 -0
  8. package/assets/fonts/amadeus-neue/light/AmadeusNeue-Light.ttf +0 -0
  9. package/assets/fonts/amadeus-neue/light/AmadeusNeue-Light.woff +0 -0
  10. package/assets/fonts/amadeus-neue/light/AmadeusNeue-Light.woff2 +0 -0
  11. package/assets/fonts/amadeus-neue/light/AmadeusNeue-LightItalic.ttf +0 -0
  12. package/assets/fonts/amadeus-neue/light/AmadeusNeue-LightItalic.woff +0 -0
  13. package/assets/fonts/amadeus-neue/light/AmadeusNeue-LightItalic.woff2 +0 -0
  14. package/assets/fonts/amadeus-neue/medium/AmadeusNeue-Medium.ttf +0 -0
  15. package/assets/fonts/amadeus-neue/medium/AmadeusNeue-Medium.woff +0 -0
  16. package/assets/fonts/amadeus-neue/medium/AmadeusNeue-Medium.woff2 +0 -0
  17. package/assets/fonts/amadeus-neue/medium/AmadeusNeue-MediumItalic.ttf +0 -0
  18. package/assets/fonts/amadeus-neue/medium/AmadeusNeue-MediumItalic.woff +0 -0
  19. package/assets/fonts/amadeus-neue/medium/AmadeusNeue-MediumItalic.woff2 +0 -0
  20. package/assets/fonts/amadeus-neue/regular/AmadeusNeue-Regular.ttf +0 -0
  21. package/assets/fonts/amadeus-neue/regular/AmadeusNeue-Regular.woff +0 -0
  22. package/assets/fonts/amadeus-neue/regular/AmadeusNeue-Regular.woff2 +0 -0
  23. package/assets/fonts/amadeus-neue/regular/AmadeusNeue-RegularItalic.ttf +0 -0
  24. package/assets/fonts/amadeus-neue/regular/AmadeusNeue-RegularItalic.woff +0 -0
  25. package/assets/fonts/amadeus-neue/regular/AmadeusNeue-RegularItalic.woff2 +0 -0
  26. package/design-factory-initial-branding.css +1 -0
  27. package/design-factory-initial-branding.scss +1 -0
  28. package/design-factory.css +1 -3
  29. package/design-factory.scss +1 -0
  30. package/esm2022/lib/angular/accessibility/components/skip-links-container/skip-links-container.component.mjs +3 -3
  31. package/esm2022/lib/angular/df.module.mjs +102 -0
  32. package/esm2022/lib/angular/icon/amadeus-icon.mjs +2 -2
  33. package/esm2022/lib/angular/sidenav/sidenavlist.component.mjs +3 -12
  34. package/esm2022/lib/angular/stepper/stepper.component.mjs +65 -0
  35. package/esm2022/lib/angular/stepper/stepper.directive.mjs +174 -0
  36. package/esm2022/lib/angular/stepper/stepper.module.mjs +17 -0
  37. package/esm2022/lib/angular/stepper/stepper.service.mjs +213 -0
  38. package/esm2022/lib/angular/tooltip/truncate/tooltipTruncate.directive.mjs +5 -3
  39. package/esm2022/lib/index.mjs +9 -96
  40. package/fesm2022/design-factory.mjs +1838 -1427
  41. package/fesm2022/design-factory.mjs.map +1 -1
  42. package/lib/angular/df.module.d.ts +26 -0
  43. package/lib/angular/stepper/stepper.component.d.ts +31 -0
  44. package/lib/angular/stepper/stepper.directive.d.ts +37 -0
  45. package/lib/angular/stepper/stepper.module.d.ts +8 -0
  46. package/lib/angular/stepper/stepper.service.d.ts +126 -0
  47. package/lib/angular/tooltip/truncate/tooltipTruncate.directive.d.ts +1 -0
  48. package/lib/index.d.ts +7 -23
  49. package/package.json +23 -4
  50. package/schematics/migrations/15_0_0/remove-ngx-slider/index.js +0 -1
  51. package/schematics/migrations/16_0_0/navbar-logo-dark/index.d.ts +9 -0
  52. package/schematics/migrations/16_0_0/navbar-logo-dark/index.js +43 -0
  53. package/schematics/migrations/16_0_0/revert-to-old-brand/index.d.ts +7 -0
  54. package/schematics/migrations/16_0_0/revert-to-old-brand/index.js +115 -0
  55. package/schematics/migrations/16_0_0/scss-var/files/removed.json +55 -0
  56. package/schematics/migrations/16_0_0/scss-var/files/renames.json +76 -0
  57. package/schematics/migrations/16_0_0/scss-var/index.d.ts +7 -0
  58. package/schematics/migrations/16_0_0/scss-var/index.js +57 -0
  59. package/schematics/migrations/16_0_0/stepper-classes/index.d.ts +13 -0
  60. package/schematics/migrations/16_0_0/stepper-classes/index.js +63 -0
  61. package/schematics/migrations/helpers.js +0 -1
  62. package/schematics/migrations/migration.json +23 -1
  63. package/schematics/migrations/utils/component-resource-collector.d.ts +44 -0
  64. package/schematics/migrations/utils/component-resource-collector.js +166 -0
  65. package/schematics/migrations/utils/project_tsconfig_paths.js +0 -1
  66. package/schematics/migrations/utils/style-updater.d.ts +9 -0
  67. package/schematics/migrations/utils/style-updater.js +38 -0
  68. package/schematics/migrations/utils/template-updater.d.ts +9 -0
  69. package/schematics/migrations/utils/template-updater.js +38 -0
  70. package/schematics/migrations/utils/typescript/compiler_host.js +0 -1
  71. package/schematics/migrations/utils/typescript/decorators.d.ts +22 -0
  72. package/schematics/migrations/utils/typescript/decorators.js +41 -0
  73. package/schematics/migrations/utils/typescript/functions.d.ts +14 -0
  74. package/schematics/migrations/utils/typescript/functions.js +20 -0
  75. package/schematics/migrations/utils/typescript/imports.d.ts +17 -0
  76. package/schematics/migrations/utils/typescript/imports.js +110 -0
  77. package/schematics/migrations/utils/typescript/line-mappings.d.ts +21 -0
  78. package/schematics/migrations/utils/typescript/line-mappings.js +75 -0
  79. package/schematics/migrations/utils/typescript/parse_tsconfig.js +0 -1
  80. package/schematics/migrations/utils/typescript/property-name.d.ts +18 -0
  81. package/schematics/migrations/utils/typescript/property-name.js +27 -0
  82. package/schematics/ng-add/index.js +0 -1
  83. package/schematics/ng-add/schema.js +0 -1
  84. package/styles/scss/_common.root.scss +37 -0
  85. package/styles/scss/_common.scss +3 -9
  86. package/styles/scss/_common.variables.scss +16 -6
  87. package/styles/scss/_variables.scss +0 -1
  88. package/styles/scss/bootstrap/_maps.scss +10 -9
  89. package/styles/scss/bootstrap/_mixins-override.scss +26 -0
  90. package/styles/scss/bootstrap/_variables.scss +927 -267
  91. package/styles/scss/components/accordion/_accordion.scss +31 -14
  92. package/styles/scss/components/accordion/_accordion.variables.scss +5 -5
  93. package/styles/scss/components/alert/_alert.scss +130 -228
  94. package/styles/scss/components/alert/_alert.variables.scss +22 -33
  95. package/styles/scss/components/badge/_badge.scss +130 -118
  96. package/styles/scss/components/badge/_badge.variables.scss +14 -8
  97. package/styles/scss/components/brand-color/_brand-color.mixins.scss +19 -4
  98. package/styles/scss/components/brand-color/_brand-color.scss +4 -6
  99. package/styles/scss/components/brand-color/_brand-color.variables.scss +1 -7
  100. package/styles/scss/components/brand-color/_brand-color_container.scss +28 -0
  101. package/styles/scss/components/breadcrumbs/_breadcrumbs.scss +77 -65
  102. package/styles/scss/components/breadcrumbs/_breadcrumbs.variables.scss +6 -4
  103. package/styles/scss/components/button/_button.scss +120 -55
  104. package/styles/scss/components/button/_button.variables.scss +18 -4
  105. package/styles/scss/components/button/_button_container.scss +9 -45
  106. package/styles/scss/components/card/_card.scss +90 -58
  107. package/styles/scss/components/card/_card.variables.scss +13 -13
  108. package/styles/scss/components/carousel/_carousel.scss +22 -23
  109. package/styles/scss/components/carousel/_carousel.variables.scss +2 -1
  110. package/styles/scss/components/checkbox/_checkbox.scss +14 -8
  111. package/styles/scss/components/checkbox/_checkbox.variables.scss +2 -2
  112. package/styles/scss/components/collapse/_collapse.scss +15 -7
  113. package/styles/scss/components/collapse/_collapse.variables.scss +3 -3
  114. package/styles/scss/components/datepicker/_datepicker.scss +178 -122
  115. package/styles/scss/components/datepicker/_datepicker.variables.scss +22 -15
  116. package/styles/scss/components/dropdown/_dropdown.mixins.scss +4 -4
  117. package/styles/scss/components/dropdown/_dropdown.scss +39 -19
  118. package/styles/scss/components/dropdown/_dropdown.variables.scss +4 -4
  119. package/styles/scss/components/fieldset/_fieldset.scss +4 -2
  120. package/styles/scss/components/fonts/_fonts-family.scss +112 -29
  121. package/styles/scss/components/fonts/_fonts.root.scss +27 -0
  122. package/styles/scss/components/fonts/_fonts.scss +25 -26
  123. package/styles/scss/components/fonts/_fonts.variables.scss +2 -2
  124. package/styles/scss/components/footer/_footer.scss +48 -18
  125. package/styles/scss/components/footer/_footer.variables.scss +4 -2
  126. package/styles/scss/components/form/_form.scss +69 -16
  127. package/styles/scss/components/form/_form.variables.scss +23 -3
  128. package/styles/scss/components/icon/_amadeus-icon.scss +2 -2
  129. package/styles/scss/components/icon/_amadeus-icon.variables.scss +1 -0
  130. package/styles/scss/components/inputs/_inputs.mixin.scss +8 -4
  131. package/styles/scss/components/inputs/_inputs.root.scss +8 -0
  132. package/styles/scss/components/inputs/_inputs.scss +159 -118
  133. package/styles/scss/components/inputs/_inputs.variables.scss +2 -1
  134. package/styles/scss/components/link/_link.mixins.scss +49 -49
  135. package/styles/scss/components/link/_link.scss +84 -22
  136. package/styles/scss/components/link/_link.variables.scss +6 -6
  137. package/styles/scss/components/list/_list.scss +10 -5
  138. package/styles/scss/components/list-group/_list-group.scss +54 -48
  139. package/styles/scss/components/list-group/_list-group.variables.scss +6 -14
  140. package/styles/scss/components/media/_media.scss +17 -9
  141. package/styles/scss/components/media/_media.variables.scss +2 -1
  142. package/styles/scss/components/modal/_modal.scss +88 -39
  143. package/styles/scss/components/modal/_modal.variables.scss +4 -5
  144. package/styles/scss/components/navbar/_navbar.scss +298 -115
  145. package/styles/scss/components/navbar/_navbar.variables.scss +29 -18
  146. package/styles/scss/components/pagination/_pagination.scss +68 -82
  147. package/styles/scss/components/pagination/_pagination.variables.scss +5 -8
  148. package/styles/scss/components/pagination/_pagination_container.scss +3 -0
  149. package/styles/scss/components/popover/_popover.mixin.scss +20 -33
  150. package/styles/scss/components/popover/_popover.scss +25 -7
  151. package/styles/scss/components/popover/_popover_container.scss +123 -74
  152. package/styles/scss/components/progressbar/_progressbar.scss +15 -7
  153. package/styles/scss/components/progressbar/_progressbar.variables.scss +3 -2
  154. package/styles/scss/components/radio/_radio.scss +19 -14
  155. package/styles/scss/components/rating/_rating.scss +41 -22
  156. package/styles/scss/components/rating/_rating.variables.scss +5 -5
  157. package/styles/scss/components/scrollspy/_scrollspy.scss +30 -13
  158. package/styles/scss/components/scrollspy/_scrollspy.variables.scss +2 -1
  159. package/styles/scss/components/select/_select.scss +232 -166
  160. package/styles/scss/components/select/_select.variables.scss +15 -15
  161. package/styles/scss/components/separator/_separator.scss +2 -1
  162. package/styles/scss/components/sidenav/_sidenav.scss +208 -135
  163. package/styles/scss/components/sidenav/_sidenav.variables.scss +19 -20
  164. package/styles/scss/components/skip-links/_skip-links.scss +31 -16
  165. package/styles/scss/components/skip-links/_skip-links.variables.scss +6 -6
  166. package/styles/scss/components/slider/_slider.scss +11 -10
  167. package/styles/scss/components/slider/_slider.variables.scss +8 -8
  168. package/styles/scss/components/speechbubble/_speechbubble.scss +50 -30
  169. package/styles/scss/components/speechbubble/_speechbubble.variables.scss +4 -2
  170. package/styles/scss/components/spinner/_spinner.scss +34 -29
  171. package/styles/scss/components/stepper/_stepper.mixins.scss +111 -151
  172. package/styles/scss/components/stepper/_stepper.scss +163 -69
  173. package/styles/scss/components/stepper/_stepper.variables.scss +23 -17
  174. package/styles/scss/components/table/_advancedtables.scss +50 -31
  175. package/styles/scss/components/table/_table.variables.scss +3 -2
  176. package/styles/scss/components/tabs/_tabs.scss +98 -49
  177. package/styles/scss/components/tabs/_tabs.variables.scss +11 -10
  178. package/styles/scss/components/toast/_toast.scss +136 -68
  179. package/styles/scss/components/toast/_toast.variables.scss +4 -4
  180. package/styles/scss/components/toggle/_toggle.scss +90 -44
  181. package/styles/scss/components/toggle/_toggle.variables.scss +7 -5
  182. package/styles/scss/components/typeahead/_typeahead.scss +18 -8
  183. package/styles/scss/components/typeahead/_typeahead.variables.scss +1 -1
  184. package/styles/scss/df-styles-namespace.scss +8 -11
  185. package/styles/scss/df-styles.scss +6 -3
  186. package/styles/scss/themes/brand2023/_variables.scss +588 -0
  187. package/styles/scss/utilities/_common.utilities.scss +112 -32
  188. package/assets/fonts/amadeus-light/amadeus-light.svg +0 -8658
  189. package/assets/fonts/amadeus-light/amadeus-light.ttf +0 -0
  190. package/assets/fonts/amadeus-light/amadeus-light.woff +0 -0
  191. package/assets/fonts/amadeus-light/amadeus-light.woff2 +0 -0
  192. package/assets/icon-amadeus.svg +0 -1
  193. package/esm2022/lib/angular/utils/html-element-helper.mjs +0 -8
  194. package/esm2022/lib/angular/utils/titleTruncate.directive.mjs +0 -39
  195. package/lib/angular/utils/html-element-helper.d.ts +0 -5
  196. package/lib/angular/utils/titleTruncate.directive.d.ts +0 -16
  197. package/schematics/migrations/15_0_0/remove-ngx-slider/index.js.map +0 -1
  198. package/schematics/migrations/helpers.js.map +0 -1
  199. package/schematics/migrations/utils/project_tsconfig_paths.js.map +0 -1
  200. package/schematics/migrations/utils/typescript/compiler_host.js.map +0 -1
  201. package/schematics/migrations/utils/typescript/parse_tsconfig.js.map +0 -1
  202. package/schematics/ng-add/index.js.map +0 -1
  203. package/schematics/ng-add/schema.js.map +0 -1
  204. package/styles/scss/components/tooltip/_tooltip.scss +0 -3
  205. package/styles/scss/components/tooltip/_tooltip.variables.scss +0 -5
@@ -0,0 +1,174 @@
1
+ import { Directive, ElementRef, HostListener, Renderer2, inject } from '@angular/core';
2
+ import { DfDirectionDetectionService, RightToLeftDirectionEnum } from '../right-to-left/directionDetection.service';
3
+ import { DfStepperService } from './stepper.service';
4
+ import * as i0 from "@angular/core";
5
+ export const DF_STEP_CLASS = 'df-stepper-step';
6
+ export class DfStepperStepDirective {
7
+ constructor() {
8
+ this.unlistener = [];
9
+ this.renderer2 = inject(Renderer2);
10
+ this.element = inject(ElementRef);
11
+ }
12
+ ngOnInit() {
13
+ this.unlistener.push(this.renderer2.listen(this.element.nativeElement, 'focus', () => {
14
+ this.handleFocusTabIndex();
15
+ }));
16
+ this.unlistener.push(this.renderer2.listen(this.element.nativeElement, 'blur', (event) => {
17
+ this.handleBlurTabIndex(event);
18
+ }));
19
+ }
20
+ handleFocusTabIndex() {
21
+ this.element.nativeElement.tabIndex = 0;
22
+ }
23
+ handleBlurTabIndex(event) {
24
+ if (event.relatedTarget &&
25
+ 'classList' in event.relatedTarget &&
26
+ event.relatedTarget.classList.contains(DF_STEP_CLASS)) {
27
+ this.element.nativeElement.tabIndex = -1;
28
+ }
29
+ }
30
+ ngOnDestroy() {
31
+ this.unlistener.forEach((ul) => ul());
32
+ }
33
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperStepDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
34
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.4", type: DfStepperStepDirective, isStandalone: true, selector: "[dfStepperStep]", exportAs: ["dfStepperStep"], ngImport: i0 }); }
35
+ }
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperStepDirective, decorators: [{
37
+ type: Directive,
38
+ args: [{
39
+ selector: '[dfStepperStep]',
40
+ exportAs: 'dfStepperStep',
41
+ standalone: true
42
+ }]
43
+ }] });
44
+ export class DfStepperDirective {
45
+ constructor() {
46
+ this.stepperService = inject(DfStepperService);
47
+ this.element = inject(ElementRef);
48
+ this.rtlDirectionService = inject(DfDirectionDetectionService);
49
+ }
50
+ ngOnInit() {
51
+ this.direction = this.rtlDirectionService.getPageDirection(this.element);
52
+ }
53
+ handleEnterDown() {
54
+ this.handleSelect();
55
+ }
56
+ handleSpaceDown() {
57
+ this.handleSelect();
58
+ }
59
+ handleGoPrevious() {
60
+ if (this.direction === RightToLeftDirectionEnum.LeftToRight) {
61
+ this.arrowLeftInnerHandler();
62
+ }
63
+ else {
64
+ this.arrowRightInnerHandler();
65
+ }
66
+ }
67
+ handleGoNext() {
68
+ if (this.direction === RightToLeftDirectionEnum.LeftToRight) {
69
+ this.arrowRightInnerHandler();
70
+ }
71
+ else {
72
+ this.arrowLeftInnerHandler();
73
+ }
74
+ }
75
+ handleKeyDownRight(event) {
76
+ if (!this.stepperService.state.isVertical) {
77
+ this.handleGoNext();
78
+ event.preventDefault();
79
+ }
80
+ }
81
+ handleKeyDown(event) {
82
+ if (!this.stepperService.state.isVertical) {
83
+ this.handleGoPrevious();
84
+ event.preventDefault();
85
+ }
86
+ }
87
+ handleKeyDownUp(event) {
88
+ if (this.stepperService.state.isVertical) {
89
+ this.handleGoNext();
90
+ event.preventDefault();
91
+ }
92
+ }
93
+ handleKeyDownDown(event) {
94
+ if (this.stepperService.state.isVertical) {
95
+ this.handleGoPrevious();
96
+ event.preventDefault();
97
+ }
98
+ }
99
+ getSteps() {
100
+ return this.element.nativeElement.querySelectorAll(`:scope .${DF_STEP_CLASS}`);
101
+ }
102
+ handleSelect() {
103
+ const listStep = this.getSteps();
104
+ const currentPos = Array.prototype.indexOf.call(listStep, document.activeElement);
105
+ if (currentPos !== -1) {
106
+ listStep[currentPos].click();
107
+ }
108
+ }
109
+ arrowRightInnerHandler() {
110
+ const listStep = this.getSteps();
111
+ const currentPos = Array.prototype.indexOf.call(listStep, document.activeElement);
112
+ // Test if the focus is in the list (otherwise we do nothing)
113
+ if (currentPos !== -1) {
114
+ // we put the focus on the next element.
115
+ if (currentPos === listStep.length - 1) {
116
+ listStep[0].focus();
117
+ }
118
+ else {
119
+ listStep[currentPos + 1].focus();
120
+ }
121
+ }
122
+ }
123
+ arrowLeftInnerHandler() {
124
+ const listStep = this.getSteps();
125
+ const currentPos = Array.prototype.indexOf.call(listStep, document.activeElement);
126
+ // Test if the focus is in the list (otherwise we do nothing)
127
+ if (currentPos !== -1) {
128
+ // we put the focus on the next element.
129
+ if (currentPos === 0) {
130
+ listStep[listStep.length - 1].focus();
131
+ }
132
+ else {
133
+ listStep[currentPos - 1].focus();
134
+ }
135
+ }
136
+ }
137
+ ngAfterViewChecked() {
138
+ // Put back the focus on the active elements
139
+ if (this.stepperService.setFocus) {
140
+ const listStep = this.getSteps();
141
+ listStep[this.stepperService.state.active].focus();
142
+ this.stepperService.resetFocus();
143
+ }
144
+ }
145
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
146
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.4", type: DfStepperDirective, isStandalone: true, selector: "[dfStepperLogic]", host: { listeners: { "keydown.Enter": "handleEnterDown()", "keydown.Space": "handleSpaceDown()", "keydown.arrowRight": "handleKeyDownRight($event)", "keydown.arrowLeft": "handleKeyDown($event)", "keydown.arrowDown": "handleKeyDownUp($event)", "keydown.arrowUp": "handleKeyDownDown($event)" } }, exportAs: ["dfStepperLogic"], ngImport: i0 }); }
147
+ }
148
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperDirective, decorators: [{
149
+ type: Directive,
150
+ args: [{
151
+ selector: '[dfStepperLogic]',
152
+ exportAs: 'dfStepperLogic',
153
+ standalone: true
154
+ }]
155
+ }], propDecorators: { handleEnterDown: [{
156
+ type: HostListener,
157
+ args: ['keydown.Enter']
158
+ }], handleSpaceDown: [{
159
+ type: HostListener,
160
+ args: ['keydown.Space']
161
+ }], handleKeyDownRight: [{
162
+ type: HostListener,
163
+ args: ['keydown.arrowRight', ['$event']]
164
+ }], handleKeyDown: [{
165
+ type: HostListener,
166
+ args: ['keydown.arrowLeft', ['$event']]
167
+ }], handleKeyDownUp: [{
168
+ type: HostListener,
169
+ args: ['keydown.arrowDown', ['$event']]
170
+ }], handleKeyDownDown: [{
171
+ type: HostListener,
172
+ args: ['keydown.arrowUp', ['$event']]
173
+ }] } });
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.directive.js","sourceRoot":"","sources":["../../../../../../projects/design-factory/src/lib/angular/stepper/stepper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  Directive,\n  ElementRef,\n  HostListener,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  inject\n} from '@angular/core';\nimport { DfDirectionDetectionService, RightToLeftDirectionEnum } from '../right-to-left/directionDetection.service';\nimport { DfStepperService } from './stepper.service';\nexport const DF_STEP_CLASS = 'df-stepper-step';\n\n@Directive({\n  selector: '[dfStepperStep]',\n  exportAs: 'dfStepperStep',\n  standalone: true\n})\nexport class DfStepperStepDirective implements OnInit, OnDestroy {\n  private readonly unlistener: Array<() => void> = [];\n\n  private readonly renderer2: Renderer2 = inject(Renderer2);\n  private readonly element: ElementRef = inject(ElementRef);\n\n  ngOnInit() {\n    this.unlistener.push(\n      this.renderer2.listen(this.element.nativeElement, 'focus', () => {\n        this.handleFocusTabIndex();\n      })\n    );\n    this.unlistener.push(\n      this.renderer2.listen(this.element.nativeElement, 'blur', (event: FocusEvent) => {\n        this.handleBlurTabIndex(event);\n      })\n    );\n  }\n\n  handleFocusTabIndex() {\n    this.element.nativeElement.tabIndex = 0;\n  }\n\n  handleBlurTabIndex(event: FocusEvent) {\n    if (\n      event.relatedTarget &&\n      'classList' in event.relatedTarget &&\n      (event.relatedTarget.classList as DOMTokenList).contains(DF_STEP_CLASS)\n    ) {\n      this.element.nativeElement.tabIndex = -1;\n    }\n  }\n\n  ngOnDestroy() {\n    this.unlistener.forEach((ul) => ul());\n  }\n}\n\n@Directive({\n  selector: '[dfStepperLogic]',\n  exportAs: 'dfStepperLogic',\n  standalone: true\n})\nexport class DfStepperDirective implements OnInit, AfterViewChecked {\n  private direction!: string;\n  stepperService = inject(DfStepperService);\n  private readonly element: ElementRef = inject(ElementRef);\n  private readonly rtlDirectionService: DfDirectionDetectionService = inject(DfDirectionDetectionService);\n\n  ngOnInit(): void {\n    this.direction = this.rtlDirectionService.getPageDirection(this.element);\n  }\n\n  @HostListener('keydown.Enter')\n  handleEnterDown() {\n    this.handleSelect();\n  }\n\n  @HostListener('keydown.Space')\n  handleSpaceDown() {\n    this.handleSelect();\n  }\n\n  private handleGoPrevious() {\n    if (this.direction === RightToLeftDirectionEnum.LeftToRight) {\n      this.arrowLeftInnerHandler();\n    } else {\n      this.arrowRightInnerHandler();\n    }\n  }\n\n  private handleGoNext() {\n    if (this.direction === RightToLeftDirectionEnum.LeftToRight) {\n      this.arrowRightInnerHandler();\n    } else {\n      this.arrowLeftInnerHandler();\n    }\n  }\n\n  @HostListener('keydown.arrowRight', ['$event'])\n  handleKeyDownRight(event: KeyboardEvent) {\n    if (!this.stepperService.state.isVertical) {\n      this.handleGoNext();\n      event.preventDefault();\n    }\n  }\n\n  @HostListener('keydown.arrowLeft', ['$event'])\n  handleKeyDown(event: KeyboardEvent) {\n    if (!this.stepperService.state.isVertical) {\n      this.handleGoPrevious();\n      event.preventDefault();\n    }\n  }\n\n  @HostListener('keydown.arrowDown', ['$event'])\n  handleKeyDownUp(event: KeyboardEvent) {\n    if (this.stepperService.state.isVertical) {\n      this.handleGoNext();\n      event.preventDefault();\n    }\n  }\n\n  @HostListener('keydown.arrowUp', ['$event'])\n  handleKeyDownDown(event: KeyboardEvent) {\n    if (this.stepperService.state.isVertical) {\n      this.handleGoPrevious();\n      event.preventDefault();\n    }\n  }\n\n  getSteps(): HTMLButtonElement[] {\n    return this.element.nativeElement.querySelectorAll(`:scope .${DF_STEP_CLASS}`);\n  }\n\n  private handleSelect() {\n    const listStep = this.getSteps();\n    const currentPos = Array.prototype.indexOf.call(listStep, document.activeElement);\n    if (currentPos !== -1) {\n      listStep[currentPos].click();\n    }\n  }\n\n  private arrowRightInnerHandler() {\n    const listStep = this.getSteps();\n    const currentPos = Array.prototype.indexOf.call(listStep, document.activeElement);\n    // Test if the focus is in the list (otherwise we do nothing)\n    if (currentPos !== -1) {\n      // we put the focus on the next element.\n      if (currentPos === listStep.length - 1) {\n        listStep[0].focus();\n      } else {\n        listStep[currentPos + 1].focus();\n      }\n    }\n  }\n\n  private arrowLeftInnerHandler() {\n    const listStep = this.getSteps();\n    const currentPos = Array.prototype.indexOf.call(listStep, document.activeElement);\n    // Test if the focus is in the list (otherwise we do nothing)\n    if (currentPos !== -1) {\n      // we put the focus on the next element.\n      if (currentPos === 0) {\n        listStep[listStep.length - 1].focus();\n      } else {\n        listStep[currentPos - 1].focus();\n      }\n    }\n  }\n\n  ngAfterViewChecked() {\n    // Put back the focus on the active elements\n    if (this.stepperService.setFocus) {\n      const listStep: HTMLButtonElement[] = this.getSteps();\n      listStep[this.stepperService.state.active].focus();\n      this.stepperService.resetFocus();\n    }\n  }\n}\n"]}
@@ -0,0 +1,17 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { DfStepperDirective, DfStepperStepDirective } from './stepper.directive';
3
+ import { DfStepperComponent, DfStepperStepContentDirective } from './stepper.component';
4
+ import * as i0 from "@angular/core";
5
+ export class DfStepperModule {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.4", ngImport: i0, type: DfStepperModule, imports: [DfStepperDirective, DfStepperStepDirective, DfStepperComponent, DfStepperStepContentDirective], exports: [DfStepperDirective, DfStepperStepDirective, DfStepperComponent, DfStepperStepContentDirective] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperModule, imports: [DfStepperComponent] }); }
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ imports: [DfStepperDirective, DfStepperStepDirective, DfStepperComponent, DfStepperStepContentDirective],
14
+ exports: [DfStepperDirective, DfStepperStepDirective, DfStepperComponent, DfStepperStepContentDirective]
15
+ }]
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tZmFjdG9yeS9zcmMvbGliL2FuZ3VsYXIvc3RlcHBlci9zdGVwcGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxzQkFBc0IsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSw2QkFBNkIsRUFBQyxNQUFNLHFCQUFxQixDQUFDOztBQU12RixNQUFNLE9BQU8sZUFBZTs4R0FBZixlQUFlOytHQUFmLGVBQWUsWUFIaEIsa0JBQWtCLEVBQUUsc0JBQXNCLEVBQUUsa0JBQWtCLEVBQUUsNkJBQTZCLGFBQzdGLGtCQUFrQixFQUFFLHNCQUFzQixFQUFFLGtCQUFrQixFQUFFLDZCQUE2QjsrR0FFNUYsZUFBZSxZQUg0QixrQkFBa0I7OzJGQUc3RCxlQUFlO2tCQUozQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixFQUFFLHNCQUFzQixFQUFFLGtCQUFrQixFQUFFLDZCQUE2QixDQUFDO29CQUN4RyxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxzQkFBc0IsRUFBRSxrQkFBa0IsRUFBRSw2QkFBNkIsQ0FBQztpQkFDekciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGZTdGVwcGVyRGlyZWN0aXZlLCBEZlN0ZXBwZXJTdGVwRGlyZWN0aXZlfSBmcm9tICcuL3N0ZXBwZXIuZGlyZWN0aXZlJztcbmltcG9ydCB7IERmU3RlcHBlckNvbXBvbmVudCwgRGZTdGVwcGVyU3RlcENvbnRlbnREaXJlY3RpdmV9IGZyb20gJy4vc3RlcHBlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbRGZTdGVwcGVyRGlyZWN0aXZlLCBEZlN0ZXBwZXJTdGVwRGlyZWN0aXZlLCBEZlN0ZXBwZXJDb21wb25lbnQsIERmU3RlcHBlclN0ZXBDb250ZW50RGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW0RmU3RlcHBlckRpcmVjdGl2ZSwgRGZTdGVwcGVyU3RlcERpcmVjdGl2ZSwgRGZTdGVwcGVyQ29tcG9uZW50LCBEZlN0ZXBwZXJTdGVwQ29udGVudERpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgRGZTdGVwcGVyTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,213 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class DfStepperService {
5
+ constructor() {
6
+ this.setFocus = false;
7
+ this._stepperState$ = new BehaviorSubject({
8
+ steps: [],
9
+ active: 0,
10
+ isLinear: false,
11
+ isInline: false,
12
+ isVertical: false
13
+ });
14
+ this._state = {
15
+ steps: [],
16
+ active: 0,
17
+ isLinear: false,
18
+ isInline: false,
19
+ isVertical: false
20
+ };
21
+ this._completedLabel = 'Completed';
22
+ this._warningLabel = 'Warning';
23
+ this._stepperAriaLabel = 'Stepper';
24
+ }
25
+ get stepperState$() {
26
+ return this._stepperState$.asObservable();
27
+ }
28
+ // initState must be used to push new Steps to the service
29
+ get state() {
30
+ return this._state;
31
+ }
32
+ dispatchStepperState() {
33
+ this._stepperState$.next(this._state);
34
+ }
35
+ updateStepperState() {
36
+ this._state = this.normalizeState(this._state);
37
+ this.dispatchStepperState();
38
+ }
39
+ // API
40
+ /**
41
+ * Use this to init the list of Elements from your stepper
42
+ *
43
+ * Here we are not deep copying the array --> the function will change it
44
+ */
45
+ initStepperState(state) {
46
+ // normalize the steps here
47
+ this._state = this.normalizeState(state);
48
+ this.dispatchStepperState();
49
+ }
50
+ /**
51
+ * Use this to normalize the state of the stepper (completed, warning, current, future)
52
+ * @param state
53
+ * @returns
54
+ */
55
+ normalizeState(state) {
56
+ const stepsList = [];
57
+ for (let i = 0; i < state.steps.length; i++) {
58
+ if (state.steps[i].warning) {
59
+ stepsList.push({ ...state.steps[i], type: 'warning' });
60
+ }
61
+ else if (i === state.active) {
62
+ stepsList.push({ ...state.steps[i], type: 'current' });
63
+ }
64
+ else if (state.steps[i].completed) {
65
+ stepsList.push({ ...state.steps[i], type: 'completed' });
66
+ }
67
+ else {
68
+ stepsList.push({ ...state.steps[i], type: 'future' });
69
+ }
70
+ }
71
+ return { ...state, steps: stepsList };
72
+ }
73
+ /**
74
+ * Internal to get the stepper aria label in the template
75
+ */
76
+ get stepperAriaLabel() {
77
+ return this._stepperAriaLabel;
78
+ }
79
+ /**
80
+ * Use this to set the stepper aria label (i18n)
81
+ */
82
+ set stepperAriaLabel(label) {
83
+ this._stepperAriaLabel = label;
84
+ }
85
+ /**
86
+ * Internal to get the completed label in the template
87
+ */
88
+ get completedLabel() {
89
+ return this._completedLabel;
90
+ }
91
+ /**
92
+ * Internal to get the waring label in the template
93
+ */
94
+ get warningLabel() {
95
+ return this._warningLabel;
96
+ }
97
+ /**
98
+ * Use this to set the completed label (i18n)
99
+ */
100
+ set completedLabel(label) {
101
+ this._completedLabel = label;
102
+ }
103
+ /**
104
+ * Use this to set the warning label (i18n)
105
+ */
106
+ set warningLabel(label) {
107
+ this._warningLabel = label;
108
+ }
109
+ /**
110
+ * TODO make it customizable
111
+ * @param index - index of the step
112
+ * @returns - string of the step number to display
113
+ */
114
+ getStepNumberLabel(index) {
115
+ return `${index + 1}`;
116
+ }
117
+ resetFocus() {
118
+ this.setFocus = false;
119
+ }
120
+ /**
121
+ *
122
+ * @param isLinear - true if the stepper is linear
123
+ */
124
+ setLinear(isLinear) {
125
+ this._state.isLinear = isLinear;
126
+ this.dispatchStepperState();
127
+ }
128
+ /**
129
+ *
130
+ * @param isInline - true if the stepper is inline
131
+ */
132
+ setInline(isInline) {
133
+ this._state.isInline = isInline;
134
+ this.dispatchStepperState();
135
+ }
136
+ /**
137
+ *
138
+ * @param index - index of the step to select start at 0
139
+ */
140
+ selectStep(index) {
141
+ if (index < 0 || index >= this._state.steps.length) {
142
+ return;
143
+ }
144
+ this._state.active = index;
145
+ this.updateStepperState();
146
+ }
147
+ /**
148
+ * Same as selectStep but with focus on the step selected
149
+ * @param index - index of the step to select start at 0
150
+ */
151
+ selectWithFocus(index) {
152
+ if (index < 0 || index >= this._state.steps.length) {
153
+ return;
154
+ }
155
+ this.setFocus = true;
156
+ this.selectStep(index);
157
+ }
158
+ /**
159
+ *
160
+ * @param index - index of the step to complete start at 0
161
+ */
162
+ completeStep(index) {
163
+ if (index < 0 || index >= this._state.steps.length) {
164
+ return;
165
+ }
166
+ this._state.steps[index].completed = true;
167
+ this._state.steps[index].warning = false;
168
+ this.updateStepperState();
169
+ }
170
+ /**
171
+ *
172
+ * @param index - index of the step to complete start at 0
173
+ */
174
+ completeStepAndGoNext(index) {
175
+ this.completeStep(index);
176
+ this.selectStep(index + 1);
177
+ }
178
+ /**
179
+ * Attention if the step was completed it will be uncompleted after.
180
+ * @param index - index of the step to make Warning start at 0
181
+ * @param warningLabel - label to display in the warning by default it will take the warningLabel if it exists or the label
182
+ */
183
+ makeWarning(index, warningLabel) {
184
+ if (index < 0 || index >= this._state.steps.length) {
185
+ return;
186
+ }
187
+ this._state.steps[index].warning = true;
188
+ this._state.steps[index].completed = false;
189
+ this._state.steps[index].warningLabel = warningLabel
190
+ ? warningLabel
191
+ : this._state.steps[index].warningLabel
192
+ ? this._state.steps[index].warningLabel
193
+ : this._state.steps[index].label;
194
+ this.updateStepperState();
195
+ }
196
+ /**
197
+ *
198
+ * @param index - index of the step to remove Warning start at 0
199
+ */
200
+ removeWarning(index) {
201
+ if (index < 0 || index >= this._state.steps.length) {
202
+ return;
203
+ }
204
+ this._state.steps[index].warning = false;
205
+ this.updateStepperState();
206
+ }
207
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
208
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperService }); }
209
+ }
210
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfStepperService, decorators: [{
211
+ type: Injectable
212
+ }] });
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.service.js","sourceRoot":"","sources":["../../../../../../projects/design-factory/src/lib/angular/stepper/stepper.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\nexport interface DfStepperStep {\n  warning: boolean;\n  completed: boolean;\n  label: string;\n  ariaControl: string;\n  warningLabel?: string;\n  optionalLabel?: string;\n}\n\nexport type DfStepType = 'warning' | 'current' | 'completed' | 'future';\n\nexport interface DfStepperNormalizedStep extends DfStepperStep {\n  type: DfStepType;\n}\nexport interface DfStepperState {\n  steps: DfStepperStep[];\n  active: number;\n  isLinear: boolean;\n  isInline: boolean;\n  isVertical: boolean;\n}\nexport interface DfStepperNormalizedState {\n  steps: DfStepperNormalizedStep[];\n  active: number;\n  isLinear: boolean;\n  isInline: boolean;\n  isVertical: boolean;\n}\n\n@Injectable()\nexport class DfStepperService {\n  setFocus = false;\n  private readonly _stepperState$ = new BehaviorSubject<DfStepperNormalizedState>({\n    steps: [],\n    active: 0,\n    isLinear: false,\n    isInline: false,\n    isVertical: false\n  });\n  private _state: DfStepperNormalizedState = {\n    steps: [],\n    active: 0,\n    isLinear: false,\n    isInline: false,\n    isVertical: false\n  };\n  private _completedLabel = 'Completed';\n  private _warningLabel = 'Warning';\n  private _stepperAriaLabel = 'Stepper';\n\n  get stepperState$(): Observable<DfStepperNormalizedState> {\n    return this._stepperState$.asObservable();\n  }\n  // initState must be used to push new Steps to the service\n  get state(): DfStepperNormalizedState {\n    return this._state;\n  }\n\n  private dispatchStepperState() {\n    this._stepperState$.next(this._state);\n  }\n\n  private updateStepperState() {\n    this._state = this.normalizeState(this._state as DfStepperState);\n    this.dispatchStepperState();\n  }\n\n  // API\n  /**\n   * Use this to init the list of Elements from your stepper\n   *\n   * Here we are not deep copying the array --> the function will change it\n   */\n  initStepperState(state: DfStepperState) {\n    // normalize the steps here\n    this._state = this.normalizeState(state);\n    this.dispatchStepperState();\n  }\n\n  /**\n   * Use this to normalize the state of the stepper (completed, warning, current, future)\n   * @param state\n   * @returns\n   */\n  normalizeState(state: DfStepperState): DfStepperNormalizedState {\n    const stepsList: DfStepperNormalizedStep[] = [];\n    for (let i = 0; i < state.steps.length; i++) {\n      if (state.steps[i].warning) {\n        stepsList.push({ ...state.steps[i], type: 'warning' });\n      } else if (i === state.active) {\n        stepsList.push({ ...state.steps[i], type: 'current' });\n      } else if (state.steps[i].completed) {\n        stepsList.push({ ...state.steps[i], type: 'completed' });\n      } else {\n        stepsList.push({ ...state.steps[i], type: 'future' });\n      }\n    }\n    return { ...state, steps: stepsList };\n  }\n\n  /**\n   * Internal to get the stepper aria label in the template\n   */\n  get stepperAriaLabel(): string {\n    return this._stepperAriaLabel;\n  }\n\n  /**\n   * Use this to set the stepper aria label (i18n)\n   */\n  set stepperAriaLabel(label: string) {\n    this._stepperAriaLabel = label;\n  }\n\n  /**\n   * Internal to get the completed label in the template\n   */\n  get completedLabel(): string {\n    return this._completedLabel;\n  }\n\n  /**\n   * Internal to get the waring label in the template\n   */\n  get warningLabel(): string {\n    return this._warningLabel;\n  }\n\n  /**\n   * Use this to set the completed label (i18n)\n   */\n  set completedLabel(label: string) {\n    this._completedLabel = label;\n  }\n\n  /**\n   * Use this to set the warning label (i18n)\n   */\n  set warningLabel(label: string) {\n    this._warningLabel = label;\n  }\n\n  /**\n   * TODO make it customizable\n   * @param index - index of the step\n   * @returns - string of the step number to display\n   */\n  getStepNumberLabel(index: number): string {\n    return `${index + 1}`;\n  }\n\n  resetFocus() {\n    this.setFocus = false;\n  }\n\n  /**\n   *\n   * @param isLinear - true if the stepper is linear\n   */\n  setLinear(isLinear: boolean) {\n    this._state.isLinear = isLinear;\n    this.dispatchStepperState();\n  }\n\n  /**\n   *\n   * @param isInline - true if the stepper is inline\n   */\n  setInline(isInline: boolean) {\n    this._state.isInline = isInline;\n    this.dispatchStepperState();\n  }\n\n  /**\n   *\n   * @param index - index of the step to select start at 0\n   */\n  selectStep(index: number) {\n    if (index < 0 || index >= this._state.steps.length) {\n      return;\n    }\n    this._state.active = index;\n    this.updateStepperState();\n  }\n\n  /**\n   * Same as selectStep but with focus on the step selected\n   * @param index - index of the step to select start at 0\n   */\n  selectWithFocus(index: number) {\n    if (index < 0 || index >= this._state.steps.length) {\n      return;\n    }\n    this.setFocus = true;\n    this.selectStep(index);\n  }\n\n  /**\n   *\n   * @param index - index of the step to complete start at 0\n   */\n  completeStep(index: number) {\n    if (index < 0 || index >= this._state.steps.length) {\n      return;\n    }\n    this._state.steps[index].completed = true;\n    this._state.steps[index].warning = false;\n    this.updateStepperState();\n  }\n\n  /**\n   *\n   * @param index - index of the step to complete start at 0\n   */\n  completeStepAndGoNext(index: number) {\n    this.completeStep(index);\n    this.selectStep(index + 1);\n  }\n\n  /**\n   * Attention if the step was completed it will be uncompleted after.\n   * @param index - index of the step to make Warning start at 0\n   * @param warningLabel - label to display in the warning by default it will take the warningLabel if it exists or the label\n   */\n  makeWarning(index: number, warningLabel?: string) {\n    if (index < 0 || index >= this._state.steps.length) {\n      return;\n    }\n    this._state.steps[index].warning = true;\n    this._state.steps[index].completed = false;\n    this._state.steps[index].warningLabel = warningLabel\n      ? warningLabel\n      : this._state.steps[index].warningLabel\n      ? this._state.steps[index].warningLabel\n      : this._state.steps[index].label;\n    this.updateStepperState();\n  }\n\n  /**\n   *\n   * @param index - index of the step to remove Warning start at 0\n   */\n  removeWarning(index: number) {\n    if (index < 0 || index >= this._state.steps.length) {\n      return;\n    }\n    this._state.steps[index].warning = false;\n    this.updateStepperState();\n  }\n}\n"]}
@@ -1,5 +1,4 @@
1
1
  import { Directive } from '@angular/core';
2
- import { hasOverflow } from '../../utils/html-element-helper';
3
2
  import * as i0 from "@angular/core";
4
3
  import * as i1 from "@ng-bootstrap/ng-bootstrap";
5
4
  /**
@@ -15,7 +14,10 @@ export class DfTooltipTruncateDirective {
15
14
  this.renderer.addClass(this.elementRef.nativeElement, 'text-truncate');
16
15
  }
17
16
  ngDoCheck() {
18
- this.tooltip.disableTooltip = !hasOverflow(this.elementRef.nativeElement);
17
+ this.tooltip.disableTooltip = !this.hasOverflow(this.elementRef.nativeElement);
18
+ }
19
+ hasOverflow(element) {
20
+ return element?.offsetHeight < element?.scrollHeight || element?.offsetWidth < element?.scrollWidth;
19
21
  }
20
22
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: DfTooltipTruncateDirective, deps: [{ token: i1.NgbTooltip }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
21
23
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.4", type: DfTooltipTruncateDirective, isStandalone: true, selector: "[dfTooltipTruncate]", exportAs: ["dfTooltipTruncate"], ngImport: i0 }); }
@@ -28,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
28
30
  standalone: true
29
31
  }]
30
32
  }], ctorParameters: function () { return [{ type: i1.NgbTooltip }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; } });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcFRydW5jYXRlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1mYWN0b3J5L3NyYy9saWIvYW5ndWxhci90b29sdGlwL3RydW5jYXRlL3Rvb2x0aXBUcnVuY2F0ZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBMEMsTUFBTSxlQUFlLENBQUM7QUFFbEYsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOzs7QUFFOUQ7O0dBRUc7QUFNSCxNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLFlBQ21CLE9BQW1CLEVBQ25CLFVBQW1DLEVBQ25DLFFBQW1CO1FBRm5CLFlBQU8sR0FBUCxPQUFPLENBQVk7UUFDbkIsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFDbkMsYUFBUSxHQUFSLFFBQVEsQ0FBVztJQUNuQyxDQUFDO0lBRUosUUFBUTtRQUNOLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxDQUFDLE9BQU8sQ0FBQyxjQUFjLEdBQUcsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUM1RSxDQUFDOzhHQWJVLDBCQUEwQjtrR0FBMUIsMEJBQTBCOzsyRkFBMUIsMEJBQTBCO2tCQUx0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFFBQVEsRUFBRSxxQkFBcUI7b0JBQy9CLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRG9DaGVjaywgRWxlbWVudFJlZiwgT25Jbml0LCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nYlRvb2x0aXAgfSBmcm9tICdAbmctYm9vdHN0cmFwL25nLWJvb3RzdHJhcCc7XG5pbXBvcnQgeyBoYXNPdmVyZmxvdyB9IGZyb20gJy4uLy4uL3V0aWxzL2h0bWwtZWxlbWVudC1oZWxwZXInO1xuXG4vKipcbiAqIE15IGRmVG9vbHRpcFRydW5jYXRlIGRpcmVjdGl2ZVxuICovXG5ARGlyZWN0aXZlKHtcbiAgZXhwb3J0QXM6ICdkZlRvb2x0aXBUcnVuY2F0ZScsXG4gIHNlbGVjdG9yOiAnW2RmVG9vbHRpcFRydW5jYXRlXScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGZUb29sdGlwVHJ1bmNhdGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIERvQ2hlY2sge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IHRvb2x0aXA6IE5nYlRvb2x0aXAsXG4gICAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcbiAgICBwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyOiBSZW5kZXJlcjJcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMucmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICd0ZXh0LXRydW5jYXRlJyk7XG4gIH1cblxuICBuZ0RvQ2hlY2soKSB7XG4gICAgdGhpcy50b29sdGlwLmRpc2FibGVUb29sdGlwID0gIWhhc092ZXJmbG93KHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50KTtcbiAgfVxufVxuIl19
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcFRydW5jYXRlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1mYWN0b3J5L3NyYy9saWIvYW5ndWxhci90b29sdGlwL3RydW5jYXRlL3Rvb2x0aXBUcnVuY2F0ZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBMEMsTUFBTSxlQUFlLENBQUM7OztBQUdsRjs7R0FFRztBQU1ILE1BQU0sT0FBTywwQkFBMEI7SUFDckMsWUFDbUIsT0FBbUIsRUFDbkIsVUFBbUMsRUFDbkMsUUFBbUI7UUFGbkIsWUFBTyxHQUFQLE9BQU8sQ0FBWTtRQUNuQixlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQUNuQyxhQUFRLEdBQVIsUUFBUSxDQUFXO0lBQ25DLENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsZUFBZSxDQUFDLENBQUM7SUFDekUsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNqRixDQUFDO0lBRU8sV0FBVyxDQUFDLE9BQW9CO1FBQ3RDLE9BQU8sT0FBTyxFQUFFLFlBQVksR0FBRyxPQUFPLEVBQUUsWUFBWSxJQUFJLE9BQU8sRUFBRSxXQUFXLEdBQUcsT0FBTyxFQUFFLFdBQVcsQ0FBQztJQUN0RyxDQUFDOzhHQWpCVSwwQkFBMEI7a0dBQTFCLDBCQUEwQjs7MkZBQTFCLDBCQUEwQjtrQkFMdEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIERvQ2hlY2ssIEVsZW1lbnRSZWYsIE9uSW5pdCwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ2JUb29sdGlwIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnO1xuXG4vKipcbiAqIE15IGRmVG9vbHRpcFRydW5jYXRlIGRpcmVjdGl2ZVxuICovXG5ARGlyZWN0aXZlKHtcbiAgZXhwb3J0QXM6ICdkZlRvb2x0aXBUcnVuY2F0ZScsXG4gIHNlbGVjdG9yOiAnW2RmVG9vbHRpcFRydW5jYXRlXScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGZUb29sdGlwVHJ1bmNhdGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIERvQ2hlY2sge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IHRvb2x0aXA6IE5nYlRvb2x0aXAsXG4gICAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcbiAgICBwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyOiBSZW5kZXJlcjJcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMucmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICd0ZXh0LXRydW5jYXRlJyk7XG4gIH1cblxuICBuZ0RvQ2hlY2soKSB7XG4gICAgdGhpcy50b29sdGlwLmRpc2FibGVUb29sdGlwID0gIXRoaXMuaGFzT3ZlcmZsb3codGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQpO1xuICB9XG5cbiAgcHJpdmF0ZSBoYXNPdmVyZmxvdyhlbGVtZW50OiBIVE1MRWxlbWVudCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBlbGVtZW50Py5vZmZzZXRIZWlnaHQgPCBlbGVtZW50Py5zY3JvbGxIZWlnaHQgfHwgZWxlbWVudD8ub2Zmc2V0V2lkdGggPCBlbGVtZW50Py5zY3JvbGxXaWR0aDtcbiAgfVxufVxuIl19