@ngrdt/button 0.0.17 → 0.0.19
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 +7 -7
- package/fesm2022/ngrdt-button.mjs +118 -224
- package/fesm2022/ngrdt-button.mjs.map +1 -1
- package/index.d.ts +120 -5
- package/package.json +3 -4
- package/esm2022/index.mjs +0 -6
- package/esm2022/lib/button/rdt-button-base.mjs +0 -307
- package/esm2022/lib/button/rdt-button-constants.mjs +0 -7
- package/esm2022/lib/button/rdt-button-int.mjs +0 -2
- package/esm2022/lib/button/rdt-button-notification.service.mjs +0 -2
- package/esm2022/lib/button-outlet/rdt-button-outlet.directive.mjs +0 -69
- package/esm2022/ngrdt-button.mjs +0 -5
- package/lib/button/rdt-button-base.d.ts +0 -87
- package/lib/button/rdt-button-constants.d.ts +0 -7
- package/lib/button/rdt-button-int.d.ts +0 -29
- package/lib/button/rdt-button-notification.service.d.ts +0 -4
- package/lib/button-outlet/rdt-button-outlet.directive.d.ts +0 -25
package/index.d.ts
CHANGED
|
@@ -1,5 +1,120 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import * as _angular_core from '@angular/core';
|
|
2
|
+
import { Signal, ElementRef, Renderer2, EventEmitter, InjectionToken, Type, OnChanges } from '@angular/core';
|
|
3
|
+
import { Params, Router } from '@angular/router';
|
|
4
|
+
import { RdtInteractiveElementComponent, RdtLinkedState, RdtBooleanResult } from '@ngrdt/core';
|
|
5
|
+
import { Nullable, WindowOpenTargetType, AriaAttributes } from '@ngrdt/utils';
|
|
6
|
+
import { Observable } from 'rxjs';
|
|
7
|
+
|
|
8
|
+
interface RdtButtonBaseInputsInt<TIcon = string> {
|
|
9
|
+
label: Nullable<string>;
|
|
10
|
+
propagate: boolean;
|
|
11
|
+
tabIndex: Nullable<number>;
|
|
12
|
+
href: Nullable<string>;
|
|
13
|
+
ngHref: Nullable<string>;
|
|
14
|
+
target: WindowOpenTargetType;
|
|
15
|
+
stateParams: Nullable<Params>;
|
|
16
|
+
queryParams: Nullable<Params>;
|
|
17
|
+
download: Nullable<string>;
|
|
18
|
+
icon: Nullable<TIcon>;
|
|
19
|
+
dataTestId: string;
|
|
20
|
+
onlineEnabled$: Nullable<Observable<boolean>>;
|
|
21
|
+
aria: Partial<AriaAttributes>;
|
|
22
|
+
}
|
|
23
|
+
interface RdtButtonBaseInt<TIcon = string> extends RdtInteractiveElementComponent, RdtLinkedState<RdtButtonBaseInputsInt<TIcon>> {
|
|
24
|
+
readonly click$: Observable<MouseEvent>;
|
|
25
|
+
readonly anchorElement: Signal<HTMLElement | null>;
|
|
26
|
+
readonly focusElement: Signal<HTMLElement | null>;
|
|
27
|
+
readonly ariaElement: Signal<HTMLElement | null>;
|
|
28
|
+
focus(): void;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
interface RdtButtonNotificationServiceInt {
|
|
32
|
+
error(message: string): void;
|
|
33
|
+
accessDenied(): void;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
declare abstract class RdtButtonBase<TIcon = string> extends RdtInteractiveElementComponent implements RdtButtonBaseInt<TIcon> {
|
|
37
|
+
protected readonly elRef: ElementRef<any>;
|
|
38
|
+
protected readonly router: Router;
|
|
39
|
+
protected readonly baseHref: string;
|
|
40
|
+
protected readonly renderer: Renderer2;
|
|
41
|
+
protected readonly notificationService?: RdtButtonNotificationServiceInt;
|
|
42
|
+
protected internalDisabledMap: Record<symbol, boolean>;
|
|
43
|
+
protected internalLoadingMap: Record<symbol, boolean>;
|
|
44
|
+
abstract readonly focusElement: Signal<HTMLElement | null>;
|
|
45
|
+
abstract readonly ariaElement: Signal<HTMLElement | null>;
|
|
46
|
+
abstract readonly anchorElement: Signal<HTMLElement | null>;
|
|
47
|
+
readonly propagateInput: _angular_core.InputSignalWithTransform<boolean, unknown>;
|
|
48
|
+
readonly propagate: _angular_core.WritableSignal<boolean>;
|
|
49
|
+
readonly tabIndexInput: _angular_core.InputSignalWithTransform<number | null, unknown>;
|
|
50
|
+
readonly tabIndex: _angular_core.WritableSignal<number | null>;
|
|
51
|
+
readonly hrefInput: _angular_core.InputSignal<Nullable<string>>;
|
|
52
|
+
readonly href: _angular_core.WritableSignal<Nullable<string>>;
|
|
53
|
+
readonly ngHrefInput: _angular_core.InputSignal<Nullable<string>>;
|
|
54
|
+
readonly ngHref: _angular_core.WritableSignal<Nullable<string>>;
|
|
55
|
+
readonly targetInput: _angular_core.InputSignal<WindowOpenTargetType>;
|
|
56
|
+
readonly target: _angular_core.WritableSignal<WindowOpenTargetType>;
|
|
57
|
+
readonly stateParamsInput: _angular_core.InputSignal<Nullable<Params>>;
|
|
58
|
+
readonly stateParams: _angular_core.WritableSignal<Nullable<Params>>;
|
|
59
|
+
readonly queryParamsInput: _angular_core.InputSignal<Nullable<Params>>;
|
|
60
|
+
readonly queryParams: _angular_core.WritableSignal<Nullable<Params>>;
|
|
61
|
+
readonly downloadInput: _angular_core.InputSignal<Nullable<string>>;
|
|
62
|
+
readonly download: _angular_core.WritableSignal<Nullable<string>>;
|
|
63
|
+
readonly iconInput: _angular_core.InputSignal<Nullable<TIcon>>;
|
|
64
|
+
readonly icon: _angular_core.WritableSignal<Nullable<TIcon>>;
|
|
65
|
+
readonly labelInput: _angular_core.InputSignal<Nullable<string>>;
|
|
66
|
+
readonly label: _angular_core.WritableSignal<Nullable<string>>;
|
|
67
|
+
readonly dataTestIdInput: _angular_core.InputSignal<undefined>;
|
|
68
|
+
readonly dataTestId: _angular_core.WritableSignal<string>;
|
|
69
|
+
readonly onlineEnabledInput$: _angular_core.InputSignal<Nullable<Observable<boolean>>>;
|
|
70
|
+
readonly onlineEnabled$: _angular_core.WritableSignal<Nullable<Observable<boolean>>>;
|
|
71
|
+
readonly ariaInput: _angular_core.InputSignal<Partial<AriaAttributes>>;
|
|
72
|
+
readonly aria: _angular_core.WritableSignal<Partial<AriaAttributes>>;
|
|
73
|
+
readonly hrefWithParams: Signal<Nullable<string>>;
|
|
74
|
+
protected readonly ariaRenderEffect: _angular_core.AfterRenderRef;
|
|
75
|
+
readonly click$: EventEmitter<MouseEvent>;
|
|
76
|
+
focus(): void;
|
|
77
|
+
canFocus(): RdtBooleanResult;
|
|
78
|
+
protected onClicked($event: MouseEvent): void;
|
|
79
|
+
private emitAndStopProp;
|
|
80
|
+
private onClickPermissionAllowed;
|
|
81
|
+
private navigateOrEmit;
|
|
82
|
+
private notifyAccessDenied;
|
|
83
|
+
private finishOnlineCheck;
|
|
84
|
+
private updateAriaAttributes;
|
|
85
|
+
protected static readonly ONLINE_ENABLED_KEY: unique symbol;
|
|
86
|
+
static ɵfac: _angular_core.ɵɵFactoryDeclaration<RdtButtonBase<any>, never>;
|
|
87
|
+
static ɵdir: _angular_core.ɵɵDirectiveDeclaration<RdtButtonBase<any>, never, never, { "propagateInput": { "alias": "propagate"; "required": false; "isSignal": true; }; "tabIndexInput": { "alias": "tabIndex"; "required": false; "isSignal": true; }; "hrefInput": { "alias": "href"; "required": false; "isSignal": true; }; "ngHrefInput": { "alias": "ngHref"; "required": false; "isSignal": true; }; "targetInput": { "alias": "target"; "required": false; "isSignal": true; }; "stateParamsInput": { "alias": "stateParams"; "required": false; "isSignal": true; }; "queryParamsInput": { "alias": "queryParams"; "required": false; "isSignal": true; }; "downloadInput": { "alias": "download"; "required": false; "isSignal": true; }; "iconInput": { "alias": "icon"; "required": false; "isSignal": true; }; "labelInput": { "alias": "label"; "required": false; "isSignal": true; }; "dataTestIdInput": { "alias": "dataTestId"; "required": false; "isSignal": true; }; "onlineEnabledInput$": { "alias": "onlineEnabled"; "required": false; "isSignal": true; }; "ariaInput": { "alias": "aria"; "required": false; "isSignal": true; }; }, { "click$": "click$"; }, never, never, true, never>;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
declare const RDT_BUTTON_SETTER_KEY: unique symbol;
|
|
91
|
+
declare const RDT_BUTTON_DEFAULT_PROPAGATE = false;
|
|
92
|
+
declare const RDT_BUTTON_DEFAULT_TARGET = "_self";
|
|
93
|
+
declare const RDT_BUTTON_DEFAULT_TAB_INDEX: null;
|
|
94
|
+
declare const RDT_BUTTON_BASE_PROVIDER: InjectionToken<Type<RdtButtonBaseInt<string>>>;
|
|
95
|
+
|
|
96
|
+
declare class RdtButtonOutletDirective<TButton extends RdtButtonBaseInt, TButtonInputs extends RdtButtonBaseInputsInt = RdtButtonBaseInputsInt> implements OnChanges {
|
|
97
|
+
readonly buttonClass: _angular_core.Type<RdtButtonBaseInt<string>>;
|
|
98
|
+
private readonly _viewContainerRef;
|
|
99
|
+
inputs: Partial<TButtonInputs>;
|
|
100
|
+
click$: EventEmitter<MouseEvent>;
|
|
101
|
+
get instance(): TButton | undefined;
|
|
102
|
+
private _componentRef?;
|
|
103
|
+
/**
|
|
104
|
+
* A helper data structure that allows us to track inputs that were part of the
|
|
105
|
+
* ngComponentOutletInputs expression. Tracking inputs is necessary for proper removal of ones
|
|
106
|
+
* that are no longer referenced.
|
|
107
|
+
*/
|
|
108
|
+
private _inputsUsed;
|
|
109
|
+
constructor();
|
|
110
|
+
/** @nodoc */
|
|
111
|
+
ngOnChanges(): void;
|
|
112
|
+
private onInputsChanged;
|
|
113
|
+
/** @nodoc */
|
|
114
|
+
private _applyInputStateDiff;
|
|
115
|
+
static ɵfac: _angular_core.ɵɵFactoryDeclaration<RdtButtonOutletDirective<any, any>, never>;
|
|
116
|
+
static ɵdir: _angular_core.ɵɵDirectiveDeclaration<RdtButtonOutletDirective<any, any>, "[rdtButtonOutlet]", ["rdtButtonOutlet"], { "inputs": { "alias": "inputs"; "required": false; }; }, { "click$": "click$"; }, never, never, true, never>;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
export { RDT_BUTTON_BASE_PROVIDER, RDT_BUTTON_DEFAULT_PROPAGATE, RDT_BUTTON_DEFAULT_TAB_INDEX, RDT_BUTTON_DEFAULT_TARGET, RDT_BUTTON_SETTER_KEY, RdtButtonBase, RdtButtonOutletDirective };
|
|
120
|
+
export type { RdtButtonBaseInputsInt, RdtButtonBaseInt, RdtButtonNotificationServiceInt };
|
package/package.json
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ngrdt/button",
|
|
3
|
-
"version": "v0.0.
|
|
3
|
+
"version": "v0.0.19",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": ">=18.2.0",
|
|
6
6
|
"@angular/core": ">=18.2.0",
|
|
7
7
|
"@angular/router": ">=18.2.0",
|
|
8
8
|
"rxjs": ">=7.0.0",
|
|
9
|
-
"@ngrdt/utils": ">=0.0.
|
|
9
|
+
"@ngrdt/utils": ">=0.0.18",
|
|
10
|
+
"@ngrdt/core": ">=0.0.18"
|
|
10
11
|
},
|
|
11
12
|
"sideEffects": false,
|
|
12
13
|
"module": "fesm2022/ngrdt-button.mjs",
|
|
@@ -17,8 +18,6 @@
|
|
|
17
18
|
},
|
|
18
19
|
".": {
|
|
19
20
|
"types": "./index.d.ts",
|
|
20
|
-
"esm2022": "./esm2022/ngrdt-button.mjs",
|
|
21
|
-
"esm": "./esm2022/ngrdt-button.mjs",
|
|
22
21
|
"default": "./fesm2022/ngrdt-button.mjs"
|
|
23
22
|
}
|
|
24
23
|
},
|
package/esm2022/index.mjs
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export * from './lib/button/rdt-button-base';
|
|
2
|
-
export * from './lib/button/rdt-button-constants';
|
|
3
|
-
export * from './lib/button/rdt-button-int';
|
|
4
|
-
export * from './lib/button/rdt-button-notification.service';
|
|
5
|
-
export * from './lib/button-outlet/rdt-button-outlet.directive';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9AbmdyZHQvYnV0dG9uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhDQUE4QyxDQUFDO0FBRTdELGNBQWMsaURBQWlELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9idXR0b24vcmR0LWJ1dHRvbi1iYXNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYnV0dG9uL3JkdC1idXR0b24tY29uc3RhbnRzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYnV0dG9uL3JkdC1idXR0b24taW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYnV0dG9uL3JkdC1idXR0b24tbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYnV0dG9uLW91dGxldC9yZHQtYnV0dG9uLW91dGxldC5kaXJlY3RpdmUnO1xyXG4iXX0=
|
|
@@ -1,307 +0,0 @@
|
|
|
1
|
-
import { booleanAttribute, ChangeDetectorRef, Directive, ElementRef, EventEmitter, inject, Input, numberAttribute, Output, Renderer2, } from '@angular/core';
|
|
2
|
-
import { Router } from '@angular/router';
|
|
3
|
-
import { RdtStringUtils, } from '@ngrdt/utils';
|
|
4
|
-
import { take } from 'rxjs';
|
|
5
|
-
import { RDT_BUTTON_DEFAULT_TAB_INDEX, RDT_BUTTON_DEFAULT_TARGET, RDT_BUTTON_SETTER_KEY, } from './rdt-button-constants';
|
|
6
|
-
import { PlatformLocation } from '@angular/common';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export class RdtButtonBase {
|
|
9
|
-
elRef = inject(ElementRef);
|
|
10
|
-
cd = inject(ChangeDetectorRef);
|
|
11
|
-
router = inject(Router);
|
|
12
|
-
baseHref = inject(PlatformLocation).getBaseHrefFromDOM();
|
|
13
|
-
renderer = inject(Renderer2);
|
|
14
|
-
notificationService;
|
|
15
|
-
internalDisabledMap = {};
|
|
16
|
-
internalLoadingMap = {};
|
|
17
|
-
hrefWithParams;
|
|
18
|
-
get focusElement() {
|
|
19
|
-
return this.elRef?.nativeElement ?? null;
|
|
20
|
-
}
|
|
21
|
-
get ariaElement() {
|
|
22
|
-
return this.elRef?.nativeElement ?? null;
|
|
23
|
-
}
|
|
24
|
-
get anchorElement() {
|
|
25
|
-
return this.elRef?.nativeElement ?? null;
|
|
26
|
-
}
|
|
27
|
-
set disabled(value) {
|
|
28
|
-
this.setDisabled(RDT_BUTTON_SETTER_KEY, value);
|
|
29
|
-
}
|
|
30
|
-
get disabled() {
|
|
31
|
-
return this._disabled;
|
|
32
|
-
}
|
|
33
|
-
_disabled = false;
|
|
34
|
-
set loading(value) {
|
|
35
|
-
this.setLoading(RDT_BUTTON_SETTER_KEY, value);
|
|
36
|
-
}
|
|
37
|
-
get loading() {
|
|
38
|
-
return this._loading;
|
|
39
|
-
}
|
|
40
|
-
_loading = false;
|
|
41
|
-
propagate = false;
|
|
42
|
-
set tabIndex(value) {
|
|
43
|
-
this._tabIndex = value;
|
|
44
|
-
this.updateTabIndexValue();
|
|
45
|
-
}
|
|
46
|
-
get tabIndex() {
|
|
47
|
-
return this._tabIndex;
|
|
48
|
-
}
|
|
49
|
-
_tabIndex = RDT_BUTTON_DEFAULT_TAB_INDEX;
|
|
50
|
-
set href(value) {
|
|
51
|
-
this._href = value;
|
|
52
|
-
this.updateHrefWithQueryParams();
|
|
53
|
-
}
|
|
54
|
-
get href() {
|
|
55
|
-
return this._href;
|
|
56
|
-
}
|
|
57
|
-
_href;
|
|
58
|
-
set ngHref(value) {
|
|
59
|
-
this._ngHref = value;
|
|
60
|
-
this.cd.markForCheck();
|
|
61
|
-
}
|
|
62
|
-
get ngHref() {
|
|
63
|
-
return this._ngHref;
|
|
64
|
-
}
|
|
65
|
-
_ngHref;
|
|
66
|
-
set target(value) {
|
|
67
|
-
this._target = value;
|
|
68
|
-
this.cd.markForCheck();
|
|
69
|
-
}
|
|
70
|
-
get target() {
|
|
71
|
-
return this._target;
|
|
72
|
-
}
|
|
73
|
-
_target = RDT_BUTTON_DEFAULT_TARGET;
|
|
74
|
-
set stateParams(value) {
|
|
75
|
-
this._stateParams = value;
|
|
76
|
-
this.cd.markForCheck();
|
|
77
|
-
}
|
|
78
|
-
get stateParams() {
|
|
79
|
-
return this._stateParams;
|
|
80
|
-
}
|
|
81
|
-
_stateParams;
|
|
82
|
-
set queryParams(value) {
|
|
83
|
-
this._queryParams = value;
|
|
84
|
-
this.updateHrefWithQueryParams();
|
|
85
|
-
}
|
|
86
|
-
get queryParams() {
|
|
87
|
-
return this._queryParams;
|
|
88
|
-
}
|
|
89
|
-
_queryParams;
|
|
90
|
-
set download(value) {
|
|
91
|
-
this._download = value;
|
|
92
|
-
this.cd.markForCheck();
|
|
93
|
-
}
|
|
94
|
-
get download() {
|
|
95
|
-
return this._download ?? undefined;
|
|
96
|
-
}
|
|
97
|
-
_download;
|
|
98
|
-
set icon(value) {
|
|
99
|
-
this._icon = value;
|
|
100
|
-
this.cd.markForCheck();
|
|
101
|
-
}
|
|
102
|
-
get icon() {
|
|
103
|
-
return this._icon;
|
|
104
|
-
}
|
|
105
|
-
_icon;
|
|
106
|
-
set label(value) {
|
|
107
|
-
this._label = value;
|
|
108
|
-
this.cd.markForCheck();
|
|
109
|
-
}
|
|
110
|
-
get label() {
|
|
111
|
-
return this._label;
|
|
112
|
-
}
|
|
113
|
-
_label;
|
|
114
|
-
set dataTestId(value) {
|
|
115
|
-
this._dataTestId = value;
|
|
116
|
-
this.cd.markForCheck();
|
|
117
|
-
}
|
|
118
|
-
get dataTestId() {
|
|
119
|
-
return this._dataTestId;
|
|
120
|
-
}
|
|
121
|
-
_dataTestId = '';
|
|
122
|
-
set onlineEnabled$(value) {
|
|
123
|
-
this._onlineEnabled$ = value;
|
|
124
|
-
this.cd.markForCheck();
|
|
125
|
-
}
|
|
126
|
-
get onlineEnabled$() {
|
|
127
|
-
return this._onlineEnabled$;
|
|
128
|
-
}
|
|
129
|
-
_onlineEnabled$;
|
|
130
|
-
set aria(value) {
|
|
131
|
-
this._aria = value;
|
|
132
|
-
this.updateAriaAttributes();
|
|
133
|
-
}
|
|
134
|
-
get aria() {
|
|
135
|
-
return this._aria;
|
|
136
|
-
}
|
|
137
|
-
_aria = {};
|
|
138
|
-
click$ = new EventEmitter();
|
|
139
|
-
ngAfterViewInit() {
|
|
140
|
-
this.updateAriaAttributes();
|
|
141
|
-
}
|
|
142
|
-
setDisabled(key, disabled) {
|
|
143
|
-
this.internalDisabledMap[key] = disabled;
|
|
144
|
-
this.updateDisabledValue();
|
|
145
|
-
}
|
|
146
|
-
setLoading(key, disabled) {
|
|
147
|
-
this.internalLoadingMap[key] = disabled;
|
|
148
|
-
this.updateLoadingValue();
|
|
149
|
-
}
|
|
150
|
-
focus() {
|
|
151
|
-
this.focusElement?.focus();
|
|
152
|
-
}
|
|
153
|
-
onClicked($event) {
|
|
154
|
-
if (this._onlineEnabled$) {
|
|
155
|
-
if (this._disabled) {
|
|
156
|
-
return;
|
|
157
|
-
}
|
|
158
|
-
$event.stopPropagation();
|
|
159
|
-
this.setDisabled(RdtButtonBase.ONLINE_ENABLED_KEY, true);
|
|
160
|
-
this.setLoading(RdtButtonBase.ONLINE_ENABLED_KEY, true);
|
|
161
|
-
const observer = {
|
|
162
|
-
next: () => {
|
|
163
|
-
this.onClickPermissionAllowed($event);
|
|
164
|
-
this.finishOnlineCheck();
|
|
165
|
-
},
|
|
166
|
-
error: (error) => {
|
|
167
|
-
this.notifyAccessDenied(error);
|
|
168
|
-
this.finishOnlineCheck();
|
|
169
|
-
},
|
|
170
|
-
complete: () => this.finishOnlineCheck(),
|
|
171
|
-
};
|
|
172
|
-
this._onlineEnabled$.pipe(take(1)).subscribe(observer);
|
|
173
|
-
}
|
|
174
|
-
else {
|
|
175
|
-
this.emitAndStopProp($event);
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
emitAndStopProp($event) {
|
|
179
|
-
// stopPropagation prevents routerLinks from working
|
|
180
|
-
if (!this.propagate && !this._ngHref && !this._href) {
|
|
181
|
-
$event.stopPropagation();
|
|
182
|
-
}
|
|
183
|
-
if (!this._disabled && !this._ngHref && !this._href) {
|
|
184
|
-
this.click$.emit($event);
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
onClickPermissionAllowed($event) {
|
|
188
|
-
if (!this.propagate) {
|
|
189
|
-
$event.stopPropagation();
|
|
190
|
-
}
|
|
191
|
-
if (!this._disabled) {
|
|
192
|
-
this.navigateOrEmit($event);
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
navigateOrEmit(event) {
|
|
196
|
-
if (this._ngHref) {
|
|
197
|
-
if (this._target !== '_self') {
|
|
198
|
-
const absolutePath = RdtStringUtils.createAbsoluteUrl(this._ngHref, this.baseHref);
|
|
199
|
-
const pathWithParams = RdtStringUtils.appendQueryParams(absolutePath, this.queryParams);
|
|
200
|
-
window.open(pathWithParams, this._target);
|
|
201
|
-
}
|
|
202
|
-
else {
|
|
203
|
-
this.router.navigate([this._ngHref], {
|
|
204
|
-
queryParams: this._queryParams,
|
|
205
|
-
state: this._stateParams ?? undefined,
|
|
206
|
-
});
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
else if (this._href) {
|
|
210
|
-
const pathWithParams = RdtStringUtils.appendQueryParams(this._href, this.queryParams);
|
|
211
|
-
window.open(pathWithParams, this._target);
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
this.click$.emit(event);
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
notifyAccessDenied(error) {
|
|
218
|
-
if (this.notificationService) {
|
|
219
|
-
if (typeof error === 'string') {
|
|
220
|
-
this.notificationService.error(error);
|
|
221
|
-
}
|
|
222
|
-
else {
|
|
223
|
-
this.notificationService.accessDenied();
|
|
224
|
-
}
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
finishOnlineCheck() {
|
|
228
|
-
this.setDisabled(RdtButtonBase.ONLINE_ENABLED_KEY, false);
|
|
229
|
-
this.setLoading(RdtButtonBase.ONLINE_ENABLED_KEY, false);
|
|
230
|
-
}
|
|
231
|
-
updateDisabledValue() {
|
|
232
|
-
this._disabled = Object.values(this.internalDisabledMap).some((value) => value);
|
|
233
|
-
this.cd.markForCheck();
|
|
234
|
-
}
|
|
235
|
-
updateLoadingValue() {
|
|
236
|
-
this._loading = Object.values(this.internalLoadingMap).some((value) => value);
|
|
237
|
-
this.cd.markForCheck();
|
|
238
|
-
}
|
|
239
|
-
updateHrefWithQueryParams() {
|
|
240
|
-
if (this._href && this._queryParams) {
|
|
241
|
-
this.hrefWithParams = RdtStringUtils.appendQueryParams(this._href, this._queryParams);
|
|
242
|
-
}
|
|
243
|
-
else {
|
|
244
|
-
this.hrefWithParams = this._href;
|
|
245
|
-
}
|
|
246
|
-
this.cd.markForCheck();
|
|
247
|
-
}
|
|
248
|
-
updateTabIndexValue() {
|
|
249
|
-
this.cd.markForCheck();
|
|
250
|
-
}
|
|
251
|
-
updateAriaAttributes() {
|
|
252
|
-
const el = this.ariaElement;
|
|
253
|
-
if (this.ariaElement) {
|
|
254
|
-
Object.entries(this._aria).forEach(([key, value]) => {
|
|
255
|
-
if (value === null || value === undefined) {
|
|
256
|
-
this.renderer.removeAttribute(el, key);
|
|
257
|
-
}
|
|
258
|
-
else {
|
|
259
|
-
this.renderer.setAttribute(el, key, String(value));
|
|
260
|
-
}
|
|
261
|
-
});
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
static ONLINE_ENABLED_KEY = Symbol();
|
|
265
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtButtonBase, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
266
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.7", type: RdtButtonBase, inputs: { disabled: ["disabled", "disabled", booleanAttribute], loading: ["loading", "loading", booleanAttribute], propagate: ["propagate", "propagate", booleanAttribute], tabIndex: ["tabIndex", "tabIndex", numberAttribute], href: "href", ngHref: "ngHref", target: "target", stateParams: "stateParams", queryParams: "queryParams", download: "download", icon: "icon", label: "label", dataTestId: "dataTestId", onlineEnabled$: "onlineEnabled$", aria: "aria" }, outputs: { click$: "click$" }, ngImport: i0 });
|
|
267
|
-
}
|
|
268
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtButtonBase, decorators: [{
|
|
269
|
-
type: Directive
|
|
270
|
-
}], propDecorators: { disabled: [{
|
|
271
|
-
type: Input,
|
|
272
|
-
args: [{ transform: booleanAttribute }]
|
|
273
|
-
}], loading: [{
|
|
274
|
-
type: Input,
|
|
275
|
-
args: [{ transform: booleanAttribute }]
|
|
276
|
-
}], propagate: [{
|
|
277
|
-
type: Input,
|
|
278
|
-
args: [{ transform: booleanAttribute }]
|
|
279
|
-
}], tabIndex: [{
|
|
280
|
-
type: Input,
|
|
281
|
-
args: [{ transform: numberAttribute }]
|
|
282
|
-
}], href: [{
|
|
283
|
-
type: Input
|
|
284
|
-
}], ngHref: [{
|
|
285
|
-
type: Input
|
|
286
|
-
}], target: [{
|
|
287
|
-
type: Input
|
|
288
|
-
}], stateParams: [{
|
|
289
|
-
type: Input
|
|
290
|
-
}], queryParams: [{
|
|
291
|
-
type: Input
|
|
292
|
-
}], download: [{
|
|
293
|
-
type: Input
|
|
294
|
-
}], icon: [{
|
|
295
|
-
type: Input
|
|
296
|
-
}], label: [{
|
|
297
|
-
type: Input
|
|
298
|
-
}], dataTestId: [{
|
|
299
|
-
type: Input
|
|
300
|
-
}], onlineEnabled$: [{
|
|
301
|
-
type: Input
|
|
302
|
-
}], aria: [{
|
|
303
|
-
type: Input
|
|
304
|
-
}], click$: [{
|
|
305
|
-
type: Output
|
|
306
|
-
}] } });
|
|
307
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rdt-button-base.js","sourceRoot":"","sources":["../../../../../../@ngrdt/button/src/lib/button/rdt-button-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  booleanAttribute,\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  inject,\r\n  Input,\r\n  numberAttribute,\r\n  Output,\r\n  Renderer2,\r\n} from '@angular/core';\r\nimport { RdtButtonBaseInt } from './rdt-button-int';\r\nimport { Params, Router } from '@angular/router';\r\nimport {\r\n  Nullable,\r\n  WindowOpenTargetType,\r\n  RdtStringUtils,\r\n  AriaAttributes,\r\n} from '@ngrdt/utils';\r\nimport { Observable, take } from 'rxjs';\r\nimport {\r\n  RDT_BUTTON_DEFAULT_TAB_INDEX,\r\n  RDT_BUTTON_DEFAULT_TARGET,\r\n  RDT_BUTTON_SETTER_KEY,\r\n} from './rdt-button-constants';\r\nimport { RdtButtonNotificationServiceInt } from './rdt-button-notification.service';\r\nimport { PlatformLocation } from '@angular/common';\r\n\r\n@Directive()\r\nexport abstract class RdtButtonBase<TIcon = string>\r\n  implements RdtButtonBaseInt<TIcon>, AfterViewInit\r\n{\r\n  protected readonly elRef = inject(ElementRef);\r\n  protected readonly cd = inject(ChangeDetectorRef);\r\n  protected readonly router = inject(Router);\r\n  protected readonly baseHref = inject(PlatformLocation).getBaseHrefFromDOM();\r\n  protected readonly renderer = inject(Renderer2);\r\n\r\n  protected readonly notificationService?: RdtButtonNotificationServiceInt;\r\n\r\n  protected internalDisabledMap: Record<symbol, boolean> = {};\r\n  protected internalLoadingMap: Record<symbol, boolean> = {};\r\n  protected hrefWithParams: Nullable<string>;\r\n\r\n  get focusElement(): HTMLElement | null {\r\n    return this.elRef?.nativeElement ?? null;\r\n  }\r\n\r\n  get ariaElement(): HTMLElement | null {\r\n    return this.elRef?.nativeElement ?? null;\r\n  }\r\n\r\n  get anchorElement(): HTMLElement | null {\r\n    return this.elRef?.nativeElement ?? null;\r\n  }\r\n\r\n  @Input({ transform: booleanAttribute })\r\n  set disabled(value: boolean) {\r\n    this.setDisabled(RDT_BUTTON_SETTER_KEY, value);\r\n  }\r\n  get disabled(): boolean {\r\n    return this._disabled;\r\n  }\r\n  private _disabled = false;\r\n\r\n  @Input({ transform: booleanAttribute })\r\n  set loading(value: boolean) {\r\n    this.setLoading(RDT_BUTTON_SETTER_KEY, value);\r\n  }\r\n  get loading(): boolean {\r\n    return this._loading;\r\n  }\r\n  private _loading = false;\r\n\r\n  @Input({ transform: booleanAttribute })\r\n  propagate = false;\r\n\r\n  @Input({ transform: numberAttribute })\r\n  set tabIndex(value: Nullable<number>) {\r\n    this._tabIndex = value;\r\n    this.updateTabIndexValue();\r\n  }\r\n  get tabIndex() {\r\n    return this._tabIndex;\r\n  }\r\n  private _tabIndex: Nullable<number> = RDT_BUTTON_DEFAULT_TAB_INDEX;\r\n\r\n  @Input()\r\n  set href(value: Nullable<string>) {\r\n    this._href = value;\r\n    this.updateHrefWithQueryParams();\r\n  }\r\n  get href() {\r\n    return this._href;\r\n  }\r\n  private _href: Nullable<string>;\r\n\r\n  @Input()\r\n  set ngHref(value: Nullable<string>) {\r\n    this._ngHref = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get ngHref() {\r\n    return this._ngHref;\r\n  }\r\n  private _ngHref: Nullable<string>;\r\n\r\n  @Input()\r\n  set target(value: WindowOpenTargetType) {\r\n    this._target = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get target() {\r\n    return this._target;\r\n  }\r\n  private _target: WindowOpenTargetType = RDT_BUTTON_DEFAULT_TARGET;\r\n\r\n  @Input()\r\n  set stateParams(value: Nullable<Params>) {\r\n    this._stateParams = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get stateParams() {\r\n    return this._stateParams;\r\n  }\r\n  private _stateParams: Nullable<Params>;\r\n\r\n  @Input()\r\n  set queryParams(value: Nullable<Params>) {\r\n    this._queryParams = value;\r\n    this.updateHrefWithQueryParams();\r\n  }\r\n  get queryParams() {\r\n    return this._queryParams;\r\n  }\r\n  private _queryParams: Nullable<Params>;\r\n\r\n  @Input()\r\n  set download(value: Nullable<string>) {\r\n    this._download = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get download() {\r\n    return this._download ?? undefined;\r\n  }\r\n  private _download: Nullable<string>;\r\n\r\n  @Input()\r\n  set icon(value: Nullable<TIcon>) {\r\n    this._icon = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get icon() {\r\n    return this._icon;\r\n  }\r\n  private _icon: Nullable<TIcon>;\r\n\r\n  @Input()\r\n  set label(value: Nullable<string>) {\r\n    this._label = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get label() {\r\n    return this._label;\r\n  }\r\n  private _label: Nullable<string>;\r\n\r\n  @Input()\r\n  set dataTestId(value: string) {\r\n    this._dataTestId = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get dataTestId() {\r\n    return this._dataTestId;\r\n  }\r\n  private _dataTestId = '';\r\n\r\n  @Input()\r\n  set onlineEnabled$(value: Nullable<Observable<boolean>>) {\r\n    this._onlineEnabled$ = value;\r\n    this.cd.markForCheck();\r\n  }\r\n  get onlineEnabled$() {\r\n    return this._onlineEnabled$;\r\n  }\r\n  private _onlineEnabled$: Nullable<Observable<boolean>>;\r\n\r\n  @Input()\r\n  set aria(value: Partial<AriaAttributes>) {\r\n    this._aria = value;\r\n    this.updateAriaAttributes();\r\n  }\r\n  get aria() {\r\n    return this._aria;\r\n  }\r\n  private _aria: Partial<AriaAttributes> = {};\r\n\r\n  @Output()\r\n  readonly click$ = new EventEmitter<MouseEvent>();\r\n\r\n  ngAfterViewInit(): void {\r\n    this.updateAriaAttributes();\r\n  }\r\n\r\n  setDisabled(key: symbol, disabled: boolean): void {\r\n    this.internalDisabledMap[key] = disabled;\r\n    this.updateDisabledValue();\r\n  }\r\n\r\n  setLoading(key: symbol, disabled: boolean): void {\r\n    this.internalLoadingMap[key] = disabled;\r\n    this.updateLoadingValue();\r\n  }\r\n\r\n  focus(): void {\r\n    this.focusElement?.focus();\r\n  }\r\n\r\n  protected onClicked($event: MouseEvent) {\r\n    if (this._onlineEnabled$) {\r\n      if (this._disabled) {\r\n        return;\r\n      }\r\n\r\n      $event.stopPropagation();\r\n      this.setDisabled(RdtButtonBase.ONLINE_ENABLED_KEY, true);\r\n      this.setLoading(RdtButtonBase.ONLINE_ENABLED_KEY, true);\r\n      const observer = {\r\n        next: () => {\r\n          this.onClickPermissionAllowed($event);\r\n          this.finishOnlineCheck();\r\n        },\r\n        error: (error: any) => {\r\n          this.notifyAccessDenied(error);\r\n          this.finishOnlineCheck();\r\n        },\r\n        complete: () => this.finishOnlineCheck(),\r\n      };\r\n      this._onlineEnabled$.pipe(take(1)).subscribe(observer);\r\n    } else {\r\n      this.emitAndStopProp($event);\r\n    }\r\n  }\r\n\r\n  private emitAndStopProp($event: MouseEvent) {\r\n    // stopPropagation prevents routerLinks from working\r\n    if (!this.propagate && !this._ngHref && !this._href) {\r\n      $event.stopPropagation();\r\n    }\r\n    if (!this._disabled && !this._ngHref && !this._href) {\r\n      this.click$.emit($event);\r\n    }\r\n  }\r\n\r\n  private onClickPermissionAllowed($event: MouseEvent) {\r\n    if (!this.propagate) {\r\n      $event.stopPropagation();\r\n    }\r\n    if (!this._disabled) {\r\n      this.navigateOrEmit($event);\r\n    }\r\n  }\r\n\r\n  private navigateOrEmit(event: MouseEvent) {\r\n    if (this._ngHref) {\r\n      if (this._target !== '_self') {\r\n        const absolutePath = RdtStringUtils.createAbsoluteUrl(\r\n          this._ngHref,\r\n          this.baseHref\r\n        );\r\n        const pathWithParams = RdtStringUtils.appendQueryParams(\r\n          absolutePath,\r\n          this.queryParams\r\n        );\r\n        window.open(pathWithParams, this._target);\r\n      } else {\r\n        this.router.navigate([this._ngHref], {\r\n          queryParams: this._queryParams,\r\n          state: this._stateParams ?? undefined,\r\n        });\r\n      }\r\n    } else if (this._href) {\r\n      const pathWithParams = RdtStringUtils.appendQueryParams(\r\n        this._href,\r\n        this.queryParams\r\n      );\r\n      window.open(pathWithParams, this._target);\r\n    } else {\r\n      this.click$.emit(event);\r\n    }\r\n  }\r\n\r\n  private notifyAccessDenied(error?: unknown) {\r\n    if (this.notificationService) {\r\n      if (typeof error === 'string') {\r\n        this.notificationService.error(error);\r\n      } else {\r\n        this.notificationService.accessDenied();\r\n      }\r\n    }\r\n  }\r\n\r\n  private finishOnlineCheck() {\r\n    this.setDisabled(RdtButtonBase.ONLINE_ENABLED_KEY, false);\r\n    this.setLoading(RdtButtonBase.ONLINE_ENABLED_KEY, false);\r\n  }\r\n\r\n  private updateDisabledValue() {\r\n    this._disabled = Object.values(this.internalDisabledMap).some(\r\n      (value) => value\r\n    );\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  private updateLoadingValue() {\r\n    this._loading = Object.values(this.internalLoadingMap).some(\r\n      (value) => value\r\n    );\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  private updateHrefWithQueryParams() {\r\n    if (this._href && this._queryParams) {\r\n      this.hrefWithParams = RdtStringUtils.appendQueryParams(\r\n        this._href,\r\n        this._queryParams\r\n      );\r\n    } else {\r\n      this.hrefWithParams = this._href;\r\n    }\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  protected updateTabIndexValue() {\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  private updateAriaAttributes() {\r\n    const el = this.ariaElement;\r\n    if (this.ariaElement) {\r\n      Object.entries(this._aria).forEach(([key, value]) => {\r\n        if (value === null || value === undefined) {\r\n          this.renderer.removeAttribute(el, key);\r\n        } else {\r\n          this.renderer.setAttribute(el, key, String(value));\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  protected static readonly ONLINE_ENABLED_KEY = Symbol();\r\n}\r\n"]}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { InjectionToken } from '@angular/core';
|
|
2
|
-
export const RDT_BUTTON_SETTER_KEY = Symbol();
|
|
3
|
-
export const RDT_BUTTON_DEFAULT_PROPAGATE = false;
|
|
4
|
-
export const RDT_BUTTON_DEFAULT_TARGET = '_self';
|
|
5
|
-
export const RDT_BUTTON_DEFAULT_TAB_INDEX = null;
|
|
6
|
-
export const RDT_BUTTON_BASE_PROVIDER = new InjectionToken('RdtButton');
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmR0LWJ1dHRvbi1jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9AbmdyZHQvYnV0dG9uL3NyYy9saWIvYnV0dG9uL3JkdC1idXR0b24tY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFHckQsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsTUFBTSxFQUFFLENBQUM7QUFFOUMsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsS0FBSyxDQUFDO0FBQ2xELE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLE9BQU8sQ0FBQztBQUNqRCxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxJQUFJLENBQUM7QUFFakQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsSUFBSSxjQUFjLENBRXhELFdBQVcsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUmR0QnV0dG9uQmFzZUludCB9IGZyb20gJy4vcmR0LWJ1dHRvbi1pbnQnO1xyXG5cclxuZXhwb3J0IGNvbnN0IFJEVF9CVVRUT05fU0VUVEVSX0tFWSA9IFN5bWJvbCgpO1xyXG5cclxuZXhwb3J0IGNvbnN0IFJEVF9CVVRUT05fREVGQVVMVF9QUk9QQUdBVEUgPSBmYWxzZTtcclxuZXhwb3J0IGNvbnN0IFJEVF9CVVRUT05fREVGQVVMVF9UQVJHRVQgPSAnX3NlbGYnO1xyXG5leHBvcnQgY29uc3QgUkRUX0JVVFRPTl9ERUZBVUxUX1RBQl9JTkRFWCA9IG51bGw7XHJcblxyXG5leHBvcnQgY29uc3QgUkRUX0JVVFRPTl9CQVNFX1BST1ZJREVSID0gbmV3IEluamVjdGlvblRva2VuPFxyXG4gIFR5cGU8UmR0QnV0dG9uQmFzZUludD5cclxuPignUmR0QnV0dG9uJyk7XHJcbiJdfQ==
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmR0LWJ1dHRvbi1pbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9AbmdyZHQvYnV0dG9uL3NyYy9saWIvYnV0dG9uL3JkdC1idXR0b24taW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQYXJhbXMgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBBcmlhQXR0cmlidXRlcywgTnVsbGFibGUsIFdpbmRvd09wZW5UYXJnZXRUeXBlIH0gZnJvbSAnQG5ncmR0L3V0aWxzJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBSZHRCdXR0b25CYXNlSW5wdXRzSW50PFRJY29uID0gc3RyaW5nPiB7XHJcbiAgbGFiZWw6IE51bGxhYmxlPHN0cmluZz47XHJcbiAgZGlzYWJsZWQ6IGJvb2xlYW47XHJcbiAgbG9hZGluZzogYm9vbGVhbjtcclxuICBwcm9wYWdhdGU6IGJvb2xlYW47XHJcbiAgdGFiSW5kZXg6IE51bGxhYmxlPG51bWJlcj47XHJcbiAgaHJlZjogTnVsbGFibGU8c3RyaW5nPjtcclxuICBuZ0hyZWY6IE51bGxhYmxlPHN0cmluZz47XHJcbiAgdGFyZ2V0OiBXaW5kb3dPcGVuVGFyZ2V0VHlwZTtcclxuICBzdGF0ZVBhcmFtczogTnVsbGFibGU8UGFyYW1zPjtcclxuICBxdWVyeVBhcmFtczogTnVsbGFibGU8UGFyYW1zPjtcclxuICBkb3dubG9hZDogTnVsbGFibGU8c3RyaW5nPjtcclxuICBpY29uOiBOdWxsYWJsZTxUSWNvbj47XHJcbiAgZGF0YVRlc3RJZDogc3RyaW5nO1xyXG4gIG9ubGluZUVuYWJsZWQkOiBOdWxsYWJsZTxPYnNlcnZhYmxlPGJvb2xlYW4+PjtcclxuICBhcmlhOiBQYXJ0aWFsPEFyaWFBdHRyaWJ1dGVzPjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBSZHRCdXR0b25CYXNlSW50PFRJY29uID0gc3RyaW5nPlxyXG4gIGV4dGVuZHMgUmR0QnV0dG9uQmFzZUlucHV0c0ludDxUSWNvbj4ge1xyXG4gIHJlYWRvbmx5IGNsaWNrJDogT2JzZXJ2YWJsZTxNb3VzZUV2ZW50PjtcclxuXHJcbiAgcmVhZG9ubHkgYW5jaG9yRWxlbWVudDogSFRNTEVsZW1lbnQgfCBudWxsO1xyXG4gIHJlYWRvbmx5IGZvY3VzRWxlbWVudDogSFRNTEVsZW1lbnQgfCBudWxsO1xyXG4gIHJlYWRvbmx5IGFyaWFFbGVtZW50OiBIVE1MRWxlbWVudCB8IG51bGw7XHJcblxyXG4gIHNldERpc2FibGVkKGtleTogc3ltYm9sLCBkaXNhYmxlZDogYm9vbGVhbik6IHZvaWQ7XHJcbiAgc2V0TG9hZGluZyhrZXk6IHN5bWJvbCwgZGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkO1xyXG4gIGZvY3VzKCk6IHZvaWQ7XHJcbn1cclxuIl19
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmR0LWJ1dHRvbi1ub3RpZmljYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL0BuZ3JkdC9idXR0b24vc3JjL2xpYi9idXR0b24vcmR0LWJ1dHRvbi1ub3RpZmljYXRpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBSZHRCdXR0b25Ob3RpZmljYXRpb25TZXJ2aWNlSW50IHtcclxuICBlcnJvcihtZXNzYWdlOiBzdHJpbmcpOiB2b2lkO1xyXG4gIGFjY2Vzc0RlbmllZCgpOiB2b2lkO1xyXG59XHJcbiJdfQ==
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { Directive, EventEmitter, inject, Input, Output, ViewContainerRef, } from '@angular/core';
|
|
2
|
-
import { RDT_BUTTON_BASE_PROVIDER } from '../button/rdt-button-constants';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class RdtButtonOutletDirective {
|
|
5
|
-
buttonClass = inject(RDT_BUTTON_BASE_PROVIDER);
|
|
6
|
-
_viewContainerRef = inject(ViewContainerRef);
|
|
7
|
-
inputs = {};
|
|
8
|
-
click$ = new EventEmitter();
|
|
9
|
-
get instance() {
|
|
10
|
-
return this._componentRef?.instance;
|
|
11
|
-
}
|
|
12
|
-
_componentRef;
|
|
13
|
-
/**
|
|
14
|
-
* A helper data structure that allows us to track inputs that were part of the
|
|
15
|
-
* ngComponentOutletInputs expression. Tracking inputs is necessary for proper removal of ones
|
|
16
|
-
* that are no longer referenced.
|
|
17
|
-
*/
|
|
18
|
-
_inputsUsed = new Map();
|
|
19
|
-
constructor() {
|
|
20
|
-
const injector = this._viewContainerRef.injector;
|
|
21
|
-
this._componentRef = this._viewContainerRef.createComponent(this.buttonClass, {
|
|
22
|
-
injector,
|
|
23
|
-
});
|
|
24
|
-
this.onInputsChanged();
|
|
25
|
-
this._componentRef.instance.click$.subscribe(this.click$);
|
|
26
|
-
}
|
|
27
|
-
/** @nodoc */
|
|
28
|
-
ngOnChanges() {
|
|
29
|
-
this.onInputsChanged();
|
|
30
|
-
}
|
|
31
|
-
onInputsChanged() {
|
|
32
|
-
for (const inputName of Object.keys(this.inputs)) {
|
|
33
|
-
this._inputsUsed.set(inputName, true);
|
|
34
|
-
}
|
|
35
|
-
if (this._componentRef) {
|
|
36
|
-
this._applyInputStateDiff(this._componentRef);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
/** @nodoc */
|
|
40
|
-
_applyInputStateDiff(componentRef) {
|
|
41
|
-
for (const [inputName, touched] of this._inputsUsed) {
|
|
42
|
-
if (!touched) {
|
|
43
|
-
// The input that was previously active no longer exists and needs to be set to undefined.
|
|
44
|
-
componentRef.setInput(inputName, undefined);
|
|
45
|
-
this._inputsUsed.delete(inputName);
|
|
46
|
-
}
|
|
47
|
-
else {
|
|
48
|
-
// Since touched is true, it can be asserted that the inputs object is not empty.
|
|
49
|
-
componentRef.setInput(inputName, this.inputs[inputName]);
|
|
50
|
-
this._inputsUsed.set(inputName, false);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtButtonOutletDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
55
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: RdtButtonOutletDirective, isStandalone: true, selector: "[rdtButtonOutlet]", inputs: { inputs: "inputs" }, outputs: { click$: "click$" }, exportAs: ["rdtButtonOutlet"], usesOnChanges: true, ngImport: i0 });
|
|
56
|
-
}
|
|
57
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtButtonOutletDirective, decorators: [{
|
|
58
|
-
type: Directive,
|
|
59
|
-
args: [{
|
|
60
|
-
selector: '[rdtButtonOutlet]',
|
|
61
|
-
standalone: true,
|
|
62
|
-
exportAs: 'rdtButtonOutlet',
|
|
63
|
-
}]
|
|
64
|
-
}], ctorParameters: () => [], propDecorators: { inputs: [{
|
|
65
|
-
type: Input
|
|
66
|
-
}], click$: [{
|
|
67
|
-
type: Output
|
|
68
|
-
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmR0LWJ1dHRvbi1vdXRsZXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vQG5ncmR0L2J1dHRvbi9zcmMvbGliL2J1dHRvbi1vdXRsZXQvcmR0LWJ1dHRvbi1vdXRsZXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLE1BQU0sRUFDTixLQUFLLEVBRUwsTUFBTSxFQUNOLGdCQUFnQixHQUNqQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFXMUUsTUFBTSxPQUFPLHdCQUF3QjtJQUsxQixXQUFXLEdBQUcsTUFBTSxDQUFDLHdCQUF3QixDQUFDLENBQUM7SUFFdkMsaUJBQWlCLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFHOUQsTUFBTSxHQUEyQixFQUFFLENBQUM7SUFHcEMsTUFBTSxHQUFHLElBQUksWUFBWSxFQUFjLENBQUM7SUFFeEMsSUFBSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsYUFBYSxFQUFFLFFBQVEsQ0FBQztJQUN0QyxDQUFDO0lBQ08sYUFBYSxDQUF5QjtJQUU5Qzs7OztPQUlHO0lBQ0ssV0FBVyxHQUFHLElBQUksR0FBRyxFQUFtQixDQUFDO0lBRWpEO1FBQ0UsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQztRQUNqRCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLENBQ3pELElBQUksQ0FBQyxXQUFXLEVBQ2hCO1lBQ0UsUUFBUTtTQUNULENBQ3VCLENBQUM7UUFDM0IsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxhQUFhO0lBQ2IsV0FBVztRQUNULElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRU8sZUFBZTtRQUNyQixLQUFLLE1BQU0sU0FBUyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDakQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3hDLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN2QixJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2hELENBQUM7SUFDSCxDQUFDO0lBRUQsYUFBYTtJQUNMLG9CQUFvQixDQUFDLFlBQW1DO1FBQzlELEtBQUssTUFBTSxDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUMsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDcEQsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUNiLDBGQUEwRjtnQkFDMUYsWUFBWSxDQUFDLFFBQVEsQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7Z0JBQzVDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3JDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixpRkFBaUY7Z0JBQ2pGLFlBQVksQ0FBQyxRQUFRLENBQ25CLFNBQVMsRUFDVCxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQWdDLENBQUMsQ0FDOUMsQ0FBQztnQkFDRixJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDekMsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO3VHQXJFVSx3QkFBd0I7MkZBQXhCLHdCQUF3Qjs7MkZBQXhCLHdCQUF3QjtrQkFMcEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGlCQUFpQjtpQkFDNUI7d0RBV0MsTUFBTTtzQkFETCxLQUFLO2dCQUlOLE1BQU07c0JBREwsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50UmVmLFxyXG4gIERpcmVjdGl2ZSxcclxuICBFdmVudEVtaXR0ZXIsXHJcbiAgaW5qZWN0LFxyXG4gIElucHV0LFxyXG4gIE9uQ2hhbmdlcyxcclxuICBPdXRwdXQsXHJcbiAgVmlld0NvbnRhaW5lclJlZixcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUkRUX0JVVFRPTl9CQVNFX1BST1ZJREVSIH0gZnJvbSAnLi4vYnV0dG9uL3JkdC1idXR0b24tY29uc3RhbnRzJztcclxuaW1wb3J0IHtcclxuICBSZHRCdXR0b25CYXNlSW5wdXRzSW50LFxyXG4gIFJkdEJ1dHRvbkJhc2VJbnQsXHJcbn0gZnJvbSAnLi4vYnV0dG9uL3JkdC1idXR0b24taW50JztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW3JkdEJ1dHRvbk91dGxldF0nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgZXhwb3J0QXM6ICdyZHRCdXR0b25PdXRsZXQnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmR0QnV0dG9uT3V0bGV0RGlyZWN0aXZlPFxyXG4gIFRCdXR0b24gZXh0ZW5kcyBSZHRCdXR0b25CYXNlSW50LFxyXG4gIFRCdXR0b25JbnB1dHMgZXh0ZW5kcyBSZHRCdXR0b25CYXNlSW5wdXRzSW50ID0gUmR0QnV0dG9uQmFzZUlucHV0c0ludFxyXG4+IGltcGxlbWVudHMgT25DaGFuZ2VzXHJcbntcclxuICByZWFkb25seSBidXR0b25DbGFzcyA9IGluamVjdChSRFRfQlVUVE9OX0JBU0VfUFJPVklERVIpO1xyXG5cclxuICBwcml2YXRlIHJlYWRvbmx5IF92aWV3Q29udGFpbmVyUmVmID0gaW5qZWN0KFZpZXdDb250YWluZXJSZWYpO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIGlucHV0czogUGFydGlhbDxUQnV0dG9uSW5wdXRzPiA9IHt9O1xyXG5cclxuICBAT3V0cHV0KClcclxuICBjbGljayQgPSBuZXcgRXZlbnRFbWl0dGVyPE1vdXNlRXZlbnQ+KCk7XHJcblxyXG4gIGdldCBpbnN0YW5jZSgpIHtcclxuICAgIHJldHVybiB0aGlzLl9jb21wb25lbnRSZWY/Lmluc3RhbmNlO1xyXG4gIH1cclxuICBwcml2YXRlIF9jb21wb25lbnRSZWY/OiBDb21wb25lbnRSZWY8VEJ1dHRvbj47XHJcblxyXG4gIC8qKlxyXG4gICAqIEEgaGVscGVyIGRhdGEgc3RydWN0dXJlIHRoYXQgYWxsb3dzIHVzIHRvIHRyYWNrIGlucHV0cyB0aGF0IHdlcmUgcGFydCBvZiB0aGVcclxuICAgKiBuZ0NvbXBvbmVudE91dGxldElucHV0cyBleHByZXNzaW9uLiBUcmFja2luZyBpbnB1dHMgaXMgbmVjZXNzYXJ5IGZvciBwcm9wZXIgcmVtb3ZhbCBvZiBvbmVzXHJcbiAgICogdGhhdCBhcmUgbm8gbG9uZ2VyIHJlZmVyZW5jZWQuXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBfaW5wdXRzVXNlZCA9IG5ldyBNYXA8c3RyaW5nLCBib29sZWFuPigpO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIGNvbnN0IGluamVjdG9yID0gdGhpcy5fdmlld0NvbnRhaW5lclJlZi5pbmplY3RvcjtcclxuICAgIHRoaXMuX2NvbXBvbmVudFJlZiA9IHRoaXMuX3ZpZXdDb250YWluZXJSZWYuY3JlYXRlQ29tcG9uZW50KFxyXG4gICAgICB0aGlzLmJ1dHRvbkNsYXNzLFxyXG4gICAgICB7XHJcbiAgICAgICAgaW5qZWN0b3IsXHJcbiAgICAgIH1cclxuICAgICkgYXMgQ29tcG9uZW50UmVmPFRCdXR0b24+O1xyXG4gICAgdGhpcy5vbklucHV0c0NoYW5nZWQoKTtcclxuICAgIHRoaXMuX2NvbXBvbmVudFJlZi5pbnN0YW5jZS5jbGljayQuc3Vic2NyaWJlKHRoaXMuY2xpY2skKTtcclxuICB9XHJcblxyXG4gIC8qKiBAbm9kb2MgKi9cclxuICBuZ09uQ2hhbmdlcygpIHtcclxuICAgIHRoaXMub25JbnB1dHNDaGFuZ2VkKCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIG9uSW5wdXRzQ2hhbmdlZCgpIHtcclxuICAgIGZvciAoY29uc3QgaW5wdXROYW1lIG9mIE9iamVjdC5rZXlzKHRoaXMuaW5wdXRzKSkge1xyXG4gICAgICB0aGlzLl9pbnB1dHNVc2VkLnNldChpbnB1dE5hbWUsIHRydWUpO1xyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMuX2NvbXBvbmVudFJlZikge1xyXG4gICAgICB0aGlzLl9hcHBseUlucHV0U3RhdGVEaWZmKHRoaXMuX2NvbXBvbmVudFJlZik7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKiogQG5vZG9jICovXHJcbiAgcHJpdmF0ZSBfYXBwbHlJbnB1dFN0YXRlRGlmZihjb21wb25lbnRSZWY6IENvbXBvbmVudFJlZjx1bmtub3duPikge1xyXG4gICAgZm9yIChjb25zdCBbaW5wdXROYW1lLCB0b3VjaGVkXSBvZiB0aGlzLl9pbnB1dHNVc2VkKSB7XHJcbiAgICAgIGlmICghdG91Y2hlZCkge1xyXG4gICAgICAgIC8vIFRoZSBpbnB1dCB0aGF0IHdhcyBwcmV2aW91c2x5IGFjdGl2ZSBubyBsb25nZXIgZXhpc3RzIGFuZCBuZWVkcyB0byBiZSBzZXQgdG8gdW5kZWZpbmVkLlxyXG4gICAgICAgIGNvbXBvbmVudFJlZi5zZXRJbnB1dChpbnB1dE5hbWUsIHVuZGVmaW5lZCk7XHJcbiAgICAgICAgdGhpcy5faW5wdXRzVXNlZC5kZWxldGUoaW5wdXROYW1lKTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICAvLyBTaW5jZSB0b3VjaGVkIGlzIHRydWUsIGl0IGNhbiBiZSBhc3NlcnRlZCB0aGF0IHRoZSBpbnB1dHMgb2JqZWN0IGlzIG5vdCBlbXB0eS5cclxuICAgICAgICBjb21wb25lbnRSZWYuc2V0SW5wdXQoXHJcbiAgICAgICAgICBpbnB1dE5hbWUsXHJcbiAgICAgICAgICB0aGlzLmlucHV0c1tpbnB1dE5hbWUgYXMga2V5b2YgVEJ1dHRvbklucHV0c11cclxuICAgICAgICApO1xyXG4gICAgICAgIHRoaXMuX2lucHV0c1VzZWQuc2V0KGlucHV0TmFtZSwgZmFsc2UpO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
package/esm2022/ngrdt-button.mjs
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdyZHQtYnV0dG9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vQG5ncmR0L2J1dHRvbi9zcmMvbmdyZHQtYnV0dG9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|