vk-payments 0.2.13 → 0.2.15

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.
@@ -5,12 +5,15 @@
5
5
  */
6
6
  import * as tslib_1 from "tslib";
7
7
  import { Component, EventEmitter, Input, Output } from '@angular/core';
8
+ import { ActivatedRoute } from '@angular/router';
8
9
  import { ModoApiService } from '../../services/modo-api.service';
9
10
  var ModoComponent = /** @class */ (function () {
10
- function ModoComponent(modoApi) {
11
+ function ModoComponent(modoApi, route) {
11
12
  this.modoApi = modoApi;
13
+ this.route = route;
12
14
  this.statusPay = new EventEmitter();
13
15
  this.isLoading = false;
16
+ this.executionEnv = 'desktop';
14
17
  }
15
18
  /**
16
19
  * @return {?}
@@ -19,7 +22,47 @@ var ModoComponent = /** @class */ (function () {
19
22
  * @return {?}
20
23
  */
21
24
  function () {
22
- this.loadModoScript();
25
+ this.detectEnvironment();
26
+ if (this.executionEnv === 'desktop') {
27
+ this.loadModoScript();
28
+ }
29
+ };
30
+ /**
31
+ * @private
32
+ * @return {?}
33
+ */
34
+ ModoComponent.prototype.detectEnvironment = /**
35
+ * @private
36
+ * @return {?}
37
+ */
38
+ function () {
39
+ try {
40
+ /** @type {?} */
41
+ var params = this.route.snapshot.params;
42
+ /** @type {?} */
43
+ var guid = params['guid'];
44
+ /** @type {?} */
45
+ var platform = (/** @type {?} */ (params['platform']));
46
+ if (platform === 'iOS' || platform === 'Android' || guid === 'app') {
47
+ this.executionEnv = 'native-app';
48
+ this.devicePlatform = platform;
49
+ console.log("MODO Payment: Entorno detectado -> Nativo (" + (this.devicePlatform || 'app') + ")");
50
+ return;
51
+ }
52
+ }
53
+ catch (error) {
54
+ console.warn('MODO Payment: No se pudo leer los parámetros de la ruta. Se continuará con la detección por User Agent.');
55
+ }
56
+ /** @type {?} */
57
+ var userAgent = navigator.userAgent || navigator.vendor || ((/** @type {?} */ (window))).opera;
58
+ if (/android/i.test(userAgent) || /iPad|iPhone|iPod/.test(userAgent)) {
59
+ this.executionEnv = 'mobile-browser';
60
+ console.log('MODO Payment: Entorno detectado -> Navegador Móvil');
61
+ }
62
+ else {
63
+ this.executionEnv = 'desktop';
64
+ console.log('MODO Payment: Entorno detectado -> Desktop');
65
+ }
23
66
  };
24
67
  /**
25
68
  * @return {?}
@@ -29,8 +72,7 @@ var ModoComponent = /** @class */ (function () {
29
72
  */
30
73
  function () {
31
74
  return tslib_1.__awaiter(this, void 0, void 0, function () {
32
- var initialData_1, modalObject, error_1;
33
- var _this = this;
75
+ var initialData, error_1;
34
76
  return tslib_1.__generator(this, function (_a) {
35
77
  switch (_a.label) {
36
78
  case 0:
@@ -40,49 +82,23 @@ var ModoComponent = /** @class */ (function () {
40
82
  _a.trys.push([1, 3, , 4]);
41
83
  return [4 /*yield*/, this.createModoPayment()];
42
84
  case 2:
43
- initialData_1 = _a.sent();
85
+ initialData = _a.sent();
44
86
  this.isLoading = false;
45
- modalObject = {
46
- version: '2',
47
- qrString: initialData_1.qrString,
48
- checkoutId: initialData_1.checkoutId,
49
- deeplink: {
50
- url: initialData_1.deeplink,
51
- callbackURL: this.callbackUrl,
52
- callbackURLSuccess: this.callbackUrlSuccess
53
- },
54
- callbackURL: this.callbackUrl,
55
- refreshData: (/**
56
- * @return {?}
57
- */
58
- function () { return _this.createModoPayment(); }),
59
- onSuccess: (/**
60
- * @return {?}
61
- */
62
- function () {
63
- _this.statusPay.emit({ success: true, paymentId: initialData_1.checkoutId });
64
- }),
65
- onFailure: (/**
66
- * @return {?}
67
- */
68
- function () {
69
- _this.statusPay.emit({ success: false, paymentId: initialData_1.checkoutId });
70
- }),
71
- onCancel: (/**
72
- * @return {?}
73
- */
74
- function () {
75
- console.log('Pago cancelado por el usuario en el celular.');
76
- }),
77
- onClose: (/**
78
- * @return {?}
79
- */
80
- function () {
81
- console.log('Modal de MODO cerrado.');
82
- }),
83
- };
84
- // 3. Inicia el SDK de MODO
85
- ModoSDK.modoInitPayment(modalObject);
87
+ switch (this.executionEnv) {
88
+ case 'native-app':
89
+ // Llama a la función nativa para abrir en un navegador externo
90
+ this.openOnNativeNavigator(initialData.deeplink);
91
+ break;
92
+ case 'mobile-browser':
93
+ // Abre el deeplink en una nueva pestaña
94
+ window.open(initialData.deeplink, '_blank');
95
+ break;
96
+ case 'desktop':
97
+ default:
98
+ // Abrir el modal del SDK
99
+ this.initModoSdkModal(initialData);
100
+ break;
101
+ }
86
102
  return [3 /*break*/, 4];
87
103
  case 3:
88
104
  error_1 = _a.sent();
@@ -96,18 +112,92 @@ var ModoComponent = /** @class */ (function () {
96
112
  });
97
113
  };
98
114
  /**
99
- * Esta función se encarga de llamar a tu backend.
100
- * Se usa tanto para la carga inicial como para el refresco del SDK.
115
+ * @private
116
+ * @param {?} url
117
+ * @return {?}
118
+ */
119
+ ModoComponent.prototype.openOnNativeNavigator = /**
120
+ * @private
121
+ * @param {?} url
122
+ * @return {?}
101
123
  */
124
+ function (url) {
125
+ try {
126
+ if (this.devicePlatform === 'iOS') {
127
+ ((/** @type {?} */ (window))).webkit.messageHandlers.externalURL.postMessage(url);
128
+ }
129
+ else if (this.devicePlatform === 'Android') {
130
+ ((/** @type {?} */ (window))).externalURL.postMessage(url);
131
+ }
132
+ else {
133
+ // Fallback si por alguna razón no se detectó la plataforma pero sí el entorno nativo
134
+ window.open(url, '_blank');
135
+ }
136
+ }
137
+ catch (e) {
138
+ console.error('Error al intentar invocar el message handler nativo:', e);
139
+ }
140
+ };
141
+ /**
142
+ * @private
143
+ * @param {?} initialData
144
+ * @return {?}
145
+ */
146
+ ModoComponent.prototype.initModoSdkModal = /**
147
+ * @private
148
+ * @param {?} initialData
149
+ * @return {?}
150
+ */
151
+ function (initialData) {
152
+ var _this = this;
153
+ /** @type {?} */
154
+ var modalObject = {
155
+ version: '2',
156
+ qrString: initialData.qrString,
157
+ checkoutId: initialData.checkoutId,
158
+ deeplink: {
159
+ url: initialData.deeplink,
160
+ callbackURL: this.callbackUrl,
161
+ callbackURLSuccess: this.callbackUrlSuccess
162
+ },
163
+ callbackURL: this.callbackUrl,
164
+ refreshData: (/**
165
+ * @return {?}
166
+ */
167
+ function () { return _this.createModoPayment(); }),
168
+ onSuccess: (/**
169
+ * @return {?}
170
+ */
171
+ function () {
172
+ _this.statusPay.emit({ success: true, paymentId: initialData.checkoutId });
173
+ }),
174
+ onFailure: (/**
175
+ * @return {?}
176
+ */
177
+ function () {
178
+ _this.statusPay.emit({ success: false, paymentId: initialData.checkoutId });
179
+ }),
180
+ onCancel: (/**
181
+ * @return {?}
182
+ */
183
+ function () {
184
+ console.log('Pago cancelado por el usuario en el celular.');
185
+ }),
186
+ onClose: (/**
187
+ * @return {?}
188
+ */
189
+ function () {
190
+ console.log('Modal de MODO cerrado.');
191
+ }),
192
+ };
193
+ // 3. Inicia el SDK de MODO
194
+ ModoSDK.modoInitPayment(modalObject);
195
+ };
102
196
  /**
103
- * Esta función se encarga de llamar a tu backend.
104
- * Se usa tanto para la carga inicial como para el refresco del SDK.
105
197
  * @private
106
198
  * @return {?}
107
199
  */
108
200
  ModoComponent.prototype.createModoPayment = /**
109
- * Esta función se encarga de llamar a tu backend.
110
- * Se usa tanto para la carga inicial como para el refresco del SDK.
111
201
  * @private
112
202
  * @return {?}
113
203
  */
@@ -169,7 +259,8 @@ var ModoComponent = /** @class */ (function () {
169
259
  ];
170
260
  /** @nocollapse */
171
261
  ModoComponent.ctorParameters = function () { return [
172
- { type: ModoApiService }
262
+ { type: ModoApiService },
263
+ { type: ActivatedRoute }
173
264
  ]; };
174
265
  ModoComponent.propDecorators = {
175
266
  accessToken: [{ type: Input }],
@@ -209,10 +300,25 @@ if (false) {
209
300
  ModoComponent.prototype.statusPay;
210
301
  /** @type {?} */
211
302
  ModoComponent.prototype.isLoading;
303
+ /**
304
+ * @type {?}
305
+ * @private
306
+ */
307
+ ModoComponent.prototype.executionEnv;
308
+ /**
309
+ * @type {?}
310
+ * @private
311
+ */
312
+ ModoComponent.prototype.devicePlatform;
212
313
  /**
213
314
  * @type {?}
214
315
  * @private
215
316
  */
216
317
  ModoComponent.prototype.modoApi;
318
+ /**
319
+ * @type {?}
320
+ * @private
321
+ */
322
+ ModoComponent.prototype.route;
217
323
  }
218
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modo.component.js","sourceRoot":"ng://vk-payments/","sources":["lib/modo/components/modo/modo.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ModoApiService } from '../../services/modo-api.service';\nimport { CreatePaymentRequest } from '../../models/modo.models';\n\n// Declara la variable global del SDK\ndeclare var ModoSDK: any;\n\n@Component({\n  selector: 'vk-modo-payment',\n  templateUrl: './modo.component.html',\n  styleUrls: ['./modo.component.scss']\n})\nexport class ModoComponent implements OnInit {\n\n  @Input() accessToken!: string;\n  @Input() storeId: string;\n  @Input() idVen: number;\n  @Input() data: string;\n  @Input() amount: number;\n  @Input() orderId: string;\n  @Input() vkUrlApi: string;\n  @Input() callbackUrl: string;\n  @Input() callbackUrlSuccess: string;\n  @Output() statusPay = new EventEmitter<{ success: boolean; paymentId: string }>();\n\n  isLoading = false;\n\n  constructor(private modoApi: ModoApiService) { }\n\n  ngOnInit(): void {\n    this.loadModoScript();\n  }\n\n  async startModoPayment(): Promise<void> {\n    this.isLoading = true;\n\n    try {\n      const initialData = await this.createModoPayment();\n      this.isLoading = false;\n\n      const modalObject = {\n        version: '2',\n        qrString: initialData.qrString,\n        checkoutId: initialData.checkoutId,\n        deeplink: {\n          url: initialData.deeplink,\n          callbackURL: this.callbackUrl,\n          callbackURLSuccess: this.callbackUrlSuccess\n        },\n\n        callbackURL: this.callbackUrl,\n\n        refreshData: () => this.createModoPayment(),\n\n        onSuccess: () => {\n          this.statusPay.emit({ success: true, paymentId: initialData.checkoutId });\n        },\n        onFailure: () => {\n          this.statusPay.emit({ success: false, paymentId: initialData.checkoutId });\n        },\n        onCancel: () => {\n          console.log('Pago cancelado por el usuario en el celular.');\n        },\n        onClose: () => {\n          console.log('Modal de MODO cerrado.');\n        },\n      };\n\n      // 3. Inicia el SDK de MODO\n      ModoSDK.modoInitPayment(modalObject);\n\n    } catch (error) {\n      this.isLoading = false;\n      this.statusPay.emit({ success: false, paymentId: '' });\n      console.error(\"Error al iniciar el pago con MODO\", error);\n    }\n  }\n\n  /**\n   * Esta función se encarga de llamar a tu backend.\n   * Se usa tanto para la carga inicial como para el refresco del SDK.\n   */\n  private async createModoPayment(): Promise<{ qrString: string; checkoutId: string; deeplink: string }> {\n    const paymentRequest: CreatePaymentRequest = {\n      amount: this.amount,\n      orderId: this.orderId,\n      storeId: this.storeId,\n      idVen: this.idVen,\n      data: this.data\n    };\n\n    const response = await this.modoApi.createPayment(this.accessToken, paymentRequest, this.vkUrlApi).toPromise();\n\n    if (response.success && response.data) {\n      return {\n        qrString: response.data.qrString,\n        checkoutId: response.data.internalPaymentId,\n        deeplink: response.data.deeplink\n      };\n    } else {\n      throw new Error('La respuesta de la API no fue exitosa.');\n    }\n  }\n\n  private loadModoScript(): void {\n    const scriptUrl = 'https://ecommerce-modal.modo.com.ar/bundle.js';\n    if (!document.querySelector(`script[src=\"${scriptUrl}\"]`)) {\n      const script = document.createElement('script');\n      script.src = scriptUrl;\n      document.body.appendChild(script);\n    }\n  }\n}"]}
324
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modo.component.js","sourceRoot":"ng://vk-payments/","sources":["lib/modo/components/modo/modo.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { ModoApiService } from '../../services/modo-api.service';\nimport { CreatePaymentRequest } from '../../models/modo.models';\n\n// Declara la variable global del SDK\ndeclare var ModoSDK: any;\n\ntype ExecutionEnvironment = 'desktop' | 'mobile-browser' | 'native-app';\n\n@Component({\n  selector: 'vk-modo-payment',\n  templateUrl: './modo.component.html',\n  styleUrls: ['./modo.component.scss']\n})\nexport class ModoComponent implements OnInit {\n\n  @Input() accessToken!: string;\n  @Input() storeId: string;\n  @Input() idVen: number;\n  @Input() data: string;\n  @Input() amount: number;\n  @Input() orderId: string;\n  @Input() vkUrlApi: string;\n  @Input() callbackUrl: string;\n  @Input() callbackUrlSuccess: string;\n  @Output() statusPay = new EventEmitter<{ success: boolean; paymentId: string }>();\n\n  isLoading = false;\n  private executionEnv: ExecutionEnvironment = 'desktop';\n  private devicePlatform: 'iOS' | 'Android' | undefined;\n\n  constructor(\n    private modoApi: ModoApiService,\n    private route: ActivatedRoute\n  ) { }\n\n  ngOnInit(): void {\n    this.detectEnvironment();\n    if (this.executionEnv === 'desktop') {\n      this.loadModoScript();\n    }\n  }\n\n  private detectEnvironment(): void {\n    try {\n      const params = this.route.snapshot.params;\n      const guid = params['guid'];\n      const platform = params['platform'] as 'iOS' | 'Android';\n\n      if (platform === 'iOS' || platform === 'Android' || guid === 'app') {\n        this.executionEnv = 'native-app';\n        this.devicePlatform = platform;\n        console.log(`MODO Payment: Entorno detectado -> Nativo (${this.devicePlatform || 'app'})`);\n        return;\n      }\n    } catch (error) {\n      console.warn('MODO Payment: No se pudo leer los parámetros de la ruta. Se continuará con la detección por User Agent.');\n    }\n\n    const userAgent = navigator.userAgent || navigator.vendor || (window as any).opera;\n    if (/android/i.test(userAgent) || /iPad|iPhone|iPod/.test(userAgent)) {\n      this.executionEnv = 'mobile-browser';\n      console.log('MODO Payment: Entorno detectado -> Navegador Móvil');\n    } else {\n      this.executionEnv = 'desktop';\n      console.log('MODO Payment: Entorno detectado -> Desktop');\n    }\n  }\n\n  async startModoPayment(): Promise<void> {\n    this.isLoading = true;\n\n    try {\n      const initialData = await this.createModoPayment();\n      this.isLoading = false;\n\n      switch (this.executionEnv) {\n        case 'native-app':\n          // Llama a la función nativa para abrir en un navegador externo\n          this.openOnNativeNavigator(initialData.deeplink);\n          break;\n        case 'mobile-browser':\n          // Abre el deeplink en una nueva pestaña\n          window.open(initialData.deeplink, '_blank');\n          break;\n        case 'desktop':\n        default:\n          // Abrir el modal del SDK\n          this.initModoSdkModal(initialData);\n          break;\n      }\n\n    \n    } catch (error) {\n      this.isLoading = false;\n      this.statusPay.emit({ success: false, paymentId: '' });\n      console.error(\"Error al iniciar el pago con MODO\", error);\n    }\n  }\n\n  private openOnNativeNavigator(url: string): void {\n    try {\n      if (this.devicePlatform === 'iOS') {\n        (window as any).webkit.messageHandlers.externalURL.postMessage(url);\n      } else if (this.devicePlatform === 'Android') {\n        (window as any).externalURL.postMessage(url);\n      } else {\n        // Fallback si por alguna razón no se detectó la plataforma pero sí el entorno nativo\n        window.open(url, '_blank');\n      }\n    } catch (e) {\n      console.error('Error al intentar invocar el message handler nativo:', e);\n    }\n  }\n\n  private initModoSdkModal(initialData: { qrString: string; checkoutId: string; deeplink: string }): void {\n\n    const modalObject = {\n      version: '2',\n      qrString: initialData.qrString,\n      checkoutId: initialData.checkoutId,\n      deeplink: {\n        url: initialData.deeplink,\n        callbackURL: this.callbackUrl,\n        callbackURLSuccess: this.callbackUrlSuccess\n      },\n\n      callbackURL: this.callbackUrl,\n\n      refreshData: () => this.createModoPayment(),\n\n      onSuccess: () => {\n        this.statusPay.emit({ success: true, paymentId: initialData.checkoutId });\n      },\n      onFailure: () => {\n        this.statusPay.emit({ success: false, paymentId: initialData.checkoutId });\n      },\n      onCancel: () => {\n        console.log('Pago cancelado por el usuario en el celular.');\n      },\n      onClose: () => {\n        console.log('Modal de MODO cerrado.');\n      },\n    };\n\n    // 3. Inicia el SDK de MODO\n    ModoSDK.modoInitPayment(modalObject);\n\n  }\n\n\n  private async createModoPayment(): Promise<{ qrString: string; checkoutId: string; deeplink: string }> {\n    const paymentRequest: CreatePaymentRequest = {\n      amount: this.amount,\n      orderId: this.orderId,\n      storeId: this.storeId,\n      idVen: this.idVen,\n      data: this.data\n    };\n\n    const response = await this.modoApi.createPayment(this.accessToken, paymentRequest, this.vkUrlApi).toPromise();\n\n    if (response.success && response.data) {\n      return {\n        qrString: response.data.qrString,\n        checkoutId: response.data.internalPaymentId,\n        deeplink: response.data.deeplink\n      };\n    } else {\n      throw new Error('La respuesta de la API no fue exitosa.');\n    }\n  }\n\n  private loadModoScript(): void {\n    const scriptUrl = 'https://ecommerce-modal.modo.com.ar/bundle.js';\n    if (!document.querySelector(`script[src=\"${scriptUrl}\"]`)) {\n      const script = document.createElement('script');\n      script.src = scriptUrl;\n      document.body.appendChild(script);\n    }\n  }\n}"]}
@@ -1,7 +1,7 @@
1
1
  import { Injectable, ɵɵdefineInjectable, ɵɵinject, EventEmitter, Component, Input, Output, ViewChild, NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
- import { Router, RouterModule } from '@angular/router';
4
+ import { Router, RouterModule, ActivatedRoute } from '@angular/router';
5
5
  import { HttpHeaders, HttpClient, HttpClientModule } from '@angular/common/http';
6
6
  import sha256 from 'sha256';
7
7
  import { __awaiter } from 'tslib';
@@ -2306,7 +2306,8 @@ class GoCuotasComponent {
2306
2306
  this.installments = 0;
2307
2307
  this.currentInstallments = [
2308
2308
  { value: 2, label: '2 Cuotas' },
2309
- { value: 3, label: '3 Cuotas' }
2309
+ { value: 3, label: '3 Cuotas' },
2310
+ { value: 4, label: '4 Cuotas' }
2310
2311
  ]; // Opciones para "Cantidad de cuotas"
2311
2312
  this.totalAmount = Number(this.paymentAmount);
2312
2313
  }
@@ -2851,17 +2852,56 @@ if (false) {
2851
2852
  class ModoComponent {
2852
2853
  /**
2853
2854
  * @param {?} modoApi
2855
+ * @param {?} route
2854
2856
  */
2855
- constructor(modoApi) {
2857
+ constructor(modoApi, route) {
2856
2858
  this.modoApi = modoApi;
2859
+ this.route = route;
2857
2860
  this.statusPay = new EventEmitter();
2858
2861
  this.isLoading = false;
2862
+ this.executionEnv = 'desktop';
2859
2863
  }
2860
2864
  /**
2861
2865
  * @return {?}
2862
2866
  */
2863
2867
  ngOnInit() {
2864
- this.loadModoScript();
2868
+ this.detectEnvironment();
2869
+ if (this.executionEnv === 'desktop') {
2870
+ this.loadModoScript();
2871
+ }
2872
+ }
2873
+ /**
2874
+ * @private
2875
+ * @return {?}
2876
+ */
2877
+ detectEnvironment() {
2878
+ try {
2879
+ /** @type {?} */
2880
+ const params = this.route.snapshot.params;
2881
+ /** @type {?} */
2882
+ const guid = params['guid'];
2883
+ /** @type {?} */
2884
+ const platform = (/** @type {?} */ (params['platform']));
2885
+ if (platform === 'iOS' || platform === 'Android' || guid === 'app') {
2886
+ this.executionEnv = 'native-app';
2887
+ this.devicePlatform = platform;
2888
+ console.log(`MODO Payment: Entorno detectado -> Nativo (${this.devicePlatform || 'app'})`);
2889
+ return;
2890
+ }
2891
+ }
2892
+ catch (error) {
2893
+ console.warn('MODO Payment: No se pudo leer los parámetros de la ruta. Se continuará con la detección por User Agent.');
2894
+ }
2895
+ /** @type {?} */
2896
+ const userAgent = navigator.userAgent || navigator.vendor || ((/** @type {?} */ (window))).opera;
2897
+ if (/android/i.test(userAgent) || /iPad|iPhone|iPod/.test(userAgent)) {
2898
+ this.executionEnv = 'mobile-browser';
2899
+ console.log('MODO Payment: Entorno detectado -> Navegador Móvil');
2900
+ }
2901
+ else {
2902
+ this.executionEnv = 'desktop';
2903
+ console.log('MODO Payment: Entorno detectado -> Desktop');
2904
+ }
2865
2905
  }
2866
2906
  /**
2867
2907
  * @return {?}
@@ -2873,48 +2913,21 @@ class ModoComponent {
2873
2913
  /** @type {?} */
2874
2914
  const initialData = yield this.createModoPayment();
2875
2915
  this.isLoading = false;
2876
- /** @type {?} */
2877
- const modalObject = {
2878
- version: '2',
2879
- qrString: initialData.qrString,
2880
- checkoutId: initialData.checkoutId,
2881
- deeplink: {
2882
- url: initialData.deeplink,
2883
- callbackURL: this.callbackUrl,
2884
- callbackURLSuccess: this.callbackUrlSuccess
2885
- },
2886
- callbackURL: this.callbackUrl,
2887
- refreshData: (/**
2888
- * @return {?}
2889
- */
2890
- () => this.createModoPayment()),
2891
- onSuccess: (/**
2892
- * @return {?}
2893
- */
2894
- () => {
2895
- this.statusPay.emit({ success: true, paymentId: initialData.checkoutId });
2896
- }),
2897
- onFailure: (/**
2898
- * @return {?}
2899
- */
2900
- () => {
2901
- this.statusPay.emit({ success: false, paymentId: initialData.checkoutId });
2902
- }),
2903
- onCancel: (/**
2904
- * @return {?}
2905
- */
2906
- () => {
2907
- console.log('Pago cancelado por el usuario en el celular.');
2908
- }),
2909
- onClose: (/**
2910
- * @return {?}
2911
- */
2912
- () => {
2913
- console.log('Modal de MODO cerrado.');
2914
- }),
2915
- };
2916
- // 3. Inicia el SDK de MODO
2917
- ModoSDK.modoInitPayment(modalObject);
2916
+ switch (this.executionEnv) {
2917
+ case 'native-app':
2918
+ // Llama a la función nativa para abrir en un navegador externo
2919
+ this.openOnNativeNavigator(initialData.deeplink);
2920
+ break;
2921
+ case 'mobile-browser':
2922
+ // Abre el deeplink en una nueva pestaña
2923
+ window.open(initialData.deeplink, '_blank');
2924
+ break;
2925
+ case 'desktop':
2926
+ default:
2927
+ // Abrir el modal del SDK
2928
+ this.initModoSdkModal(initialData);
2929
+ break;
2930
+ }
2918
2931
  }
2919
2932
  catch (error) {
2920
2933
  this.isLoading = false;
@@ -2924,8 +2937,77 @@ class ModoComponent {
2924
2937
  });
2925
2938
  }
2926
2939
  /**
2927
- * Esta función se encarga de llamar a tu backend.
2928
- * Se usa tanto para la carga inicial como para el refresco del SDK.
2940
+ * @private
2941
+ * @param {?} url
2942
+ * @return {?}
2943
+ */
2944
+ openOnNativeNavigator(url) {
2945
+ try {
2946
+ if (this.devicePlatform === 'iOS') {
2947
+ ((/** @type {?} */ (window))).webkit.messageHandlers.externalURL.postMessage(url);
2948
+ }
2949
+ else if (this.devicePlatform === 'Android') {
2950
+ ((/** @type {?} */ (window))).externalURL.postMessage(url);
2951
+ }
2952
+ else {
2953
+ // Fallback si por alguna razón no se detectó la plataforma pero sí el entorno nativo
2954
+ window.open(url, '_blank');
2955
+ }
2956
+ }
2957
+ catch (e) {
2958
+ console.error('Error al intentar invocar el message handler nativo:', e);
2959
+ }
2960
+ }
2961
+ /**
2962
+ * @private
2963
+ * @param {?} initialData
2964
+ * @return {?}
2965
+ */
2966
+ initModoSdkModal(initialData) {
2967
+ /** @type {?} */
2968
+ const modalObject = {
2969
+ version: '2',
2970
+ qrString: initialData.qrString,
2971
+ checkoutId: initialData.checkoutId,
2972
+ deeplink: {
2973
+ url: initialData.deeplink,
2974
+ callbackURL: this.callbackUrl,
2975
+ callbackURLSuccess: this.callbackUrlSuccess
2976
+ },
2977
+ callbackURL: this.callbackUrl,
2978
+ refreshData: (/**
2979
+ * @return {?}
2980
+ */
2981
+ () => this.createModoPayment()),
2982
+ onSuccess: (/**
2983
+ * @return {?}
2984
+ */
2985
+ () => {
2986
+ this.statusPay.emit({ success: true, paymentId: initialData.checkoutId });
2987
+ }),
2988
+ onFailure: (/**
2989
+ * @return {?}
2990
+ */
2991
+ () => {
2992
+ this.statusPay.emit({ success: false, paymentId: initialData.checkoutId });
2993
+ }),
2994
+ onCancel: (/**
2995
+ * @return {?}
2996
+ */
2997
+ () => {
2998
+ console.log('Pago cancelado por el usuario en el celular.');
2999
+ }),
3000
+ onClose: (/**
3001
+ * @return {?}
3002
+ */
3003
+ () => {
3004
+ console.log('Modal de MODO cerrado.');
3005
+ }),
3006
+ };
3007
+ // 3. Inicia el SDK de MODO
3008
+ ModoSDK.modoInitPayment(modalObject);
3009
+ }
3010
+ /**
2929
3011
  * @private
2930
3012
  * @return {?}
2931
3013
  */
@@ -2977,7 +3059,8 @@ ModoComponent.decorators = [
2977
3059
  ];
2978
3060
  /** @nocollapse */
2979
3061
  ModoComponent.ctorParameters = () => [
2980
- { type: ModoApiService }
3062
+ { type: ModoApiService },
3063
+ { type: ActivatedRoute }
2981
3064
  ];
2982
3065
  ModoComponent.propDecorators = {
2983
3066
  accessToken: [{ type: Input }],
@@ -3014,11 +3097,26 @@ if (false) {
3014
3097
  ModoComponent.prototype.statusPay;
3015
3098
  /** @type {?} */
3016
3099
  ModoComponent.prototype.isLoading;
3100
+ /**
3101
+ * @type {?}
3102
+ * @private
3103
+ */
3104
+ ModoComponent.prototype.executionEnv;
3105
+ /**
3106
+ * @type {?}
3107
+ * @private
3108
+ */
3109
+ ModoComponent.prototype.devicePlatform;
3017
3110
  /**
3018
3111
  * @type {?}
3019
3112
  * @private
3020
3113
  */
3021
3114
  ModoComponent.prototype.modoApi;
3115
+ /**
3116
+ * @type {?}
3117
+ * @private
3118
+ */
3119
+ ModoComponent.prototype.route;
3022
3120
  }
3023
3121
 
3024
3122
  /**