surveysparrow-ionic-plugin 1.0.7-beta.4 → 2.0.0

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.
Files changed (94) hide show
  1. package/dist/angular-ui/esm2022/angular-ui.mjs +5 -0
  2. package/dist/angular-ui/esm2022/public-api.mjs +3 -0
  3. package/dist/angular-ui/esm2022/spotcheck.component.mjs +17 -0
  4. package/dist/angular-ui/esm2022/spotchecks/SpotCheck.mjs +51 -0
  5. package/dist/angular-ui/esm2022/spotchecks/SpotCheckComponent.mjs +323 -0
  6. package/dist/angular-ui/esm2022/spotchecks/SpotcheckStateService.mjs +65 -0
  7. package/dist/angular-ui/esm2022/spotchecks/api.mjs +230 -0
  8. package/dist/angular-ui/esm2022/spotchecks/helpers.mjs +328 -0
  9. package/dist/angular-ui/esm2022/spotchecks/index.mjs +2 -0
  10. package/dist/angular-ui/esm2022/spotchecks/storage.mjs +7 -0
  11. package/dist/angular-ui/esm2022/spotchecks/types.mjs +2 -0
  12. package/dist/angular-ui/fesm2022/angular-ui.mjs +1013 -0
  13. package/dist/angular-ui/fesm2022/angular-ui.mjs.map +1 -0
  14. package/dist/angular-ui/index.d.ts +5 -0
  15. package/dist/angular-ui/public-api.d.ts +2 -0
  16. package/dist/angular-ui/spotcheck.component.d.ts +5 -0
  17. package/dist/angular-ui/spotchecks/SpotCheckComponent.d.ts +56 -0
  18. package/dist/angular-ui/spotchecks/SpotcheckStateService.d.ts +12 -0
  19. package/dist/{esm → angular-ui}/spotchecks/helpers.d.ts +1 -4
  20. package/dist/angular-ui/spotchecks/index.d.ts +2 -0
  21. package/dist/angular-ui/spotchecks/storage.d.ts +2 -0
  22. package/dist/{esm → angular-ui}/spotchecks/types.d.ts +5 -4
  23. package/dist/esm/angular-ui/lib/public-api.d.ts +2 -0
  24. package/dist/esm/angular-ui/lib/public-api.js +3 -0
  25. package/dist/esm/angular-ui/lib/public-api.js.map +1 -0
  26. package/dist/esm/angular-ui/lib/spotcheck.component.d.ts +2 -0
  27. package/dist/esm/angular-ui/lib/spotcheck.component.js +20 -0
  28. package/dist/esm/angular-ui/lib/spotcheck.component.js.map +1 -0
  29. package/dist/esm/angular-ui/lib/spotchecks/SpotCheck.d.ts +4 -0
  30. package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/SpotCheck.js +1 -3
  31. package/dist/esm/angular-ui/lib/spotchecks/SpotCheck.js.map +1 -0
  32. package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/SpotCheckComponent.d.ts +1 -0
  33. package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/SpotCheckComponent.js +13 -7
  34. package/dist/esm/angular-ui/lib/spotchecks/SpotCheckComponent.js.map +1 -0
  35. package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/SpotcheckStateService.js +1 -0
  36. package/dist/esm/angular-ui/lib/spotchecks/SpotcheckStateService.js.map +1 -0
  37. package/dist/esm/angular-ui/lib/spotchecks/api.d.ts +15 -0
  38. package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/api.js +20 -29
  39. package/dist/esm/angular-ui/lib/spotchecks/api.js.map +1 -0
  40. package/dist/esm/angular-ui/lib/spotchecks/helpers.d.ts +29 -0
  41. package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/helpers.js +6 -19
  42. package/dist/esm/angular-ui/lib/spotchecks/helpers.js.map +1 -0
  43. package/dist/esm/angular-ui/lib/spotchecks/index.d.ts +2 -0
  44. package/dist/esm/angular-ui/lib/spotchecks/index.js +2 -0
  45. package/dist/esm/angular-ui/lib/spotchecks/index.js.map +1 -0
  46. package/dist/esm/angular-ui/lib/spotchecks/storage.js.map +1 -0
  47. package/dist/esm/angular-ui/lib/spotchecks/types.d.ts +78 -0
  48. package/dist/esm/angular-ui/lib/spotchecks/types.js.map +1 -0
  49. package/dist/esm/index.d.ts +1 -1
  50. package/dist/esm/index.js +1 -1
  51. package/dist/esm/index.js.map +1 -1
  52. package/dist/plugin.cjs.js +51510 -527
  53. package/dist/plugin.cjs.js.map +1 -1
  54. package/dist/plugin.js +51511 -524
  55. package/dist/plugin.js.map +1 -1
  56. package/package.json +31 -4
  57. package/src/angular-ui/lib/public-api.ts +2 -0
  58. package/src/angular-ui/lib/spotcheck.component.ts +10 -0
  59. package/src/angular-ui/lib/spotchecks/SpotCheck.ts +54 -0
  60. package/src/angular-ui/lib/spotchecks/SpotCheckComponent.css +7 -0
  61. package/src/angular-ui/lib/spotchecks/SpotCheckComponent.html +27 -0
  62. package/src/angular-ui/lib/spotchecks/SpotCheckComponent.ts +295 -0
  63. package/src/angular-ui/lib/spotchecks/SpotcheckStateService.ts +64 -0
  64. package/src/angular-ui/lib/spotchecks/api.ts +286 -0
  65. package/src/angular-ui/lib/spotchecks/helpers.ts +401 -0
  66. package/src/angular-ui/lib/spotchecks/index.ts +9 -0
  67. package/src/angular-ui/lib/spotchecks/storage.ts +7 -0
  68. package/src/angular-ui/lib/spotchecks/types.ts +84 -0
  69. package/src/angular-ui/ng-package.json +13 -0
  70. package/src/angular-ui/package.json +10 -0
  71. package/src/definitions.ts +17 -0
  72. package/src/index.ts +10 -0
  73. package/dist/esm/spotchecks/SpotCheck.js.map +0 -1
  74. package/dist/esm/spotchecks/SpotCheckComponent.js.map +0 -1
  75. package/dist/esm/spotchecks/SpotCheckService.d.ts +0 -8
  76. package/dist/esm/spotchecks/SpotCheckService.js +0 -45
  77. package/dist/esm/spotchecks/SpotCheckService.js.map +0 -1
  78. package/dist/esm/spotchecks/SpotcheckStateService.js.map +0 -1
  79. package/dist/esm/spotchecks/SpotchecksListener.d.ts +0 -9
  80. package/dist/esm/spotchecks/SpotchecksListener.js +0 -37
  81. package/dist/esm/spotchecks/SpotchecksListener.js.map +0 -1
  82. package/dist/esm/spotchecks/api.js.map +0 -1
  83. package/dist/esm/spotchecks/helpers.js.map +0 -1
  84. package/dist/esm/spotchecks/index.d.ts +0 -5
  85. package/dist/esm/spotchecks/index.js +0 -6
  86. package/dist/esm/spotchecks/index.js.map +0 -1
  87. package/dist/esm/spotchecks/storage.js.map +0 -1
  88. package/dist/esm/spotchecks/types.js.map +0 -1
  89. /package/dist/{esm → angular-ui}/spotchecks/SpotCheck.d.ts +0 -0
  90. /package/dist/{esm → angular-ui}/spotchecks/api.d.ts +0 -0
  91. /package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/SpotcheckStateService.d.ts +0 -0
  92. /package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/storage.d.ts +0 -0
  93. /package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/storage.js +0 -0
  94. /package/dist/esm/{spotchecks → angular-ui/lib/spotchecks}/types.js +0 -0
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci11aS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hbmd1bGFyLXVpL2xpYi9hbmd1bGFyLXVpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './spotcheck.component';
2
+ export * from './spotchecks';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hbmd1bGFyLXVpL2xpYi9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3Nwb3RjaGVjay5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zcG90Y2hlY2tzJzsiXX0=
@@ -0,0 +1,17 @@
1
+ import { Component } from '@angular/core';
2
+ import { SpotCheckComponent } from './spotchecks/SpotCheckComponent';
3
+ import * as i0 from "@angular/core";
4
+ export class SpotCheck {
5
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheck, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.3", type: SpotCheck, isStandalone: true, selector: "SpotCheck", ngImport: i0, template: `<SpotCheckComponent />`, isInline: true, dependencies: [{ kind: "component", type: SpotCheckComponent, selector: "SpotCheckComponent" }] });
7
+ }
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheck, decorators: [{
9
+ type: Component,
10
+ args: [{
11
+ selector: 'SpotCheck',
12
+ template: `<SpotCheckComponent />`,
13
+ standalone: true,
14
+ imports: [SpotCheckComponent],
15
+ }]
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BvdGNoZWNrLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hbmd1bGFyLXVpL2xpYi9zcG90Y2hlY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUM7O0FBUXJFLE1BQU0sT0FBTyxTQUFTO3VHQUFULFNBQVM7MkZBQVQsU0FBUyxxRUFKVix3QkFBd0IsNERBRXhCLGtCQUFrQjs7MkZBRWpCLFNBQVM7a0JBTnJCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFdBQVc7b0JBQ3JCLFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNwb3RDaGVja0NvbXBvbmVudCB9IGZyb20gJy4vc3BvdGNoZWNrcy9TcG90Q2hlY2tDb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdTcG90Q2hlY2snLFxuICB0ZW1wbGF0ZTogYDxTcG90Q2hlY2tDb21wb25lbnQgLz5gLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbU3BvdENoZWNrQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU3BvdENoZWNrIHt9XG4iXX0=
@@ -0,0 +1,51 @@
1
+ import { sendTrackScreenRequest, sendTrackEventRequest } from './api';
2
+ import { getSpotcheckStateService } from './helpers';
3
+ export const initializeSpotChecks = ({ domainName, targetToken, userDetails = {}, variables = {}, customProperties = {}, }) => {
4
+ const spotcheckStateService = getSpotcheckStateService();
5
+ spotcheckStateService.setState({
6
+ domainName,
7
+ targetToken,
8
+ userDetails,
9
+ variables,
10
+ customProperties,
11
+ });
12
+ };
13
+ export const trackScreen = async ({ screen, options }) => {
14
+ try {
15
+ const response = await sendTrackScreenRequest({ screen, options });
16
+ if (response.valid) {
17
+ console.log('Screen Tracking succeeded.');
18
+ }
19
+ else {
20
+ if ('error' in response) {
21
+ throw new Error(response.error.toString());
22
+ }
23
+ else {
24
+ throw new Error('Tracking failed without an explicit error.');
25
+ }
26
+ }
27
+ }
28
+ catch (error) {
29
+ console.log(`Screen Tracking Failed. ${error.message}`);
30
+ }
31
+ };
32
+ export const trackEvent = async ({ screen, event }) => {
33
+ try {
34
+ const response = await sendTrackEventRequest({ screen, event });
35
+ if (response.valid) {
36
+ console.log('TrackEvent succeeded.');
37
+ }
38
+ else {
39
+ if ('error' in response) {
40
+ throw new Error(response.error.toString());
41
+ }
42
+ else {
43
+ throw new Error('Tracking failed without an explicit error.');
44
+ }
45
+ }
46
+ }
47
+ catch (error) {
48
+ console.log(`Event Tracking Failed. ${error.message}`);
49
+ }
50
+ };
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3BvdENoZWNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FuZ3VsYXItdWkvbGliL3Nwb3RjaGVja3MvU3BvdENoZWNrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUN0RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFckQsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxFQUNuQyxVQUFVLEVBQ1YsV0FBVyxFQUNYLFdBQVcsR0FBRyxFQUFFLEVBQ2hCLFNBQVMsR0FBRyxFQUFFLEVBQ2QsZ0JBQWdCLEdBQUcsRUFBRSxHQUNLLEVBQUUsRUFBRTtJQUM5QixNQUFNLHFCQUFxQixHQUFHLHdCQUF3QixFQUFFLENBQUM7SUFDekQscUJBQXFCLENBQUMsUUFBUSxDQUFDO1FBQzdCLFVBQVU7UUFDVixXQUFXO1FBQ1gsV0FBVztRQUNYLFNBQVM7UUFDVCxnQkFBZ0I7S0FDakIsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQW9CLEVBQUUsRUFBRTtJQUN6RSxJQUFJLENBQUM7UUFDSCxNQUFNLFFBQVEsR0FBRyxNQUFNLHNCQUFzQixDQUFDLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDbkUsSUFBSSxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1FBQzVDLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxPQUFPLElBQUksUUFBUSxFQUFFLENBQUM7Z0JBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQzdDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixNQUFNLElBQUksS0FBSyxDQUFDLDRDQUE0QyxDQUFDLENBQUM7WUFDaEUsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBQUMsT0FBTyxLQUFVLEVBQUUsQ0FBQztRQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLDJCQUEyQixLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUMxRCxDQUFDO0FBQ0gsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQW1CLEVBQUUsRUFBRTtJQUNyRSxJQUFJLENBQUM7UUFDSCxNQUFNLFFBQVEsR0FBRyxNQUFNLHFCQUFxQixDQUFDLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDaEUsSUFBSSxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxPQUFPLElBQUksUUFBUSxFQUFFLENBQUM7Z0JBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQzdDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixNQUFNLElBQUksS0FBSyxDQUFDLDRDQUE0QyxDQUFDLENBQUM7WUFDaEUsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBQUMsT0FBTyxLQUFVLEVBQUUsQ0FBQztRQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLDBCQUEwQixLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUN6RCxDQUFDO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5pdGlhbGl6ZVNwb3RDaGVja3NQcm9wcywgVHJhY2tFdmVudFByb3BzLCBUcmFja1NjcmVlblByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzZW5kVHJhY2tTY3JlZW5SZXF1ZXN0LCBzZW5kVHJhY2tFdmVudFJlcXVlc3QgfSBmcm9tICcuL2FwaSc7XG5pbXBvcnQgeyBnZXRTcG90Y2hlY2tTdGF0ZVNlcnZpY2UgfSBmcm9tICcuL2hlbHBlcnMnO1xuXG5leHBvcnQgY29uc3QgaW5pdGlhbGl6ZVNwb3RDaGVja3MgPSAoe1xuICBkb21haW5OYW1lLFxuICB0YXJnZXRUb2tlbixcbiAgdXNlckRldGFpbHMgPSB7fSxcbiAgdmFyaWFibGVzID0ge30sXG4gIGN1c3RvbVByb3BlcnRpZXMgPSB7fSxcbn06IEluaXRpYWxpemVTcG90Q2hlY2tzUHJvcHMpID0+IHtcbiAgY29uc3Qgc3BvdGNoZWNrU3RhdGVTZXJ2aWNlID0gZ2V0U3BvdGNoZWNrU3RhdGVTZXJ2aWNlKCk7XG4gIHNwb3RjaGVja1N0YXRlU2VydmljZS5zZXRTdGF0ZSh7XG4gICAgZG9tYWluTmFtZSxcbiAgICB0YXJnZXRUb2tlbixcbiAgICB1c2VyRGV0YWlscyxcbiAgICB2YXJpYWJsZXMsXG4gICAgY3VzdG9tUHJvcGVydGllcyxcbiAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgdHJhY2tTY3JlZW4gPSBhc3luYyAoeyBzY3JlZW4sIG9wdGlvbnMgfTogVHJhY2tTY3JlZW5Qcm9wcykgPT4ge1xuICB0cnkge1xuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgc2VuZFRyYWNrU2NyZWVuUmVxdWVzdCh7IHNjcmVlbiwgb3B0aW9ucyB9KTtcbiAgICBpZiAocmVzcG9uc2UudmFsaWQpIHtcbiAgICAgIGNvbnNvbGUubG9nKCdTY3JlZW4gVHJhY2tpbmcgc3VjY2VlZGVkLicpO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoJ2Vycm9yJyBpbiByZXNwb25zZSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IocmVzcG9uc2UuZXJyb3IudG9TdHJpbmcoKSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1RyYWNraW5nIGZhaWxlZCB3aXRob3V0IGFuIGV4cGxpY2l0IGVycm9yLicpO1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCAoZXJyb3I6IGFueSkge1xuICAgIGNvbnNvbGUubG9nKGBTY3JlZW4gVHJhY2tpbmcgRmFpbGVkLiAke2Vycm9yLm1lc3NhZ2V9YCk7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCB0cmFja0V2ZW50ID0gYXN5bmMgKHsgc2NyZWVuLCBldmVudCB9OiBUcmFja0V2ZW50UHJvcHMpID0+IHtcbiAgdHJ5IHtcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHNlbmRUcmFja0V2ZW50UmVxdWVzdCh7IHNjcmVlbiwgZXZlbnQgfSk7XG4gICAgaWYgKHJlc3BvbnNlLnZhbGlkKSB7XG4gICAgICBjb25zb2xlLmxvZygnVHJhY2tFdmVudCBzdWNjZWVkZWQuJyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGlmICgnZXJyb3InIGluIHJlc3BvbnNlKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihyZXNwb25zZS5lcnJvci50b1N0cmluZygpKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignVHJhY2tpbmcgZmFpbGVkIHdpdGhvdXQgYW4gZXhwbGljaXQgZXJyb3IuJyk7XG4gICAgICB9XG4gICAgfVxuICB9IGNhdGNoIChlcnJvcjogYW55KSB7XG4gICAgY29uc29sZS5sb2coYEV2ZW50IFRyYWNraW5nIEZhaWxlZC4gJHtlcnJvci5tZXNzYWdlfWApO1xuICB9XG59O1xuIl19
@@ -0,0 +1,323 @@
1
+ import { Component, Input, ViewChild, HostListener, } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { closeSpotCheck, closeSpotCheckAndHandleSurveyEnd, getSpotcheckComponentCssStyles, handleSurveyEnd, ischatSurvey } from './helpers';
4
+ import { getSpotcheckStateService } from './helpers';
5
+ import axios from 'axios';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/platform-browser";
8
+ import * as i2 from "@angular/common";
9
+ export class WebViewComponent {
10
+ sanitizer;
11
+ url = '';
12
+ webviewType = 'classic';
13
+ isMiniCard = false;
14
+ safeUrl = null;
15
+ iframe;
16
+ constructor(sanitizer) {
17
+ this.sanitizer = sanitizer;
18
+ }
19
+ ngOnInit() {
20
+ if (this.url) {
21
+ this.safeUrl = this.sanitizer.bypassSecurityTrustResourceUrl(this.url);
22
+ }
23
+ }
24
+ ngAfterViewInit() {
25
+ const stateService = getSpotcheckStateService();
26
+ const webViewRef = this.iframe.nativeElement;
27
+ if (this.webviewType === 'classic') {
28
+ stateService.setState({
29
+ classicWebViewRef: webViewRef,
30
+ isClassicLoading: false,
31
+ });
32
+ }
33
+ else {
34
+ stateService.setState({
35
+ chatWebViewRef: webViewRef,
36
+ isChatLoading: false,
37
+ });
38
+ }
39
+ this.setupIframeLoadListener();
40
+ }
41
+ setupIframeLoadListener() {
42
+ const iframe = this.iframe.nativeElement;
43
+ iframe.addEventListener('load', () => {
44
+ const stateService = getSpotcheckStateService();
45
+ if (this.webviewType === 'classic') {
46
+ stateService.setState({ isClassicLoading: false });
47
+ }
48
+ else {
49
+ stateService.setState({ isChatLoading: false });
50
+ }
51
+ });
52
+ }
53
+ onMessage(event) {
54
+ const stateService = getSpotcheckStateService();
55
+ const { data } = event;
56
+ switch (data.type) {
57
+ case 'slideInFrame':
58
+ if (data.mounted) {
59
+ stateService.setState({ isMounted: true });
60
+ }
61
+ break;
62
+ case 'resizeWindow':
63
+ if (data.size) {
64
+ stateService.setState({
65
+ currentQuestionHeight: data.size.height,
66
+ });
67
+ }
68
+ else if (data.isCloseButtonEnabled) {
69
+ stateService.setState({
70
+ isCloseButtonEnabled: data.isCloseButtonEnabled,
71
+ });
72
+ }
73
+ break;
74
+ case 'surveyCompleted':
75
+ closeSpotCheckAndHandleSurveyEnd();
76
+ // spotchecksListener.emitSurveyCompleted(data.response);
77
+ break;
78
+ case 'surveyLoadStarted':
79
+ // spotchecksListener.emitSurveyLoadStarted(data.surveyDetails);
80
+ break;
81
+ default:
82
+ break;
83
+ }
84
+ }
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 });
86
+ 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
+ <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
+ <iframe
89
+ allow="camera; microphone; geolocation; display-capture; autoplay; clipboard-read; clipboard-write;"
90
+ #iframeRef
91
+ [src]="safeUrl"
92
+ style="width: 100%; height: 100%; display: block; border-radius: {{isMiniCard ? 12 : 0}}px;"
93
+ frameborder="0"
94
+ >
95
+ </iframe>
96
+ </div>
97
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] });
98
+ }
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: WebViewComponent, decorators: [{
100
+ type: Component,
101
+ args: [{
102
+ selector: 'WebViewComponent',
103
+ template: `
104
+ <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;">
105
+ <iframe
106
+ allow="camera; microphone; geolocation; display-capture; autoplay; clipboard-read; clipboard-write;"
107
+ #iframeRef
108
+ [src]="safeUrl"
109
+ style="width: 100%; height: 100%; display: block; border-radius: {{isMiniCard ? 12 : 0}}px;"
110
+ frameborder="0"
111
+ >
112
+ </iframe>
113
+ </div>
114
+ `,
115
+ standalone: true,
116
+ imports: [CommonModule],
117
+ }]
118
+ }], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { url: [{
119
+ type: Input
120
+ }], webviewType: [{
121
+ type: Input
122
+ }], isMiniCard: [{
123
+ type: Input
124
+ }], iframe: [{
125
+ type: ViewChild,
126
+ args: ['iframeRef']
127
+ }], onMessage: [{
128
+ type: HostListener,
129
+ args: ['window:message', ['$event']]
130
+ }] } });
131
+ export class CloseSVGComponent {
132
+ size = 32;
133
+ stroke = '#919191';
134
+ strokeWidth = 1.5;
135
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseSVGComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
136
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.3", type: CloseSVGComponent, isStandalone: true, selector: "close-svg", inputs: { size: "size", stroke: "stroke", strokeWidth: "strokeWidth" }, ngImport: i0, template: `
137
+ <svg
138
+ [attr.width]="size"
139
+ [attr.height]="size"
140
+ viewBox="0 0 32 32"
141
+ fill="none"
142
+ xmlns="https://www.w3.org/2000/svg"
143
+ >
144
+ <path
145
+ d="M10.6665 10.667L21.3332 21.3337M21.3332 10.667L10.6665 21.3337"
146
+ [attr.stroke]="stroke"
147
+ [attr.stroke-width]="strokeWidth"
148
+ stroke-linecap="round"
149
+ stroke-linejoin="round"
150
+ />
151
+ </svg>
152
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] });
153
+ }
154
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseSVGComponent, decorators: [{
155
+ type: Component,
156
+ args: [{
157
+ selector: 'close-svg',
158
+ template: `
159
+ <svg
160
+ [attr.width]="size"
161
+ [attr.height]="size"
162
+ viewBox="0 0 32 32"
163
+ fill="none"
164
+ xmlns="https://www.w3.org/2000/svg"
165
+ >
166
+ <path
167
+ d="M10.6665 10.667L21.3332 21.3337M21.3332 10.667L10.6665 21.3337"
168
+ [attr.stroke]="stroke"
169
+ [attr.stroke-width]="strokeWidth"
170
+ stroke-linecap="round"
171
+ stroke-linejoin="round"
172
+ />
173
+ </svg>
174
+ `,
175
+ standalone: true,
176
+ imports: [CommonModule],
177
+ }]
178
+ }], propDecorators: { size: [{
179
+ type: Input
180
+ }], stroke: [{
181
+ type: Input
182
+ }], strokeWidth: [{
183
+ type: Input
184
+ }] } });
185
+ export class CloseButtonComponent {
186
+ size = 30;
187
+ strokeWidth = 1.2;
188
+ state;
189
+ stateService;
190
+ stateSubscription;
191
+ isVisible = false;
192
+ isMiniCard = false;
193
+ stroke = 'black';
194
+ constructor() {
195
+ this.stateService = getSpotcheckStateService();
196
+ this.state = this.stateService.getState();
197
+ this.updateComponentState();
198
+ this.stateSubscription = this.stateService.state$.subscribe((newState) => {
199
+ this.state = newState;
200
+ this.updateComponentState();
201
+ });
202
+ }
203
+ ngOnDestroy() {
204
+ if (this.stateSubscription) {
205
+ this.stateSubscription.unsubscribe();
206
+ }
207
+ }
208
+ updateComponentState() {
209
+ this.isVisible =
210
+ this.state.isCloseButtonEnabled &&
211
+ ((this.state.currentQuestionHeight > 0 && !this.state.isFullScreenMode) ||
212
+ (this.state.isFullScreenMode &&
213
+ ((!this.state.isClassicLoading &&
214
+ this.state.spotCheckType === 'classic') ||
215
+ (!this.state.isChatLoading &&
216
+ this.state.spotCheckType === 'chat'))));
217
+ this.isMiniCard = this.state.spotChecksMode === 'miniCard';
218
+ this.stroke = this.isMiniCard ? 'black' : this.state.closeButtonStyle?.['ctaButton'] || 'black';
219
+ }
220
+ onClick = async () => {
221
+ await closeSpotCheck();
222
+ handleSurveyEnd();
223
+ };
224
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
225
+ 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
+ <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
+ <close-svg [size]="size" [stroke]="stroke" [strokeWidth]="strokeWidth" style="display: flex; align-items: center; justify-content: center;"/>
228
+ </div>
229
+ <div style="position: absolute; top: 16px; right: 16px; z-index: 100001; cursor: pointer;" (click)="onClick()" *ngIf="isVisible && !isMiniCard">
230
+ <close-svg [size]="size" [stroke]="stroke" [strokeWidth]="strokeWidth"/>
231
+ </div>
232
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CloseSVGComponent, selector: "close-svg", inputs: ["size", "stroke", "strokeWidth"] }] });
233
+ }
234
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseButtonComponent, decorators: [{
235
+ type: Component,
236
+ args: [{
237
+ selector: 'spotcheck-close-button',
238
+ template: `
239
+ <div style="position: absolute; top: -36px; right: 16px; z-index: 100001; cursor: pointer; background-color: white; border-radius: 50px;" (click)="onClick()" *ngIf="isVisible && isMiniCard">
240
+ <close-svg [size]="size" [stroke]="stroke" [strokeWidth]="strokeWidth" style="display: flex; align-items: center; justify-content: center;"/>
241
+ </div>
242
+ <div style="position: absolute; top: 16px; right: 16px; z-index: 100001; cursor: pointer;" (click)="onClick()" *ngIf="isVisible && !isMiniCard">
243
+ <close-svg [size]="size" [stroke]="stroke" [strokeWidth]="strokeWidth"/>
244
+ </div>
245
+ `,
246
+ standalone: true,
247
+ imports: [CommonModule, CloseSVGComponent],
248
+ }]
249
+ }], ctorParameters: () => [], propDecorators: { size: [{
250
+ type: Input
251
+ }], strokeWidth: [{
252
+ type: Input
253
+ }] } });
254
+ export class SpotCheckComponent {
255
+ state;
256
+ spotcheckStateService;
257
+ stateSubscription;
258
+ componentStyles = {};
259
+ avatarUrl = '';
260
+ constructor() {
261
+ this.spotcheckStateService = getSpotcheckStateService();
262
+ this.state = this.spotcheckStateService.getState();
263
+ this.updateComponentStyles();
264
+ this.stateSubscription = this.spotcheckStateService.state$.subscribe((newState) => {
265
+ this.state = newState;
266
+ this.updateComponentStyles();
267
+ this.avatarUrl = this.state.avatarUrl || "https://static.surveysparrow.com/application/images/profile.png";
268
+ });
269
+ }
270
+ ngOnInit() {
271
+ this.initializeComponent();
272
+ }
273
+ ngOnDestroy() {
274
+ if (this.stateSubscription) {
275
+ this.stateSubscription.unsubscribe();
276
+ }
277
+ }
278
+ updateComponentStyles() {
279
+ this.componentStyles = getSpotcheckComponentCssStyles(this.state);
280
+ }
281
+ initializeComponent = async () => {
282
+ try {
283
+ const domainName = this.state.domainName;
284
+ const targetToken = this.state.targetToken;
285
+ const response = await axios.get(`https://${domainName}/api/internal/spotcheck/widget/${targetToken}/init`);
286
+ const data = response.data;
287
+ if (data.filteredSpotChecks && data.filteredSpotChecks.length > 0) {
288
+ let classicIframe = false;
289
+ let chatIframe = false;
290
+ data.filteredSpotChecks.forEach((spotcheck) => {
291
+ if (spotcheck.appearance.mode === 'fullScreen' &&
292
+ ischatSurvey(spotcheck?.survey?.surveyType)) {
293
+ chatIframe = true;
294
+ }
295
+ else {
296
+ classicIframe = true;
297
+ }
298
+ });
299
+ const newClassicUrl = classicIframe
300
+ ? `https://${domainName}/eui-template/classic`
301
+ : '';
302
+ const newChatUrl = chatIframe
303
+ ? `https://${domainName}/eui-template/chat`
304
+ : '';
305
+ this.spotcheckStateService.setState({
306
+ filteredSpotChecks: data.filteredSpotChecks,
307
+ classicUrl: newClassicUrl,
308
+ chatUrl: newChatUrl,
309
+ });
310
+ }
311
+ }
312
+ catch (error) {
313
+ console.log('Error initializing widget:', JSON.stringify(error));
314
+ }
315
+ };
316
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheckComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
317
+ 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
+ }
319
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheckComponent, decorators: [{
320
+ type: Component,
321
+ 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"]}
@@ -0,0 +1,65 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class SpotcheckStateService {
5
+ initialState = {
6
+ isVisible: false,
7
+ spotcheckPosition: 'bottom',
8
+ spotcheckURL: '',
9
+ spotcheckID: 0,
10
+ spotcheckContactID: 0,
11
+ afterDelay: 0.0,
12
+ maxHeight: 0.5,
13
+ currentQuestionHeight: 0,
14
+ isFullScreenMode: false,
15
+ isBannerImageOn: false,
16
+ triggerToken: '',
17
+ closeButtonStyle: {},
18
+ isCloseButtonEnabled: false,
19
+ isSpotPassed: false,
20
+ isChecksPassed: false,
21
+ customEventsSpotChecks: [],
22
+ targetToken: '',
23
+ domainName: '',
24
+ userDetails: {},
25
+ variables: {},
26
+ customProperties: {},
27
+ traceId: '',
28
+ isClassicLoading: true,
29
+ isChatLoading: true,
30
+ classicUrl: '',
31
+ chatUrl: '',
32
+ classicWebViewRef: null,
33
+ chatWebViewRef: null,
34
+ filteredSpotChecks: [],
35
+ spotCheckType: '',
36
+ isMounted: false,
37
+ textPosition: 0,
38
+ screenHeight: 0,
39
+ keyBoardHeight: 0,
40
+ spotChecksMode: '',
41
+ avatarEnabled: false,
42
+ avatarUrl: '',
43
+ screenwiseUserDetails: {}
44
+ };
45
+ spotcheckState = new BehaviorSubject(this.initialState);
46
+ state$ = this.spotcheckState.asObservable();
47
+ setState(state) {
48
+ this.spotcheckState.next({ ...this.spotcheckState.value, ...state });
49
+ }
50
+ clearState() {
51
+ this.spotcheckState.next(this.initialState);
52
+ }
53
+ getState() {
54
+ return this.spotcheckState.getValue();
55
+ }
56
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotcheckStateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
57
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotcheckStateService, providedIn: 'root' });
58
+ }
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotcheckStateService, decorators: [{
60
+ type: Injectable,
61
+ args: [{
62
+ providedIn: 'root',
63
+ }]
64
+ }] });
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3BvdGNoZWNrU3RhdGVTZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FuZ3VsYXItdWkvbGliL3Nwb3RjaGVja3MvU3BvdGNoZWNrU3RhdGVTZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFNdkMsTUFBTSxPQUFPLHFCQUFxQjtJQUN4QixZQUFZLEdBQW1CO1FBQ3JDLFNBQVMsRUFBRSxLQUFLO1FBQ2hCLGlCQUFpQixFQUFFLFFBQVE7UUFDM0IsWUFBWSxFQUFFLEVBQUU7UUFDaEIsV0FBVyxFQUFFLENBQUM7UUFDZCxrQkFBa0IsRUFBRSxDQUFDO1FBQ3JCLFVBQVUsRUFBRSxHQUFHO1FBQ2YsU0FBUyxFQUFFLEdBQUc7UUFDZCxxQkFBcUIsRUFBRSxDQUFDO1FBQ3hCLGdCQUFnQixFQUFFLEtBQUs7UUFDdkIsZUFBZSxFQUFFLEtBQUs7UUFDdEIsWUFBWSxFQUFFLEVBQUU7UUFDaEIsZ0JBQWdCLEVBQUUsRUFBRTtRQUNwQixvQkFBb0IsRUFBRSxLQUFLO1FBQzNCLFlBQVksRUFBRSxLQUFLO1FBQ25CLGNBQWMsRUFBRSxLQUFLO1FBQ3JCLHNCQUFzQixFQUFFLEVBQUU7UUFDMUIsV0FBVyxFQUFFLEVBQUU7UUFDZixVQUFVLEVBQUUsRUFBRTtRQUNkLFdBQVcsRUFBRSxFQUFFO1FBQ2YsU0FBUyxFQUFFLEVBQUU7UUFDYixnQkFBZ0IsRUFBRSxFQUFFO1FBQ3BCLE9BQU8sRUFBRSxFQUFFO1FBQ1gsZ0JBQWdCLEVBQUUsSUFBSTtRQUN0QixhQUFhLEVBQUUsSUFBSTtRQUNuQixVQUFVLEVBQUUsRUFBRTtRQUNkLE9BQU8sRUFBRSxFQUFFO1FBQ1gsaUJBQWlCLEVBQUUsSUFBSTtRQUN2QixjQUFjLEVBQUUsSUFBSTtRQUNwQixrQkFBa0IsRUFBRSxFQUFFO1FBQ3RCLGFBQWEsRUFBRSxFQUFFO1FBQ2pCLFNBQVMsRUFBRSxLQUFLO1FBQ2hCLFlBQVksRUFBRSxDQUFDO1FBQ2YsWUFBWSxFQUFFLENBQUM7UUFDZixjQUFjLEVBQUUsQ0FBQztRQUNqQixjQUFjLEVBQUUsRUFBRTtRQUNsQixhQUFhLEVBQUUsS0FBSztRQUNwQixTQUFTLEVBQUUsRUFBRTtRQUNiLHFCQUFxQixFQUFFLEVBQUU7S0FDMUIsQ0FBQztJQUVNLGNBQWMsR0FBRyxJQUFJLGVBQWUsQ0FBaUIsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2hGLE1BQU0sR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBRTVDLFFBQVEsQ0FBQyxLQUE4QjtRQUNyQyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsR0FBRyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFFRCxRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3hDLENBQUM7dUdBdkRVLHFCQUFxQjsyR0FBckIscUJBQXFCLGNBRnBCLE1BQU07OzJGQUVQLHFCQUFxQjtrQkFIakMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFNwb3RjaGVja1N0YXRlIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBTcG90Y2hlY2tTdGF0ZVNlcnZpY2Uge1xuICBwcml2YXRlIGluaXRpYWxTdGF0ZTogU3BvdGNoZWNrU3RhdGUgPSB7XG4gICAgaXNWaXNpYmxlOiBmYWxzZSxcbiAgICBzcG90Y2hlY2tQb3NpdGlvbjogJ2JvdHRvbScsXG4gICAgc3BvdGNoZWNrVVJMOiAnJyxcbiAgICBzcG90Y2hlY2tJRDogMCxcbiAgICBzcG90Y2hlY2tDb250YWN0SUQ6IDAsXG4gICAgYWZ0ZXJEZWxheTogMC4wLFxuICAgIG1heEhlaWdodDogMC41LFxuICAgIGN1cnJlbnRRdWVzdGlvbkhlaWdodDogMCxcbiAgICBpc0Z1bGxTY3JlZW5Nb2RlOiBmYWxzZSxcbiAgICBpc0Jhbm5lckltYWdlT246IGZhbHNlLFxuICAgIHRyaWdnZXJUb2tlbjogJycsXG4gICAgY2xvc2VCdXR0b25TdHlsZToge30sXG4gICAgaXNDbG9zZUJ1dHRvbkVuYWJsZWQ6IGZhbHNlLFxuICAgIGlzU3BvdFBhc3NlZDogZmFsc2UsXG4gICAgaXNDaGVja3NQYXNzZWQ6IGZhbHNlLFxuICAgIGN1c3RvbUV2ZW50c1Nwb3RDaGVja3M6IFtdLFxuICAgIHRhcmdldFRva2VuOiAnJyxcbiAgICBkb21haW5OYW1lOiAnJyxcbiAgICB1c2VyRGV0YWlsczoge30sXG4gICAgdmFyaWFibGVzOiB7fSxcbiAgICBjdXN0b21Qcm9wZXJ0aWVzOiB7fSxcbiAgICB0cmFjZUlkOiAnJyxcbiAgICBpc0NsYXNzaWNMb2FkaW5nOiB0cnVlLFxuICAgIGlzQ2hhdExvYWRpbmc6IHRydWUsXG4gICAgY2xhc3NpY1VybDogJycsXG4gICAgY2hhdFVybDogJycsXG4gICAgY2xhc3NpY1dlYlZpZXdSZWY6IG51bGwsXG4gICAgY2hhdFdlYlZpZXdSZWY6IG51bGwsXG4gICAgZmlsdGVyZWRTcG90Q2hlY2tzOiBbXSxcbiAgICBzcG90Q2hlY2tUeXBlOiAnJyxcbiAgICBpc01vdW50ZWQ6IGZhbHNlLFxuICAgIHRleHRQb3NpdGlvbjogMCxcbiAgICBzY3JlZW5IZWlnaHQ6IDAsXG4gICAga2V5Qm9hcmRIZWlnaHQ6IDAsXG4gICAgc3BvdENoZWNrc01vZGU6ICcnLFxuICAgIGF2YXRhckVuYWJsZWQ6IGZhbHNlLFxuICAgIGF2YXRhclVybDogJycsXG4gICAgc2NyZWVud2lzZVVzZXJEZXRhaWxzOiB7fVxuICB9O1xuICBcbiAgcHJpdmF0ZSBzcG90Y2hlY2tTdGF0ZSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8U3BvdGNoZWNrU3RhdGU+KHRoaXMuaW5pdGlhbFN0YXRlKTtcbiAgc3RhdGUkID0gdGhpcy5zcG90Y2hlY2tTdGF0ZS5hc09ic2VydmFibGUoKTtcblxuICBzZXRTdGF0ZShzdGF0ZTogUGFydGlhbDxTcG90Y2hlY2tTdGF0ZT4pIHtcbiAgICB0aGlzLnNwb3RjaGVja1N0YXRlLm5leHQoeyAuLi50aGlzLnNwb3RjaGVja1N0YXRlLnZhbHVlLCAuLi5zdGF0ZSB9KTtcbiAgfVxuICBcbiAgY2xlYXJTdGF0ZSgpIHtcbiAgICB0aGlzLnNwb3RjaGVja1N0YXRlLm5leHQodGhpcy5pbml0aWFsU3RhdGUpO1xuICB9XG5cbiAgZ2V0U3RhdGUoKSB7XG4gICAgcmV0dXJuIHRoaXMuc3BvdGNoZWNrU3RhdGUuZ2V0VmFsdWUoKTtcbiAgfVxufVxuIl19