valtech-components 2.0.757 → 2.0.759

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.
@@ -90,7 +90,7 @@ export declare class ArticleComponent implements OnInit {
90
90
  contentInterpolation?: Record<string, string | number>;
91
91
  icon?: import("valtech-components").IconMetada;
92
92
  shape?: "round";
93
- size?: "default" | "small" | "large";
93
+ size?: "small" | "large" | "default";
94
94
  fill?: "default" | "clear" | "outline" | "solid";
95
95
  type: "button" | "submit" | "reset";
96
96
  token?: string;
@@ -72,7 +72,7 @@ export declare class ToolbarComponent implements OnInit {
72
72
  };
73
73
  showFlags?: boolean;
74
74
  color: import("@ionic/core").Color;
75
- size?: "default" | "small" | "large";
75
+ size?: "small" | "large" | "default";
76
76
  fill?: "default" | "clear" | "outline" | "solid";
77
77
  shape?: "round";
78
78
  expand?: "full" | "block";
@@ -4,6 +4,7 @@ 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';
7
8
  import * as i0 from "@angular/core";
8
9
  /** Resultado descriptivo del open() — útil para tests y telemetría. */
9
10
  export type NotificationOpenResult = 'navigated' | 'navigated-after-switch-org' | 'redirected-cross-app' | 'no-action-route' | 'cross-app-unconfigured' | 'handoff-failed';
@@ -23,6 +24,16 @@ export declare class NotificationActionService {
23
24
  * técnicos quedan en console.warn.
24
25
  */
25
26
  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>;
26
37
  private activeOrg;
27
38
  /**
28
39
  * Construye URL absoluta para handoff cross-app preservando pathname y otros
package/lib/version.d.ts CHANGED
@@ -2,4 +2,4 @@
2
2
  * Current version of valtech-components.
3
3
  * This is automatically updated during the publish process.
4
4
  */
5
- export declare const VERSION = "2.0.757";
5
+ export declare const VERSION = "2.0.759";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "valtech-components",
3
- "version": "2.0.757",
3
+ "version": "2.0.759",
4
4
  "private": false,
5
5
  "bin": {
6
6
  "valtech-firebase-config": "./src/lib/services/firebase/scripts/generate-sw-config.js"
@@ -96,33 +96,28 @@ if (!self.FIREBASE_CONFIG) {
96
96
  event.waitUntil(
97
97
  clients
98
98
  .matchAll({ type: 'window', includeUncontrolled: true })
99
- .then((clientList) => {
100
- // Siempre enviar postMessage para que la app pueda reaccionar
101
- for (const client of clientList) {
99
+ .then(async (clientList) => {
100
+ // Estrategia: el SW NO navega. Solo da foco al client y emite postMessage.
101
+ // La app (MessagingService NotificationActionService.openFromFCM) hace
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.
102
111
  client.postMessage(notificationPayload);
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);
115
- }
116
- }
117
-
118
- // Solo hacer focus si no hay navegación
119
- for (const client of clientList) {
120
112
  if ('focus' in client) {
121
- return client.focus();
113
+ await client.focus();
122
114
  }
115
+ return;
123
116
  }
117
+
118
+ // Sin clients abiertos: openWindow con la URL final ya resuelta.
124
119
  if (clients.openWindow) {
125
- return clients.openWindow('/');
120
+ return clients.openWindow(targetUrl);
126
121
  }
127
122
  })
128
123
  );