@design-factory/design-factory 15.2.3 → 16.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.
- package/README.md +17 -1
- package/assets/fonts/amadeus-neue/bold/AmadeusNeue-Bold.ttf +0 -0
- package/assets/fonts/amadeus-neue/bold/AmadeusNeue-Bold.woff +0 -0
- package/assets/fonts/amadeus-neue/bold/AmadeusNeue-Bold.woff2 +0 -0
- package/assets/fonts/amadeus-neue/bold/AmadeusNeue-BoldItalic.ttf +0 -0
- package/assets/fonts/amadeus-neue/bold/AmadeusNeue-BoldItalic.woff +0 -0
- package/assets/fonts/amadeus-neue/bold/AmadeusNeue-BoldItalic.woff2 +0 -0
- package/assets/fonts/amadeus-neue/light/AmadeusNeue-Light.ttf +0 -0
- package/assets/fonts/amadeus-neue/light/AmadeusNeue-Light.woff +0 -0
- package/assets/fonts/amadeus-neue/light/AmadeusNeue-Light.woff2 +0 -0
- package/assets/fonts/amadeus-neue/light/AmadeusNeue-LightItalic.ttf +0 -0
- package/assets/fonts/amadeus-neue/light/AmadeusNeue-LightItalic.woff +0 -0
- package/assets/fonts/amadeus-neue/light/AmadeusNeue-LightItalic.woff2 +0 -0
- package/assets/fonts/amadeus-neue/medium/AmadeusNeue-Medium.ttf +0 -0
- package/assets/fonts/amadeus-neue/medium/AmadeusNeue-Medium.woff +0 -0
- package/assets/fonts/amadeus-neue/medium/AmadeusNeue-Medium.woff2 +0 -0
- package/assets/fonts/amadeus-neue/medium/AmadeusNeue-MediumItalic.ttf +0 -0
- package/assets/fonts/amadeus-neue/medium/AmadeusNeue-MediumItalic.woff +0 -0
- package/assets/fonts/amadeus-neue/medium/AmadeusNeue-MediumItalic.woff2 +0 -0
- package/assets/fonts/amadeus-neue/regular/AmadeusNeue-Regular.ttf +0 -0
- package/assets/fonts/amadeus-neue/regular/AmadeusNeue-Regular.woff +0 -0
- package/assets/fonts/amadeus-neue/regular/AmadeusNeue-Regular.woff2 +0 -0
- package/assets/fonts/amadeus-neue/regular/AmadeusNeue-RegularItalic.ttf +0 -0
- package/assets/fonts/amadeus-neue/regular/AmadeusNeue-RegularItalic.woff +0 -0
- package/assets/fonts/amadeus-neue/regular/AmadeusNeue-RegularItalic.woff2 +0 -0
- package/design-factory-initial-branding.css +1 -0
- package/design-factory-initial-branding.scss +1 -0
- package/design-factory.css +1 -3
- package/design-factory.scss +1 -0
- package/esm2022/lib/angular/accessibility/components/skip-links-container/skip-links-container.component.mjs +3 -3
- package/esm2022/lib/angular/df.module.mjs +102 -0
- package/esm2022/lib/angular/icon/amadeus-icon.mjs +2 -2
- package/esm2022/lib/angular/sidenav/sidenavlist.component.mjs +3 -12
- package/esm2022/lib/angular/stepper/stepper.component.mjs +65 -0
- package/esm2022/lib/angular/stepper/stepper.directive.mjs +174 -0
- package/esm2022/lib/angular/stepper/stepper.module.mjs +17 -0
- package/esm2022/lib/angular/stepper/stepper.service.mjs +213 -0
- package/esm2022/lib/angular/tooltip/truncate/tooltipTruncate.directive.mjs +5 -3
- package/esm2022/lib/index.mjs +9 -96
- package/fesm2022/design-factory.mjs +1838 -1427
- package/fesm2022/design-factory.mjs.map +1 -1
- package/lib/angular/df.module.d.ts +26 -0
- package/lib/angular/stepper/stepper.component.d.ts +31 -0
- package/lib/angular/stepper/stepper.directive.d.ts +37 -0
- package/lib/angular/stepper/stepper.module.d.ts +8 -0
- package/lib/angular/stepper/stepper.service.d.ts +126 -0
- package/lib/angular/tooltip/truncate/tooltipTruncate.directive.d.ts +1 -0
- package/lib/index.d.ts +7 -23
- package/package.json +23 -4
- package/schematics/migrations/15_0_0/remove-ngx-slider/index.js +0 -1
- package/schematics/migrations/16_0_0/navbar-logo-dark/index.d.ts +9 -0
- package/schematics/migrations/16_0_0/navbar-logo-dark/index.js +43 -0
- package/schematics/migrations/16_0_0/revert-to-old-brand/index.d.ts +7 -0
- package/schematics/migrations/16_0_0/revert-to-old-brand/index.js +115 -0
- package/schematics/migrations/16_0_0/scss-var/files/removed.json +55 -0
- package/schematics/migrations/16_0_0/scss-var/files/renames.json +76 -0
- package/schematics/migrations/16_0_0/scss-var/index.d.ts +7 -0
- package/schematics/migrations/16_0_0/scss-var/index.js +57 -0
- package/schematics/migrations/16_0_0/stepper-classes/index.d.ts +13 -0
- package/schematics/migrations/16_0_0/stepper-classes/index.js +63 -0
- package/schematics/migrations/helpers.js +0 -1
- package/schematics/migrations/migration.json +23 -1
- package/schematics/migrations/utils/component-resource-collector.d.ts +44 -0
- package/schematics/migrations/utils/component-resource-collector.js +166 -0
- package/schematics/migrations/utils/project_tsconfig_paths.js +0 -1
- package/schematics/migrations/utils/style-updater.d.ts +9 -0
- package/schematics/migrations/utils/style-updater.js +38 -0
- package/schematics/migrations/utils/template-updater.d.ts +9 -0
- package/schematics/migrations/utils/template-updater.js +38 -0
- package/schematics/migrations/utils/typescript/compiler_host.js +0 -1
- package/schematics/migrations/utils/typescript/decorators.d.ts +22 -0
- package/schematics/migrations/utils/typescript/decorators.js +41 -0
- package/schematics/migrations/utils/typescript/functions.d.ts +14 -0
- package/schematics/migrations/utils/typescript/functions.js +20 -0
- package/schematics/migrations/utils/typescript/imports.d.ts +17 -0
- package/schematics/migrations/utils/typescript/imports.js +110 -0
- package/schematics/migrations/utils/typescript/line-mappings.d.ts +21 -0
- package/schematics/migrations/utils/typescript/line-mappings.js +75 -0
- package/schematics/migrations/utils/typescript/parse_tsconfig.js +0 -1
- package/schematics/migrations/utils/typescript/property-name.d.ts +18 -0
- package/schematics/migrations/utils/typescript/property-name.js +27 -0
- package/schematics/ng-add/index.js +0 -1
- package/schematics/ng-add/schema.js +0 -1
- package/styles/scss/_common.root.scss +37 -0
- package/styles/scss/_common.scss +3 -9
- package/styles/scss/_common.variables.scss +16 -6
- package/styles/scss/_variables.scss +0 -1
- package/styles/scss/bootstrap/_maps.scss +10 -9
- package/styles/scss/bootstrap/_mixins-override.scss +26 -0
- package/styles/scss/bootstrap/_variables.scss +927 -267
- package/styles/scss/components/accordion/_accordion.scss +31 -14
- package/styles/scss/components/accordion/_accordion.variables.scss +5 -5
- package/styles/scss/components/alert/_alert.scss +130 -228
- package/styles/scss/components/alert/_alert.variables.scss +22 -33
- package/styles/scss/components/badge/_badge.scss +130 -118
- package/styles/scss/components/badge/_badge.variables.scss +14 -8
- package/styles/scss/components/brand-color/_brand-color.mixins.scss +19 -4
- package/styles/scss/components/brand-color/_brand-color.scss +4 -6
- package/styles/scss/components/brand-color/_brand-color.variables.scss +1 -7
- package/styles/scss/components/brand-color/_brand-color_container.scss +28 -0
- package/styles/scss/components/breadcrumbs/_breadcrumbs.scss +77 -65
- package/styles/scss/components/breadcrumbs/_breadcrumbs.variables.scss +6 -4
- package/styles/scss/components/button/_button.scss +120 -55
- package/styles/scss/components/button/_button.variables.scss +18 -4
- package/styles/scss/components/button/_button_container.scss +9 -45
- package/styles/scss/components/card/_card.scss +90 -58
- package/styles/scss/components/card/_card.variables.scss +13 -13
- package/styles/scss/components/carousel/_carousel.scss +22 -23
- package/styles/scss/components/carousel/_carousel.variables.scss +2 -1
- package/styles/scss/components/checkbox/_checkbox.scss +14 -8
- package/styles/scss/components/checkbox/_checkbox.variables.scss +2 -2
- package/styles/scss/components/collapse/_collapse.scss +15 -7
- package/styles/scss/components/collapse/_collapse.variables.scss +3 -3
- package/styles/scss/components/datepicker/_datepicker.scss +178 -122
- package/styles/scss/components/datepicker/_datepicker.variables.scss +22 -15
- package/styles/scss/components/dropdown/_dropdown.mixins.scss +4 -4
- package/styles/scss/components/dropdown/_dropdown.scss +39 -19
- package/styles/scss/components/dropdown/_dropdown.variables.scss +4 -4
- package/styles/scss/components/fieldset/_fieldset.scss +4 -2
- package/styles/scss/components/fonts/_fonts-family.scss +112 -29
- package/styles/scss/components/fonts/_fonts.root.scss +27 -0
- package/styles/scss/components/fonts/_fonts.scss +25 -26
- package/styles/scss/components/fonts/_fonts.variables.scss +2 -2
- package/styles/scss/components/footer/_footer.scss +48 -18
- package/styles/scss/components/footer/_footer.variables.scss +4 -2
- package/styles/scss/components/form/_form.scss +69 -16
- package/styles/scss/components/form/_form.variables.scss +23 -3
- package/styles/scss/components/icon/_amadeus-icon.scss +2 -2
- package/styles/scss/components/icon/_amadeus-icon.variables.scss +1 -0
- package/styles/scss/components/inputs/_inputs.mixin.scss +8 -4
- package/styles/scss/components/inputs/_inputs.root.scss +8 -0
- package/styles/scss/components/inputs/_inputs.scss +159 -118
- package/styles/scss/components/inputs/_inputs.variables.scss +2 -1
- package/styles/scss/components/link/_link.mixins.scss +49 -49
- package/styles/scss/components/link/_link.scss +84 -22
- package/styles/scss/components/link/_link.variables.scss +6 -6
- package/styles/scss/components/list/_list.scss +10 -5
- package/styles/scss/components/list-group/_list-group.scss +54 -48
- package/styles/scss/components/list-group/_list-group.variables.scss +6 -14
- package/styles/scss/components/media/_media.scss +17 -9
- package/styles/scss/components/media/_media.variables.scss +2 -1
- package/styles/scss/components/modal/_modal.scss +88 -39
- package/styles/scss/components/modal/_modal.variables.scss +4 -5
- package/styles/scss/components/navbar/_navbar.scss +298 -115
- package/styles/scss/components/navbar/_navbar.variables.scss +29 -18
- package/styles/scss/components/pagination/_pagination.scss +68 -82
- package/styles/scss/components/pagination/_pagination.variables.scss +5 -8
- package/styles/scss/components/pagination/_pagination_container.scss +3 -0
- package/styles/scss/components/popover/_popover.mixin.scss +20 -33
- package/styles/scss/components/popover/_popover.scss +25 -7
- package/styles/scss/components/popover/_popover_container.scss +123 -74
- package/styles/scss/components/progressbar/_progressbar.scss +15 -7
- package/styles/scss/components/progressbar/_progressbar.variables.scss +3 -2
- package/styles/scss/components/radio/_radio.scss +19 -14
- package/styles/scss/components/rating/_rating.scss +41 -22
- package/styles/scss/components/rating/_rating.variables.scss +5 -5
- package/styles/scss/components/scrollspy/_scrollspy.scss +30 -13
- package/styles/scss/components/scrollspy/_scrollspy.variables.scss +2 -1
- package/styles/scss/components/select/_select.scss +232 -166
- package/styles/scss/components/select/_select.variables.scss +15 -15
- package/styles/scss/components/separator/_separator.scss +2 -1
- package/styles/scss/components/sidenav/_sidenav.scss +208 -135
- package/styles/scss/components/sidenav/_sidenav.variables.scss +19 -20
- package/styles/scss/components/skip-links/_skip-links.scss +31 -16
- package/styles/scss/components/skip-links/_skip-links.variables.scss +6 -6
- package/styles/scss/components/slider/_slider.scss +11 -10
- package/styles/scss/components/slider/_slider.variables.scss +8 -8
- package/styles/scss/components/speechbubble/_speechbubble.scss +50 -30
- package/styles/scss/components/speechbubble/_speechbubble.variables.scss +4 -2
- package/styles/scss/components/spinner/_spinner.scss +34 -29
- package/styles/scss/components/stepper/_stepper.mixins.scss +111 -151
- package/styles/scss/components/stepper/_stepper.scss +163 -69
- package/styles/scss/components/stepper/_stepper.variables.scss +23 -17
- package/styles/scss/components/table/_advancedtables.scss +50 -31
- package/styles/scss/components/table/_table.variables.scss +3 -2
- package/styles/scss/components/tabs/_tabs.scss +98 -49
- package/styles/scss/components/tabs/_tabs.variables.scss +11 -10
- package/styles/scss/components/toast/_toast.scss +136 -68
- package/styles/scss/components/toast/_toast.variables.scss +4 -4
- package/styles/scss/components/toggle/_toggle.scss +90 -44
- package/styles/scss/components/toggle/_toggle.variables.scss +7 -5
- package/styles/scss/components/typeahead/_typeahead.scss +18 -8
- package/styles/scss/components/typeahead/_typeahead.variables.scss +1 -1
- package/styles/scss/df-styles-namespace.scss +8 -11
- package/styles/scss/df-styles.scss +6 -3
- package/styles/scss/themes/brand2023/_variables.scss +585 -0
- package/styles/scss/utilities/_common.utilities.scss +112 -32
- package/assets/fonts/amadeus-light/amadeus-light.svg +0 -8658
- package/assets/fonts/amadeus-light/amadeus-light.ttf +0 -0
- package/assets/fonts/amadeus-light/amadeus-light.woff +0 -0
- package/assets/fonts/amadeus-light/amadeus-light.woff2 +0 -0
- package/assets/icon-amadeus.svg +0 -1
- package/esm2022/lib/angular/utils/html-element-helper.mjs +0 -8
- package/esm2022/lib/angular/utils/titleTruncate.directive.mjs +0 -39
- package/lib/angular/utils/html-element-helper.d.ts +0 -5
- package/lib/angular/utils/titleTruncate.directive.d.ts +0 -16
- package/schematics/migrations/15_0_0/remove-ngx-slider/index.js.map +0 -1
- package/schematics/migrations/helpers.js.map +0 -1
- package/schematics/migrations/utils/project_tsconfig_paths.js.map +0 -1
- package/schematics/migrations/utils/typescript/compiler_host.js.map +0 -1
- package/schematics/migrations/utils/typescript/parse_tsconfig.js.map +0 -1
- package/schematics/ng-add/index.js.map +0 -1
- package/schematics/ng-add/schema.js.map +0 -1
- package/styles/scss/components/tooltip/_tooltip.scss +0 -3
- 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":"AAAA,OAAO,EAEL,SAAS,EACT,UAAU,EACV,YAAY,EAGZ,SAAS,EACT,MAAM,EACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,2BAA2B,EAAE,wBAAwB,EAAE,MAAM,6CAA6C,CAAC;AACpH,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;;AACrD,MAAM,CAAC,MAAM,aAAa,GAAG,iBAAiB,CAAC;AAO/C,MAAM,OAAO,sBAAsB;IALnC;QAMmB,eAAU,GAAsB,EAAE,CAAC;QAEnC,cAAS,GAAc,MAAM,CAAC,SAAS,CAAC,CAAC;QACzC,YAAO,GAAe,MAAM,CAAC,UAAU,CAAC,CAAC;KAgC3D;IA9BC,QAAQ;QACN,IAAI,CAAC,UAAU,CAAC,IAAI,CAClB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,EAAE,GAAG,EAAE;YAC9D,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC7B,CAAC,CAAC,CACH,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,CAClB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,KAAiB,EAAE,EAAE;YAC9E,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC;IAC1C,CAAC;IAED,kBAAkB,CAAC,KAAiB;QAClC,IACE,KAAK,CAAC,aAAa;YACnB,WAAW,IAAI,KAAK,CAAC,aAAa;YACjC,KAAK,CAAC,aAAa,CAAC,SAA0B,CAAC,QAAQ,CAAC,aAAa,CAAC,EACvE;YACA,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;SAC1C;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IACxC,CAAC;8GAnCU,sBAAsB;kGAAtB,sBAAsB;;2FAAtB,sBAAsB;kBALlC,SAAS;mBAAC;oBACT,QAAQ,EAAE,iBAAiB;oBAC3B,QAAQ,EAAE,eAAe;oBACzB,UAAU,EAAE,IAAI;iBACjB;;AA4CD,MAAM,OAAO,kBAAkB;IAL/B;QAOE,mBAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QACzB,YAAO,GAAe,MAAM,CAAC,UAAU,CAAC,CAAC;QACzC,wBAAmB,GAAgC,MAAM,CAAC,2BAA2B,CAAC,CAAC;KAgHzG;IA9GC,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC3E,CAAC;IAGD,eAAe;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAGD,eAAe;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,SAAS,KAAK,wBAAwB,CAAC,WAAW,EAAE;YAC3D,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;aAAM;YACL,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAC/B;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,IAAI,CAAC,SAAS,KAAK,wBAAwB,CAAC,WAAW,EAAE;YAC3D,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAC/B;aAAM;YACL,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;IACH,CAAC;IAGD,kBAAkB,CAAC,KAAoB;QACrC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU,EAAE;YACzC,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;IAGD,aAAa,CAAC,KAAoB;QAChC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU,EAAE;YACzC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;IAGD,eAAe,CAAC,KAAoB;QAClC,IAAI,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU,EAAE;YACxC,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;IAGD,iBAAiB,CAAC,KAAoB;QACpC,IAAI,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU,EAAE;YACxC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,WAAW,aAAa,EAAE,CAAC,CAAC;IACjF,CAAC;IAEO,YAAY;QAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QAClF,IAAI,UAAU,KAAK,CAAC,CAAC,EAAE;YACrB,QAAQ,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE,CAAC;SAC9B;IACH,CAAC;IAEO,sBAAsB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QAClF,6DAA6D;QAC7D,IAAI,UAAU,KAAK,CAAC,CAAC,EAAE;YACrB,wCAAwC;YACxC,IAAI,UAAU,KAAK,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBACtC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;aACrB;iBAAM;gBACL,QAAQ,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;aAClC;SACF;IACH,CAAC;IAEO,qBAAqB;QAC3B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QAClF,6DAA6D;QAC7D,IAAI,UAAU,KAAK,CAAC,CAAC,EAAE;YACrB,wCAAwC;YACxC,IAAI,UAAU,KAAK,CAAC,EAAE;gBACpB,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;aACvC;iBAAM;gBACL,QAAQ,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;aAClC;SACF;IACH,CAAC;IAED,kBAAkB;QAChB,4CAA4C;QAC5C,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE;YAChC,MAAM,QAAQ,GAAwB,IAAI,CAAC,QAAQ,EAAE,CAAC;YACtD,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,CAAC;YACnD,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE,CAAC;SAClC;IACH,CAAC;8GAnHU,kBAAkB;kGAAlB,kBAAkB;;2FAAlB,kBAAkB;kBAL9B,SAAS;mBAAC;oBACT,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,gBAAgB;oBAC1B,UAAU,EAAE,IAAI;iBACjB;8BAYC,eAAe;sBADd,YAAY;uBAAC,eAAe;gBAM7B,eAAe;sBADd,YAAY;uBAAC,eAAe;gBAsB7B,kBAAkB;sBADjB,YAAY;uBAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC;gBAS9C,aAAa;sBADZ,YAAY;uBAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC;gBAS7C,eAAe;sBADd,YAAY;uBAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC;gBAS7C,iBAAiB;sBADhB,YAAY;uBAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC","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,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcFRydW5jYXRlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1mYWN0b3J5L3NyYy9saWIvYW5ndWxhci90b29sdGlwL3RydW5jYXRlL3Rvb2x0aXBUcnVuY2F0ZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBMEMsTUFBTSxlQUFlLENBQUM7OztBQUdsRjs7R0FFRztBQU1ILE1BQU0sT0FBTywwQkFBMEI7SUFDckMsWUFDbUIsT0FBbUIsRUFDbkIsVUFBbUMsRUFDbkMsUUFBbUI7UUFGbkIsWUFBTyxHQUFQLE9BQU8sQ0FBWTtRQUNuQixlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQUNuQyxhQUFRLEdBQVIsUUFBUSxDQUFXO0lBQ25DLENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsZUFBZSxDQUFDLENBQUM7SUFDekUsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNqRixDQUFDO0lBRU8sV0FBVyxDQUFDLE9BQW9CO1FBQ3RDLE9BQU8sT0FBTyxFQUFFLFlBQVksR0FBRyxPQUFPLEVBQUUsWUFBWSxJQUFJLE9BQU8sRUFBRSxXQUFXLEdBQUcsT0FBTyxFQUFFLFdBQVcsQ0FBQztJQUN0RyxDQUFDOzhHQWpCVSwwQkFBMEI7a0dBQTFCLDBCQUEwQjs7MkZBQTFCLDBCQUEwQjtrQkFMdEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIERvQ2hlY2ssIEVsZW1lbnRSZWYsIE9uSW5pdCwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ2JUb29sdGlwIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnO1xuXG4vKipcbiAqIE15IGRmVG9vbHRpcFRydW5jYXRlIGRpcmVjdGl2ZVxuICovXG5ARGlyZWN0aXZlKHtcbiAgZXhwb3J0QXM6ICdkZlRvb2x0aXBUcnVuY2F0ZScsXG4gIHNlbGVjdG9yOiAnW2RmVG9vbHRpcFRydW5jYXRlXScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGZUb29sdGlwVHJ1bmNhdGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIERvQ2hlY2sge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IHRvb2x0aXA6IE5nYlRvb2x0aXAsXG4gICAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcbiAgICBwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyOiBSZW5kZXJlcjJcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMucmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICd0ZXh0LXRydW5jYXRlJyk7XG4gIH1cblxuICBuZ0RvQ2hlY2soKSB7XG4gICAgdGhpcy50b29sdGlwLmRpc2FibGVUb29sdGlwID0gIXRoaXMuaGFzT3ZlcmZsb3codGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQpO1xuICB9XG5cbiAgcHJpdmF0ZSBoYXNPdmVyZmxvdyhlbGVtZW50OiBIVE1MRWxlbWVudCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBlbGVtZW50Py5vZmZzZXRIZWlnaHQgPCBlbGVtZW50Py5zY3JvbGxIZWlnaHQgfHwgZWxlbWVudD8ub2Zmc2V0V2lkdGggPCBlbGVtZW50Py5zY3JvbGxXaWR0aDtcbiAgfVxufVxuIl19
|