@ng-atomic/common 19.21.7 → 19.24.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/directives/active-control/index.d.ts +52 -0
- package/directives/active-control/index.d.ts.map +1 -0
- package/fesm2022/ng-atomic-common-directives-active-control.mjs +287 -0
- package/fesm2022/ng-atomic-common-directives-active-control.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-services-auth.mjs +21 -1
- package/fesm2022/ng-atomic-common-services-auth.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-editing.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-router.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-stores-selection.mjs.map +1 -1
- package/fesm2022/ng-atomic-common.mjs +146 -39
- package/fesm2022/ng-atomic-common.mjs.map +1 -1
- package/index.d.ts +35 -17
- package/index.d.ts.map +1 -1
- package/interceptors/authorization/index.d.ts.map +1 -1
- package/interceptors/token/index.d.ts.map +1 -1
- package/models/index.d.ts.map +1 -1
- package/package.json +43 -39
- package/pipes/data-accessor/index.d.ts.map +1 -1
- package/pipes/error/index.d.ts.map +1 -1
- package/pipes/pagination/index.d.ts.map +1 -1
- package/pipes/select-id/index.d.ts.map +1 -1
- package/pipes/signal/index.d.ts.map +1 -1
- package/pipes/smart-field/index.d.ts.map +1 -1
- package/pipes/style/index.d.ts.map +1 -1
- package/services/auth/index.d.ts +6 -7
- package/services/auth/index.d.ts.map +1 -1
- package/services/breakpoint/index.d.ts.map +1 -1
- package/services/editing/index.d.ts +2 -2
- package/services/editing/index.d.ts.map +1 -1
- package/services/form/columns/index.d.ts.map +1 -1
- package/services/form/index.d.ts.map +1 -1
- package/services/form/pagination/index.d.ts.map +1 -1
- package/services/form/sort/index.d.ts.map +1 -1
- package/services/initializer/index.d.ts.map +1 -1
- package/services/language/index.d.ts.map +1 -1
- package/services/loading/index.d.ts.map +1 -1
- package/services/query-resolver/index.d.ts.map +1 -1
- package/services/router/index.d.ts +3 -4
- package/services/router/index.d.ts.map +1 -1
- package/services/side-nav-mode/index.d.ts.map +1 -1
- package/services/spreadsheet/index.d.ts.map +1 -1
- package/services/ui/index.d.ts.map +1 -1
- package/stores/entities/index.d.ts.map +1 -1
- package/stores/entity/index.d.ts.map +1 -1
- package/stores/pagination/index.d.ts.map +1 -1
- package/stores/query/index.d.ts.map +1 -1
- package/stores/selection/index.d.ts +7 -7
- package/stores/selection/index.d.ts.map +1 -1
- package/stores/sort/index.d.ts.map +1 -1
- package/utils/index.d.ts.map +1 -1
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import * as _angular_core from '@angular/core';
|
|
2
|
+
import { OnDestroy } from '@angular/core';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* アクティブ状態を管理するディレクティブ
|
|
6
|
+
*
|
|
7
|
+
* クリックでアクティブ化、外部クリックで非アクティブ化し、
|
|
8
|
+
* スクロール位置の固定やイベント伝播の制御を行います。
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```html
|
|
12
|
+
* <!-- 単一セレクタ -->
|
|
13
|
+
* <div appActiveControl
|
|
14
|
+
* [scrollSelector]="'.xterm-viewport'"
|
|
15
|
+
* (activeChange)="onActiveChange($event)">
|
|
16
|
+
* <!-- content -->
|
|
17
|
+
* </div>
|
|
18
|
+
*
|
|
19
|
+
* <!-- 複数セレクタ -->
|
|
20
|
+
* <div appActiveControl
|
|
21
|
+
* [scrollSelectors]="['.xterm-viewport', '.qtp-content']"
|
|
22
|
+
* (activeChange)="onActiveChange($event)">
|
|
23
|
+
* <!-- content -->
|
|
24
|
+
* </div>
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
declare class ActiveControlDirective implements OnDestroy {
|
|
28
|
+
private readonly el;
|
|
29
|
+
readonly scrollSelector: _angular_core.InputSignal<string>;
|
|
30
|
+
readonly scrollSelectors: _angular_core.InputSignal<string[]>;
|
|
31
|
+
/** mousedownでstopPropagationを呼ばない(React Flowなどのドラッグと共存するため) */
|
|
32
|
+
readonly disableStopPropagation: _angular_core.InputSignal<boolean>;
|
|
33
|
+
/** スクロール位置のロックを無効化する(常にスクロール可能にする) */
|
|
34
|
+
readonly disableScrollLock: _angular_core.InputSignal<boolean>;
|
|
35
|
+
/** nodragクラスを付与しない(React Flowのノードでドラッグを有効化するため) */
|
|
36
|
+
readonly disableNodrag: _angular_core.InputSignal<boolean>;
|
|
37
|
+
readonly activeChange: _angular_core.OutputEmitterRef<boolean>;
|
|
38
|
+
readonly isActive: _angular_core.WritableSignal<boolean>;
|
|
39
|
+
private eventCleanupFunctions;
|
|
40
|
+
private scrollCleanupFunctions;
|
|
41
|
+
private eventHandlersInitialized;
|
|
42
|
+
constructor();
|
|
43
|
+
ngOnDestroy(): void;
|
|
44
|
+
private initializeEventHandlers;
|
|
45
|
+
private setupScrollControls;
|
|
46
|
+
private getScrollSelectors;
|
|
47
|
+
static ɵfac: _angular_core.ɵɵFactoryDeclaration<ActiveControlDirective, never>;
|
|
48
|
+
static ɵdir: _angular_core.ɵɵDirectiveDeclaration<ActiveControlDirective, "[appActiveControl]", never, { "scrollSelector": { "alias": "scrollSelector"; "required": false; "isSignal": true; }; "scrollSelectors": { "alias": "scrollSelectors"; "required": false; "isSignal": true; }; "disableStopPropagation": { "alias": "disableStopPropagation"; "required": false; "isSignal": true; }; "disableScrollLock": { "alias": "disableScrollLock"; "required": false; "isSignal": true; }; "disableNodrag": { "alias": "disableNodrag"; "required": false; "isSignal": true; }; }, { "activeChange": "activeChange"; }, never, never, true, never>;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export { ActiveControlDirective };
|
|
52
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sources":["../../../../../../packages/@ng-atomic/common/src/lib/directives/active-control/active-control.directive.ts"],"sourcesContent":[null],"names":[],"mappings":";;;AAGA;;;;;;;;;;;;;;;;;;;;;;AAsBG;AACH,cAAA,sBAAA,YAAA,SAAA;AAUE;6BACuB,aAAA,CAAA,WAAA;8BACC,aAAA,CAAA,WAAA;;qCAEO,aAAA,CAAA,WAAA;;gCAEL,aAAA,CAAA,WAAA;;4BAEJ,aAAA,CAAA,WAAA;2BACD,aAAA,CAAA,gBAAA;uBACJ,aAAA,CAAA,cAAA;;;;;AAsBjB;AAKA;AAYA;AAiBA;;;AAQD;;;;"}
|
|
@@ -0,0 +1,287 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { inject, ElementRef, input, output, signal, effect, Directive } from '@angular/core';
|
|
3
|
+
|
|
4
|
+
class ActiveControlEventHandlers {
|
|
5
|
+
constructor(hostElement, isActive, onActiveChange, options = {}) {
|
|
6
|
+
this.hostElement = hostElement;
|
|
7
|
+
this.isActive = isActive;
|
|
8
|
+
this.onActiveChange = onActiveChange;
|
|
9
|
+
this.options = options;
|
|
10
|
+
this.cleanupFunctions = [];
|
|
11
|
+
}
|
|
12
|
+
setupAll() {
|
|
13
|
+
this.setupClickHandlers();
|
|
14
|
+
this.setupPreventionHandlers();
|
|
15
|
+
return this.cleanupFunctions;
|
|
16
|
+
}
|
|
17
|
+
setupClickHandlers() {
|
|
18
|
+
// ホスト要素クリック
|
|
19
|
+
const mousedownHandler = (e) => {
|
|
20
|
+
this.toggleActive();
|
|
21
|
+
// React Flowなどのドラッグと共存するため、オプションでstopPropagationを無効化
|
|
22
|
+
if (!this.options.disableStopPropagation) {
|
|
23
|
+
e.stopPropagation();
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
this.addEventListener(this.hostElement, 'mousedown', mousedownHandler);
|
|
27
|
+
// 外部クリック
|
|
28
|
+
const documentClickListener = (e) => {
|
|
29
|
+
if (!this.hostElement.contains(e.target) && this.isActive()) {
|
|
30
|
+
this.setActive(false);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
document.addEventListener('mousedown', documentClickListener, { capture: true });
|
|
34
|
+
this.cleanupFunctions.push(() => document.removeEventListener('mousedown', documentClickListener, { capture: true }));
|
|
35
|
+
}
|
|
36
|
+
setupPreventionHandlers() {
|
|
37
|
+
// ホイールイベント(スクロール対象要素以外でのみブロック)
|
|
38
|
+
// ただし、ctrlKey + wheel(トラックパッドのピンチズーム)は常にブロック
|
|
39
|
+
// 非アクティブ時はScrollControlがスクロール位置をリセットするため、ここでは処理しない
|
|
40
|
+
this.addEventListener(this.hostElement, 'wheel', (e) => {
|
|
41
|
+
if (this.isActive()) {
|
|
42
|
+
// ctrlKey + wheel = トラックパッドのピンチズーム → 常にブロック
|
|
43
|
+
if (e.ctrlKey) {
|
|
44
|
+
e.preventDefault();
|
|
45
|
+
e.stopPropagation();
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
// 通常のホイールスクロール: スクロール対象要素からのイベントは許可
|
|
49
|
+
const target = e.target;
|
|
50
|
+
const isScrollableElement = this.options.scrollSelectors?.some(selector => target.closest(selector) !== null);
|
|
51
|
+
if (!isScrollableElement) {
|
|
52
|
+
e.preventDefault();
|
|
53
|
+
e.stopPropagation();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}, { passive: false });
|
|
57
|
+
// タッチイベント(ホスト要素レベル)
|
|
58
|
+
const touchHandler = (e) => {
|
|
59
|
+
if (!this.isActive())
|
|
60
|
+
return;
|
|
61
|
+
// スクロール対象要素からのイベントは許可
|
|
62
|
+
const target = e.target;
|
|
63
|
+
const isScrollableElement = this.options.scrollSelectors?.some(selector => target.closest(selector) !== null);
|
|
64
|
+
if (!isScrollableElement) {
|
|
65
|
+
if (e.touches.length > 1) {
|
|
66
|
+
// ピンチズームなどマルチタッチ操作をブロック
|
|
67
|
+
e.preventDefault();
|
|
68
|
+
e.stopPropagation();
|
|
69
|
+
}
|
|
70
|
+
// シングルタッチはデフォルト動作を許可(スクロールなど)
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
this.addEventListener(this.hostElement, 'touchstart', touchHandler, { passive: false });
|
|
74
|
+
this.addEventListener(this.hostElement, 'touchmove', touchHandler, { passive: false });
|
|
75
|
+
// ジェスチャーイベント(ホスト要素レベル)
|
|
76
|
+
const gestureHandler = (e) => {
|
|
77
|
+
if (this.isActive()) {
|
|
78
|
+
e.preventDefault();
|
|
79
|
+
e.stopPropagation();
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
['gesturestart', 'gesturechange', 'gestureend'].forEach(eventName => {
|
|
83
|
+
this.addEventListener(this.hostElement, eventName, gestureHandler, { passive: false });
|
|
84
|
+
});
|
|
85
|
+
// Document-level capture phaseハンドラ
|
|
86
|
+
// ブラウザのピンチズームがデフォルト動作を行う前にキャッチする
|
|
87
|
+
this.setupDocumentLevelPinchZoomPrevention();
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Document-levelでcapture phaseを使ってピンチズームを防止
|
|
91
|
+
* ホスト要素内で発生したマルチタッチ/ジェスチャーイベントのみをブロック
|
|
92
|
+
*/
|
|
93
|
+
setupDocumentLevelPinchZoomPrevention() {
|
|
94
|
+
// タッチイベント(capture phase)
|
|
95
|
+
const documentTouchHandler = (e) => {
|
|
96
|
+
if (!this.isActive())
|
|
97
|
+
return;
|
|
98
|
+
if (!this.hostElement.contains(e.target))
|
|
99
|
+
return;
|
|
100
|
+
if (e.touches.length > 1) {
|
|
101
|
+
e.preventDefault();
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
document.addEventListener('touchstart', documentTouchHandler, { capture: true, passive: false });
|
|
105
|
+
document.addEventListener('touchmove', documentTouchHandler, { capture: true, passive: false });
|
|
106
|
+
this.cleanupFunctions.push(() => {
|
|
107
|
+
document.removeEventListener('touchstart', documentTouchHandler, { capture: true });
|
|
108
|
+
document.removeEventListener('touchmove', documentTouchHandler, { capture: true });
|
|
109
|
+
});
|
|
110
|
+
// Safari gestureイベント(capture phase)
|
|
111
|
+
const documentGestureHandler = (e) => {
|
|
112
|
+
if (!this.isActive())
|
|
113
|
+
return;
|
|
114
|
+
if (!this.hostElement.contains(e.target))
|
|
115
|
+
return;
|
|
116
|
+
e.preventDefault();
|
|
117
|
+
};
|
|
118
|
+
['gesturestart', 'gesturechange', 'gestureend'].forEach(eventName => {
|
|
119
|
+
document.addEventListener(eventName, documentGestureHandler, { capture: true, passive: false });
|
|
120
|
+
this.cleanupFunctions.push(() => document.removeEventListener(eventName, documentGestureHandler, { capture: true }));
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
addEventListener(element, event, handler, options) {
|
|
124
|
+
element.addEventListener(event, handler, options);
|
|
125
|
+
this.cleanupFunctions.push(() => element.removeEventListener(event, handler, options));
|
|
126
|
+
}
|
|
127
|
+
toggleActive() {
|
|
128
|
+
this.setActive(!this.isActive());
|
|
129
|
+
}
|
|
130
|
+
setActive(active) {
|
|
131
|
+
this.isActive.set(active);
|
|
132
|
+
this.onActiveChange(active);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
class ScrollControl {
|
|
137
|
+
constructor(scrollElement, isActive, options = {}) {
|
|
138
|
+
this.scrollElement = scrollElement;
|
|
139
|
+
this.isActive = isActive;
|
|
140
|
+
this.options = options;
|
|
141
|
+
this.lockedScrollTop = 0;
|
|
142
|
+
this.wasActive = false;
|
|
143
|
+
}
|
|
144
|
+
setup() {
|
|
145
|
+
const cleanups = [];
|
|
146
|
+
// アクティブ状態の監視
|
|
147
|
+
const checkActiveState = () => {
|
|
148
|
+
const isActiveNow = this.isActive();
|
|
149
|
+
if (!this.options.disableScrollLock) {
|
|
150
|
+
if (!isActiveNow && this.wasActive) {
|
|
151
|
+
// アクティブ → 非アクティブ: 現在位置をロック
|
|
152
|
+
this.lockedScrollTop = this.scrollElement.scrollTop;
|
|
153
|
+
}
|
|
154
|
+
else if (!isActiveNow) {
|
|
155
|
+
// 継続して非アクティブ: ロック位置を維持
|
|
156
|
+
this.scrollElement.scrollTop = this.lockedScrollTop;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
// アクティブ時 or disableScrollLock時: 何もしない(自由スクロール)
|
|
160
|
+
this.wasActive = isActiveNow;
|
|
161
|
+
this.rafId = requestAnimationFrame(checkActiveState);
|
|
162
|
+
};
|
|
163
|
+
checkActiveState();
|
|
164
|
+
cleanups.push(() => {
|
|
165
|
+
if (this.rafId !== undefined) {
|
|
166
|
+
cancelAnimationFrame(this.rafId);
|
|
167
|
+
}
|
|
168
|
+
});
|
|
169
|
+
// スクロールイベント監視
|
|
170
|
+
const scrollHandler = () => {
|
|
171
|
+
if (!this.options.disableScrollLock && !this.isActive()) {
|
|
172
|
+
this.scrollElement.scrollTop = this.lockedScrollTop;
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
this.scrollElement.addEventListener('scroll', scrollHandler);
|
|
176
|
+
cleanups.push(() => this.scrollElement.removeEventListener('scroll', scrollHandler));
|
|
177
|
+
return cleanups;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
/**
|
|
182
|
+
* アクティブ状態を管理するディレクティブ
|
|
183
|
+
*
|
|
184
|
+
* クリックでアクティブ化、外部クリックで非アクティブ化し、
|
|
185
|
+
* スクロール位置の固定やイベント伝播の制御を行います。
|
|
186
|
+
*
|
|
187
|
+
* @example
|
|
188
|
+
* ```html
|
|
189
|
+
* <!-- 単一セレクタ -->
|
|
190
|
+
* <div appActiveControl
|
|
191
|
+
* [scrollSelector]="'.xterm-viewport'"
|
|
192
|
+
* (activeChange)="onActiveChange($event)">
|
|
193
|
+
* <!-- content -->
|
|
194
|
+
* </div>
|
|
195
|
+
*
|
|
196
|
+
* <!-- 複数セレクタ -->
|
|
197
|
+
* <div appActiveControl
|
|
198
|
+
* [scrollSelectors]="['.xterm-viewport', '.qtp-content']"
|
|
199
|
+
* (activeChange)="onActiveChange($event)">
|
|
200
|
+
* <!-- content -->
|
|
201
|
+
* </div>
|
|
202
|
+
* ```
|
|
203
|
+
*/
|
|
204
|
+
class ActiveControlDirective {
|
|
205
|
+
constructor() {
|
|
206
|
+
this.el = inject(ElementRef);
|
|
207
|
+
this.scrollSelector = input();
|
|
208
|
+
this.scrollSelectors = input();
|
|
209
|
+
/** mousedownでstopPropagationを呼ばない(React Flowなどのドラッグと共存するため) */
|
|
210
|
+
this.disableStopPropagation = input(false);
|
|
211
|
+
/** スクロール位置のロックを無効化する(常にスクロール可能にする) */
|
|
212
|
+
this.disableScrollLock = input(false);
|
|
213
|
+
/** nodragクラスを付与しない(React Flowのノードでドラッグを有効化するため) */
|
|
214
|
+
this.disableNodrag = input(false);
|
|
215
|
+
this.activeChange = output();
|
|
216
|
+
this.isActive = signal(false);
|
|
217
|
+
this.eventCleanupFunctions = [];
|
|
218
|
+
this.scrollCleanupFunctions = [];
|
|
219
|
+
this.eventHandlersInitialized = false;
|
|
220
|
+
// イベントハンドラーの初期化(一度だけ)
|
|
221
|
+
effect(() => {
|
|
222
|
+
if (!this.eventHandlersInitialized) {
|
|
223
|
+
setTimeout(() => this.initializeEventHandlers(), 100);
|
|
224
|
+
this.eventHandlersInitialized = true;
|
|
225
|
+
}
|
|
226
|
+
}, { allowSignalWrites: true });
|
|
227
|
+
// スクロール制御の初期化(セレクタが変わるたびに再設定)
|
|
228
|
+
effect(() => {
|
|
229
|
+
const selectors = this.getScrollSelectors();
|
|
230
|
+
setTimeout(() => this.setupScrollControls(selectors), 150);
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
ngOnDestroy() {
|
|
234
|
+
this.eventCleanupFunctions.forEach(cleanup => cleanup());
|
|
235
|
+
this.scrollCleanupFunctions.forEach(cleanup => cleanup());
|
|
236
|
+
}
|
|
237
|
+
initializeEventHandlers() {
|
|
238
|
+
const hostElement = this.el.nativeElement;
|
|
239
|
+
const scrollSelectors = this.getScrollSelectors();
|
|
240
|
+
const eventHandlers = new ActiveControlEventHandlers(hostElement, this.isActive, (active) => this.activeChange.emit(active), { disableStopPropagation: this.disableStopPropagation(), scrollSelectors });
|
|
241
|
+
this.eventCleanupFunctions.push(...eventHandlers.setupAll());
|
|
242
|
+
}
|
|
243
|
+
setupScrollControls(selectors) {
|
|
244
|
+
// 既存のスクロール制御をクリーンアップ
|
|
245
|
+
this.scrollCleanupFunctions.forEach(cleanup => cleanup());
|
|
246
|
+
this.scrollCleanupFunctions = [];
|
|
247
|
+
const hostElement = this.el.nativeElement;
|
|
248
|
+
const disableScrollLock = this.disableScrollLock();
|
|
249
|
+
for (const selector of selectors) {
|
|
250
|
+
// querySelectorAll を使用して全てのマッチする要素を取得
|
|
251
|
+
const scrollElements = hostElement.querySelectorAll(selector);
|
|
252
|
+
scrollElements.forEach(scrollElement => {
|
|
253
|
+
const scrollControl = new ScrollControl(scrollElement, this.isActive, { disableScrollLock });
|
|
254
|
+
this.scrollCleanupFunctions.push(...scrollControl.setup());
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
getScrollSelectors() {
|
|
259
|
+
const multiple = this.scrollSelectors();
|
|
260
|
+
if (multiple && multiple.length > 0) {
|
|
261
|
+
return multiple;
|
|
262
|
+
}
|
|
263
|
+
const single = this.scrollSelector();
|
|
264
|
+
return single ? [single] : [];
|
|
265
|
+
}
|
|
266
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: ActiveControlDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
267
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "20.0.5", type: ActiveControlDirective, isStandalone: true, selector: "[appActiveControl]", inputs: { scrollSelector: { classPropertyName: "scrollSelector", publicName: "scrollSelector", isSignal: true, isRequired: false, transformFunction: null }, scrollSelectors: { classPropertyName: "scrollSelectors", publicName: "scrollSelectors", isSignal: true, isRequired: false, transformFunction: null }, disableStopPropagation: { classPropertyName: "disableStopPropagation", publicName: "disableStopPropagation", isSignal: true, isRequired: false, transformFunction: null }, disableScrollLock: { classPropertyName: "disableScrollLock", publicName: "disableScrollLock", isSignal: true, isRequired: false, transformFunction: null }, disableNodrag: { classPropertyName: "disableNodrag", publicName: "disableNodrag", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { activeChange: "activeChange" }, host: { properties: { "class.active": "isActive()", "class.nodrag": "!disableNodrag()", "class.nowheel": "isActive()" } }, ngImport: i0 }); }
|
|
268
|
+
}
|
|
269
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: ActiveControlDirective, decorators: [{
|
|
270
|
+
type: Directive,
|
|
271
|
+
args: [{
|
|
272
|
+
selector: '[appActiveControl]',
|
|
273
|
+
standalone: true,
|
|
274
|
+
host: {
|
|
275
|
+
'[class.active]': 'isActive()',
|
|
276
|
+
'[class.nodrag]': '!disableNodrag()',
|
|
277
|
+
'[class.nowheel]': 'isActive()',
|
|
278
|
+
}
|
|
279
|
+
}]
|
|
280
|
+
}], ctorParameters: () => [] });
|
|
281
|
+
|
|
282
|
+
/**
|
|
283
|
+
* Generated bundle index. Do not edit.
|
|
284
|
+
*/
|
|
285
|
+
|
|
286
|
+
export { ActiveControlDirective };
|
|
287
|
+
//# sourceMappingURL=ng-atomic-common-directives-active-control.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-directives-active-control.mjs","sources":["../tmp-esm2022/directives/active-control/handlers/event-handlers.js","../tmp-esm2022/directives/active-control/handlers/scroll-control.js","../tmp-esm2022/directives/active-control/active-control.directive.js","../tmp-esm2022/directives/active-control/ng-atomic-common-directives-active-control.js"],"sourcesContent":["export class ActiveControlEventHandlers {\n constructor(hostElement, isActive, onActiveChange, options = {}) {\n this.hostElement = hostElement;\n this.isActive = isActive;\n this.onActiveChange = onActiveChange;\n this.options = options;\n this.cleanupFunctions = [];\n }\n setupAll() {\n this.setupClickHandlers();\n this.setupPreventionHandlers();\n return this.cleanupFunctions;\n }\n setupClickHandlers() {\n // ホスト要素クリック\n const mousedownHandler = (e) => {\n this.toggleActive();\n // React Flowなどのドラッグと共存するため、オプションでstopPropagationを無効化\n if (!this.options.disableStopPropagation) {\n e.stopPropagation();\n }\n };\n this.addEventListener(this.hostElement, 'mousedown', mousedownHandler);\n // 外部クリック\n const documentClickListener = (e) => {\n if (!this.hostElement.contains(e.target) && this.isActive()) {\n this.setActive(false);\n }\n };\n document.addEventListener('mousedown', documentClickListener, { capture: true });\n this.cleanupFunctions.push(() => document.removeEventListener('mousedown', documentClickListener, { capture: true }));\n }\n setupPreventionHandlers() {\n // ホイールイベント(スクロール対象要素以外でのみブロック)\n // ただし、ctrlKey + wheel(トラックパッドのピンチズーム)は常にブロック\n // 非アクティブ時はScrollControlがスクロール位置をリセットするため、ここでは処理しない\n this.addEventListener(this.hostElement, 'wheel', (e) => {\n if (this.isActive()) {\n // ctrlKey + wheel = トラックパッドのピンチズーム → 常にブロック\n if (e.ctrlKey) {\n e.preventDefault();\n e.stopPropagation();\n return;\n }\n // 通常のホイールスクロール: スクロール対象要素からのイベントは許可\n const target = e.target;\n const isScrollableElement = this.options.scrollSelectors?.some(selector => target.closest(selector) !== null);\n if (!isScrollableElement) {\n e.preventDefault();\n e.stopPropagation();\n }\n }\n }, { passive: false });\n // タッチイベント(ホスト要素レベル)\n const touchHandler = (e) => {\n if (!this.isActive())\n return;\n // スクロール対象要素からのイベントは許可\n const target = e.target;\n const isScrollableElement = this.options.scrollSelectors?.some(selector => target.closest(selector) !== null);\n if (!isScrollableElement) {\n if (e.touches.length > 1) {\n // ピンチズームなどマルチタッチ操作をブロック\n e.preventDefault();\n e.stopPropagation();\n }\n // シングルタッチはデフォルト動作を許可(スクロールなど)\n }\n };\n this.addEventListener(this.hostElement, 'touchstart', touchHandler, { passive: false });\n this.addEventListener(this.hostElement, 'touchmove', touchHandler, { passive: false });\n // ジェスチャーイベント(ホスト要素レベル)\n const gestureHandler = (e) => {\n if (this.isActive()) {\n e.preventDefault();\n e.stopPropagation();\n }\n };\n ['gesturestart', 'gesturechange', 'gestureend'].forEach(eventName => {\n this.addEventListener(this.hostElement, eventName, gestureHandler, { passive: false });\n });\n // Document-level capture phaseハンドラ\n // ブラウザのピンチズームがデフォルト動作を行う前にキャッチする\n this.setupDocumentLevelPinchZoomPrevention();\n }\n /**\n * Document-levelでcapture phaseを使ってピンチズームを防止\n * ホスト要素内で発生したマルチタッチ/ジェスチャーイベントのみをブロック\n */\n setupDocumentLevelPinchZoomPrevention() {\n // タッチイベント(capture phase)\n const documentTouchHandler = (e) => {\n if (!this.isActive())\n return;\n if (!this.hostElement.contains(e.target))\n return;\n if (e.touches.length > 1) {\n e.preventDefault();\n }\n };\n document.addEventListener('touchstart', documentTouchHandler, { capture: true, passive: false });\n document.addEventListener('touchmove', documentTouchHandler, { capture: true, passive: false });\n this.cleanupFunctions.push(() => {\n document.removeEventListener('touchstart', documentTouchHandler, { capture: true });\n document.removeEventListener('touchmove', documentTouchHandler, { capture: true });\n });\n // Safari gestureイベント(capture phase)\n const documentGestureHandler = (e) => {\n if (!this.isActive())\n return;\n if (!this.hostElement.contains(e.target))\n return;\n e.preventDefault();\n };\n ['gesturestart', 'gesturechange', 'gestureend'].forEach(eventName => {\n document.addEventListener(eventName, documentGestureHandler, { capture: true, passive: false });\n this.cleanupFunctions.push(() => document.removeEventListener(eventName, documentGestureHandler, { capture: true }));\n });\n }\n addEventListener(element, event, handler, options) {\n element.addEventListener(event, handler, options);\n this.cleanupFunctions.push(() => element.removeEventListener(event, handler, options));\n }\n toggleActive() {\n this.setActive(!this.isActive());\n }\n setActive(active) {\n this.isActive.set(active);\n this.onActiveChange(active);\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-handlers.js","sourceRoot":"","sources":["../../../../../../../../packages/@ng-atomic/common/src/lib/directives/active-control/handlers/event-handlers.ts"],"names":[],"mappings":"AAWA,MAAM,OAAO,0BAA0B;IAGrC,YACU,WAAwB,EACxB,QAAiC,EACjC,cAAyC,EACzC,UAAgC,EAAE;QAHlC,gBAAW,GAAX,WAAW,CAAa;QACxB,aAAQ,GAAR,QAAQ,CAAyB;QACjC,mBAAc,GAAd,cAAc,CAA2B;QACzC,YAAO,GAAP,OAAO,CAA2B;QANpC,qBAAgB,GAAsB,EAAE,CAAC;IAO9C,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAEO,kBAAkB;QACxB,YAAY;QACZ,MAAM,gBAAgB,GAAG,CAAC,CAAa,EAAE,EAAE;YACzC,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,qDAAqD;YACrD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;gBACzC,CAAC,CAAC,eAAe,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,WAAW,EAAE,gBAAgB,CAAC,CAAC;QAEvE,SAAS;QACT,MAAM,qBAAqB,GAAG,CAAC,CAAa,EAAE,EAAE;YAC9C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAc,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACpE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACxB,CAAC;QACH,CAAC,CAAC;QACF,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,qBAAqB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACjF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,EAAE,CAC9B,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,qBAAqB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CACpF,CAAC;IACJ,CAAC;IAEO,uBAAuB;QAC7B,+BAA+B;QAC/B,6CAA6C;QAC7C,mDAAmD;QACnD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,CAAC,CAAa,EAAE,EAAE;YACjE,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACpB,4CAA4C;gBAC5C,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC;oBACd,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,CAAC,CAAC,eAAe,EAAE,CAAC;oBACpB,OAAO;gBACT,CAAC;gBAED,oCAAoC;gBACpC,MAAM,MAAM,GAAG,CAAC,CAAC,MAAqB,CAAC;gBACvC,MAAM,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,CACxE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,IAAI,CAClC,CAAC;gBACF,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBACzB,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,CAAC,CAAC,eAAe,EAAE,CAAC;gBACtB,CAAC;YACH,CAAC;QACH,CAAC,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QAEvB,oBAAoB;QACpB,MAAM,YAAY,GAAG,CAAC,CAAa,EAAE,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBAAE,OAAO;YAE7B,sBAAsB;YACtB,MAAM,MAAM,GAAG,CAAC,CAAC,MAAqB,CAAC;YACvC,MAAM,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,CACxE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,IAAI,CAClC,CAAC;YACF,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBACzB,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACzB,wBAAwB;oBACxB,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,CAAC,CAAC,eAAe,EAAE,CAAC;gBACtB,CAAC;gBACD,8BAA8B;YAChC,CAAC;QACH,CAAC,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QACxF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QAEvF,uBAAuB;QACvB,MAAM,cAAc,GAAG,CAAC,CAAQ,EAAE,EAAE;YAClC,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACpB,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,CAAC,CAAC,eAAe,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC;QACF,CAAC,cAAc,EAAE,eAAe,EAAE,YAAY,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAClE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,SAAS,EAAE,cAAc,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QACzF,CAAC,CAAC,CAAC;QAEH,mCAAmC;QACnC,iCAAiC;QACjC,IAAI,CAAC,qCAAqC,EAAE,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACK,qCAAqC;QAC3C,yBAAyB;QACzB,MAAM,oBAAoB,GAAG,CAAC,CAAa,EAAE,EAAE;YAC7C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBAAE,OAAO;YAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAc,CAAC;gBAAE,OAAO;YAEzD,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzB,CAAC,CAAC,cAAc,EAAE,CAAC;YACrB,CAAC;QACH,CAAC,CAAC;QAEF,QAAQ,CAAC,gBAAgB,CAAC,YAAY,EAAE,oBAAoB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QACjG,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,oBAAoB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QAEhG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,EAAE;YAC9B,QAAQ,CAAC,mBAAmB,CAAC,YAAY,EAAE,oBAAoB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;YACpF,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,oBAAoB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACrF,CAAC,CAAC,CAAC;QAEH,oCAAoC;QACpC,MAAM,sBAAsB,GAAG,CAAC,CAAQ,EAAE,EAAE;YAC1C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBAAE,OAAO;YAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAc,CAAC;gBAAE,OAAO;YACzD,CAAC,CAAC,cAAc,EAAE,CAAC;QACrB,CAAC,CAAC;QAEF,CAAC,cAAc,EAAE,eAAe,EAAE,YAAY,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAClE,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,sBAAsB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;YAChG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,EAAE,CAC9B,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,sBAAsB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CACnF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,gBAAgB,CACtB,OAA+B,EAC/B,KAAa,EACb,OAAsB,EACtB,OAAiC;QAEjC,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAClD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IACzF,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IACnC,CAAC;IAEO,SAAS,CAAC,MAAe;QAC/B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC1B,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;CACF","sourcesContent":["import { Signal, WritableSignal } from '@angular/core';\n\nexport type CleanupFunction = () => void;\n\nexport interface ActiveControlOptions {\n  /** mousedownでstopPropagationを呼ばない */\n  disableStopPropagation?: boolean;\n  /** スクロールを許可する要素のセレクタ */\n  scrollSelectors?: string[];\n}\n\nexport class ActiveControlEventHandlers {\n  private cleanupFunctions: CleanupFunction[] = [];\n\n  constructor(\n    private hostElement: HTMLElement,\n    private isActive: WritableSignal<boolean>,\n    private onActiveChange: (active: boolean) => void,\n    private options: ActiveControlOptions = {}\n  ) {}\n\n  setupAll(): CleanupFunction[] {\n    this.setupClickHandlers();\n    this.setupPreventionHandlers();\n    return this.cleanupFunctions;\n  }\n\n  private setupClickHandlers(): void {\n    // ホスト要素クリック\n    const mousedownHandler = (e: MouseEvent) => {\n      this.toggleActive();\n      // React Flowなどのドラッグと共存するため、オプションでstopPropagationを無効化\n      if (!this.options.disableStopPropagation) {\n        e.stopPropagation();\n      }\n    };\n    this.addEventListener(this.hostElement, 'mousedown', mousedownHandler);\n\n    // 外部クリック\n    const documentClickListener = (e: MouseEvent) => {\n      if (!this.hostElement.contains(e.target as Node) && this.isActive()) {\n        this.setActive(false);\n      }\n    };\n    document.addEventListener('mousedown', documentClickListener, { capture: true });\n    this.cleanupFunctions.push(() =>\n      document.removeEventListener('mousedown', documentClickListener, { capture: true })\n    );\n  }\n\n  private setupPreventionHandlers(): void {\n    // ホイールイベント（スクロール対象要素以外でのみブロック）\n    // ただし、ctrlKey + wheel（トラックパッドのピンチズーム）は常にブロック\n    // 非アクティブ時はScrollControlがスクロール位置をリセットするため、ここでは処理しない\n    this.addEventListener(this.hostElement, 'wheel', (e: WheelEvent) => {\n      if (this.isActive()) {\n        // ctrlKey + wheel = トラックパッドのピンチズーム → 常にブロック\n        if (e.ctrlKey) {\n          e.preventDefault();\n          e.stopPropagation();\n          return;\n        }\n\n        // 通常のホイールスクロール: スクロール対象要素からのイベントは許可\n        const target = e.target as HTMLElement;\n        const isScrollableElement = this.options.scrollSelectors?.some(selector =>\n          target.closest(selector) !== null\n        );\n        if (!isScrollableElement) {\n          e.preventDefault();\n          e.stopPropagation();\n        }\n      }\n    }, { passive: false });\n\n    // タッチイベント（ホスト要素レベル）\n    const touchHandler = (e: TouchEvent) => {\n      if (!this.isActive()) return;\n\n      // スクロール対象要素からのイベントは許可\n      const target = e.target as HTMLElement;\n      const isScrollableElement = this.options.scrollSelectors?.some(selector =>\n        target.closest(selector) !== null\n      );\n      if (!isScrollableElement) {\n        if (e.touches.length > 1) {\n          // ピンチズームなどマルチタッチ操作をブロック\n          e.preventDefault();\n          e.stopPropagation();\n        }\n        // シングルタッチはデフォルト動作を許可（スクロールなど）\n      }\n    };\n    this.addEventListener(this.hostElement, 'touchstart', touchHandler, { passive: false });\n    this.addEventListener(this.hostElement, 'touchmove', touchHandler, { passive: false });\n\n    // ジェスチャーイベント（ホスト要素レベル）\n    const gestureHandler = (e: Event) => {\n      if (this.isActive()) {\n        e.preventDefault();\n        e.stopPropagation();\n      }\n    };\n    ['gesturestart', 'gesturechange', 'gestureend'].forEach(eventName => {\n      this.addEventListener(this.hostElement, eventName, gestureHandler, { passive: false });\n    });\n\n    // Document-level capture phaseハンドラ\n    // ブラウザのピンチズームがデフォルト動作を行う前にキャッチする\n    this.setupDocumentLevelPinchZoomPrevention();\n  }\n\n  /**\n   * Document-levelでcapture phaseを使ってピンチズームを防止\n   * ホスト要素内で発生したマルチタッチ/ジェスチャーイベントのみをブロック\n   */\n  private setupDocumentLevelPinchZoomPrevention(): void {\n    // タッチイベント（capture phase）\n    const documentTouchHandler = (e: TouchEvent) => {\n      if (!this.isActive()) return;\n      if (!this.hostElement.contains(e.target as Node)) return;\n\n      if (e.touches.length > 1) {\n        e.preventDefault();\n      }\n    };\n\n    document.addEventListener('touchstart', documentTouchHandler, { capture: true, passive: false });\n    document.addEventListener('touchmove', documentTouchHandler, { capture: true, passive: false });\n\n    this.cleanupFunctions.push(() => {\n      document.removeEventListener('touchstart', documentTouchHandler, { capture: true });\n      document.removeEventListener('touchmove', documentTouchHandler, { capture: true });\n    });\n\n    // Safari gestureイベント（capture phase）\n    const documentGestureHandler = (e: Event) => {\n      if (!this.isActive()) return;\n      if (!this.hostElement.contains(e.target as Node)) return;\n      e.preventDefault();\n    };\n\n    ['gesturestart', 'gesturechange', 'gestureend'].forEach(eventName => {\n      document.addEventListener(eventName, documentGestureHandler, { capture: true, passive: false });\n      this.cleanupFunctions.push(() =>\n        document.removeEventListener(eventName, documentGestureHandler, { capture: true })\n      );\n    });\n  }\n\n  private addEventListener(\n    element: HTMLElement | Document,\n    event: string,\n    handler: EventListener,\n    options?: AddEventListenerOptions\n  ): void {\n    element.addEventListener(event, handler, options);\n    this.cleanupFunctions.push(() => element.removeEventListener(event, handler, options));\n  }\n\n  private toggleActive(): void {\n    this.setActive(!this.isActive());\n  }\n\n  private setActive(active: boolean): void {\n    this.isActive.set(active);\n    this.onActiveChange(active);\n  }\n}\n"]}","export class ScrollControl {\n constructor(scrollElement, isActive, options = {}) {\n this.scrollElement = scrollElement;\n this.isActive = isActive;\n this.options = options;\n this.lockedScrollTop = 0;\n this.wasActive = false;\n }\n setup() {\n const cleanups = [];\n // アクティブ状態の監視\n const checkActiveState = () => {\n const isActiveNow = this.isActive();\n if (!this.options.disableScrollLock) {\n if (!isActiveNow && this.wasActive) {\n // アクティブ → 非アクティブ: 現在位置をロック\n this.lockedScrollTop = this.scrollElement.scrollTop;\n }\n else if (!isActiveNow) {\n // 継続して非アクティブ: ロック位置を維持\n this.scrollElement.scrollTop = this.lockedScrollTop;\n }\n }\n // アクティブ時 or disableScrollLock時: 何もしない(自由スクロール)\n this.wasActive = isActiveNow;\n this.rafId = requestAnimationFrame(checkActiveState);\n };\n checkActiveState();\n cleanups.push(() => {\n if (this.rafId !== undefined) {\n cancelAnimationFrame(this.rafId);\n }\n });\n // スクロールイベント監視\n const scrollHandler = () => {\n if (!this.options.disableScrollLock && !this.isActive()) {\n this.scrollElement.scrollTop = this.lockedScrollTop;\n }\n };\n this.scrollElement.addEventListener('scroll', scrollHandler);\n cleanups.push(() => this.scrollElement.removeEventListener('scroll', scrollHandler));\n return cleanups;\n }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLWNvbnRyb2wuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvbGliL2RpcmVjdGl2ZXMvYWN0aXZlLWNvbnRyb2wvaGFuZGxlcnMvc2Nyb2xsLWNvbnRyb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUUEsTUFBTSxPQUFPLGFBQWE7SUFLeEIsWUFDVSxhQUEwQixFQUMxQixRQUF5QixFQUN6QixVQUFnQyxFQUFFO1FBRmxDLGtCQUFhLEdBQWIsYUFBYSxDQUFhO1FBQzFCLGFBQVEsR0FBUixRQUFRLENBQWlCO1FBQ3pCLFlBQU8sR0FBUCxPQUFPLENBQTJCO1FBUHBDLG9CQUFlLEdBQUcsQ0FBQyxDQUFDO1FBQ3BCLGNBQVMsR0FBRyxLQUFLLENBQUM7SUFPdkIsQ0FBQztJQUVKLEtBQUs7UUFDSCxNQUFNLFFBQVEsR0FBc0IsRUFBRSxDQUFDO1FBRXZDLGFBQWE7UUFDYixNQUFNLGdCQUFnQixHQUFHLEdBQUcsRUFBRTtZQUM1QixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFFcEMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztnQkFDcEMsSUFBSSxDQUFDLFdBQVcsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7b0JBQ25DLDJCQUEyQjtvQkFDM0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQztnQkFDdEQsQ0FBQztxQkFBTSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7b0JBQ3hCLHVCQUF1QjtvQkFDdkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztnQkFDdEQsQ0FBQztZQUNILENBQUM7WUFDRCwrQ0FBK0M7WUFFL0MsSUFBSSxDQUFDLFNBQVMsR0FBRyxXQUFXLENBQUM7WUFDN0IsSUFBSSxDQUFDLEtBQUssR0FBRyxxQkFBcUIsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ3ZELENBQUMsQ0FBQztRQUNGLGdCQUFnQixFQUFFLENBQUM7UUFDbkIsUUFBUSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDakIsSUFBSSxJQUFJLENBQUMsS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO2dCQUM3QixvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbkMsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgsY0FBYztRQUNkLE1BQU0sYUFBYSxHQUFHLEdBQUcsRUFBRTtZQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxpQkFBaUIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO2dCQUN4RCxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDO1lBQ3RELENBQUM7UUFDSCxDQUFDLENBQUM7UUFDRixJQUFJLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUM3RCxRQUFRLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUM7UUFFckYsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDbGVhbnVwRnVuY3Rpb24gfSBmcm9tICcuL2V2ZW50LWhhbmRsZXJzJztcblxuZXhwb3J0IGludGVyZmFjZSBTY3JvbGxDb250cm9sT3B0aW9ucyB7XG4gIC8qKiDjgrnjgq/jg63jg7zjg6vkvY3nva7jga7jg63jg4Pjgq/jgpLnhKHlirnljJbjgZnjgovvvIjluLjjgavjgrnjgq/jg63jg7zjg6vlj6/og73jgavjgZnjgovvvIkgKi9cbiAgZGlzYWJsZVNjcm9sbExvY2s/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY2xhc3MgU2Nyb2xsQ29udHJvbCB7XG4gIHByaXZhdGUgbG9ja2VkU2Nyb2xsVG9wID0gMDtcbiAgcHJpdmF0ZSB3YXNBY3RpdmUgPSBmYWxzZTtcbiAgcHJpdmF0ZSByYWZJZD86IG51bWJlcjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHNjcm9sbEVsZW1lbnQ6IEhUTUxFbGVtZW50LFxuICAgIHByaXZhdGUgaXNBY3RpdmU6IFNpZ25hbDxib29sZWFuPixcbiAgICBwcml2YXRlIG9wdGlvbnM6IFNjcm9sbENvbnRyb2xPcHRpb25zID0ge31cbiAgKSB7fVxuXG4gIHNldHVwKCk6IENsZWFudXBGdW5jdGlvbltdIHtcbiAgICBjb25zdCBjbGVhbnVwczogQ2xlYW51cEZ1bmN0aW9uW10gPSBbXTtcblxuICAgIC8vIOOCouOCr+ODhuOCo+ODlueKtuaFi+OBruebo+imllxuICAgIGNvbnN0IGNoZWNrQWN0aXZlU3RhdGUgPSAoKSA9PiB7XG4gICAgICBjb25zdCBpc0FjdGl2ZU5vdyA9IHRoaXMuaXNBY3RpdmUoKTtcblxuICAgICAgaWYgKCF0aGlzLm9wdGlvbnMuZGlzYWJsZVNjcm9sbExvY2spIHtcbiAgICAgICAgaWYgKCFpc0FjdGl2ZU5vdyAmJiB0aGlzLndhc0FjdGl2ZSkge1xuICAgICAgICAgIC8vIOOCouOCr+ODhuOCo+ODliDihpIg6Z2e44Ki44Kv44OG44Kj44OWOiDnj77lnKjkvY3nva7jgpLjg63jg4Pjgq9cbiAgICAgICAgICB0aGlzLmxvY2tlZFNjcm9sbFRvcCA9IHRoaXMuc2Nyb2xsRWxlbWVudC5zY3JvbGxUb3A7XG4gICAgICAgIH0gZWxzZSBpZiAoIWlzQWN0aXZlTm93KSB7XG4gICAgICAgICAgLy8g57aZ57aa44GX44Gm6Z2e44Ki44Kv44OG44Kj44OWOiDjg63jg4Pjgq/kvY3nva7jgpLntq3mjIFcbiAgICAgICAgICB0aGlzLnNjcm9sbEVsZW1lbnQuc2Nyb2xsVG9wID0gdGhpcy5sb2NrZWRTY3JvbGxUb3A7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIC8vIOOCouOCr+ODhuOCo+ODluaZgiBvciBkaXNhYmxlU2Nyb2xsTG9ja+aZgjog5L2V44KC44GX44Gq44GE77yI6Ieq55Sx44K544Kv44Ot44O844Or77yJXG5cbiAgICAgIHRoaXMud2FzQWN0aXZlID0gaXNBY3RpdmVOb3c7XG4gICAgICB0aGlzLnJhZklkID0gcmVxdWVzdEFuaW1hdGlvbkZyYW1lKGNoZWNrQWN0aXZlU3RhdGUpO1xuICAgIH07XG4gICAgY2hlY2tBY3RpdmVTdGF0ZSgpO1xuICAgIGNsZWFudXBzLnB1c2goKCkgPT4ge1xuICAgICAgaWYgKHRoaXMucmFmSWQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICBjYW5jZWxBbmltYXRpb25GcmFtZSh0aGlzLnJhZklkKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIC8vIOOCueOCr+ODreODvOODq+OCpOODmeODs+ODiOebo+imllxuICAgIGNvbnN0IHNjcm9sbEhhbmRsZXIgPSAoKSA9PiB7XG4gICAgICBpZiAoIXRoaXMub3B0aW9ucy5kaXNhYmxlU2Nyb2xsTG9jayAmJiAhdGhpcy5pc0FjdGl2ZSgpKSB7XG4gICAgICAgIHRoaXMuc2Nyb2xsRWxlbWVudC5zY3JvbGxUb3AgPSB0aGlzLmxvY2tlZFNjcm9sbFRvcDtcbiAgICAgIH1cbiAgICB9O1xuICAgIHRoaXMuc2Nyb2xsRWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdzY3JvbGwnLCBzY3JvbGxIYW5kbGVyKTtcbiAgICBjbGVhbnVwcy5wdXNoKCgpID0+IHRoaXMuc2Nyb2xsRWxlbWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdzY3JvbGwnLCBzY3JvbGxIYW5kbGVyKSk7XG5cbiAgICByZXR1cm4gY2xlYW51cHM7XG4gIH1cbn1cbiJdfQ==","import { Directive, ElementRef, input, output, effect, signal, inject } from '@angular/core';\nimport { ActiveControlEventHandlers, ScrollControl } from './handlers';\nimport * as i0 from \"@angular/core\";\n/**\n * アクティブ状態を管理するディレクティブ\n *\n * クリックでアクティブ化、外部クリックで非アクティブ化し、\n * スクロール位置の固定やイベント伝播の制御を行います。\n *\n * @example\n * ```html\n * <!-- 単一セレクタ -->\n * <div appActiveControl\n * [scrollSelector]=\"'.xterm-viewport'\"\n * (activeChange)=\"onActiveChange($event)\">\n * <!-- content -->\n * </div>\n *\n * <!-- 複数セレクタ -->\n * <div appActiveControl\n * [scrollSelectors]=\"['.xterm-viewport', '.qtp-content']\"\n * (activeChange)=\"onActiveChange($event)\">\n * <!-- content -->\n * </div>\n * ```\n */\nexport class ActiveControlDirective {\n constructor() {\n this.el = inject(ElementRef);\n this.scrollSelector = input();\n this.scrollSelectors = input();\n /** mousedownでstopPropagationを呼ばない(React Flowなどのドラッグと共存するため) */\n this.disableStopPropagation = input(false);\n /** スクロール位置のロックを無効化する(常にスクロール可能にする) */\n this.disableScrollLock = input(false);\n /** nodragクラスを付与しない(React Flowのノードでドラッグを有効化するため) */\n this.disableNodrag = input(false);\n this.activeChange = output();\n this.isActive = signal(false);\n this.eventCleanupFunctions = [];\n this.scrollCleanupFunctions = [];\n this.eventHandlersInitialized = false;\n // イベントハンドラーの初期化(一度だけ)\n effect(() => {\n if (!this.eventHandlersInitialized) {\n setTimeout(() => this.initializeEventHandlers(), 100);\n this.eventHandlersInitialized = true;\n }\n }, { allowSignalWrites: true });\n // スクロール制御の初期化(セレクタが変わるたびに再設定)\n effect(() => {\n const selectors = this.getScrollSelectors();\n setTimeout(() => this.setupScrollControls(selectors), 150);\n });\n }\n ngOnDestroy() {\n this.eventCleanupFunctions.forEach(cleanup => cleanup());\n this.scrollCleanupFunctions.forEach(cleanup => cleanup());\n }\n initializeEventHandlers() {\n const hostElement = this.el.nativeElement;\n const scrollSelectors = this.getScrollSelectors();\n const eventHandlers = new ActiveControlEventHandlers(hostElement, this.isActive, (active) => this.activeChange.emit(active), { disableStopPropagation: this.disableStopPropagation(), scrollSelectors });\n this.eventCleanupFunctions.push(...eventHandlers.setupAll());\n }\n setupScrollControls(selectors) {\n // 既存のスクロール制御をクリーンアップ\n this.scrollCleanupFunctions.forEach(cleanup => cleanup());\n this.scrollCleanupFunctions = [];\n const hostElement = this.el.nativeElement;\n const disableScrollLock = this.disableScrollLock();\n for (const selector of selectors) {\n // querySelectorAll を使用して全てのマッチする要素を取得\n const scrollElements = hostElement.querySelectorAll(selector);\n scrollElements.forEach(scrollElement => {\n const scrollControl = new ScrollControl(scrollElement, this.isActive, { disableScrollLock });\n this.scrollCleanupFunctions.push(...scrollControl.setup());\n });\n }\n }\n getScrollSelectors() {\n const multiple = this.scrollSelectors();\n if (multiple && multiple.length > 0) {\n return multiple;\n }\n const single = this.scrollSelector();\n return single ? [single] : [];\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: ActiveControlDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }\n static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: \"17.1.0\", version: \"20.0.5\", type: ActiveControlDirective, isStandalone: true, selector: \"[appActiveControl]\", inputs: { scrollSelector: { classPropertyName: \"scrollSelector\", publicName: \"scrollSelector\", isSignal: true, isRequired: false, transformFunction: null }, scrollSelectors: { classPropertyName: \"scrollSelectors\", publicName: \"scrollSelectors\", isSignal: true, isRequired: false, transformFunction: null }, disableStopPropagation: { classPropertyName: \"disableStopPropagation\", publicName: \"disableStopPropagation\", isSignal: true, isRequired: false, transformFunction: null }, disableScrollLock: { classPropertyName: \"disableScrollLock\", publicName: \"disableScrollLock\", isSignal: true, isRequired: false, transformFunction: null }, disableNodrag: { classPropertyName: \"disableNodrag\", publicName: \"disableNodrag\", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { activeChange: \"activeChange\" }, host: { properties: { \"class.active\": \"isActive()\", \"class.nodrag\": \"!disableNodrag()\", \"class.nowheel\": \"isActive()\" } }, ngImport: i0 }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: ActiveControlDirective, decorators: [{\n type: Directive,\n args: [{\n selector: '[appActiveControl]',\n standalone: true,\n host: {\n '[class.active]': 'isActive()',\n '[class.nodrag]': '!disableNodrag()',\n '[class.nowheel]': 'isActive()',\n }\n }]\n }], ctorParameters: () => [] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"active-control.directive.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/common/src/lib/directives/active-control/active-control.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, input, output, effect, signal, OnDestroy, inject } from '@angular/core';\nimport { ActiveControlEventHandlers, ScrollControl } from './handlers';\n\n/**\n * アクティブ状態を管理するディレクティブ\n *\n * クリックでアクティブ化、外部クリックで非アクティブ化し、\n * スクロール位置の固定やイベント伝播の制御を行います。\n *\n * @example\n * ```html\n * <!-- 単一セレクタ -->\n * <div appActiveControl\n *      [scrollSelector]=\"'.xterm-viewport'\"\n *      (activeChange)=\"onActiveChange($event)\">\n *   <!-- content -->\n * </div>\n *\n * <!-- 複数セレクタ -->\n * <div appActiveControl\n *      [scrollSelectors]=\"['.xterm-viewport', '.qtp-content']\"\n *      (activeChange)=\"onActiveChange($event)\">\n *   <!-- content -->\n * </div>\n * ```\n */\n@Directive({\n  selector: '[appActiveControl]',\n  standalone: true,\n  host: {\n    '[class.active]': 'isActive()',\n    '[class.nodrag]': '!disableNodrag()',\n    '[class.nowheel]': 'isActive()',\n  }\n})\nexport class ActiveControlDirective implements OnDestroy {\n  private readonly el = inject(ElementRef);\n  readonly scrollSelector = input<string>();\n  readonly scrollSelectors = input<string[]>();\n  /** mousedownでstopPropagationを呼ばない（React Flowなどのドラッグと共存するため） */\n  readonly disableStopPropagation = input<boolean>(false);\n  /** スクロール位置のロックを無効化する（常にスクロール可能にする） */\n  readonly disableScrollLock = input<boolean>(false);\n  /** nodragクラスを付与しない（React Flowのノードでドラッグを有効化するため） */\n  readonly disableNodrag = input<boolean>(false);\n  readonly activeChange = output<boolean>();\n  readonly isActive = signal<boolean>(false);\n\n  private eventCleanupFunctions: (() => void)[] = [];\n  private scrollCleanupFunctions: (() => void)[] = [];\n  private eventHandlersInitialized = false;\n\n  constructor() {\n    // イベントハンドラーの初期化（一度だけ）\n    effect(() => {\n      if (!this.eventHandlersInitialized) {\n        setTimeout(() => this.initializeEventHandlers(), 100);\n        this.eventHandlersInitialized = true;\n      }\n    }, { allowSignalWrites: true });\n\n    // スクロール制御の初期化（セレクタが変わるたびに再設定）\n    effect(() => {\n      const selectors = this.getScrollSelectors();\n      setTimeout(() => this.setupScrollControls(selectors), 150);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.eventCleanupFunctions.forEach(cleanup => cleanup());\n    this.scrollCleanupFunctions.forEach(cleanup => cleanup());\n  }\n\n  private initializeEventHandlers(): void {\n    const hostElement = this.el.nativeElement as HTMLElement;\n    const scrollSelectors = this.getScrollSelectors();\n    const eventHandlers = new ActiveControlEventHandlers(\n      hostElement,\n      this.isActive,\n      (active) => this.activeChange.emit(active),\n      { disableStopPropagation: this.disableStopPropagation(), scrollSelectors }\n    );\n    this.eventCleanupFunctions.push(...eventHandlers.setupAll());\n  }\n\n  private setupScrollControls(selectors: string[]): void {\n    // 既存のスクロール制御をクリーンアップ\n    this.scrollCleanupFunctions.forEach(cleanup => cleanup());\n    this.scrollCleanupFunctions = [];\n\n    const hostElement = this.el.nativeElement as HTMLElement;\n    const disableScrollLock = this.disableScrollLock();\n    for (const selector of selectors) {\n      // querySelectorAll を使用して全てのマッチする要素を取得\n      const scrollElements = hostElement.querySelectorAll<HTMLElement>(selector);\n      scrollElements.forEach(scrollElement => {\n        const scrollControl = new ScrollControl(scrollElement, this.isActive, { disableScrollLock });\n        this.scrollCleanupFunctions.push(...scrollControl.setup());\n      });\n    }\n  }\n\n  private getScrollSelectors(): string[] {\n    const multiple = this.scrollSelectors();\n    if (multiple && multiple.length > 0) {\n      return multiple;\n    }\n    const single = this.scrollSelector();\n    return single ? [single] : [];\n  }\n}\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctYXRvbWljLWNvbW1vbi1kaXJlY3RpdmVzLWFjdGl2ZS1jb250cm9sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb21tb24vc3JjL2xpYi9kaXJlY3RpdmVzL2FjdGl2ZS1jb250cm9sL25nLWF0b21pYy1jb21tb24tZGlyZWN0aXZlcy1hY3RpdmUtY29udHJvbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { inject, Injectable } from '@angular/core';
|
|
3
3
|
import { toSignal, takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
-
import { Auth, authState, TwitterAuthProvider, signInWithPopup, GoogleAuthProvider, signInWithEmailAndPassword, createUserWithEmailAndPassword, signInWithCustomToken, signOut } from '@angular/fire/auth';
|
|
4
|
+
import { Auth, authState, TwitterAuthProvider, signInWithPopup, GoogleAuthProvider, onAuthStateChanged, signInWithEmailAndPassword, createUserWithEmailAndPassword, signInWithCustomToken, signOut } from '@angular/fire/auth';
|
|
5
5
|
import { get } from 'lodash-es';
|
|
6
6
|
import { switchMap, of, distinctUntilChanged, shareReplay, map } from 'rxjs';
|
|
7
7
|
|
|
@@ -29,12 +29,32 @@ class AuthService {
|
|
|
29
29
|
for (const scope of scopes)
|
|
30
30
|
provider.addScope(scope);
|
|
31
31
|
return signInWithPopup(this.#auth, provider).catch(async (error) => {
|
|
32
|
+
if (error.code === 'auth/popup-closed-by-user') {
|
|
33
|
+
const user = await this.#waitForAuthState();
|
|
34
|
+
if (user)
|
|
35
|
+
return { user };
|
|
36
|
+
}
|
|
32
37
|
if (error.code === 'auth/account-exists-with-different-credential') {
|
|
33
38
|
this.onFailedForAccountExistsWithDifferentCredential(error);
|
|
34
39
|
}
|
|
35
40
|
throw error;
|
|
36
41
|
});
|
|
37
42
|
}
|
|
43
|
+
#waitForAuthState(timeoutMs = 3000) {
|
|
44
|
+
return new Promise(resolve => {
|
|
45
|
+
let skip = true;
|
|
46
|
+
const timer = setTimeout(() => { unsub(); resolve(null); }, timeoutMs);
|
|
47
|
+
const unsub = onAuthStateChanged(this.#auth, user => {
|
|
48
|
+
if (skip) {
|
|
49
|
+
skip = false;
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
clearTimeout(timer);
|
|
53
|
+
unsub();
|
|
54
|
+
resolve(user);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
}
|
|
38
58
|
signInWithEmailAndPassword(email, password) {
|
|
39
59
|
return signInWithEmailAndPassword(this.#auth, email, password);
|
|
40
60
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-services-auth.mjs","sources":["../tmp-esm2022/services/auth/auth.service.js","../tmp-esm2022/services/auth/ng-atomic-common-services-auth.js"],"sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { toSignal, takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Auth, authState, signInWithCustomToken, GoogleAuthProvider, TwitterAuthProvider, signInWithPopup, signOut, signInWithEmailAndPassword, createUserWithEmailAndPassword } from '@angular/fire/auth';\nimport { get } from 'lodash-es';\nimport { distinctUntilChanged, map, of, shareReplay, switchMap } from 'rxjs';\nimport * as i0 from \"@angular/core\";\nexport class AuthService {\n constructor() {\n this.#auth = inject(Auth);\n this.auth$ = authState(this.#auth);\n this.auth = toSignal(this.auth$);\n this.accessToken$ = this.auth$.pipe(switchMap(auth => auth ? auth.getIdToken() : of(null)), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n this.accessToken = toSignal(this.accessToken$);\n this.userId$ = this.auth$.pipe(map(auth => auth?.uid ?? null), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n this.customClaims$ = this.auth$.pipe(switchMap(auth => auth ? auth.getIdTokenResult() : of(null)), map(token => token?.claims ?? {}), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n }\n #auth;\n signInWithTwitter() {\n const provider = new TwitterAuthProvider();\n return signInWithPopup(this.#auth, provider);\n }\n // signInWithGoogle() {\n // const provider = new GoogleAuthProvider();\n // return signInWithPopup(this.#auth, provider);\n // }\n async signInWithGoogle(scopes = []) {\n const provider = new GoogleAuthProvider();\n for (const scope of scopes)\n provider.addScope(scope);\n return signInWithPopup(this.#auth, provider).catch(async (error) => {\n if (error.code === 'auth/account-exists-with-different-credential') {\n this.onFailedForAccountExistsWithDifferentCredential(error);\n }\n throw error;\n });\n }\n signInWithEmailAndPassword(email, password) {\n return signInWithEmailAndPassword(this.#auth, email, password);\n }\n createUserWithEmailAndPassword(email, password) {\n return createUserWithEmailAndPassword(this.#auth, email, password);\n }\n signInWithCustomToken(customToken) {\n return signInWithCustomToken(this.#auth, customToken);\n }\n signOut() {\n return signOut(this.#auth);\n }\n onFailedForAccountExistsWithDifferentCredential(error) {\n const credential = error.customData._tokenResponse;\n // const pending = FacebookAuthProvider.credential(credential.oauthAccessToken);\n const providerId = error.customData._tokenResponse.providerId;\n // this.pends.update(pends => [...pends, {\n // credential: pending,\n // providerId: providerId,\n // email: credential.email,\n // }]);\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AuthService, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AuthService, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root'\n }]\n }] });\nexport function injectAuthState$() {\n return inject(AuthService).auth$;\n}\nexport function injectAuthState() {\n return toSignal(injectAuthState$());\n}\nexport function injectUserId$() {\n return inject(AuthService).userId$.pipe(distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n}\nexport function injectUserId() {\n return toSignal(injectUserId$());\n}\nexport function injectTwitterId$() {\n return inject(AuthService).auth$.pipe(map(auth => auth?.providerData?.[0]?.uid ?? null), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n}\nexport function injectClaim$(claim) {\n return inject(AuthService).customClaims$.pipe(map(token => claim ? get(token, claim) : token), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n}\nexport function injectClaim(claim) {\n return toSignal(injectClaim$(claim));\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/common/src/lib/services/auth/auth.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAC1E,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,eAAe,EAAE,OAAO,EAAkB,0BAA0B,EAAE,8BAA8B,EAAE,MAAM,oBAAoB,CAAC;AAC3N,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAChC,OAAO,EAAc,oBAAoB,EAAE,GAAG,EAAE,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;AA2BzF,MAAM,OAAO,WAAW;IAHxB;QAIW,UAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QACrB,UAAK,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,SAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,iBAAY,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CACrC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,EACtD,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,kBAAkB,EAAE,CACrB,CAAC;QACO,gBAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAEnD,YAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CACvB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,IAAI,IAAI,CAAC,EAC9B,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,kBAAkB,EAAE,CACrB,CAAC;QAEO,kBAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CACtC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,EAC5D,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,IAAI,EAAE,CAAC,EACjC,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,kBAAkB,EAAE,CACrB,CAAC;KAiDH;IAzEU,KAAK,CAAgB;IA0B9B,iBAAiB;QACf,MAAM,QAAQ,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAC3C,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAoB,CAAA;IACjE,CAAC;IAED,uBAAuB;IACvB,+CAA+C;IAC/C,kDAAkD;IAClD,IAAI;IAEJ,KAAK,CAAC,gBAAgB,CAAC,SAAmB,EAAE;QAC1C,MAAM,QAAQ,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAC1C,KAAK,MAAM,KAAK,IAAI,MAAM;YAAE,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrD,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,KAAK,CAAC,KAAK,EAAC,KAAK,EAAC,EAAE;YAC/D,IAAI,KAAK,CAAC,IAAI,KAAK,+CAA+C,EAAE,CAAC;gBACnE,IAAI,CAAC,+CAA+C,CAAC,KAAK,CAAC,CAAC;YAC9D,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC;IAED,0BAA0B,CAAC,KAAa,EAAE,QAAgB;QACxD,OAAO,0BAA0B,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;IACjE,CAAC;IAED,8BAA8B,CAAC,KAAa,EAAE,QAAgB;QAC5D,OAAO,8BAA8B,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;IACrE,CAAC;IAED,qBAAqB,CAAC,WAAmB;QACvC,OAAO,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,CAAoB,CAAC;IAC3E,CAAC;IAED,OAAO;QACL,OAAO,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAEO,+CAA+C,CAAC,KAAU;QAChE,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,cAAc,CAAC;QACnD,gFAAgF;QAChF,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC;QAC9D,0CAA0C;QAC1C,yBAAyB;QACzB,4BAA4B;QAC5B,6BAA6B;QAC7B,OAAO;IACT,CAAC;8GAzEU,WAAW;kHAAX,WAAW,cAFV,MAAM;;2FAEP,WAAW;kBAHvB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;AA6ED,MAAM,UAAU,gBAAgB;IAC9B,OAAO,MAAM,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,eAAe;IAC7B,OAAO,QAAQ,CAAC,gBAAgB,EAAE,CAAC,CAAC;AACtC,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,IAAI,CACrC,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,kBAAkB,EAAE,CACrB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,YAAY;IAC1B,OAAO,QAAQ,CAAC,aAAa,EAAE,CAAC,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,gBAAgB;IAC9B,OAAO,MAAM,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,IAAI,CACnC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,IAAI,CAAC,EACjD,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,kBAAkB,EAAE,CACrB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,YAAY,CAAa,KAAa;IACpD,OAAO,MAAM,CAAC,WAAW,CAAC,CAAC,aAAa,CAAC,IAAI,CAC3C,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAC/C,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,kBAAkB,EAAE,CACd,CAAC;AACX,CAAC;AAED,MAAM,UAAU,WAAW,CAAa,KAAa;IACnD,OAAO,QAAQ,CAAC,YAAY,CAAI,KAAK,CAAC,CAAC,CAAC;AAC1C,CAAC","sourcesContent":["import { Injectable, Signal, inject } from '@angular/core';\nimport { toSignal, takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Auth, authState, signInWithCustomToken, GoogleAuthProvider, TwitterAuthProvider, signInWithPopup, signOut, UserCredential, signInWithEmailAndPassword, createUserWithEmailAndPassword } from '@angular/fire/auth';\nimport { get } from 'lodash-es';\nimport { Observable, distinctUntilChanged, map, of, shareReplay, switchMap } from 'rxjs';\n\nexport interface TwitterCredential {\n  context: string;\n  displayName: string;\n  email: string;\n  emailVerified: boolean;\n  expiresIn: string;\n  federatedId: string;\n  fullName: string;\n  idToken: string;\n  kind: 'identitytoolkit#VerifyAssertionResponse';\n  localId: string;\n  oauthAccessToken: string;\n  oauthTokenSecret: string;\n  photoUrl: string;\n  providerId: 'twitter.com';\n  rawUserInfo: string;\n  refreshToken: string;\n  screenName: string;\n}\n\nexport type Result = UserCredential & {_tokenResponse: TwitterCredential};\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AuthService {\n  readonly #auth = inject(Auth);\n  readonly auth$ = authState(this.#auth);\n  readonly auth = toSignal(this.auth$);\n  readonly accessToken$ = this.auth$.pipe(\n    switchMap(auth => auth ? auth.getIdToken() : of(null)),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n  readonly accessToken = toSignal(this.accessToken$);\n\n  userId$ = this.auth$.pipe(\n    map(auth => auth?.uid ?? null),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n\n  readonly customClaims$ = this.auth$.pipe(\n    switchMap(auth => auth ? auth.getIdTokenResult() : of(null)),\n    map(token => token?.claims ?? {}),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n\n  signInWithTwitter(): Promise<Result> {\n    const provider = new TwitterAuthProvider();\n    return signInWithPopup(this.#auth, provider) as Promise<Result>\n  }\n\n  // signInWithGoogle() {\n  //   const provider = new GoogleAuthProvider();\n  //   return signInWithPopup(this.#auth, provider);\n  // }\n\n  async signInWithGoogle(scopes: string[] = []) {\n    const provider = new GoogleAuthProvider();\n    for (const scope of scopes) provider.addScope(scope);\n    return signInWithPopup(this.#auth, provider).catch(async error => {\n      if (error.code === 'auth/account-exists-with-different-credential') {\n        this.onFailedForAccountExistsWithDifferentCredential(error);\n      }\n      throw error;\n    });\n  }\n\n  signInWithEmailAndPassword(email: string, password: string) {\n    return signInWithEmailAndPassword(this.#auth, email, password);\n  }\n\n  createUserWithEmailAndPassword(email: string, password: string) {\n    return createUserWithEmailAndPassword(this.#auth, email, password);\n  }\n\n  signInWithCustomToken(customToken: string): Promise<Result> {\n    return signInWithCustomToken(this.#auth, customToken) as Promise<Result>;\n  }\n\n  signOut() {\n    return signOut(this.#auth);\n  }\n\n  private onFailedForAccountExistsWithDifferentCredential(error: any) {\n    const credential = error.customData._tokenResponse;\n    // const pending = FacebookAuthProvider.credential(credential.oauthAccessToken);\n    const providerId = error.customData._tokenResponse.providerId;\n    // this.pends.update(pends => [...pends, {\n    //   credential: pending,\n    //   providerId: providerId,\n    //   email: credential.email,\n    // }]);\n  }\n}\n\nexport function injectAuthState$() {\n  return inject(AuthService).auth$;\n}\n\nexport function injectAuthState() {\n  return toSignal(injectAuthState$());\n}\n\nexport function injectUserId$(): Observable<string | null> {\n  return inject(AuthService).userId$.pipe(\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n}\n\nexport function injectUserId(): Signal<string | null> {\n  return toSignal(injectUserId$());\n}\n\nexport function injectTwitterId$() {\n  return inject(AuthService).auth$.pipe(\n    map(auth => auth?.providerData?.[0]?.uid ?? null),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n}\n\nexport function injectClaim$<T = string>(claim: string): Observable<T> {\n  return inject(AuthService).customClaims$.pipe(\n    map(token => claim ? get(token, claim) : token),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  ) as any;\n}\n\nexport function injectClaim<T = string>(claim: string): Signal<T> {\n  return toSignal(injectClaim$<T>(claim));\n}\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctYXRvbWljLWNvbW1vbi1zZXJ2aWNlcy1hdXRoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb21tb24vc3JjL2xpYi9zZXJ2aWNlcy9hdXRoL25nLWF0b21pYy1jb21tb24tc2VydmljZXMtYXV0aC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-services-auth.mjs","sources":["../tmp-esm2022/services/auth/auth.service.js","../tmp-esm2022/services/auth/ng-atomic-common-services-auth.js"],"sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { toSignal, takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Auth, authState, signInWithCustomToken, GoogleAuthProvider, TwitterAuthProvider, signInWithPopup, signOut, signInWithEmailAndPassword, createUserWithEmailAndPassword, onAuthStateChanged } from '@angular/fire/auth';\nimport { get } from 'lodash-es';\nimport { distinctUntilChanged, map, of, shareReplay, switchMap } from 'rxjs';\nimport * as i0 from \"@angular/core\";\nexport class AuthService {\n constructor() {\n this.#auth = inject(Auth);\n this.auth$ = authState(this.#auth);\n this.auth = toSignal(this.auth$);\n this.accessToken$ = this.auth$.pipe(switchMap(auth => auth ? auth.getIdToken() : of(null)), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n this.accessToken = toSignal(this.accessToken$);\n this.userId$ = this.auth$.pipe(map(auth => auth?.uid ?? null), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n this.customClaims$ = this.auth$.pipe(switchMap(auth => auth ? auth.getIdTokenResult() : of(null)), map(token => token?.claims ?? {}), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n }\n #auth;\n signInWithTwitter() {\n const provider = new TwitterAuthProvider();\n return signInWithPopup(this.#auth, provider);\n }\n // signInWithGoogle() {\n // const provider = new GoogleAuthProvider();\n // return signInWithPopup(this.#auth, provider);\n // }\n async signInWithGoogle(scopes = []) {\n const provider = new GoogleAuthProvider();\n for (const scope of scopes)\n provider.addScope(scope);\n return signInWithPopup(this.#auth, provider).catch(async (error) => {\n if (error.code === 'auth/popup-closed-by-user') {\n const user = await this.#waitForAuthState();\n if (user)\n return { user };\n }\n if (error.code === 'auth/account-exists-with-different-credential') {\n this.onFailedForAccountExistsWithDifferentCredential(error);\n }\n throw error;\n });\n }\n #waitForAuthState(timeoutMs = 3000) {\n return new Promise(resolve => {\n let skip = true;\n const timer = setTimeout(() => { unsub(); resolve(null); }, timeoutMs);\n const unsub = onAuthStateChanged(this.#auth, user => {\n if (skip) {\n skip = false;\n return;\n }\n clearTimeout(timer);\n unsub();\n resolve(user);\n });\n });\n }\n signInWithEmailAndPassword(email, password) {\n return signInWithEmailAndPassword(this.#auth, email, password);\n }\n createUserWithEmailAndPassword(email, password) {\n return createUserWithEmailAndPassword(this.#auth, email, password);\n }\n signInWithCustomToken(customToken) {\n return signInWithCustomToken(this.#auth, customToken);\n }\n signOut() {\n return signOut(this.#auth);\n }\n onFailedForAccountExistsWithDifferentCredential(error) {\n const credential = error.customData._tokenResponse;\n // const pending = FacebookAuthProvider.credential(credential.oauthAccessToken);\n const providerId = error.customData._tokenResponse.providerId;\n // this.pends.update(pends => [...pends, {\n // credential: pending,\n // providerId: providerId,\n // email: credential.email,\n // }]);\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AuthService, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AuthService, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root'\n }]\n }] });\nexport function injectAuthState$() {\n return inject(AuthService).auth$;\n}\nexport function injectAuthState() {\n return toSignal(injectAuthState$());\n}\nexport function injectUserId$() {\n return inject(AuthService).userId$.pipe(distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n}\nexport function injectUserId() {\n return toSignal(injectUserId$());\n}\nexport function injectTwitterId$() {\n return inject(AuthService).auth$.pipe(map(auth => auth?.providerData?.[0]?.uid ?? null), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n}\nexport function injectClaim$(claim) {\n return inject(AuthService).customClaims$.pipe(map(token => claim ? get(token, claim) : token), distinctUntilChanged(), shareReplay(1), takeUntilDestroyed());\n}\nexport function injectClaim(claim) {\n return toSignal(injectClaim$(claim));\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../../../packages/@ng-atomic/common/src/lib/services/auth/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Signal, inject } from '@angular/core';\nimport { toSignal, takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Auth, authState, signInWithCustomToken, GoogleAuthProvider, TwitterAuthProvider, signInWithPopup, signOut, UserCredential, signInWithEmailAndPassword, createUserWithEmailAndPassword, User, onAuthStateChanged } from '@angular/fire/auth';\nimport { get } from 'lodash-es';\nimport { Observable, distinctUntilChanged, map, of, shareReplay, switchMap } from 'rxjs';\n\nexport interface TwitterCredential {\n  context: string;\n  displayName: string;\n  email: string;\n  emailVerified: boolean;\n  expiresIn: string;\n  federatedId: string;\n  fullName: string;\n  idToken: string;\n  kind: 'identitytoolkit#VerifyAssertionResponse';\n  localId: string;\n  oauthAccessToken: string;\n  oauthTokenSecret: string;\n  photoUrl: string;\n  providerId: 'twitter.com';\n  rawUserInfo: string;\n  refreshToken: string;\n  screenName: string;\n}\n\nexport type Result = UserCredential & {_tokenResponse: TwitterCredential};\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AuthService {\n  readonly #auth = inject(Auth);\n  readonly auth$: Observable<User | null> = authState(this.#auth);\n  readonly auth: Signal<User | null | undefined> = toSignal(this.auth$);\n  readonly accessToken$ = this.auth$.pipe(\n    switchMap(auth => auth ? auth.getIdToken() : of(null)),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n  readonly accessToken = toSignal(this.accessToken$);\n\n  userId$ = this.auth$.pipe(\n    map(auth => auth?.uid ?? null),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n\n  readonly customClaims$: Observable<Record<string, unknown>> = this.auth$.pipe(\n    switchMap(auth => auth ? auth.getIdTokenResult() : of(null)),\n    map(token => token?.claims ?? {}),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n\n  signInWithTwitter(): Promise<Result> {\n    const provider = new TwitterAuthProvider();\n    return signInWithPopup(this.#auth, provider) as Promise<Result>\n  }\n\n  // signInWithGoogle() {\n  //   const provider = new GoogleAuthProvider();\n  //   return signInWithPopup(this.#auth, provider);\n  // }\n\n  async signInWithGoogle(scopes: string[] = []) {\n    const provider = new GoogleAuthProvider();\n    for (const scope of scopes) provider.addScope(scope);\n    return signInWithPopup(this.#auth, provider).catch(async error => {\n      if (error.code === 'auth/popup-closed-by-user') {\n        const user = await this.#waitForAuthState();\n        if (user) return { user } as UserCredential;\n      }\n      if (error.code === 'auth/account-exists-with-different-credential') {\n        this.onFailedForAccountExistsWithDifferentCredential(error);\n      }\n      throw error;\n    });\n  }\n\n  #waitForAuthState(timeoutMs = 3000): Promise<User | null> {\n    return new Promise(resolve => {\n      let skip = true;\n      const timer = setTimeout(() => { unsub(); resolve(null); }, timeoutMs);\n      const unsub = onAuthStateChanged(this.#auth, user => {\n        if (skip) { skip = false; return; }\n        clearTimeout(timer); unsub(); resolve(user);\n      });\n    });\n  }\n\n  signInWithEmailAndPassword(email: string, password: string) {\n    return signInWithEmailAndPassword(this.#auth, email, password);\n  }\n\n  createUserWithEmailAndPassword(email: string, password: string) {\n    return createUserWithEmailAndPassword(this.#auth, email, password);\n  }\n\n  signInWithCustomToken(customToken: string): Promise<Result> {\n    return signInWithCustomToken(this.#auth, customToken) as Promise<Result>;\n  }\n\n  signOut() {\n    return signOut(this.#auth);\n  }\n\n  private onFailedForAccountExistsWithDifferentCredential(error: any) {\n    const credential = error.customData._tokenResponse;\n    // const pending = FacebookAuthProvider.credential(credential.oauthAccessToken);\n    const providerId = error.customData._tokenResponse.providerId;\n    // this.pends.update(pends => [...pends, {\n    //   credential: pending,\n    //   providerId: providerId,\n    //   email: credential.email,\n    // }]);\n  }\n}\n\nexport function injectAuthState$(): Observable<User | null> {\n  return inject(AuthService).auth$;\n}\n\nexport function injectAuthState(): Signal<User | null | undefined> {\n  return toSignal(injectAuthState$());\n}\n\nexport function injectUserId$(): Observable<string | null> {\n  return inject(AuthService).userId$.pipe(\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n}\n\nexport function injectUserId(): Signal<string | null> {\n  return toSignal(injectUserId$());\n}\n\nexport function injectTwitterId$() {\n  return inject(AuthService).auth$.pipe(\n    map(auth => auth?.providerData?.[0]?.uid ?? null),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  );\n}\n\nexport function injectClaim$<T = string>(claim: string): Observable<T> {\n  return inject(AuthService).customClaims$.pipe(\n    map(token => claim ? get(token, claim) : token),\n    distinctUntilChanged(),\n    shareReplay(1),\n    takeUntilDestroyed(),\n  ) as any;\n}\n\nexport function injectClaim<T = string>(claim: string): Signal<T> {\n  return toSignal(injectClaim$<T>(claim));\n}\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctYXRvbWljLWNvbW1vbi1zZXJ2aWNlcy1hdXRoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb21tb24vc3JjL2xpYi9zZXJ2aWNlcy9hdXRoL25nLWF0b21pYy1jb21tb24tc2VydmljZXMtYXV0aC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
|