valtech-components 2.0.759 → 2.0.761
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/esm2022/lib/services/auth/config.mjs +2 -39
- package/esm2022/lib/services/auth/notification-action.service.mjs +1 -24
- package/esm2022/lib/version.mjs +2 -2
- package/fesm2022/valtech-components.mjs +2959 -3017
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/services/auth/notification-action.service.d.ts +0 -11
- package/lib/version.d.ts +1 -1
- package/package.json +1 -1
- package/src/lib/services/firebase/firebase-messaging-sw.js +22 -17
|
@@ -4,7 +4,6 @@ import { HandoffService } from './handoff.service';
|
|
|
4
4
|
import { OrgSwitchService } from './org-switch.service';
|
|
5
5
|
import { ValtechAuthConfig } from './types';
|
|
6
6
|
import { NotificationDocument, NotificationsService } from '../firebase/notifications.service';
|
|
7
|
-
import { NotificationClickEvent } from '../firebase/types';
|
|
8
7
|
import * as i0 from "@angular/core";
|
|
9
8
|
/** Resultado descriptivo del open() — útil para tests y telemetría. */
|
|
10
9
|
export type NotificationOpenResult = 'navigated' | 'navigated-after-switch-org' | 'redirected-cross-app' | 'no-action-route' | 'cross-app-unconfigured' | 'handoff-failed';
|
|
@@ -24,16 +23,6 @@ export declare class NotificationActionService {
|
|
|
24
23
|
* técnicos quedan en console.warn.
|
|
25
24
|
*/
|
|
26
25
|
open(notif: NotificationDocument): Promise<NotificationOpenResult>;
|
|
27
|
-
/**
|
|
28
|
-
* Variante para clicks de FCM push (background SW → postMessage).
|
|
29
|
-
* Mapea el payload del FCM a la forma de `NotificationDocument` y delega en `open()`.
|
|
30
|
-
*
|
|
31
|
-
* Diferencias con clicks de inbox Firestore:
|
|
32
|
-
* - No hay `id` Firestore → markAsRead se skipea (no aplica).
|
|
33
|
-
* - `appId`/`orgId`/`actionRoute` se extraen de `notification.data` (lo que el
|
|
34
|
-
* backend `push.SendPush` puso allí) o de `event.action` (parsed por MessagingService).
|
|
35
|
-
*/
|
|
36
|
-
openFromFCM(event: NotificationClickEvent): Promise<NotificationOpenResult>;
|
|
37
26
|
private activeOrg;
|
|
38
27
|
/**
|
|
39
28
|
* Construye URL absoluta para handoff cross-app preservando pathname y otros
|
package/lib/version.d.ts
CHANGED
package/package.json
CHANGED
|
@@ -96,28 +96,33 @@ if (!self.FIREBASE_CONFIG) {
|
|
|
96
96
|
event.waitUntil(
|
|
97
97
|
clients
|
|
98
98
|
.matchAll({ type: 'window', includeUncontrolled: true })
|
|
99
|
-
.then(
|
|
100
|
-
//
|
|
101
|
-
|
|
102
|
-
// routing via Angular Router → SPA navigation + handoff cross-app + switch-org.
|
|
103
|
-
// `client.navigate()` haría full reload y compite con Router → ambos pierden.
|
|
104
|
-
//
|
|
105
|
-
// Solo abrimos nueva ventana (con URL completa) cuando NO hay client abierto;
|
|
106
|
-
// ese caso es el único donde el SW SÍ define la URL inicial.
|
|
107
|
-
if (clientList.length > 0) {
|
|
108
|
-
const client = clientList[0];
|
|
109
|
-
// postMessage al primer client — el wire de la app (APP_INITIALIZER de
|
|
110
|
-
// provideValtechAuth) recibe y dispatcha NotificationActionService.
|
|
99
|
+
.then((clientList) => {
|
|
100
|
+
// Siempre enviar postMessage para que la app pueda reaccionar
|
|
101
|
+
for (const client of clientList) {
|
|
111
102
|
client.postMessage(notificationPayload);
|
|
112
|
-
|
|
113
|
-
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// Navegar si hay route o url
|
|
106
|
+
if (targetUrl !== '/') {
|
|
107
|
+
for (const client of clientList) {
|
|
108
|
+
if ('navigate' in client) {
|
|
109
|
+
return client.navigate(targetUrl).then((c) => c?.focus());
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
// Si no hay cliente abierto, abrir nueva ventana
|
|
113
|
+
if (clients.openWindow) {
|
|
114
|
+
return clients.openWindow(targetUrl);
|
|
114
115
|
}
|
|
115
|
-
return;
|
|
116
116
|
}
|
|
117
117
|
|
|
118
|
-
//
|
|
118
|
+
// Solo hacer focus si no hay navegación
|
|
119
|
+
for (const client of clientList) {
|
|
120
|
+
if ('focus' in client) {
|
|
121
|
+
return client.focus();
|
|
122
|
+
}
|
|
123
|
+
}
|
|
119
124
|
if (clients.openWindow) {
|
|
120
|
-
return clients.openWindow(
|
|
125
|
+
return clients.openWindow('/');
|
|
121
126
|
}
|
|
122
127
|
})
|
|
123
128
|
);
|