surveysparrow-ionic-plugin 1.0.7-beta.14 → 1.0.7-beta.16
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/Package.swift +8 -8
- package/README.md +85 -16
- package/{SurveysparrowIonicPlugin2.podspec → SurveysparrowIonicPlugin.podspec} +1 -1
- package/android/build.gradle +7 -2
- package/android/src/main/java/com/surveysparrow/plugins/ionic/SurveySparrowIonicPlugin.java +53 -0
- package/android/src/main/java/com/surveysparrow/plugins/ionic/SurveySparrowIonicPluginPlugin.java +74 -0
- package/dist/angular-ui/esm2022/angular-ui.mjs +5 -0
- package/dist/angular-ui/esm2022/spotcheck.component.mjs +4 -4
- package/dist/angular-ui/esm2022/spotchecks/SpotCheck.mjs +1 -1
- package/dist/angular-ui/esm2022/spotchecks/SpotCheckComponent.mjs +16 -16
- package/dist/angular-ui/esm2022/spotchecks/SpotcheckStateService.mjs +4 -4
- package/dist/angular-ui/esm2022/spotchecks/api.mjs +4 -4
- package/dist/angular-ui/esm2022/spotchecks/helpers.mjs +1 -1
- package/dist/angular-ui/esm2022/spotchecks/types.mjs +1 -1
- package/dist/angular-ui/fesm2022/{surveysparrow-ionic-plugin-angular-ui.mjs → angular-ui.mjs} +25 -25
- package/dist/angular-ui/fesm2022/angular-ui.mjs.map +1 -0
- package/dist/angular-ui/index.d.ts +1 -1
- package/dist/angular-ui/spotchecks/types.d.ts +4 -4
- package/dist/docs.json +4462 -10
- package/dist/esm/angular-ui/lib/public-api.d.ts +2 -0
- package/dist/esm/angular-ui/lib/public-api.js +3 -0
- package/dist/esm/angular-ui/lib/public-api.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotcheck.component.d.ts +2 -0
- package/dist/esm/angular-ui/lib/spotcheck.component.js +20 -0
- package/dist/esm/angular-ui/lib/spotcheck.component.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheck.d.ts +4 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheck.js +51 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheck.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckComponent.d.ts +46 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckComponent.js +306 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotCheckComponent.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotcheckStateService.d.ts +9 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotcheckStateService.js +69 -0
- package/dist/esm/angular-ui/lib/spotchecks/SpotcheckStateService.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/api.d.ts +15 -0
- package/dist/esm/angular-ui/lib/spotchecks/api.js +240 -0
- package/dist/esm/angular-ui/lib/spotchecks/api.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/helpers.d.ts +30 -0
- package/dist/esm/angular-ui/lib/spotchecks/helpers.js +293 -0
- package/dist/esm/angular-ui/lib/spotchecks/helpers.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/index.d.ts +2 -0
- package/dist/esm/angular-ui/lib/spotchecks/index.js +2 -0
- package/dist/esm/angular-ui/lib/spotchecks/index.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/storage.d.ts +2 -0
- package/dist/esm/angular-ui/lib/spotchecks/storage.js +7 -0
- package/dist/esm/angular-ui/lib/spotchecks/storage.js.map +1 -0
- package/dist/esm/angular-ui/lib/spotchecks/types.d.ts +77 -0
- package/dist/esm/angular-ui/lib/spotchecks/types.js +2 -0
- package/dist/esm/angular-ui/lib/spotchecks/types.js.map +1 -0
- package/dist/esm/definitions.d.ts +13 -6
- package/dist/esm/definitions.js.map +1 -1
- package/dist/esm/index.d.ts +4 -3
- package/dist/esm/index.js +3 -4
- package/dist/esm/index.js.map +1 -1
- package/dist/plugin.cjs.js +52019 -10
- package/dist/plugin.cjs.js.map +1 -1
- package/dist/plugin.js +52018 -12
- package/dist/plugin.js.map +1 -1
- package/ios/Sources/SurveySparrowIonicPluginPlugin/SsSurveyDelegate.swift +16 -0
- package/ios/Sources/SurveySparrowIonicPluginPlugin/SsSurveyHelper.swift +179 -0
- package/ios/Sources/SurveySparrowIonicPluginPlugin/SsSurveyView.swift +320 -0
- package/ios/Sources/SurveySparrowIonicPluginPlugin/SsSurveyViewController.swift +81 -0
- package/ios/Sources/SurveySparrowIonicPluginPlugin/SurveySparrow.swift +158 -0
- package/ios/Sources/SurveySparrowIonicPluginPlugin/SurveySparrowIonicPlugin.swift +70 -0
- package/ios/Sources/SurveySparrowIonicPluginPlugin/SurveySparrowIonicPluginPlugin.swift +50 -0
- package/ios/Tests/SurveySparrowIonicPluginPluginTests/SurveySparrowIonicPluginPluginTests.swift +72 -0
- package/package.json +36 -27
- package/src/angular-ui/lib/spotchecks/SpotCheckComponent.ts +1 -0
- package/src/angular-ui/lib/spotchecks/api.ts +3 -3
- package/src/angular-ui/lib/spotchecks/types.ts +4 -4
- package/src/angular-ui/package.json +2 -2
- package/src/definitions.ts +16 -2
- package/src/index.ts +5 -5
- package/android/src/main/java/com/surveysparrow/plugins/ionic2/SurveySparrowIonicPlugin2.java +0 -11
- package/android/src/main/java/com/surveysparrow/plugins/ionic2/SurveySparrowIonicPlugin2Plugin.java +0 -22
- package/dist/angular-ui/esm2022/surveysparrow-ionic-plugin-angular-ui.mjs +0 -5
- package/dist/angular-ui/fesm2022/surveysparrow-ionic-plugin-angular-ui.mjs.map +0 -1
- package/dist/angular-ui/package.json +0 -26
- package/dist/esm/web.d.ts +0 -9
- package/dist/esm/web.js +0 -8
- package/dist/esm/web.js.map +0 -1
- package/ios/Sources/SurveySparrowIonicPlugin2Plugin/SurveySparrowIonicPlugin2.swift +0 -8
- package/ios/Sources/SurveySparrowIonicPlugin2Plugin/SurveySparrowIonicPlugin2Plugin.swift +0 -23
- package/ios/Tests/SurveySparrowIonicPlugin2PluginTests/SurveySparrowIonicPlugin2PluginTests.swift +0 -15
- package/src/angular-ui/node_modules/.cache/ng-packagr/content-v2/sha512/48/7f/62c610601af12f907a6c451b7403632ec1b46aa6eb934436e975d11fb0279bdd48f99cd9a6ef9bebf4e76fa3729a01de5dbbd44495621cce4510729329ec +0 -1
- package/src/angular-ui/node_modules/.cache/ng-packagr/content-v2/sha512/49/e2/92b07f833cfa67fb9ab260b8bb1c7d98ead9388ed23fec5b45ef6bef19cbe6f669e2ad8757d9c89a1282bfe033f6e28d0207466d924e58e26709cf3cf85e +0 -1
- package/src/angular-ui/node_modules/.cache/ng-packagr/index-v5/05/e4/21e297b0d6f5d32263635d13178d37fffd2b116f3038a4d89284cd86fee9 +0 -2
- package/src/angular-ui/node_modules/.cache/ng-packagr/index-v5/0f/08/0e2e594d25ea02e021f3ad76398fc4fc5fa4e65caeafa6128083c83ee494 +0 -2
- package/src/angular-ui/node_modules/.cache/ng-packagr/tsbuildinfo/surveysparrow-ionic-plugin-angular-ui.tsbuildinfo +0 -1
- package/src/web.ts +0 -10
package/Package.swift
CHANGED
|
@@ -2,27 +2,27 @@
|
|
|
2
2
|
import PackageDescription
|
|
3
3
|
|
|
4
4
|
let package = Package(
|
|
5
|
-
name: "
|
|
5
|
+
name: "SurveysparrowIonicPlugin",
|
|
6
6
|
platforms: [.iOS(.v14)],
|
|
7
7
|
products: [
|
|
8
8
|
.library(
|
|
9
|
-
name: "
|
|
10
|
-
targets: ["
|
|
9
|
+
name: "SurveysparrowIonicPlugin",
|
|
10
|
+
targets: ["SurveySparrowIonicPluginPlugin"])
|
|
11
11
|
],
|
|
12
12
|
dependencies: [
|
|
13
13
|
.package(url: "https://github.com/ionic-team/capacitor-swift-pm.git", from: "7.0.0")
|
|
14
14
|
],
|
|
15
15
|
targets: [
|
|
16
16
|
.target(
|
|
17
|
-
name: "
|
|
17
|
+
name: "SurveySparrowIonicPluginPlugin",
|
|
18
18
|
dependencies: [
|
|
19
19
|
.product(name: "Capacitor", package: "capacitor-swift-pm"),
|
|
20
20
|
.product(name: "Cordova", package: "capacitor-swift-pm")
|
|
21
21
|
],
|
|
22
|
-
path: "ios/Sources/
|
|
22
|
+
path: "ios/Sources/SurveySparrowIonicPluginPlugin"),
|
|
23
23
|
.testTarget(
|
|
24
|
-
name: "
|
|
25
|
-
dependencies: ["
|
|
26
|
-
path: "ios/Tests/
|
|
24
|
+
name: "SurveySparrowIonicPluginPluginTests",
|
|
25
|
+
dependencies: ["SurveySparrowIonicPluginPlugin"],
|
|
26
|
+
path: "ios/Tests/SurveySparrowIonicPluginPluginTests")
|
|
27
27
|
]
|
|
28
28
|
)
|
package/README.md
CHANGED
|
@@ -1,37 +1,106 @@
|
|
|
1
|
-
# surveysparrow-ionic-plugin
|
|
1
|
+
# surveysparrow-ionic-plugin
|
|
2
2
|
|
|
3
|
-
SurveySparrow SDK enables you to collect feedback from your mobile app. Embed the Classic, Chat & NPS surveys in your
|
|
3
|
+
SurveySparrow SDK enables you to collect feedback from your mobile app. Embed the Classic, Chat & NPS surveys in your Ionic application seamlessly with few lines of code.
|
|
4
4
|
|
|
5
5
|
## Install
|
|
6
6
|
|
|
7
7
|
```bash
|
|
8
|
-
npm install surveysparrow-ionic-plugin
|
|
8
|
+
npm install surveysparrow-ionic-plugin
|
|
9
9
|
npx cap sync
|
|
10
10
|
```
|
|
11
11
|
|
|
12
|
-
##
|
|
12
|
+
## Permissions Required
|
|
13
|
+
|
|
14
|
+
To use this plugin, ensure the following permissions are added to your app:
|
|
15
|
+
|
|
16
|
+
### Android
|
|
17
|
+
|
|
18
|
+
Add this in your **root** `build.gradle` at the end of repositories:
|
|
13
19
|
|
|
14
|
-
|
|
20
|
+
```gradle
|
|
21
|
+
allprojects {
|
|
22
|
+
repositories {
|
|
23
|
+
...
|
|
24
|
+
maven { url 'https://jitpack.io' }
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
Add these permissions to your `AndroidManifest.xml`:
|
|
15
30
|
|
|
16
|
-
|
|
31
|
+
```xml
|
|
32
|
+
<uses-permission android:name="android.permission.INTERNET" />
|
|
33
|
+
<uses-permission android:name="android.permission.CAMERA" />
|
|
34
|
+
<uses-permission android:name="android.permission.RECORD_AUDIO" />
|
|
35
|
+
```
|
|
17
36
|
|
|
18
|
-
|
|
37
|
+
### iOS
|
|
19
38
|
|
|
20
|
-
|
|
21
|
-
<!--Update the source file JSDoc comments and rerun docgen to update the docs below-->
|
|
39
|
+
Add the necessary permissions to your `Info.plist`:
|
|
22
40
|
|
|
23
|
-
|
|
41
|
+
```xml
|
|
42
|
+
<key>NSCameraUsageDescription</key>
|
|
43
|
+
<string>We need camera access to capture photos and videos.</string>
|
|
44
|
+
<key>NSMicrophoneUsageDescription</key>
|
|
45
|
+
<string>We need microphone access to record audio.</string>
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
### General Note
|
|
49
|
+
|
|
50
|
+
Based on the survey type being used, ensure the necessary permissions (e.g., for photos, videos, audio, or storage) are added to your app's configuration.
|
|
51
|
+
|
|
52
|
+
## API
|
|
53
|
+
|
|
54
|
+
[loadFullScreenSurvey(...)](#loadfullscreensurvey)
|
|
55
|
+
|
|
56
|
+
[loadFullScreenSurveyWithValidation(...)](#loadfullscreensurveywithvalidation)
|
|
57
|
+
|
|
58
|
+
### loadFullScreenSurvey(...)
|
|
24
59
|
|
|
25
60
|
```typescript
|
|
26
|
-
|
|
61
|
+
loadFullScreenSurvey(options: { domain: String; token: String; params: Object; properties: Object; }) => Promise<void>
|
|
27
62
|
```
|
|
28
63
|
|
|
29
|
-
| Param | Type
|
|
30
|
-
| ------------- |
|
|
31
|
-
| **`options`** | <code>{
|
|
64
|
+
| Param | Type |
|
|
65
|
+
| ------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
66
|
+
| **`options`** | <code>{ domain: <a href="#string">String</a>; token: <a href="#string">String</a>; params: <a href="#object">Object</a>; properties: <a href="#object">Object</a>; }</code> |
|
|
32
67
|
|
|
33
|
-
|
|
68
|
+
--------------------
|
|
34
69
|
|
|
70
|
+
### loadFullScreenSurveyWithValidation(...)
|
|
71
|
+
|
|
72
|
+
```typescript
|
|
73
|
+
loadFullScreenSurveyWithValidation(options: { domain: String; token: String; params: Object; properties: Object; }) => Promise<void>
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
| Param | Type |
|
|
77
|
+
| ------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
78
|
+
| **`options`** | <code>{ domain: <a href="#string">String</a>; token: <a href="#string">String</a>; params: <a href="#object">Object</a>; properties: <a href="#object">Object</a>; }</code> |
|
|
35
79
|
--------------------
|
|
36
80
|
|
|
37
|
-
|
|
81
|
+
## Validations
|
|
82
|
+
|
|
83
|
+
Validations include **Limit Submission Per User** and **Survey Throttling**.
|
|
84
|
+
|
|
85
|
+
To achieve this, the **`emailaddress`** of the user must be passed in the `params` object.
|
|
86
|
+
|
|
87
|
+
## Params
|
|
88
|
+
|
|
89
|
+
The `params` object allows passing **survey variables**, which can be accessed in the survey's end-user interface. Ensure that the spelling of survey variables matches the configured values. Additionally, make sure to include the **`emailaddress`** field for validations.
|
|
90
|
+
|
|
91
|
+
## Properties
|
|
92
|
+
|
|
93
|
+
The `properties` object includes the following parameters:
|
|
94
|
+
|
|
95
|
+
1. **`isCloseButtonEnabled`** (default: `true`)
|
|
96
|
+
- If set to `false`, the close button will be removed.
|
|
97
|
+
- **Note:** Disabling this option will also disable the survey validation.
|
|
98
|
+
|
|
99
|
+
2. **`langCode`** (default: `en`)
|
|
100
|
+
- To load the survey in a specific language, pass the corresponding language code.
|
|
101
|
+
- Ensure that the language is configured in the SurveySparrow app.
|
|
102
|
+
- A list of supported language codes can be found [here](https://docs.google.com/document/d/1cmmWJQba8B3UkV6g5m93DgpenVojclzeOB0mdn-rlrg/edit?usp=sharing).
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
## Support
|
|
106
|
+
For questions or issues, contact us at [support@surveysparrow.com](mailto:support@surveysparrow.com).
|
|
@@ -3,7 +3,7 @@ require 'json'
|
|
|
3
3
|
package = JSON.parse(File.read(File.join(__dir__, 'package.json')))
|
|
4
4
|
|
|
5
5
|
Pod::Spec.new do |s|
|
|
6
|
-
s.name = '
|
|
6
|
+
s.name = 'SurveysparrowIonicPlugin'
|
|
7
7
|
s.version = package['version']
|
|
8
8
|
s.summary = package['description']
|
|
9
9
|
s.license = package['license']
|
package/android/build.gradle
CHANGED
|
@@ -11,14 +11,14 @@ buildscript {
|
|
|
11
11
|
mavenCentral()
|
|
12
12
|
}
|
|
13
13
|
dependencies {
|
|
14
|
-
classpath 'com.android.tools.build:gradle:8.
|
|
14
|
+
classpath 'com.android.tools.build:gradle:8.6.1'
|
|
15
15
|
}
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
apply plugin: 'com.android.library'
|
|
19
19
|
|
|
20
20
|
android {
|
|
21
|
-
namespace "com.surveysparrow.plugins.
|
|
21
|
+
namespace "com.surveysparrow.plugins.ionic"
|
|
22
22
|
compileSdk project.hasProperty('compileSdkVersion') ? rootProject.ext.compileSdkVersion : 35
|
|
23
23
|
defaultConfig {
|
|
24
24
|
minSdkVersion project.hasProperty('minSdkVersion') ? rootProject.ext.minSdkVersion : 23
|
|
@@ -45,6 +45,7 @@ android {
|
|
|
45
45
|
repositories {
|
|
46
46
|
google()
|
|
47
47
|
mavenCentral()
|
|
48
|
+
maven { url 'https://jitpack.io' }
|
|
48
49
|
}
|
|
49
50
|
|
|
50
51
|
|
|
@@ -53,6 +54,10 @@ dependencies {
|
|
|
53
54
|
implementation project(':capacitor-android')
|
|
54
55
|
implementation "androidx.appcompat:appcompat:$androidxAppCompatVersion"
|
|
55
56
|
testImplementation "junit:junit:$junitVersion"
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
implementation("com.github.surveysparrow:surveysparrow-android-sdk:0.6.4-beta.2")
|
|
60
|
+
|
|
56
61
|
androidTestImplementation "androidx.test.ext:junit:$androidxJunitVersion"
|
|
57
62
|
androidTestImplementation "androidx.test.espresso:espresso-core:$androidxEspressoCoreVersion"
|
|
58
63
|
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
package com.surveysparrow.plugins.ionic;
|
|
2
|
+
|
|
3
|
+
import android.util.Log;
|
|
4
|
+
|
|
5
|
+
import androidx.appcompat.app.AppCompatActivity;
|
|
6
|
+
|
|
7
|
+
import com.surveysparrow.ss_android_sdk.OnSsResponseEventListener;
|
|
8
|
+
import com.surveysparrow.ss_android_sdk.OnSsValidateSurveyEventListener;
|
|
9
|
+
import com.surveysparrow.ss_android_sdk.SsSurvey;
|
|
10
|
+
import com.surveysparrow.ss_android_sdk.SsSurvey.CustomParam;
|
|
11
|
+
import com.surveysparrow.ss_android_sdk.SurveySparrow;
|
|
12
|
+
import org.json.JSONObject;
|
|
13
|
+
import java.util.HashMap;
|
|
14
|
+
|
|
15
|
+
public class SurveySparrowIonicPlugin implements OnSsValidateSurveyEventListener, OnSsResponseEventListener {
|
|
16
|
+
|
|
17
|
+
private static final int SURVEY_REQUEST_CODE = 1;
|
|
18
|
+
private static final int SURVEY_SCHEDULE_REQUEST_CODE = 2;
|
|
19
|
+
|
|
20
|
+
public void loadFullScreenSurvey(String domain, String token, CustomParam[] params, HashMap properties, AppCompatActivity activity) {
|
|
21
|
+
if(activity == null) {
|
|
22
|
+
throw new RuntimeException("Activity is null. Error fetching activity.");
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
SsSurvey survey = new SsSurvey(domain, token, params, properties);
|
|
26
|
+
SurveySparrow surveySparrow = new SurveySparrow(activity, survey)
|
|
27
|
+
.enableBackButton(true)
|
|
28
|
+
.setWaitTime(2000);
|
|
29
|
+
|
|
30
|
+
surveySparrow.startSurveyForResult(SURVEY_REQUEST_CODE);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
public void loadFullScreenSurveyWithValidation(String domain, String token, CustomParam[] params, HashMap properties, AppCompatActivity activity) {
|
|
34
|
+
SsSurvey survey = new SsSurvey(domain, token, params, properties);
|
|
35
|
+
SurveySparrow surveySparrow = new SurveySparrow(activity, survey)
|
|
36
|
+
.enableBackButton(true)
|
|
37
|
+
.setWaitTime(2000);
|
|
38
|
+
|
|
39
|
+
surveySparrow.scheduleSurvey(SURVEY_SCHEDULE_REQUEST_CODE);
|
|
40
|
+
surveySparrow.setValidateSurveyListener(this);
|
|
41
|
+
surveySparrow.startSurvey(SURVEY_REQUEST_CODE);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
@Override
|
|
45
|
+
public void onSsValidateSurvey(JSONObject jsonObject) {
|
|
46
|
+
Log.v("SurveySparrow", "Survey validation error json: " + jsonObject.toString());
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
@Override
|
|
50
|
+
public void onSsResponseEvent(JSONObject jsonObject) {
|
|
51
|
+
Log.v("SurveySparrow", "Survey response received: " + jsonObject.toString());
|
|
52
|
+
}
|
|
53
|
+
}
|
package/android/src/main/java/com/surveysparrow/plugins/ionic/SurveySparrowIonicPluginPlugin.java
ADDED
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
package com.surveysparrow.plugins.ionic;
|
|
2
|
+
|
|
3
|
+
import com.getcapacitor.JSObject;
|
|
4
|
+
import com.getcapacitor.Plugin;
|
|
5
|
+
import com.getcapacitor.PluginCall;
|
|
6
|
+
import com.getcapacitor.PluginMethod;
|
|
7
|
+
import com.getcapacitor.annotation.CapacitorPlugin;
|
|
8
|
+
|
|
9
|
+
import com.surveysparrow.ss_android_sdk.SsSurvey.CustomParam;
|
|
10
|
+
|
|
11
|
+
import java.util.List;
|
|
12
|
+
import java.util.ArrayList;
|
|
13
|
+
import java.util.HashMap;
|
|
14
|
+
import java.util.Iterator;
|
|
15
|
+
|
|
16
|
+
@CapacitorPlugin(name = "SurveySparrowIonicPlugin")
|
|
17
|
+
public class SurveySparrowIonicPluginPlugin extends Plugin {
|
|
18
|
+
|
|
19
|
+
private final SurveySparrowIonicPlugin implementation = new SurveySparrowIonicPlugin();
|
|
20
|
+
|
|
21
|
+
@PluginMethod
|
|
22
|
+
public void loadFullScreenSurvey(PluginCall call) {
|
|
23
|
+
String domain = call.getString("domain");
|
|
24
|
+
String token = call.getString("token");
|
|
25
|
+
CustomParam[] params = parseParams(call.getObject("params"));
|
|
26
|
+
HashMap<String, String> properties = parseProperties(call.getObject("properties"));
|
|
27
|
+
|
|
28
|
+
implementation.loadFullScreenSurvey(domain, token, params, properties, this.getActivity());
|
|
29
|
+
call.resolve();
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
@PluginMethod
|
|
33
|
+
public void loadFullScreenSurveyWithValidation(PluginCall call) {
|
|
34
|
+
String domain = call.getString("domain");
|
|
35
|
+
String token = call.getString("token");
|
|
36
|
+
CustomParam[] params = parseParams(call.getObject("params"));
|
|
37
|
+
HashMap<String, String> properties = parseProperties(call.getObject("properties"));
|
|
38
|
+
|
|
39
|
+
implementation.loadFullScreenSurveyWithValidation(domain, token, params, properties, this.getActivity());
|
|
40
|
+
call.resolve();
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
private CustomParam[] parseParams(JSObject jsParams) {
|
|
44
|
+
if (jsParams == null) {
|
|
45
|
+
return new CustomParam[0];
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
Iterator<String> keysIterator = jsParams.keys();
|
|
49
|
+
List<CustomParam> paramsList = new ArrayList<>();
|
|
50
|
+
|
|
51
|
+
while (keysIterator.hasNext()) {
|
|
52
|
+
String key = keysIterator.next();
|
|
53
|
+
String value = jsParams.getString(key);
|
|
54
|
+
paramsList.add(new CustomParam(key, value));
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return paramsList.toArray(new CustomParam[0]);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
private HashMap<String, String> parseProperties(JSObject jsProperties) {
|
|
61
|
+
HashMap<String, String> properties = new HashMap<>();
|
|
62
|
+
if (jsProperties != null) {
|
|
63
|
+
for (Iterator<String> it = jsProperties.keys(); it.hasNext(); ) {
|
|
64
|
+
String key = it.next();
|
|
65
|
+
properties.put(key, jsProperties.getString(key));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
if (!properties.containsKey("langCode")) {
|
|
69
|
+
properties.put("langCode", "en");
|
|
70
|
+
}
|
|
71
|
+
return properties;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
@@ -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=
|
|
@@ -2,10 +2,10 @@ import { Component } from '@angular/core';
|
|
|
2
2
|
import { SpotCheckComponent } from './spotchecks/SpotCheckComponent';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class SpotCheck {
|
|
5
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
6
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
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
7
|
}
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheck, decorators: [{
|
|
9
9
|
type: Component,
|
|
10
10
|
args: [{
|
|
11
11
|
selector: 'SpotCheck',
|
|
@@ -14,4 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
14
14
|
imports: [SpotCheckComponent],
|
|
15
15
|
}]
|
|
16
16
|
}] });
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BvdGNoZWNrLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hbmd1bGFyLXVpL2xpYi9zcG90Y2hlY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUM7O0FBUXJFLE1BQU0sT0FBTyxTQUFTO3VHQUFULFNBQVM7MkZBQVQsU0FBUyxxRUFKVix3QkFBd0IsNERBRXhCLGtCQUFrQjs7MkZBRWpCLFNBQVM7a0JBTnJCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFdBQVc7b0JBQ3JCLFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNwb3RDaGVja0NvbXBvbmVudCB9IGZyb20gJy4vc3BvdGNoZWNrcy9TcG90Q2hlY2tDb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdTcG90Q2hlY2snLFxuICB0ZW1wbGF0ZTogYDxTcG90Q2hlY2tDb21wb25lbnQgLz5gLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbU3BvdENoZWNrQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU3BvdENoZWNrIHt9XG4iXX0=
|
|
@@ -48,4 +48,4 @@ export const trackEvent = async ({ screen, event }) => {
|
|
|
48
48
|
console.log(`Event Tracking Failed. ${error.message}`);
|
|
49
49
|
}
|
|
50
50
|
};
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3BvdENoZWNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FuZ3VsYXItdWkvbGliL3Nwb3RjaGVja3MvU3BvdENoZWNrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUN0RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFckQsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxFQUNuQyxVQUFVLEVBQ1YsV0FBVyxFQUNYLFdBQVcsR0FBRyxFQUFFLEVBQ2hCLFNBQVMsR0FBRyxFQUFFLEVBQ2QsZ0JBQWdCLEdBQUcsRUFBRSxHQUNLLEVBQUUsRUFBRTtJQUM5QixNQUFNLHFCQUFxQixHQUFHLHdCQUF3QixFQUFFLENBQUM7SUFDekQscUJBQXFCLENBQUMsUUFBUSxDQUFDO1FBQzdCLFVBQVU7UUFDVixXQUFXO1FBQ1gsV0FBVztRQUNYLFNBQVM7UUFDVCxnQkFBZ0I7S0FDakIsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQW9CLEVBQUUsRUFBRTtJQUN6RSxJQUFJLENBQUM7UUFDSCxNQUFNLFFBQVEsR0FBRyxNQUFNLHNCQUFzQixDQUFDLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDbkUsSUFBSSxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1FBQzVDLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxPQUFPLElBQUksUUFBUSxFQUFFLENBQUM7Z0JBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQzdDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixNQUFNLElBQUksS0FBSyxDQUFDLDRDQUE0QyxDQUFDLENBQUM7WUFDaEUsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBQUMsT0FBTyxLQUFVLEVBQUUsQ0FBQztRQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLDJCQUEyQixLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUMxRCxDQUFDO0FBQ0gsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQW1CLEVBQUUsRUFBRTtJQUNyRSxJQUFJLENBQUM7UUFDSCxNQUFNLFFBQVEsR0FBRyxNQUFNLHFCQUFxQixDQUFDLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDaEUsSUFBSSxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxPQUFPLElBQUksUUFBUSxFQUFFLENBQUM7Z0JBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQzdDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixNQUFNLElBQUksS0FBSyxDQUFDLDRDQUE0QyxDQUFDLENBQUM7WUFDaEUsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBQUMsT0FBTyxLQUFVLEVBQUUsQ0FBQztRQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLDBCQUEwQixLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUN6RCxDQUFDO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5pdGlhbGl6ZVNwb3RDaGVja3NQcm9wcywgVHJhY2tFdmVudFByb3BzLCBUcmFja1NjcmVlblByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzZW5kVHJhY2tTY3JlZW5SZXF1ZXN0LCBzZW5kVHJhY2tFdmVudFJlcXVlc3QgfSBmcm9tICcuL2FwaSc7XG5pbXBvcnQgeyBnZXRTcG90Y2hlY2tTdGF0ZVNlcnZpY2UgfSBmcm9tICcuL2hlbHBlcnMnO1xuXG5leHBvcnQgY29uc3QgaW5pdGlhbGl6ZVNwb3RDaGVja3MgPSAoe1xuICBkb21haW5OYW1lLFxuICB0YXJnZXRUb2tlbixcbiAgdXNlckRldGFpbHMgPSB7fSxcbiAgdmFyaWFibGVzID0ge30sXG4gIGN1c3RvbVByb3BlcnRpZXMgPSB7fSxcbn06IEluaXRpYWxpemVTcG90Q2hlY2tzUHJvcHMpID0+IHtcbiAgY29uc3Qgc3BvdGNoZWNrU3RhdGVTZXJ2aWNlID0gZ2V0U3BvdGNoZWNrU3RhdGVTZXJ2aWNlKCk7XG4gIHNwb3RjaGVja1N0YXRlU2VydmljZS5zZXRTdGF0ZSh7XG4gICAgZG9tYWluTmFtZSxcbiAgICB0YXJnZXRUb2tlbixcbiAgICB1c2VyRGV0YWlscyxcbiAgICB2YXJpYWJsZXMsXG4gICAgY3VzdG9tUHJvcGVydGllcyxcbiAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgdHJhY2tTY3JlZW4gPSBhc3luYyAoeyBzY3JlZW4sIG9wdGlvbnMgfTogVHJhY2tTY3JlZW5Qcm9wcykgPT4ge1xuICB0cnkge1xuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgc2VuZFRyYWNrU2NyZWVuUmVxdWVzdCh7IHNjcmVlbiwgb3B0aW9ucyB9KTtcbiAgICBpZiAocmVzcG9uc2UudmFsaWQpIHtcbiAgICAgIGNvbnNvbGUubG9nKCdTY3JlZW4gVHJhY2tpbmcgc3VjY2VlZGVkLicpO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoJ2Vycm9yJyBpbiByZXNwb25zZSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IocmVzcG9uc2UuZXJyb3IudG9TdHJpbmcoKSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1RyYWNraW5nIGZhaWxlZCB3aXRob3V0IGFuIGV4cGxpY2l0IGVycm9yLicpO1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCAoZXJyb3I6IGFueSkge1xuICAgIGNvbnNvbGUubG9nKGBTY3JlZW4gVHJhY2tpbmcgRmFpbGVkLiAke2Vycm9yLm1lc3NhZ2V9YCk7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCB0cmFja0V2ZW50ID0gYXN5bmMgKHsgc2NyZWVuLCBldmVudCB9OiBUcmFja0V2ZW50UHJvcHMpID0+IHtcbiAgdHJ5IHtcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHNlbmRUcmFja0V2ZW50UmVxdWVzdCh7IHNjcmVlbiwgZXZlbnQgfSk7XG4gICAgaWYgKHJlc3BvbnNlLnZhbGlkKSB7XG4gICAgICBjb25zb2xlLmxvZygnVHJhY2tFdmVudCBzdWNjZWVkZWQuJyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGlmICgnZXJyb3InIGluIHJlc3BvbnNlKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihyZXNwb25zZS5lcnJvci50b1N0cmluZygpKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignVHJhY2tpbmcgZmFpbGVkIHdpdGhvdXQgYW4gZXhwbGljaXQgZXJyb3IuJyk7XG4gICAgICB9XG4gICAgfVxuICB9IGNhdGNoIChlcnJvcjogYW55KSB7XG4gICAgY29uc29sZS5sb2coYEV2ZW50IFRyYWNraW5nIEZhaWxlZC4gJHtlcnJvci5tZXNzYWdlfWApO1xuICB9XG59O1xuIl19
|
|
@@ -81,8 +81,8 @@ export class WebViewComponent {
|
|
|
81
81
|
break;
|
|
82
82
|
}
|
|
83
83
|
}
|
|
84
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
85
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
84
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: WebViewComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
85
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.3", type: WebViewComponent, isStandalone: true, selector: "WebViewComponent", inputs: { url: "url", webviewType: "webviewType" }, host: { listeners: { "window:message": "onMessage($event)" } }, viewQueries: [{ propertyName: "iframe", first: true, predicate: ["iframeRef"], descendants: true }], ngImport: i0, template: `
|
|
86
86
|
<div style="overflow: hidden; height: 100%;">
|
|
87
87
|
<iframe
|
|
88
88
|
#iframeRef
|
|
@@ -94,7 +94,7 @@ export class WebViewComponent {
|
|
|
94
94
|
</div>
|
|
95
95
|
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] });
|
|
96
96
|
}
|
|
97
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: WebViewComponent, decorators: [{
|
|
98
98
|
type: Component,
|
|
99
99
|
args: [{
|
|
100
100
|
selector: 'WebViewComponent',
|
|
@@ -112,7 +112,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
112
112
|
standalone: true,
|
|
113
113
|
imports: [CommonModule],
|
|
114
114
|
}]
|
|
115
|
-
}], ctorParameters:
|
|
115
|
+
}], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { url: [{
|
|
116
116
|
type: Input
|
|
117
117
|
}], webviewType: [{
|
|
118
118
|
type: Input
|
|
@@ -127,8 +127,8 @@ export class CloseSVGComponent {
|
|
|
127
127
|
size = 32;
|
|
128
128
|
stroke = '#919191';
|
|
129
129
|
strokeWidth = 1.5;
|
|
130
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
131
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
130
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseSVGComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
131
|
+
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: `
|
|
132
132
|
<svg
|
|
133
133
|
[attr.width]="size"
|
|
134
134
|
[attr.height]="size"
|
|
@@ -146,7 +146,7 @@ export class CloseSVGComponent {
|
|
|
146
146
|
</svg>
|
|
147
147
|
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] });
|
|
148
148
|
}
|
|
149
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
149
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseSVGComponent, decorators: [{
|
|
150
150
|
type: Component,
|
|
151
151
|
args: [{
|
|
152
152
|
selector: 'close-svg',
|
|
@@ -216,8 +216,8 @@ export class CloseButtonComponent {
|
|
|
216
216
|
await closeSpotCheck();
|
|
217
217
|
handleSurveyEnd();
|
|
218
218
|
};
|
|
219
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
220
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
219
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
220
|
+
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: `
|
|
221
221
|
<div style="position: absolute; top: -36px; right: 16px; z-index: 100001; cursor: pointer; background-color: white; border-radius: 50px;" (click)="onClick()" *ngIf="isVisible && isMiniCard">
|
|
222
222
|
<close-svg [size]="size" [stroke]="stroke" [strokeWidth]="strokeWidth" style="display: flex; align-items: center; justify-content: center;"/>
|
|
223
223
|
</div>
|
|
@@ -226,7 +226,7 @@ export class CloseButtonComponent {
|
|
|
226
226
|
</div>
|
|
227
227
|
`, 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"] }] });
|
|
228
228
|
}
|
|
229
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
229
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: CloseButtonComponent, decorators: [{
|
|
230
230
|
type: Component,
|
|
231
231
|
args: [{
|
|
232
232
|
selector: 'spotcheck-close-button',
|
|
@@ -241,7 +241,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
241
241
|
standalone: true,
|
|
242
242
|
imports: [CommonModule, CloseSVGComponent],
|
|
243
243
|
}]
|
|
244
|
-
}], ctorParameters:
|
|
244
|
+
}], ctorParameters: () => [], propDecorators: { size: [{
|
|
245
245
|
type: Input
|
|
246
246
|
}], strokeWidth: [{
|
|
247
247
|
type: Input
|
|
@@ -308,11 +308,11 @@ export class SpotCheckComponent {
|
|
|
308
308
|
console.log('Error initializing widget:', JSON.stringify(error));
|
|
309
309
|
}
|
|
310
310
|
};
|
|
311
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
312
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
311
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheckComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
312
|
+
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\">\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 />\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 />\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", 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"] }, { kind: "component", type: CloseButtonComponent, selector: "spotcheck-close-button", inputs: ["size", "strokeWidth"] }] });
|
|
313
313
|
}
|
|
314
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
314
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: SpotCheckComponent, decorators: [{
|
|
315
315
|
type: Component,
|
|
316
316
|
args: [{ selector: 'SpotCheckComponent', standalone: true, imports: [CommonModule, WebViewComponent, CloseButtonComponent], template: "<div [ngStyle]=\"componentStyles.wrapperStyles\">\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 />\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 />\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" }]
|
|
317
|
-
}], ctorParameters:
|
|
318
|
-
//# 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%;\">\n      <iframe\n        #iframeRef\n        [src]=\"safeUrl\"\n        style=\"width: 100%; height: 100%; display: block;\"\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\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@Component({\n  selector: 'SpotCheckComponent',\n  templateUrl: './SpotCheckComponent.html',\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\">\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      />\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      />\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"]}
|
|
317
|
+
}], ctorParameters: () => [] });
|
|
318
|
+
//# 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%;\">\n      <iframe\n        #iframeRef\n        [src]=\"safeUrl\"\n        style=\"width: 100%; height: 100%; display: block;\"\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\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  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\">\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      />\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      />\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"]}
|