surveysparrow-ionic-plugin 2.0.1 → 2.0.2-beta.2
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/dist/angular-ui/esm2022/spotchecks/SpotCheckComponent.mjs +80 -51
- package/dist/angular-ui/esm2022/spotchecks/SpotCheckEventListener.mjs +26 -0
- package/dist/angular-ui/esm2022/spotchecks/api.mjs +1 -1
- package/dist/angular-ui/esm2022/spotchecks/helpers.mjs +6 -3
- package/dist/angular-ui/esm2022/spotchecks/index.mjs +2 -1
- package/dist/angular-ui/fesm2022/angular-ui.mjs +109 -54
- package/dist/angular-ui/fesm2022/angular-ui.mjs.map +1 -1
- package/dist/angular-ui/spotchecks/SpotCheckComponent.d.ts +10 -4
- package/dist/angular-ui/spotchecks/SpotCheckEventListener.d.ts +16 -0
- package/dist/angular-ui/spotchecks/index.d.ts +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckComponent.d.ts +10 -4
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckComponent.js +75 -48
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckComponent.js.map +1 -1
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckEventListener.d.ts +16 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckEventListener.js +28 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckEventListener.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/api.js.map +1 -1
- package/dist/esm/angular-ui/lib/spotchecks/helpers.js +5 -2
- package/dist/esm/angular-ui/lib/spotchecks/helpers.js.map +1 -1
- package/dist/esm/angular-ui/lib/spotchecks/index.d.ts +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/index.js +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/index.js.map +1 -1
- package/dist/plugin.cjs.js +103 -44
- package/dist/plugin.cjs.js.map +1 -1
- package/dist/plugin.js +103 -44
- package/dist/plugin.js.map +1 -1
- package/package.json +1 -1
- package/src/angular-ui/lib/spotchecks/SpotCheckComponent.ts +75 -44
- package/src/angular-ui/lib/spotchecks/SpotCheckEventListener.ts +50 -0
- package/src/angular-ui/lib/spotchecks/api.ts +2 -2
- package/src/angular-ui/lib/spotchecks/helpers.ts +6 -4
- package/src/angular-ui/lib/spotchecks/index.ts +3 -0
|
@@ -2,19 +2,24 @@ import { Component, Input, ViewChild, HostListener, } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { closeSpotCheck, closeSpotCheckAndHandleSurveyEnd, getSpotcheckComponentCssStyles, handleSurveyEnd, ischatSurvey } from './helpers';
|
|
4
4
|
import { getSpotcheckStateService } from './helpers';
|
|
5
|
+
import { getSpotCheckEventListener } from './SpotCheckEventListener';
|
|
5
6
|
import axios from 'axios';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/platform-browser";
|
|
8
9
|
import * as i2 from "@angular/common";
|
|
9
10
|
export class WebViewComponent {
|
|
10
11
|
sanitizer;
|
|
12
|
+
ngZone;
|
|
13
|
+
cdr;
|
|
11
14
|
url = '';
|
|
12
15
|
webviewType = 'classic';
|
|
13
16
|
isMiniCard = false;
|
|
14
17
|
safeUrl = null;
|
|
15
18
|
iframe;
|
|
16
|
-
constructor(sanitizer) {
|
|
19
|
+
constructor(sanitizer, ngZone, cdr) {
|
|
17
20
|
this.sanitizer = sanitizer;
|
|
21
|
+
this.ngZone = ngZone;
|
|
22
|
+
this.cdr = cdr;
|
|
18
23
|
}
|
|
19
24
|
ngOnInit() {
|
|
20
25
|
if (this.url) {
|
|
@@ -41,48 +46,55 @@ export class WebViewComponent {
|
|
|
41
46
|
setupIframeLoadListener() {
|
|
42
47
|
const iframe = this.iframe.nativeElement;
|
|
43
48
|
iframe.addEventListener('load', () => {
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
49
|
+
this.ngZone.run(() => {
|
|
50
|
+
const stateService = getSpotcheckStateService();
|
|
51
|
+
if (this.webviewType === 'classic') {
|
|
52
|
+
stateService.setState({ isClassicLoading: false });
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
stateService.setState({ isChatLoading: false });
|
|
56
|
+
}
|
|
57
|
+
});
|
|
51
58
|
});
|
|
52
59
|
}
|
|
53
60
|
onMessage(event) {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
61
|
+
this.ngZone.run(() => {
|
|
62
|
+
const stateService = getSpotcheckStateService();
|
|
63
|
+
const { data } = event;
|
|
64
|
+
switch (data.type) {
|
|
65
|
+
case 'slideInFrame':
|
|
66
|
+
if (data.mounted) {
|
|
67
|
+
stateService.setState({ isMounted: true });
|
|
68
|
+
}
|
|
69
|
+
break;
|
|
70
|
+
case 'resizeWindow':
|
|
71
|
+
if (data.size) {
|
|
72
|
+
stateService.setState({
|
|
73
|
+
currentQuestionHeight: data.size.height,
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
else if (data.isCloseButtonEnabled) {
|
|
77
|
+
stateService.setState({
|
|
78
|
+
isCloseButtonEnabled: data.isCloseButtonEnabled,
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
break;
|
|
82
|
+
case 'surveyCompleted':
|
|
83
|
+
closeSpotCheckAndHandleSurveyEnd().then(() => {
|
|
84
|
+
getSpotCheckEventListener().emit('surveyCompleted', data.response);
|
|
85
|
+
this.cdr.detectChanges();
|
|
71
86
|
});
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
default:
|
|
82
|
-
break;
|
|
83
|
-
}
|
|
87
|
+
break;
|
|
88
|
+
case 'surveyLoadStarted':
|
|
89
|
+
getSpotCheckEventListener().emit('surveyLoadStarted', data.surveyDetails);
|
|
90
|
+
break;
|
|
91
|
+
default:
|
|
92
|
+
break;
|
|
93
|
+
}
|
|
94
|
+
this.cdr.detectChanges();
|
|
95
|
+
});
|
|
84
96
|
}
|
|
85
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: WebViewComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
97
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: WebViewComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
86
98
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.3", type: WebViewComponent, isStandalone: true, selector: "WebViewComponent", inputs: { url: "url", webviewType: "webviewType", isMiniCard: "isMiniCard" }, host: { listeners: { "window:message": "onMessage($event)" } }, viewQueries: [{ propertyName: "iframe", first: true, predicate: ["iframeRef"], descendants: true }], ngImport: i0, template: `
|
|
87
99
|
<div style="overflow: hidden; height: 100%; border-radius: {{isMiniCard ? 12 : 0}}px; padding-left: {{isMiniCard ? 12 : 0}}px; padding-right: {{isMiniCard ? 12 : 0}}px; box-sizing: border-box;">
|
|
88
100
|
<iframe
|
|
@@ -115,7 +127,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImpor
|
|
|
115
127
|
standalone: true,
|
|
116
128
|
imports: [CommonModule],
|
|
117
129
|
}]
|
|
118
|
-
}], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { url: [{
|
|
130
|
+
}], ctorParameters: () => [{ type: i1.DomSanitizer }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }], propDecorators: { url: [{
|
|
119
131
|
type: Input
|
|
120
132
|
}], webviewType: [{
|
|
121
133
|
type: Input
|
|
@@ -183,6 +195,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImpor
|
|
|
183
195
|
type: Input
|
|
184
196
|
}] } });
|
|
185
197
|
export class CloseButtonComponent {
|
|
198
|
+
ngZone;
|
|
199
|
+
cdr;
|
|
186
200
|
size = 30;
|
|
187
201
|
strokeWidth = 1.2;
|
|
188
202
|
state;
|
|
@@ -191,13 +205,18 @@ export class CloseButtonComponent {
|
|
|
191
205
|
isVisible = false;
|
|
192
206
|
isMiniCard = false;
|
|
193
207
|
stroke = 'black';
|
|
194
|
-
constructor() {
|
|
208
|
+
constructor(ngZone, cdr) {
|
|
209
|
+
this.ngZone = ngZone;
|
|
210
|
+
this.cdr = cdr;
|
|
195
211
|
this.stateService = getSpotcheckStateService();
|
|
196
212
|
this.state = this.stateService.getState();
|
|
197
213
|
this.updateComponentState();
|
|
198
214
|
this.stateSubscription = this.stateService.state$.subscribe((newState) => {
|
|
199
|
-
this.
|
|
200
|
-
|
|
215
|
+
this.ngZone.run(() => {
|
|
216
|
+
this.state = newState;
|
|
217
|
+
this.updateComponentState();
|
|
218
|
+
this.cdr.detectChanges();
|
|
219
|
+
});
|
|
201
220
|
});
|
|
202
221
|
}
|
|
203
222
|
ngOnDestroy() {
|
|
@@ -220,8 +239,11 @@ export class CloseButtonComponent {
|
|
|
220
239
|
onClick = async () => {
|
|
221
240
|
await closeSpotCheck();
|
|
222
241
|
handleSurveyEnd();
|
|
242
|
+
this.ngZone.run(() => {
|
|
243
|
+
this.cdr.detectChanges();
|
|
244
|
+
});
|
|
223
245
|
};
|
|
224
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
246
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseButtonComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
225
247
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.3", type: CloseButtonComponent, isStandalone: true, selector: "spotcheck-close-button", inputs: { size: "size", strokeWidth: "strokeWidth" }, ngImport: i0, template: `
|
|
226
248
|
<div style="position: absolute; top: -36px; right: 16px; z-index: 100001; cursor: pointer; background-color: white; border-radius: 50px;" (click)="onClick()" *ngIf="isVisible && isMiniCard">
|
|
227
249
|
<close-svg [size]="size" [stroke]="stroke" [strokeWidth]="strokeWidth" style="display: flex; align-items: center; justify-content: center;"/>
|
|
@@ -246,25 +268,32 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImpor
|
|
|
246
268
|
standalone: true,
|
|
247
269
|
imports: [CommonModule, CloseSVGComponent],
|
|
248
270
|
}]
|
|
249
|
-
}], ctorParameters: () => [], propDecorators: { size: [{
|
|
271
|
+
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ChangeDetectorRef }], propDecorators: { size: [{
|
|
250
272
|
type: Input
|
|
251
273
|
}], strokeWidth: [{
|
|
252
274
|
type: Input
|
|
253
275
|
}] } });
|
|
254
276
|
export class SpotCheckComponent {
|
|
277
|
+
ngZone;
|
|
278
|
+
cdr;
|
|
255
279
|
state;
|
|
256
280
|
spotcheckStateService;
|
|
257
281
|
stateSubscription;
|
|
258
282
|
componentStyles = {};
|
|
259
283
|
avatarUrl = '';
|
|
260
|
-
constructor() {
|
|
284
|
+
constructor(ngZone, cdr) {
|
|
285
|
+
this.ngZone = ngZone;
|
|
286
|
+
this.cdr = cdr;
|
|
261
287
|
this.spotcheckStateService = getSpotcheckStateService();
|
|
262
288
|
this.state = this.spotcheckStateService.getState();
|
|
263
289
|
this.updateComponentStyles();
|
|
264
290
|
this.stateSubscription = this.spotcheckStateService.state$.subscribe((newState) => {
|
|
265
|
-
this.
|
|
266
|
-
|
|
267
|
-
|
|
291
|
+
this.ngZone.run(() => {
|
|
292
|
+
this.state = newState;
|
|
293
|
+
this.updateComponentStyles();
|
|
294
|
+
this.avatarUrl = this.state.avatarUrl || "https://static.surveysparrow.com/application/images/profile.png";
|
|
295
|
+
this.cdr.detectChanges();
|
|
296
|
+
});
|
|
268
297
|
});
|
|
269
298
|
}
|
|
270
299
|
ngOnInit() {
|
|
@@ -313,11 +342,11 @@ export class SpotCheckComponent {
|
|
|
313
342
|
console.log('Error initializing widget:', JSON.stringify(error));
|
|
314
343
|
}
|
|
315
344
|
};
|
|
316
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheckComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
345
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheckComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
317
346
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.3", type: SpotCheckComponent, isStandalone: true, selector: "SpotCheckComponent", ngImport: i0, template: "<div [ngStyle]=\"componentStyles.wrapperStyles\" class=\"safe-area\">\n <div [ngStyle]=\"componentStyles.styles\">\n <div style=\"position: relative; height: 100%;\">\n <spotcheck-close-button />\n \n <WebViewComponent\n *ngIf=\"state.classicUrl && state.classicUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'classic'\"\n [url]=\"state.classicUrl\"\n [webviewType]=\"'classic'\"\n [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n />\n \n <WebViewComponent\n *ngIf=\"state.chatUrl && state.chatUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'chat'\"\n [url]=\"state.chatUrl\"\n [webviewType]=\"'chat'\"\n [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n />\n\n <div *ngIf=\"state.spotChecksMode === 'miniCard' && state.avatarEnabled\">\n <div style=\"position: absolute; bottom: -66px; left: 16px; z-index: 100001;\">\n <img [src]=\"avatarUrl\" style=\"width: 56px; height: 56px; border-radius: 50px; background-color: white;\"/>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".safe-area{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);box-sizing:border-box}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: WebViewComponent, selector: "WebViewComponent", inputs: ["url", "webviewType", "isMiniCard"] }, { kind: "component", type: CloseButtonComponent, selector: "spotcheck-close-button", inputs: ["size", "strokeWidth"] }] });
|
|
318
347
|
}
|
|
319
348
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheckComponent, decorators: [{
|
|
320
349
|
type: Component,
|
|
321
350
|
args: [{ selector: 'SpotCheckComponent', standalone: true, imports: [CommonModule, WebViewComponent, CloseButtonComponent], template: "<div [ngStyle]=\"componentStyles.wrapperStyles\" class=\"safe-area\">\n <div [ngStyle]=\"componentStyles.styles\">\n <div style=\"position: relative; height: 100%;\">\n <spotcheck-close-button />\n \n <WebViewComponent\n *ngIf=\"state.classicUrl && state.classicUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'classic'\"\n [url]=\"state.classicUrl\"\n [webviewType]=\"'classic'\"\n [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n />\n \n <WebViewComponent\n *ngIf=\"state.chatUrl && state.chatUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'chat'\"\n [url]=\"state.chatUrl\"\n [webviewType]=\"'chat'\"\n [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n />\n\n <div *ngIf=\"state.spotChecksMode === 'miniCard' && state.avatarEnabled\">\n <div style=\"position: absolute; bottom: -66px; left: 16px; z-index: 100001;\">\n <img [src]=\"avatarUrl\" style=\"width: 56px; height: 56px; border-radius: 50px; background-color: white;\"/>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".safe-area{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);box-sizing:border-box}\n"] }]
|
|
322
|
-
}], ctorParameters: () => [] });
|
|
323
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SpotCheckComponent.js","sourceRoot":"","sources":["../../../../src/angular-ui/lib/spotchecks/SpotCheckComponent.ts","../../../../src/angular-ui/lib/spotchecks/SpotCheckComponent.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  OnInit,\n  Component,\n  Input,\n  OnDestroy,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  HostListener,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Subscription } from 'rxjs';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { closeSpotCheck, closeSpotCheckAndHandleSurveyEnd, getSpotcheckComponentCssStyles, handleSurveyEnd, ischatSurvey } from './helpers';\nimport { SpotcheckState } from './types';\nimport { getSpotcheckStateService } from './helpers';\nimport { SpotcheckStateService } from './SpotcheckStateService';\nimport axios from 'axios';\n\n@Component({\n  selector: 'WebViewComponent',\n  template: `\n    <div style=\"overflow: hidden; height: 100%; border-radius: {{isMiniCard ? 12 : 0}}px; padding-left: {{isMiniCard ? 12 : 0}}px; padding-right: {{isMiniCard ? 12 : 0}}px; box-sizing: border-box;\">\n      <iframe\n        allow=\"camera; microphone; geolocation; display-capture; autoplay; clipboard-read; clipboard-write;\"\n        #iframeRef\n        [src]=\"safeUrl\"\n        style=\"width: 100%; height: 100%; display: block; border-radius: {{isMiniCard ? 12 : 0}}px;\"\n        frameborder=\"0\"\n      >\n      </iframe>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class WebViewComponent implements OnInit, AfterViewInit {\n  @Input() url: string = '';\n  @Input() webviewType: 'classic' | 'chat' = 'classic';\n  @Input() isMiniCard: boolean = false;\n\n  safeUrl: SafeResourceUrl | null = null;\n  @ViewChild('iframeRef') iframe!: ElementRef<HTMLIFrameElement>;\n\n  constructor(private sanitizer: DomSanitizer) {}\n  ngOnInit() {\n    if (this.url) {\n      this.safeUrl = this.sanitizer.bypassSecurityTrustResourceUrl(this.url);\n    }\n  }\n\n  ngAfterViewInit() {\n    const stateService = getSpotcheckStateService();\n    const webViewRef = this.iframe.nativeElement;\n\n    if (this.webviewType === 'classic') {\n      stateService.setState({\n        classicWebViewRef: webViewRef,\n        isClassicLoading: false,\n      });\n    } else {\n      stateService.setState({\n        chatWebViewRef: webViewRef,\n        isChatLoading: false,\n      });\n    }\n    this.setupIframeLoadListener();\n  }\n\n  private setupIframeLoadListener() {\n    const iframe = this.iframe.nativeElement;\n    iframe.addEventListener('load', () => {\n      const stateService = getSpotcheckStateService();\n      if (this.webviewType === 'classic') {\n        stateService.setState({ isClassicLoading: false });\n      } else {\n        stateService.setState({ isChatLoading: false });\n      }\n    });\n  }\n\n  @HostListener('window:message', ['$event'])\n  onMessage(event: MessageEvent) {\n    const stateService = getSpotcheckStateService();\n    const { data } = event;\n    switch (data.type) {\n      case 'slideInFrame':\n        if (data.mounted) {\n          stateService.setState({ isMounted: true });\n        }\n        break;\n\n      case 'resizeWindow':\n        if (data.size) {\n          stateService.setState({\n            currentQuestionHeight: data.size.height,\n          });\n        } else if (data.isCloseButtonEnabled) {\n          stateService.setState({\n            isCloseButtonEnabled: data.isCloseButtonEnabled,\n          });\n        }\n        break;\n\n      case 'surveyCompleted':\n        closeSpotCheckAndHandleSurveyEnd();\n        // spotchecksListener.emitSurveyCompleted(data.response);\n        break;\n\n      case 'surveyLoadStarted':\n        // spotchecksListener.emitSurveyLoadStarted(data.surveyDetails);\n        break;\n\n      default:\n        break;\n    }\n  }\n}\n\n@Component({\n  selector: 'close-svg',\n  template: `\n    <svg\n      [attr.width]=\"size\"\n      [attr.height]=\"size\"\n      viewBox=\"0 0 32 32\"\n      fill=\"none\"\n      xmlns=\"https://www.w3.org/2000/svg\"\n    >\n      <path\n        d=\"M10.6665 10.667L21.3332 21.3337M21.3332 10.667L10.6665 21.3337\"\n        [attr.stroke]=\"stroke\"\n        [attr.stroke-width]=\"strokeWidth\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n    </svg>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class CloseSVGComponent {\n  @Input() size: number = 32;\n  @Input() stroke: string = '#919191';\n  @Input() strokeWidth: number = 1.5;\n}\n\n@Component({\n  selector: 'spotcheck-close-button',\n  template: `\n      <div style=\"position: absolute; top: -36px; right: 16px; z-index: 100001; cursor: pointer; background-color: white; border-radius: 50px;\" (click)=\"onClick()\" *ngIf=\"isVisible && isMiniCard\">\n        <close-svg [size]=\"size\" [stroke]=\"stroke\" [strokeWidth]=\"strokeWidth\" style=\"display: flex; align-items: center; justify-content: center;\"/>\n      </div>\n      <div style=\"position: absolute; top: 16px; right: 16px; z-index: 100001; cursor: pointer;\" (click)=\"onClick()\" *ngIf=\"isVisible && !isMiniCard\">\n        <close-svg [size]=\"size\" [stroke]=\"stroke\" [strokeWidth]=\"strokeWidth\"/>\n      </div>\n  `,\n  standalone: true,\n  imports: [CommonModule, CloseSVGComponent],\n})\nexport class CloseButtonComponent implements OnDestroy {\n  @Input() size: number = 30;\n  @Input() strokeWidth: number = 1.2;\n  \n  state: SpotcheckState;\n  private stateService: SpotcheckStateService;\n  private stateSubscription!: Subscription;\n  \n  isVisible: boolean = false;\n  isMiniCard: boolean = false;\n  stroke: string = 'black';\n  \n  constructor() {\n    this.stateService = getSpotcheckStateService();\n    this.state = this.stateService.getState();\n    this.updateComponentState();\n\n    this.stateSubscription = this.stateService.state$.subscribe(\n      (newState: SpotcheckState) => {\n        this.state = newState;\n        this.updateComponentState();\n      }\n    );\n  }\n\n  ngOnDestroy(): void {\n    if (this.stateSubscription) {\n      this.stateSubscription.unsubscribe();\n    }\n  }\n\n  private updateComponentState(): void {\n    this.isVisible =\n      this.state.isCloseButtonEnabled &&\n      ((this.state.currentQuestionHeight > 0 && !this.state.isFullScreenMode) ||\n        (this.state.isFullScreenMode &&\n          ((!this.state.isClassicLoading &&\n            this.state.spotCheckType === 'classic') ||\n            (!this.state.isChatLoading &&\n              this.state.spotCheckType === 'chat'))));\n    this.isMiniCard = this.state.spotChecksMode === 'miniCard';\n    this.stroke = this.isMiniCard ? 'black' : this.state.closeButtonStyle?.['ctaButton'] || 'black';\n  }\n\n  onClick = async () => {\n    await closeSpotCheck();\n    handleSurveyEnd();\n  };\n}\n\n\n@Component({\n  selector: 'SpotCheckComponent',\n  templateUrl: './SpotCheckComponent.html',\n  styleUrls: ['./SpotCheckComponent.css'],\n  standalone: true,\n  imports: [CommonModule, WebViewComponent, CloseButtonComponent],\n})\nexport class SpotCheckComponent implements OnInit, OnDestroy {\n  state: SpotcheckState;\n  private spotcheckStateService: SpotcheckStateService;\n  private stateSubscription: Subscription;\n  componentStyles: any = {};\n  avatarUrl: string = '';\n\n  constructor() {\n    this.spotcheckStateService = getSpotcheckStateService();\n    this.state = this.spotcheckStateService.getState();\n    this.updateComponentStyles();\n\n    this.stateSubscription = this.spotcheckStateService.state$.subscribe(\n      (newState: SpotcheckState) => {\n        this.state = newState;\n        this.updateComponentStyles();\n        this.avatarUrl = this.state.avatarUrl || \"https://static.surveysparrow.com/application/images/profile.png\";\n      }\n    );\n  }\n\n  ngOnInit(): void {\n    this.initializeComponent();\n  }\n\n  ngOnDestroy(): void {\n    if (this.stateSubscription) {\n      this.stateSubscription.unsubscribe();\n    }\n  }\n\n  private updateComponentStyles(): void {\n    this.componentStyles = getSpotcheckComponentCssStyles(this.state);\n  }\n\n  initializeComponent = async () => {\n    try {\n      const domainName = this.state.domainName;\n      const targetToken = this.state.targetToken;\n      const response = await axios.get(\n        `https://${domainName}/api/internal/spotcheck/widget/${targetToken}/init`\n      );\n      const data = response.data;\n\n      if (data.filteredSpotChecks && data.filteredSpotChecks.length > 0) {\n        let classicIframe = false;\n        let chatIframe = false;\n\n        data.filteredSpotChecks.forEach((spotcheck: any) => {\n          if (\n            spotcheck.appearance.mode === 'fullScreen' &&\n            ischatSurvey(spotcheck?.survey?.surveyType)\n          ) {\n            chatIframe = true;\n          } else {\n            classicIframe = true;\n          }\n        });\n\n        const newClassicUrl = classicIframe\n          ? `https://${domainName}/eui-template/classic`\n          : '';\n        const newChatUrl = chatIframe\n          ? `https://${domainName}/eui-template/chat`\n          : '';\n\n        this.spotcheckStateService.setState({\n          filteredSpotChecks: data.filteredSpotChecks,\n          classicUrl: newClassicUrl,\n          chatUrl: newChatUrl,\n        });\n      }\n    } catch (error) {\n      console.log('Error initializing widget:', JSON.stringify(error));\n    }\n  };\n}\n","<div [ngStyle]=\"componentStyles.wrapperStyles\" class=\"safe-area\">\n  <div [ngStyle]=\"componentStyles.styles\">\n    <div style=\"position: relative; height: 100%;\">\n      <spotcheck-close-button />\n  \n      <WebViewComponent\n        *ngIf=\"state.classicUrl && state.classicUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'classic'\"\n        [url]=\"state.classicUrl\"\n        [webviewType]=\"'classic'\"\n        [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n      />\n  \n      <WebViewComponent\n        *ngIf=\"state.chatUrl && state.chatUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'chat'\"\n        [url]=\"state.chatUrl\"\n        [webviewType]=\"'chat'\"\n        [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n      />\n\n      <div *ngIf=\"state.spotChecksMode === 'miniCard' && state.avatarEnabled\">\n        <div style=\"position: absolute; bottom: -66px; left: 16px; z-index: 100001;\">\n          <img [src]=\"avatarUrl\" style=\"width: 56px; height: 56px; border-radius: 50px; background-color: white;\"/>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
351
|
+
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ChangeDetectorRef }] });
|
|
352
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SpotCheckComponent.js","sourceRoot":"","sources":["../../../../src/angular-ui/lib/spotchecks/SpotCheckComponent.ts","../../../../src/angular-ui/lib/spotchecks/SpotCheckComponent.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  OnInit,\n  Component,\n  Input,\n  OnDestroy,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  HostListener,\n  NgZone,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Subscription } from 'rxjs';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { closeSpotCheck, closeSpotCheckAndHandleSurveyEnd, getSpotcheckComponentCssStyles, handleSurveyEnd, ischatSurvey } from './helpers';\nimport { SpotcheckState } from './types';\nimport { getSpotcheckStateService } from './helpers';\nimport { SpotcheckStateService } from './SpotcheckStateService';\nimport { getSpotCheckEventListener } from './SpotCheckEventListener';\nimport axios from 'axios';\n\n@Component({\n  selector: 'WebViewComponent',\n  template: `\n    <div style=\"overflow: hidden; height: 100%; border-radius: {{isMiniCard ? 12 : 0}}px; padding-left: {{isMiniCard ? 12 : 0}}px; padding-right: {{isMiniCard ? 12 : 0}}px; box-sizing: border-box;\">\n      <iframe\n        allow=\"camera; microphone; geolocation; display-capture; autoplay; clipboard-read; clipboard-write;\"\n        #iframeRef\n        [src]=\"safeUrl\"\n        style=\"width: 100%; height: 100%; display: block; border-radius: {{isMiniCard ? 12 : 0}}px;\"\n        frameborder=\"0\"\n      >\n      </iframe>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class WebViewComponent implements OnInit, AfterViewInit {\n  @Input() url: string = '';\n  @Input() webviewType: 'classic' | 'chat' = 'classic';\n  @Input() isMiniCard: boolean = false;\n\n  safeUrl: SafeResourceUrl | null = null;\n  @ViewChild('iframeRef') iframe!: ElementRef<HTMLIFrameElement>;\n\n  constructor(\n    private sanitizer: DomSanitizer,\n    private ngZone: NgZone,\n    private cdr: ChangeDetectorRef,\n  ) {}\n  ngOnInit() {\n    if (this.url) {\n      this.safeUrl = this.sanitizer.bypassSecurityTrustResourceUrl(this.url);\n    }\n  }\n\n  ngAfterViewInit() {\n    const stateService = getSpotcheckStateService();\n    const webViewRef = this.iframe.nativeElement;\n\n    if (this.webviewType === 'classic') {\n      stateService.setState({\n        classicWebViewRef: webViewRef,\n        isClassicLoading: false,\n      });\n    } else {\n      stateService.setState({\n        chatWebViewRef: webViewRef,\n        isChatLoading: false,\n      });\n    }\n    this.setupIframeLoadListener();\n  }\n\n  private setupIframeLoadListener() {\n    const iframe = this.iframe.nativeElement;\n    iframe.addEventListener('load', () => {\n      this.ngZone.run(() => {\n        const stateService = getSpotcheckStateService();\n        if (this.webviewType === 'classic') {\n          stateService.setState({ isClassicLoading: false });\n        } else {\n          stateService.setState({ isChatLoading: false });\n        }\n      });\n    });\n  }\n\n  @HostListener('window:message', ['$event'])\n  onMessage(event: MessageEvent) {\n    this.ngZone.run(() => {\n      const stateService = getSpotcheckStateService();\n      const { data } = event;\n      switch (data.type) {\n        case 'slideInFrame':\n          if (data.mounted) {\n            stateService.setState({ isMounted: true });\n          }\n          break;\n\n        case 'resizeWindow':\n          if (data.size) {\n            stateService.setState({\n              currentQuestionHeight: data.size.height,\n            });\n          } else if (data.isCloseButtonEnabled) {\n            stateService.setState({\n              isCloseButtonEnabled: data.isCloseButtonEnabled,\n            });\n          }\n          break;\n\n        case 'surveyCompleted':\n          closeSpotCheckAndHandleSurveyEnd().then(() => {\n            getSpotCheckEventListener().emit('surveyCompleted', data.response);\n            this.cdr.detectChanges();\n          });\n          break;\n\n        case 'surveyLoadStarted':\n          getSpotCheckEventListener().emit('surveyLoadStarted', data.surveyDetails);\n          break;\n\n        default:\n          break;\n      }\n      this.cdr.detectChanges();\n    });\n  }\n}\n\n@Component({\n  selector: 'close-svg',\n  template: `\n    <svg\n      [attr.width]=\"size\"\n      [attr.height]=\"size\"\n      viewBox=\"0 0 32 32\"\n      fill=\"none\"\n      xmlns=\"https://www.w3.org/2000/svg\"\n    >\n      <path\n        d=\"M10.6665 10.667L21.3332 21.3337M21.3332 10.667L10.6665 21.3337\"\n        [attr.stroke]=\"stroke\"\n        [attr.stroke-width]=\"strokeWidth\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n    </svg>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class CloseSVGComponent {\n  @Input() size: number = 32;\n  @Input() stroke: string = '#919191';\n  @Input() strokeWidth: number = 1.5;\n}\n\n@Component({\n  selector: 'spotcheck-close-button',\n  template: `\n      <div style=\"position: absolute; top: -36px; right: 16px; z-index: 100001; cursor: pointer; background-color: white; border-radius: 50px;\" (click)=\"onClick()\" *ngIf=\"isVisible && isMiniCard\">\n        <close-svg [size]=\"size\" [stroke]=\"stroke\" [strokeWidth]=\"strokeWidth\" style=\"display: flex; align-items: center; justify-content: center;\"/>\n      </div>\n      <div style=\"position: absolute; top: 16px; right: 16px; z-index: 100001; cursor: pointer;\" (click)=\"onClick()\" *ngIf=\"isVisible && !isMiniCard\">\n        <close-svg [size]=\"size\" [stroke]=\"stroke\" [strokeWidth]=\"strokeWidth\"/>\n      </div>\n  `,\n  standalone: true,\n  imports: [CommonModule, CloseSVGComponent],\n})\nexport class CloseButtonComponent implements OnDestroy {\n  @Input() size: number = 30;\n  @Input() strokeWidth: number = 1.2;\n  \n  state: SpotcheckState;\n  private stateService: SpotcheckStateService;\n  private stateSubscription!: Subscription;\n  \n  isVisible: boolean = false;\n  isMiniCard: boolean = false;\n  stroke: string = 'black';\n  \n  constructor(\n    private ngZone: NgZone,\n    private cdr: ChangeDetectorRef,\n  ) {\n    this.stateService = getSpotcheckStateService();\n    this.state = this.stateService.getState();\n    this.updateComponentState();\n\n    this.stateSubscription = this.stateService.state$.subscribe(\n      (newState: SpotcheckState) => {\n        this.ngZone.run(() => {\n          this.state = newState;\n          this.updateComponentState();\n          this.cdr.detectChanges();\n        });\n      }\n    );\n  }\n\n  ngOnDestroy(): void {\n    if (this.stateSubscription) {\n      this.stateSubscription.unsubscribe();\n    }\n  }\n\n  private updateComponentState(): void {\n    this.isVisible =\n      this.state.isCloseButtonEnabled &&\n      ((this.state.currentQuestionHeight > 0 && !this.state.isFullScreenMode) ||\n        (this.state.isFullScreenMode &&\n          ((!this.state.isClassicLoading &&\n            this.state.spotCheckType === 'classic') ||\n            (!this.state.isChatLoading &&\n              this.state.spotCheckType === 'chat'))));\n    this.isMiniCard = this.state.spotChecksMode === 'miniCard';\n    this.stroke = this.isMiniCard ? 'black' : this.state.closeButtonStyle?.['ctaButton'] || 'black';\n  }\n\n  onClick = async () => {\n    await closeSpotCheck();\n    handleSurveyEnd();\n    this.ngZone.run(() => {\n      this.cdr.detectChanges();\n    });\n  };\n}\n\n\n@Component({\n  selector: 'SpotCheckComponent',\n  templateUrl: './SpotCheckComponent.html',\n  styleUrls: ['./SpotCheckComponent.css'],\n  standalone: true,\n  imports: [CommonModule, WebViewComponent, CloseButtonComponent],\n})\nexport class SpotCheckComponent implements OnInit, OnDestroy {\n  state: SpotcheckState;\n  private spotcheckStateService: SpotcheckStateService;\n  private stateSubscription: Subscription;\n  componentStyles: any = {};\n  avatarUrl: string = '';\n\n  constructor(\n    private ngZone: NgZone,\n    private cdr: ChangeDetectorRef,\n  ) {\n    this.spotcheckStateService = getSpotcheckStateService();\n    this.state = this.spotcheckStateService.getState();\n    this.updateComponentStyles();\n\n    this.stateSubscription = this.spotcheckStateService.state$.subscribe(\n      (newState: SpotcheckState) => {\n        this.ngZone.run(() => {\n          this.state = newState;\n          this.updateComponentStyles();\n          this.avatarUrl = this.state.avatarUrl || \"https://static.surveysparrow.com/application/images/profile.png\";\n          this.cdr.detectChanges();\n        });\n      }\n    );\n  }\n\n  ngOnInit(): void {\n    this.initializeComponent();\n  }\n\n  ngOnDestroy(): void {\n    if (this.stateSubscription) {\n      this.stateSubscription.unsubscribe();\n    }\n  }\n\n  private updateComponentStyles(): void {\n    this.componentStyles = getSpotcheckComponentCssStyles(this.state);\n  }\n\n  initializeComponent = async () => {\n    try {\n      const domainName = this.state.domainName;\n      const targetToken = this.state.targetToken;\n\n      const response = await axios.get<any>(\n        `https://${domainName}/api/internal/spotcheck/widget/${targetToken}/init`\n      );\n\n      const data = response.data;\n\n      if (data.filteredSpotChecks && data.filteredSpotChecks.length > 0) {\n        let classicIframe = false;\n        let chatIframe = false;\n\n        data.filteredSpotChecks.forEach((spotcheck: any) => {\n          if (\n            spotcheck.appearance.mode === 'fullScreen' &&\n            ischatSurvey(spotcheck?.survey?.surveyType)\n          ) {\n            chatIframe = true;\n          } else {\n            classicIframe = true;\n          }\n        });\n\n        const newClassicUrl = classicIframe\n          ? `https://${domainName}/eui-template/classic`\n          : '';\n        const newChatUrl = chatIframe\n          ? `https://${domainName}/eui-template/chat`\n          : '';\n\n        this.spotcheckStateService.setState({\n          filteredSpotChecks: data.filteredSpotChecks,\n          classicUrl: newClassicUrl,\n          chatUrl: newChatUrl,\n        });\n      }\n    } catch (error) {\n      console.log('Error initializing widget:', JSON.stringify(error));\n    }\n  };\n}\n","<div [ngStyle]=\"componentStyles.wrapperStyles\" class=\"safe-area\">\n  <div [ngStyle]=\"componentStyles.styles\">\n    <div style=\"position: relative; height: 100%;\">\n      <spotcheck-close-button />\n  \n      <WebViewComponent\n        *ngIf=\"state.classicUrl && state.classicUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'classic'\"\n        [url]=\"state.classicUrl\"\n        [webviewType]=\"'classic'\"\n        [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n      />\n  \n      <WebViewComponent\n        *ngIf=\"state.chatUrl && state.chatUrl.length > 0 && state.spotcheckURL.length > 0 && state.spotCheckType === 'chat'\"\n        [url]=\"state.chatUrl\"\n        [webviewType]=\"'chat'\"\n        [isMiniCard]=\"state.spotChecksMode === 'miniCard'\"\n      />\n\n      <div *ngIf=\"state.spotChecksMode === 'miniCard' && state.avatarEnabled\">\n        <div style=\"position: absolute; bottom: -66px; left: 16px; z-index: 100001;\">\n          <img [src]=\"avatarUrl\" style=\"width: 56px; height: 56px; border-radius: 50px; background-color: white;\"/>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Subject } from 'rxjs';
|
|
2
|
+
class SpotCheckEventListenerService {
|
|
3
|
+
eventSubject = new Subject();
|
|
4
|
+
event$ = this.eventSubject.asObservable();
|
|
5
|
+
emit(type, data) {
|
|
6
|
+
this.eventSubject.next({ type, data });
|
|
7
|
+
}
|
|
8
|
+
addListener(eventType, callback) {
|
|
9
|
+
return this.event$.subscribe((event) => {
|
|
10
|
+
if (event.type === eventType) {
|
|
11
|
+
callback(event.data);
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
let globalInstance;
|
|
17
|
+
export const getSpotCheckEventListener = () => {
|
|
18
|
+
if (!globalInstance) {
|
|
19
|
+
globalInstance = new SpotCheckEventListenerService();
|
|
20
|
+
}
|
|
21
|
+
return globalInstance;
|
|
22
|
+
};
|
|
23
|
+
export const addSpotCheckListener = (eventType, callback) => {
|
|
24
|
+
return getSpotCheckEventListener().addListener(eventType, callback);
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3BvdENoZWNrRXZlbnRMaXN0ZW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hbmd1bGFyLXVpL2xpYi9zcG90Y2hlY2tzL1Nwb3RDaGVja0V2ZW50TGlzdGVuZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQWUvQixNQUFNLDZCQUE2QjtJQUN6QixZQUFZLEdBQUcsSUFBSSxPQUFPLEVBQWtCLENBQUM7SUFDN0MsTUFBTSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7SUFFbEQsSUFBSSxDQUFDLElBQXdCLEVBQUUsSUFBVTtRQUN2QyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxXQUFXLENBQ1QsU0FBNkIsRUFDN0IsUUFBdUI7UUFFdkIsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQXFCLEVBQUUsRUFBRTtZQUNyRCxJQUFJLEtBQUssQ0FBQyxJQUFJLEtBQUssU0FBUyxFQUFFLENBQUM7Z0JBQzdCLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdkIsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBRUQsSUFBSSxjQUE2QyxDQUFDO0FBRWxELE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLEdBQWtDLEVBQUU7SUFDM0UsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3BCLGNBQWMsR0FBRyxJQUFJLDZCQUE2QixFQUFFLENBQUM7SUFDdkQsQ0FBQztJQUNELE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLENBQ2xDLFNBQTZCLEVBQzdCLFFBQXVCLEVBQ1QsRUFBRTtJQUNoQixPQUFPLHlCQUF5QixFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUMsQ0FBQztBQUN0RSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgdHlwZSB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgdHlwZSBTcG90Q2hlY2tFdmVudFR5cGUgPVxuICB8ICdzdXJ2ZXlDb21wbGV0ZWQnXG4gIHwgJ3N1cnZleURpc21pc3NlZCdcbiAgfCAnc3VydmV5TG9hZFN0YXJ0ZWQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNwb3RDaGVja0V2ZW50IHtcbiAgdHlwZTogU3BvdENoZWNrRXZlbnRUeXBlO1xuICBkYXRhPzogYW55O1xufVxuXG50eXBlIEV2ZW50Q2FsbGJhY2sgPSAoZGF0YT86IGFueSkgPT4gdm9pZDtcblxuY2xhc3MgU3BvdENoZWNrRXZlbnRMaXN0ZW5lclNlcnZpY2Uge1xuICBwcml2YXRlIGV2ZW50U3ViamVjdCA9IG5ldyBTdWJqZWN0PFNwb3RDaGVja0V2ZW50PigpO1xuICBwcml2YXRlIGV2ZW50JCA9IHRoaXMuZXZlbnRTdWJqZWN0LmFzT2JzZXJ2YWJsZSgpO1xuXG4gIGVtaXQodHlwZTogU3BvdENoZWNrRXZlbnRUeXBlLCBkYXRhPzogYW55KTogdm9pZCB7XG4gICAgdGhpcy5ldmVudFN1YmplY3QubmV4dCh7IHR5cGUsIGRhdGEgfSk7XG4gIH1cblxuICBhZGRMaXN0ZW5lcihcbiAgICBldmVudFR5cGU6IFNwb3RDaGVja0V2ZW50VHlwZSxcbiAgICBjYWxsYmFjazogRXZlbnRDYWxsYmFja1xuICApOiBTdWJzY3JpcHRpb24ge1xuICAgIHJldHVybiB0aGlzLmV2ZW50JC5zdWJzY3JpYmUoKGV2ZW50OiBTcG90Q2hlY2tFdmVudCkgPT4ge1xuICAgICAgaWYgKGV2ZW50LnR5cGUgPT09IGV2ZW50VHlwZSkge1xuICAgICAgICBjYWxsYmFjayhldmVudC5kYXRhKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxufVxuXG5sZXQgZ2xvYmFsSW5zdGFuY2U6IFNwb3RDaGVja0V2ZW50TGlzdGVuZXJTZXJ2aWNlO1xuXG5leHBvcnQgY29uc3QgZ2V0U3BvdENoZWNrRXZlbnRMaXN0ZW5lciA9ICgpOiBTcG90Q2hlY2tFdmVudExpc3RlbmVyU2VydmljZSA9PiB7XG4gIGlmICghZ2xvYmFsSW5zdGFuY2UpIHtcbiAgICBnbG9iYWxJbnN0YW5jZSA9IG5ldyBTcG90Q2hlY2tFdmVudExpc3RlbmVyU2VydmljZSgpO1xuICB9XG4gIHJldHVybiBnbG9iYWxJbnN0YW5jZTtcbn07XG5cbmV4cG9ydCBjb25zdCBhZGRTcG90Q2hlY2tMaXN0ZW5lciA9IChcbiAgZXZlbnRUeXBlOiBTcG90Q2hlY2tFdmVudFR5cGUsXG4gIGNhbGxiYWNrOiBFdmVudENhbGxiYWNrXG4pOiBTdWJzY3JpcHRpb24gPT4ge1xuICByZXR1cm4gZ2V0U3BvdENoZWNrRXZlbnRMaXN0ZW5lcigpLmFkZExpc3RlbmVyKGV2ZW50VHlwZSwgY2FsbGJhY2spO1xufTtcbiJdfQ==
|
|
@@ -227,4 +227,4 @@ export const sendTrackEventRequest = async ({ screen, event }) => {
|
|
|
227
227
|
return { valid: false, error: error.message };
|
|
228
228
|
}
|
|
229
229
|
};
|
|
230
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/angular-ui/lib/spotchecks/api.ts"],"names":[],"mappings":"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","sourcesContent":["import { generateTraceId, getOS, setAppearance } from './helpers';\nimport { getStoredUUID, setUUID } from './storage';\nimport { TrackScreenProps, UserDetails, Variables, CustomProperties, TrackEventProps } from './types';\nimport { getSpotcheckStateService } from './helpers';\nimport axios from 'axios';\n\nexport const sendTrackScreenRequest = async ({\n  screen,\n  options,\n}: TrackScreenProps) => {\n  try {\n    const spotcheckStateService = getSpotcheckStateService();\n    const oldState = spotcheckStateService.getState();\n    let variables = { ...oldState.variables } as Variables;\n    let customProperties = { ...oldState.customProperties } as CustomProperties;\n    let userDetails = { ...oldState.userDetails } as UserDetails;    \n\n    if (options && options.variables && Object.keys(options.variables).length > 0) {\n      variables = { ...variables, ...options.variables };\n    }\n    if (options && options.customProperties && Object.keys(options.customProperties).length > 0) {\n      customProperties = { ...customProperties, ...options.customProperties };\n    }\n    if (options && options.userDetails && Object.keys(options.userDetails).length > 0) {\n      userDetails = { ...userDetails, ...options.userDetails };\n    }\n\n    let traceId = oldState.traceId;\n    if (!traceId) {\n      traceId = generateTraceId();\n    }\n\n    if (!userDetails.uuid && !userDetails.email && !userDetails.mobile) {\n      const uuid = getStoredUUID();\n      if (uuid) {\n        userDetails.uuid = uuid;\n      }\n    }\n\n    spotcheckStateService.setState({\n      traceId,\n      screenwiseUserDetails: {\n        [screen]: userDetails\n      },\n    });\n\n    const state = spotcheckStateService.getState();\n    let { isSpotPassed, isChecksPassed } = state;\n    const payload = {\n      screenName: screen,\n      variables: variables,\n      userDetails: userDetails,\n      visitor: {\n        deviceType: 'MOBILE',\n        operatingSystem: await getOS(),\n        screenResolution: {\n          height: window.innerHeight,\n          width: window.innerWidth,\n        },\n        currentDate: new Date().toISOString(),\n        timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n      },\n      traceId: state.traceId,\n      customProperties: customProperties,\n    };\n\n    const url = `https://${state.domainName}/api/internal/spotcheck/widget/${state.targetToken}/properties?isSpotCheck=true&sdk=IONIC`;\n    const response = await axios.post(url, payload, {\n      headers: {\n        'Content-Type': 'application/json',\n      },\n    });\n\n    if(response.status === 200) {\n      const responseJson = response.data;\n\n      if (responseJson.uuid) {\n        setUUID(responseJson.uuid);\n      }\n\n      if (responseJson?.show) {\n        if (responseJson?.show) {\n          const appearance_response = await setAppearance(\n            responseJson,\n            screen,\n            state.domainName,\n            traceId,\n            variables\n          );\n          if (appearance_response) {\n            isSpotPassed = true;\n            spotcheckStateService.setState({ isSpotPassed });\n            return { valid: true };\n          }\n        } else {\n          throw new Error('');\n        }\n      }\n    \n      if (!isSpotPassed && responseJson?.checkPassed) {\n        if (responseJson.checkCondition) {\n          const checkCondition = responseJson.checkCondition;\n          spotcheckStateService.setState({ afterDelay: checkCondition.afterDelay || 0 });\n          if (checkCondition.customEvent) {\n            spotcheckStateService.setState({ customEventsSpotChecks: [responseJson] });\n            throw new Error('');\n          }\n        }\n\n        const appearance_response = await setAppearance(\n          responseJson,\n          screen,\n          state.domainName,\n          traceId,\n          variables\n        );\n        if (appearance_response) {\n          isChecksPassed = true;\n          spotcheckStateService.setState({ isChecksPassed });\n          return { valid: true };\n        }\n      }\n\n      if (!isSpotPassed && !isChecksPassed && responseJson?.multiShow != null) {\n        if (responseJson.multiShow) {\n          spotcheckStateService.setState({ customEventsSpotChecks: responseJson.resultantSpotCheck });\n\n          let selectedSpotCheck = {};\n          let minDelay: number = Number.POSITIVE_INFINITY;\n\n          for (const spotcheck of responseJson.resultantSpotCheck) {\n            const checks = spotcheck?.checks || {};\n            if (Object.keys(checks).length === 0) {\n              minDelay = 0;\n              selectedSpotCheck = spotcheck;\n            } else if (checks.afterDelay != null) {\n              const delay = parseFloat(checks.afterDelay);\n              if (minDelay > delay) {\n                minDelay = delay;\n                selectedSpotCheck = spotcheck;\n              }\n            }\n          }\n\n          if (Object.keys(selectedSpotCheck).length > 0) {\n            spotcheckStateService.setState({ afterDelay: minDelay });\n            const appearance_response = await setAppearance(\n              selectedSpotCheck,\n              screen,\n              state.domainName,\n              traceId,\n              variables\n            );\n            if (appearance_response) {\n              return { valid: true };\n            }\n          }\n        }\n      }\n\n      throw new Error(responseJson?.reason.toString());\n    } else {\n      throw new Error(`Received status code ${response.status}`);\n    }\n  } catch (error: any) {\n    return { valid: false, error: error.message };\n  }\n};\n\n\nexport const sendTrackEventRequest = async ({ screen, event }: TrackEventProps) => {\n  try {\n    const intMax = Number.POSITIVE_INFINITY;\n    const state = getSpotcheckStateService().getState();\n    let selectedSpotCheckID = intMax;\n    let { isSpotPassed } = state;\n    if (state.customEventsSpotChecks.length > 0) {\n      const eventKeys = Object.keys(event);\n      for (const spotCheck of state.customEventsSpotChecks) {\n        const checks = spotCheck?.['checks'] ?? spotCheck?.['checkCondition'];\n\n        if (checks) {\n          const customEvent = checks?.customEvent;\n\n          if (eventKeys.includes(customEvent?.eventName)) {\n            selectedSpotCheckID =\n              spotCheck?.['id'] ?? spotCheck?.['spotCheckId'] ?? intMax;\n\n            if (selectedSpotCheckID !== intMax) {\n              const payload = {\n                screenName: screen,\n                variables: state.variables,\n                userDetails: state.screenwiseUserDetails[screen] || {},\n                visitor: {\n                  deviceType: 'MOBILE',\n                  operatingSystem: await getOS(),\n                  screenResolution: {\n                    height: window.innerHeight,\n                    width: window.innerWidth,\n                  },\n                  currentDate: new Date().toISOString(),\n                  timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n                },\n                spotCheckId: selectedSpotCheckID,\n                eventTrigger: {\n                  customEvent: event,\n                },\n                traceId: state.traceId,\n                customProperties: state.customProperties,\n              };\n\n              const url = `https://${state.domainName}/api/internal/spotcheck/widget/${state.targetToken}/eventTrigger?isSpotCheck=true`;\n\n              try {\n                const response = await axios.post(url, payload, {\n                  headers: {\n                    'Content-Type': 'application/json',\n                  },\n                });\n\n                if (response.status === 200) {\n                  const responseJson = response.data;\n                  if (responseJson?.show != null) {\n                    if (responseJson?.show) {\n                      const appearance_response = await setAppearance(\n                        responseJson,\n                        screen,\n                        state.domainName,\n                        state.traceId,\n                        state.variables\n                      );\n\n                      if (appearance_response) {\n                        getSpotcheckStateService().setState({ isSpotPassed: true });\n                        isSpotPassed = true;\n                        return { valid: true };\n                      }\n                    }\n                  }\n\n                  if (!isSpotPassed && responseJson?.eventShow) {\n                    if (responseJson?.checkCondition != null) {\n                      const checkCondition = responseJson?.checkCondition;\n                      getSpotcheckStateService().setState({\n                        afterDelay: checkCondition?.afterDelay ?? 0,\n                      });\n\n                      if (checkCondition?.customEvent != null) {\n                        getSpotcheckStateService().setState({\n                          afterDelay: checkCondition?.customEvent?.delayInSeconds ?? 0,\n                        });\n                      }\n                    }\n\n                    const appearance_response = await setAppearance(\n                      responseJson,\n                      screen,\n                      state.domainName,\n                      state.traceId,\n                      state.variables\n                    );\n\n                    if (appearance_response) {\n                      return { valid: true };\n                    }\n                  }\n\n                  throw new Error(responseJson?.reason.toString());\n                } else {\n                  throw new Error(`Received status code ${response.status}`);\n                }\n              } catch (error: any) {\n                throw new Error(error.message);\n              }\n            }\n          }\n        }\n      }\n      throw new Error('');\n    } else {\n      throw new Error('');\n    }\n  } catch (error: any) {\n    return { valid: false, error: error.message };\n  }\n};"]}
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/angular-ui/lib/spotchecks/api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AACrD,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,MAAM,sBAAsB,GAAG,KAAK,EAAE,EAC3C,MAAM,EACN,OAAO,GACU,EAAE,EAAE;IACrB,IAAI,CAAC;QACH,MAAM,qBAAqB,GAAG,wBAAwB,EAAE,CAAC;QACzD,MAAM,QAAQ,GAAG,qBAAqB,CAAC,QAAQ,EAAE,CAAC;QAClD,IAAI,SAAS,GAAG,EAAE,GAAG,QAAQ,CAAC,SAAS,EAAe,CAAC;QACvD,IAAI,gBAAgB,GAAG,EAAE,GAAG,QAAQ,CAAC,gBAAgB,EAAsB,CAAC;QAC5E,IAAI,WAAW,GAAG,EAAE,GAAG,QAAQ,CAAC,WAAW,EAAiB,CAAC;QAE7D,IAAI,OAAO,IAAI,OAAO,CAAC,SAAS,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9E,SAAS,GAAG,EAAE,GAAG,SAAS,EAAE,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;QACrD,CAAC;QACD,IAAI,OAAO,IAAI,OAAO,CAAC,gBAAgB,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5F,gBAAgB,GAAG,EAAE,GAAG,gBAAgB,EAAE,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;QAC1E,CAAC;QACD,IAAI,OAAO,IAAI,OAAO,CAAC,WAAW,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClF,WAAW,GAAG,EAAE,GAAG,WAAW,EAAE,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;QAC3D,CAAC;QAED,IAAI,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;QAC/B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,GAAG,eAAe,EAAE,CAAC;QAC9B,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YACnE,MAAM,IAAI,GAAG,aAAa,EAAE,CAAC;YAC7B,IAAI,IAAI,EAAE,CAAC;gBACT,WAAW,CAAC,IAAI,GAAG,IAAI,CAAC;YAC1B,CAAC;QACH,CAAC;QAED,qBAAqB,CAAC,QAAQ,CAAC;YAC7B,OAAO;YACP,qBAAqB,EAAE;gBACrB,CAAC,MAAM,CAAC,EAAE,WAAW;aACtB;SACF,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,qBAAqB,CAAC,QAAQ,EAAE,CAAC;QAC/C,IAAI,EAAE,YAAY,EAAE,cAAc,EAAE,GAAG,KAAK,CAAC;QAC7C,MAAM,OAAO,GAAG;YACd,UAAU,EAAE,MAAM;YAClB,SAAS,EAAE,SAAS;YACpB,WAAW,EAAE,WAAW;YACxB,OAAO,EAAE;gBACP,UAAU,EAAE,QAAQ;gBACpB,eAAe,EAAE,MAAM,KAAK,EAAE;gBAC9B,gBAAgB,EAAE;oBAChB,MAAM,EAAE,MAAM,CAAC,WAAW;oBAC1B,KAAK,EAAE,MAAM,CAAC,UAAU;iBACzB;gBACD,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACrC,QAAQ,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,eAAe,EAAE,CAAC,QAAQ;aAC3D;YACD,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,gBAAgB,EAAE,gBAAgB;SACnC,CAAC;QAEF,MAAM,GAAG,GAAG,WAAW,KAAK,CAAC,UAAU,kCAAkC,KAAK,CAAC,WAAW,wCAAwC,CAAC;QACnI,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,IAAI,CAAM,GAAG,EAAE,OAAO,EAAE;YACnD,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;aACnC;SACF,CAAC,CAAC;QAEH,IAAG,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;YAC3B,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC;YAEnC,IAAI,YAAY,CAAC,IAAI,EAAE,CAAC;gBACtB,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAC7B,CAAC;YAED,IAAI,YAAY,EAAE,IAAI,EAAE,CAAC;gBACvB,IAAI,YAAY,EAAE,IAAI,EAAE,CAAC;oBACvB,MAAM,mBAAmB,GAAG,MAAM,aAAa,CAC7C,YAAY,EACZ,MAAM,EACN,KAAK,CAAC,UAAU,EAChB,OAAO,EACP,SAAS,CACV,CAAC;oBACF,IAAI,mBAAmB,EAAE,CAAC;wBACxB,YAAY,GAAG,IAAI,CAAC;wBACpB,qBAAqB,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC;wBACjD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;oBACzB,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC;gBACtB,CAAC;YACH,CAAC;YAED,IAAI,CAAC,YAAY,IAAI,YAAY,EAAE,WAAW,EAAE,CAAC;gBAC/C,IAAI,YAAY,CAAC,cAAc,EAAE,CAAC;oBAChC,MAAM,cAAc,GAAG,YAAY,CAAC,cAAc,CAAC;oBACnD,qBAAqB,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,cAAc,CAAC,UAAU,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC/E,IAAI,cAAc,CAAC,WAAW,EAAE,CAAC;wBAC/B,qBAAqB,CAAC,QAAQ,CAAC,EAAE,sBAAsB,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;wBAC3E,MAAM,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC;oBACtB,CAAC;gBACH,CAAC;gBAED,MAAM,mBAAmB,GAAG,MAAM,aAAa,CAC7C,YAAY,EACZ,MAAM,EACN,KAAK,CAAC,UAAU,EAChB,OAAO,EACP,SAAS,CACV,CAAC;gBACF,IAAI,mBAAmB,EAAE,CAAC;oBACxB,cAAc,GAAG,IAAI,CAAC;oBACtB,qBAAqB,CAAC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC;oBACnD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;gBACzB,CAAC;YACH,CAAC;YAED,IAAI,CAAC,YAAY,IAAI,CAAC,cAAc,IAAI,YAAY,EAAE,SAAS,IAAI,IAAI,EAAE,CAAC;gBACxE,IAAI,YAAY,CAAC,SAAS,EAAE,CAAC;oBAC3B,qBAAqB,CAAC,QAAQ,CAAC,EAAE,sBAAsB,EAAE,YAAY,CAAC,kBAAkB,EAAE,CAAC,CAAC;oBAE5F,IAAI,iBAAiB,GAAG,EAAE,CAAC;oBAC3B,IAAI,QAAQ,GAAW,MAAM,CAAC,iBAAiB,CAAC;oBAEhD,KAAK,MAAM,SAAS,IAAI,YAAY,CAAC,kBAAkB,EAAE,CAAC;wBACxD,MAAM,MAAM,GAAG,SAAS,EAAE,MAAM,IAAI,EAAE,CAAC;wBACvC,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;4BACrC,QAAQ,GAAG,CAAC,CAAC;4BACb,iBAAiB,GAAG,SAAS,CAAC;wBAChC,CAAC;6BAAM,IAAI,MAAM,CAAC,UAAU,IAAI,IAAI,EAAE,CAAC;4BACrC,MAAM,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;4BAC5C,IAAI,QAAQ,GAAG,KAAK,EAAE,CAAC;gCACrB,QAAQ,GAAG,KAAK,CAAC;gCACjB,iBAAiB,GAAG,SAAS,CAAC;4BAChC,CAAC;wBACH,CAAC;oBACH,CAAC;oBAED,IAAI,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBAC9C,qBAAqB,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;wBACzD,MAAM,mBAAmB,GAAG,MAAM,aAAa,CAC7C,iBAAiB,EACjB,MAAM,EACN,KAAK,CAAC,UAAU,EAChB,OAAO,EACP,SAAS,CACV,CAAC;wBACF,IAAI,mBAAmB,EAAE,CAAC;4BACxB,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;wBACzB,CAAC;oBACH,CAAC;gBACH,CAAC;YACH,CAAC;YAED,MAAM,IAAI,KAAK,CAAC,YAAY,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,wBAAwB,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAAC,OAAO,KAAU,EAAE,CAAC;QACpB,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;IAChD,CAAC;AACH,CAAC,CAAC;AAGF,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,EAAE,EAAE,MAAM,EAAE,KAAK,EAAmB,EAAE,EAAE;IAChF,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC;QACxC,MAAM,KAAK,GAAG,wBAAwB,EAAE,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,mBAAmB,GAAG,MAAM,CAAC;QACjC,IAAI,EAAE,YAAY,EAAE,GAAG,KAAK,CAAC;QAC7B,IAAI,KAAK,CAAC,sBAAsB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5C,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrC,KAAK,MAAM,SAAS,IAAI,KAAK,CAAC,sBAAsB,EAAE,CAAC;gBACrD,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC,QAAQ,CAAC,IAAI,SAAS,EAAE,CAAC,gBAAgB,CAAC,CAAC;gBAEtE,IAAI,MAAM,EAAE,CAAC;oBACX,MAAM,WAAW,GAAG,MAAM,EAAE,WAAW,CAAC;oBAExC,IAAI,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,SAAS,CAAC,EAAE,CAAC;wBAC/C,mBAAmB;4BACjB,SAAS,EAAE,CAAC,IAAI,CAAC,IAAI,SAAS,EAAE,CAAC,aAAa,CAAC,IAAI,MAAM,CAAC;wBAE5D,IAAI,mBAAmB,KAAK,MAAM,EAAE,CAAC;4BACnC,MAAM,OAAO,GAAG;gCACd,UAAU,EAAE,MAAM;gCAClB,SAAS,EAAE,KAAK,CAAC,SAAS;gCAC1B,WAAW,EAAE,KAAK,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,EAAE;gCACtD,OAAO,EAAE;oCACP,UAAU,EAAE,QAAQ;oCACpB,eAAe,EAAE,MAAM,KAAK,EAAE;oCAC9B,gBAAgB,EAAE;wCAChB,MAAM,EAAE,MAAM,CAAC,WAAW;wCAC1B,KAAK,EAAE,MAAM,CAAC,UAAU;qCACzB;oCACD,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;oCACrC,QAAQ,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,eAAe,EAAE,CAAC,QAAQ;iCAC3D;gCACD,WAAW,EAAE,mBAAmB;gCAChC,YAAY,EAAE;oCACZ,WAAW,EAAE,KAAK;iCACnB;gCACD,OAAO,EAAE,KAAK,CAAC,OAAO;gCACtB,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;6BACzC,CAAC;4BAEF,MAAM,GAAG,GAAG,WAAW,KAAK,CAAC,UAAU,kCAAkC,KAAK,CAAC,WAAW,gCAAgC,CAAC;4BAE3H,IAAI,CAAC;gCACH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,IAAI,CAAM,GAAG,EAAE,OAAO,EAAE;oCACnD,OAAO,EAAE;wCACP,cAAc,EAAE,kBAAkB;qCACnC;iCACF,CAAC,CAAC;gCAEH,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;oCAC5B,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC;oCACnC,IAAI,YAAY,EAAE,IAAI,IAAI,IAAI,EAAE,CAAC;wCAC/B,IAAI,YAAY,EAAE,IAAI,EAAE,CAAC;4CACvB,MAAM,mBAAmB,GAAG,MAAM,aAAa,CAC7C,YAAY,EACZ,MAAM,EACN,KAAK,CAAC,UAAU,EAChB,KAAK,CAAC,OAAO,EACb,KAAK,CAAC,SAAS,CAChB,CAAC;4CAEF,IAAI,mBAAmB,EAAE,CAAC;gDACxB,wBAAwB,EAAE,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC;gDAC5D,YAAY,GAAG,IAAI,CAAC;gDACpB,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;4CACzB,CAAC;wCACH,CAAC;oCACH,CAAC;oCAED,IAAI,CAAC,YAAY,IAAI,YAAY,EAAE,SAAS,EAAE,CAAC;wCAC7C,IAAI,YAAY,EAAE,cAAc,IAAI,IAAI,EAAE,CAAC;4CACzC,MAAM,cAAc,GAAG,YAAY,EAAE,cAAc,CAAC;4CACpD,wBAAwB,EAAE,CAAC,QAAQ,CAAC;gDAClC,UAAU,EAAE,cAAc,EAAE,UAAU,IAAI,CAAC;6CAC5C,CAAC,CAAC;4CAEH,IAAI,cAAc,EAAE,WAAW,IAAI,IAAI,EAAE,CAAC;gDACxC,wBAAwB,EAAE,CAAC,QAAQ,CAAC;oDAClC,UAAU,EAAE,cAAc,EAAE,WAAW,EAAE,cAAc,IAAI,CAAC;iDAC7D,CAAC,CAAC;4CACL,CAAC;wCACH,CAAC;wCAED,MAAM,mBAAmB,GAAG,MAAM,aAAa,CAC7C,YAAY,EACZ,MAAM,EACN,KAAK,CAAC,UAAU,EAChB,KAAK,CAAC,OAAO,EACb,KAAK,CAAC,SAAS,CAChB,CAAC;wCAEF,IAAI,mBAAmB,EAAE,CAAC;4CACxB,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;wCACzB,CAAC;oCACH,CAAC;oCAED,MAAM,IAAI,KAAK,CAAC,YAAY,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;gCACnD,CAAC;qCAAM,CAAC;oCACN,MAAM,IAAI,KAAK,CAAC,wBAAwB,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;gCAC7D,CAAC;4BACH,CAAC;4BAAC,OAAO,KAAU,EAAE,CAAC;gCACpB,MAAM,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;4BACjC,CAAC;wBACH,CAAC;oBACH,CAAC;gBACH,CAAC;YACH,CAAC;YACD,MAAM,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC;QACtB,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC;QACtB,CAAC;IACH,CAAC;IAAC,OAAO,KAAU,EAAE,CAAC;QACpB,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;IAChD,CAAC;AACH,CAAC,CAAC","sourcesContent":["import { generateTraceId, getOS, setAppearance } from './helpers';\nimport { getStoredUUID, setUUID } from './storage';\nimport { TrackScreenProps, UserDetails, Variables, CustomProperties, TrackEventProps } from './types';\nimport { getSpotcheckStateService } from './helpers';\nimport axios from 'axios';\n\nexport const sendTrackScreenRequest = async ({\n  screen,\n  options,\n}: TrackScreenProps) => {\n  try {\n    const spotcheckStateService = getSpotcheckStateService();\n    const oldState = spotcheckStateService.getState();\n    let variables = { ...oldState.variables } as Variables;\n    let customProperties = { ...oldState.customProperties } as CustomProperties;\n    let userDetails = { ...oldState.userDetails } as UserDetails;    \n\n    if (options && options.variables && Object.keys(options.variables).length > 0) {\n      variables = { ...variables, ...options.variables };\n    }\n    if (options && options.customProperties && Object.keys(options.customProperties).length > 0) {\n      customProperties = { ...customProperties, ...options.customProperties };\n    }\n    if (options && options.userDetails && Object.keys(options.userDetails).length > 0) {\n      userDetails = { ...userDetails, ...options.userDetails };\n    }\n\n    let traceId = oldState.traceId;\n    if (!traceId) {\n      traceId = generateTraceId();\n    }\n\n    if (!userDetails.uuid && !userDetails.email && !userDetails.mobile) {\n      const uuid = getStoredUUID();\n      if (uuid) {\n        userDetails.uuid = uuid;\n      }\n    }\n\n    spotcheckStateService.setState({\n      traceId,\n      screenwiseUserDetails: {\n        [screen]: userDetails\n      },\n    });\n\n    const state = spotcheckStateService.getState();\n    let { isSpotPassed, isChecksPassed } = state;\n    const payload = {\n      screenName: screen,\n      variables: variables,\n      userDetails: userDetails,\n      visitor: {\n        deviceType: 'MOBILE',\n        operatingSystem: await getOS(),\n        screenResolution: {\n          height: window.innerHeight,\n          width: window.innerWidth,\n        },\n        currentDate: new Date().toISOString(),\n        timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n      },\n      traceId: state.traceId,\n      customProperties: customProperties,\n    };\n\n    const url = `https://${state.domainName}/api/internal/spotcheck/widget/${state.targetToken}/properties?isSpotCheck=true&sdk=IONIC`;\n    const response = await axios.post<any>(url, payload, {\n      headers: {\n        'Content-Type': 'application/json',\n      },\n    });\n\n    if(response.status === 200) {\n      const responseJson = response.data;\n\n      if (responseJson.uuid) {\n        setUUID(responseJson.uuid);\n      }\n\n      if (responseJson?.show) {\n        if (responseJson?.show) {\n          const appearance_response = await setAppearance(\n            responseJson,\n            screen,\n            state.domainName,\n            traceId,\n            variables\n          );\n          if (appearance_response) {\n            isSpotPassed = true;\n            spotcheckStateService.setState({ isSpotPassed });\n            return { valid: true };\n          }\n        } else {\n          throw new Error('');\n        }\n      }\n    \n      if (!isSpotPassed && responseJson?.checkPassed) {\n        if (responseJson.checkCondition) {\n          const checkCondition = responseJson.checkCondition;\n          spotcheckStateService.setState({ afterDelay: checkCondition.afterDelay || 0 });\n          if (checkCondition.customEvent) {\n            spotcheckStateService.setState({ customEventsSpotChecks: [responseJson] });\n            throw new Error('');\n          }\n        }\n\n        const appearance_response = await setAppearance(\n          responseJson,\n          screen,\n          state.domainName,\n          traceId,\n          variables\n        );\n        if (appearance_response) {\n          isChecksPassed = true;\n          spotcheckStateService.setState({ isChecksPassed });\n          return { valid: true };\n        }\n      }\n\n      if (!isSpotPassed && !isChecksPassed && responseJson?.multiShow != null) {\n        if (responseJson.multiShow) {\n          spotcheckStateService.setState({ customEventsSpotChecks: responseJson.resultantSpotCheck });\n\n          let selectedSpotCheck = {};\n          let minDelay: number = Number.POSITIVE_INFINITY;\n\n          for (const spotcheck of responseJson.resultantSpotCheck) {\n            const checks = spotcheck?.checks || {};\n            if (Object.keys(checks).length === 0) {\n              minDelay = 0;\n              selectedSpotCheck = spotcheck;\n            } else if (checks.afterDelay != null) {\n              const delay = parseFloat(checks.afterDelay);\n              if (minDelay > delay) {\n                minDelay = delay;\n                selectedSpotCheck = spotcheck;\n              }\n            }\n          }\n\n          if (Object.keys(selectedSpotCheck).length > 0) {\n            spotcheckStateService.setState({ afterDelay: minDelay });\n            const appearance_response = await setAppearance(\n              selectedSpotCheck,\n              screen,\n              state.domainName,\n              traceId,\n              variables\n            );\n            if (appearance_response) {\n              return { valid: true };\n            }\n          }\n        }\n      }\n\n      throw new Error(responseJson?.reason.toString());\n    } else {\n      throw new Error(`Received status code ${response.status}`);\n    }\n  } catch (error: any) {\n    return { valid: false, error: error.message };\n  }\n};\n\n\nexport const sendTrackEventRequest = async ({ screen, event }: TrackEventProps) => {\n  try {\n    const intMax = Number.POSITIVE_INFINITY;\n    const state = getSpotcheckStateService().getState();\n    let selectedSpotCheckID = intMax;\n    let { isSpotPassed } = state;\n    if (state.customEventsSpotChecks.length > 0) {\n      const eventKeys = Object.keys(event);\n      for (const spotCheck of state.customEventsSpotChecks) {\n        const checks = spotCheck?.['checks'] ?? spotCheck?.['checkCondition'];\n\n        if (checks) {\n          const customEvent = checks?.customEvent;\n\n          if (eventKeys.includes(customEvent?.eventName)) {\n            selectedSpotCheckID =\n              spotCheck?.['id'] ?? spotCheck?.['spotCheckId'] ?? intMax;\n\n            if (selectedSpotCheckID !== intMax) {\n              const payload = {\n                screenName: screen,\n                variables: state.variables,\n                userDetails: state.screenwiseUserDetails[screen] || {},\n                visitor: {\n                  deviceType: 'MOBILE',\n                  operatingSystem: await getOS(),\n                  screenResolution: {\n                    height: window.innerHeight,\n                    width: window.innerWidth,\n                  },\n                  currentDate: new Date().toISOString(),\n                  timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n                },\n                spotCheckId: selectedSpotCheckID,\n                eventTrigger: {\n                  customEvent: event,\n                },\n                traceId: state.traceId,\n                customProperties: state.customProperties,\n              };\n\n              const url = `https://${state.domainName}/api/internal/spotcheck/widget/${state.targetToken}/eventTrigger?isSpotCheck=true`;\n\n              try {\n                const response = await axios.post<any>(url, payload, {\n                  headers: {\n                    'Content-Type': 'application/json',\n                  },\n                });\n\n                if (response.status === 200) {\n                  const responseJson = response.data;\n                  if (responseJson?.show != null) {\n                    if (responseJson?.show) {\n                      const appearance_response = await setAppearance(\n                        responseJson,\n                        screen,\n                        state.domainName,\n                        state.traceId,\n                        state.variables\n                      );\n\n                      if (appearance_response) {\n                        getSpotcheckStateService().setState({ isSpotPassed: true });\n                        isSpotPassed = true;\n                        return { valid: true };\n                      }\n                    }\n                  }\n\n                  if (!isSpotPassed && responseJson?.eventShow) {\n                    if (responseJson?.checkCondition != null) {\n                      const checkCondition = responseJson?.checkCondition;\n                      getSpotcheckStateService().setState({\n                        afterDelay: checkCondition?.afterDelay ?? 0,\n                      });\n\n                      if (checkCondition?.customEvent != null) {\n                        getSpotcheckStateService().setState({\n                          afterDelay: checkCondition?.customEvent?.delayInSeconds ?? 0,\n                        });\n                      }\n                    }\n\n                    const appearance_response = await setAppearance(\n                      responseJson,\n                      screen,\n                      state.domainName,\n                      state.traceId,\n                      state.variables\n                    );\n\n                    if (appearance_response) {\n                      return { valid: true };\n                    }\n                  }\n\n                  throw new Error(responseJson?.reason.toString());\n                } else {\n                  throw new Error(`Received status code ${response.status}`);\n                }\n              } catch (error: any) {\n                throw new Error(error.message);\n              }\n            }\n          }\n        }\n      }\n      throw new Error('');\n    } else {\n      throw new Error('');\n    }\n  } catch (error: any) {\n    return { valid: false, error: error.message };\n  }\n};"]}
|