react-native-steerpath-smart-map 1.17.8 → 1.19.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 (32) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/README.md +12 -0
  3. package/android/bin/.project +34 -0
  4. package/android/bin/.settings/org.eclipse.buildship.core.prefs +13 -0
  5. package/android/bin/README.md +14 -0
  6. package/android/bin/build.gradle +59 -0
  7. package/android/bin/gradle/wrapper/gradle-wrapper.jar +0 -0
  8. package/android/bin/gradle/wrapper/gradle-wrapper.properties +6 -0
  9. package/android/bin/gradlew +172 -0
  10. package/android/bin/gradlew.bat +84 -0
  11. package/android/bin/src/main/AndroidManifest.xml +4 -0
  12. package/android/bin/src/main/java/com/steerpath/rnsmartmap/RNEventKeys.class +0 -0
  13. package/android/bin/src/main/java/com/steerpath/rnsmartmap/RNSmartGeofenceManager.class +0 -0
  14. package/android/bin/src/main/java/com/steerpath/rnsmartmap/RNSmartMapManager.class +0 -0
  15. package/android/bin/src/main/java/com/steerpath/rnsmartmap/RNSmartMapModule.class +0 -0
  16. package/android/bin/src/main/java/com/steerpath/rnsmartmap/RNSmartMapPackage.class +0 -0
  17. package/android/bin/src/main/java/com/steerpath/rnsmartmap/RNSmartMapView.class +0 -0
  18. package/android/bin/src/main/java/com/steerpath/rnsmartmap/RNSmartMapViewManager.class +0 -0
  19. package/android/bin/src/main/java/com/steerpath/rnsmartmap/Utils.class +0 -0
  20. package/android/build.gradle +1 -1
  21. package/android/src/main/java/com/steerpath/rnsmartmap/RNSmartMapModule.java +20 -0
  22. package/dist/SmartMapView.js +8 -0
  23. package/dist/SmartMapView.web.js +4 -0
  24. package/dist/SmartMapViewProps.d.ts +8 -0
  25. package/ios/RCTConvert+SmartMapView.h +1 -0
  26. package/ios/RCTConvert+SmartMapView.m +15 -0
  27. package/ios/RNSmartMapViewManager.m +14 -0
  28. package/package.json +2 -2
  29. package/react-native-steerpath-smart-map.podspec +1 -1
  30. package/src/SmartMapView.tsx +10 -0
  31. package/src/SmartMapView.web.tsx +6 -0
  32. package/src/SmartMapViewProps.ts +9 -0
package/CHANGELOG.md CHANGED
@@ -15,6 +15,17 @@ This package is built on top of Steerpath's Smart SDK, and most of releases are
15
15
  - [iOS](https://s3-eu-west-1.amazonaws.com/steerpath/ios/releases/smart-sdk-changelog/index.html)
16
16
  - [Web](https://s3-eu-west-1.amazonaws.com/steerpath-web-sdk/documentation/smart/latest/index.html)
17
17
 
18
+ # [1.19.0] - 2023-02-06
19
+
20
+ - Bump Android Smart SDK version to android-smart-1.17.1
21
+
22
+ # [1.18.0] - 2023-01-13
23
+
24
+ - New API: SmartMapView.getSmartMapCameraOptions()
25
+ - Bump Android Smart SDK version to android-smart-1.16.0
26
+ - Bump iOS Smart SDK version to 1.16.1
27
+ - Bump Web SDK version to 2.2.6
28
+
18
29
  # [1.17.7]
19
30
  - Update web sdk
20
31
 
package/README.md CHANGED
@@ -127,6 +127,18 @@ The default offline data file name is “sp_offline_data.sff”. If you want to
127
127
  <string>sp_offline_data.sff</string>
128
128
  ```
129
129
 
130
+ #### iOS trouble shooting
131
+
132
+ * For the error whe doing pod install on /example folder
133
+ ```
134
+ Error
135
+
136
+ Errno::ENOENT - No such file or directory @ realpath_rec - .../react-native-steerpath-smartmap/example/node_modules/react-native-steerpath-smart-map/node_modules
137
+ ```
138
+
139
+ Run ```cd example && yarn add react-native-steerpath-smart-map --force --ignore-scripts```. The node_modules should re-appear
140
+
141
+
130
142
  ### Web
131
143
 
132
144
  Using the offline bundle with react-native-steerpath-smartmap package on web platform is not yet supported. You can use the example of Steerpath Core SDK found in the Offline bundle ***./style*** folder to view maps.
@@ -0,0 +1,34 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <projectDescription>
3
+ <name>android</name>
4
+ <comment>Project android created by Buildship.</comment>
5
+ <projects>
6
+ </projects>
7
+ <buildSpec>
8
+ <buildCommand>
9
+ <name>org.eclipse.jdt.core.javabuilder</name>
10
+ <arguments>
11
+ </arguments>
12
+ </buildCommand>
13
+ <buildCommand>
14
+ <name>org.eclipse.buildship.core.gradleprojectbuilder</name>
15
+ <arguments>
16
+ </arguments>
17
+ </buildCommand>
18
+ </buildSpec>
19
+ <natures>
20
+ <nature>org.eclipse.jdt.core.javanature</nature>
21
+ <nature>org.eclipse.buildship.core.gradleprojectnature</nature>
22
+ </natures>
23
+ <filteredResources>
24
+ <filter>
25
+ <id>1665064202851</id>
26
+ <name></name>
27
+ <type>30</type>
28
+ <matcher>
29
+ <id>org.eclipse.core.resources.regexFilterMatcher</id>
30
+ <arguments>node_modules|\.git|__CREATED_BY_JAVA_LANGUAGE_SERVER__</arguments>
31
+ </matcher>
32
+ </filter>
33
+ </filteredResources>
34
+ </projectDescription>
@@ -0,0 +1,13 @@
1
+ arguments=
2
+ auto.sync=false
3
+ build.scans.enabled=false
4
+ connection.gradle.distribution=GRADLE_DISTRIBUTION(WRAPPER)
5
+ connection.project.dir=
6
+ eclipse.preferences.version=1
7
+ gradle.user.home=
8
+ java.home=/Library/Java/JavaVirtualMachines/adoptopenjdk-11.jdk/Contents/Home
9
+ jvm.arguments=
10
+ offline.mode=false
11
+ override.workspace.settings=true
12
+ show.console.view=true
13
+ show.executions.view=true
@@ -0,0 +1,14 @@
1
+ README
2
+ ======
3
+
4
+ If you want to publish the lib as a maven dependency, follow these steps before publishing a new version to npm:
5
+
6
+ 1. Be sure to have the Android [SDK](https://developer.android.com/studio/index.html) and [NDK](https://developer.android.com/ndk/guides/index.html) installed
7
+ 2. Be sure to have a `local.properties` file in this folder that points to the Android SDK and NDK
8
+ ```
9
+ ndk.dir=/Users/{username}/Library/Android/sdk/ndk-bundle
10
+ sdk.dir=/Users/{username}/Library/Android/sdk
11
+ ```
12
+ 3. Delete the `maven` folder
13
+ 4. Run `sudo ./gradlew installArchives`
14
+ 5. Verify that latest set of generated files is in the maven folder with the correct version number
@@ -0,0 +1,59 @@
1
+ buildscript {
2
+ ext.safeExtGet = {prop, fallback ->
3
+ rootProject.ext.has(prop) ? rootProject.ext.get(prop) : fallback
4
+ }
5
+ repositories {
6
+ mavenCentral()
7
+ google()
8
+ jcenter()
9
+ }
10
+
11
+ dependencies {
12
+ classpath("com.android.tools.build:gradle:${safeExtGet('gradlePluginVersion', '4.0.2')}")
13
+ }
14
+ }
15
+
16
+ apply plugin: 'com.android.library'
17
+ apply plugin: 'maven-publish'
18
+
19
+ def DEFAULT_COMPILE_SDK_VERSION = 30
20
+ def DEFAULT_BUILD_TOOLS_VERSION = "30.0.3"
21
+ def DEFAULT_MIN_SDK_VERSION = 21
22
+ def DEFAULT_TARGET_SDK_VERSION = 30
23
+
24
+ android {
25
+ compileSdkVersion safeExtGet('compileSdkVersion', DEFAULT_COMPILE_SDK_VERSION)
26
+ buildToolsVersion safeExtGet('buildToolsVersion', DEFAULT_BUILD_TOOLS_VERSION)
27
+
28
+ defaultConfig {
29
+ minSdkVersion safeExtGet('minSdkVersion', DEFAULT_MIN_SDK_VERSION)
30
+ targetSdkVersion safeExtGet('targetSdkVersion', DEFAULT_TARGET_SDK_VERSION)
31
+ versionCode 1
32
+ versionName "1.0"
33
+ }
34
+ lintOptions {
35
+ abortOnError false
36
+ }
37
+
38
+ compileOptions {
39
+ sourceCompatibility JavaVersion.VERSION_1_8
40
+ targetCompatibility JavaVersion.VERSION_1_8
41
+ }
42
+ }
43
+
44
+ repositories {
45
+ maven {
46
+ url "$projectDir/../node_modules/react-native/android"
47
+ }
48
+ mavenCentral()
49
+ // For Steerpath Smart Map SDK
50
+ maven { url "https://android-sdk.steerpath.net" }
51
+ google()
52
+ }
53
+
54
+ dependencies {
55
+ implementation "com.facebook.react:react-native:${safeExtGet('reactnativeVersion', '+')}"
56
+ implementation "com.steerpath:smart:android-smart-1.15.0"
57
+ implementation 'androidx.lifecycle:lifecycle-extensions:2.2.0'
58
+ implementation "androidx.lifecycle:lifecycle-viewmodel:2.2.0"
59
+ }
@@ -0,0 +1,6 @@
1
+ #Wed May 11 12:57:00 EEST 2022
2
+ distributionBase=GRADLE_USER_HOME
3
+ distributionUrl=https\://services.gradle.org/distributions/gradle-6.1.1-bin.zip
4
+ distributionPath=wrapper/dists
5
+ zipStorePath=wrapper/dists
6
+ zipStoreBase=GRADLE_USER_HOME
@@ -0,0 +1,172 @@
1
+ #!/usr/bin/env sh
2
+
3
+ ##############################################################################
4
+ ##
5
+ ## Gradle start up script for UN*X
6
+ ##
7
+ ##############################################################################
8
+
9
+ # Attempt to set APP_HOME
10
+ # Resolve links: $0 may be a link
11
+ PRG="$0"
12
+ # Need this for relative symlinks.
13
+ while [ -h "$PRG" ] ; do
14
+ ls=`ls -ld "$PRG"`
15
+ link=`expr "$ls" : '.*-> \(.*\)$'`
16
+ if expr "$link" : '/.*' > /dev/null; then
17
+ PRG="$link"
18
+ else
19
+ PRG=`dirname "$PRG"`"/$link"
20
+ fi
21
+ done
22
+ SAVED="`pwd`"
23
+ cd "`dirname \"$PRG\"`/" >/dev/null
24
+ APP_HOME="`pwd -P`"
25
+ cd "$SAVED" >/dev/null
26
+
27
+ APP_NAME="Gradle"
28
+ APP_BASE_NAME=`basename "$0"`
29
+
30
+ # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
31
+ DEFAULT_JVM_OPTS=""
32
+
33
+ # Use the maximum available, or set MAX_FD != -1 to use that value.
34
+ MAX_FD="maximum"
35
+
36
+ warn () {
37
+ echo "$*"
38
+ }
39
+
40
+ die () {
41
+ echo
42
+ echo "$*"
43
+ echo
44
+ exit 1
45
+ }
46
+
47
+ # OS specific support (must be 'true' or 'false').
48
+ cygwin=false
49
+ msys=false
50
+ darwin=false
51
+ nonstop=false
52
+ case "`uname`" in
53
+ CYGWIN* )
54
+ cygwin=true
55
+ ;;
56
+ Darwin* )
57
+ darwin=true
58
+ ;;
59
+ MINGW* )
60
+ msys=true
61
+ ;;
62
+ NONSTOP* )
63
+ nonstop=true
64
+ ;;
65
+ esac
66
+
67
+ CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
68
+
69
+ # Determine the Java command to use to start the JVM.
70
+ if [ -n "$JAVA_HOME" ] ; then
71
+ if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
72
+ # IBM's JDK on AIX uses strange locations for the executables
73
+ JAVACMD="$JAVA_HOME/jre/sh/java"
74
+ else
75
+ JAVACMD="$JAVA_HOME/bin/java"
76
+ fi
77
+ if [ ! -x "$JAVACMD" ] ; then
78
+ die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
79
+
80
+ Please set the JAVA_HOME variable in your environment to match the
81
+ location of your Java installation."
82
+ fi
83
+ else
84
+ JAVACMD="java"
85
+ which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
86
+
87
+ Please set the JAVA_HOME variable in your environment to match the
88
+ location of your Java installation."
89
+ fi
90
+
91
+ # Increase the maximum file descriptors if we can.
92
+ if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
93
+ MAX_FD_LIMIT=`ulimit -H -n`
94
+ if [ $? -eq 0 ] ; then
95
+ if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
96
+ MAX_FD="$MAX_FD_LIMIT"
97
+ fi
98
+ ulimit -n $MAX_FD
99
+ if [ $? -ne 0 ] ; then
100
+ warn "Could not set maximum file descriptor limit: $MAX_FD"
101
+ fi
102
+ else
103
+ warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
104
+ fi
105
+ fi
106
+
107
+ # For Darwin, add options to specify how the application appears in the dock
108
+ if $darwin; then
109
+ GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
110
+ fi
111
+
112
+ # For Cygwin, switch paths to Windows format before running java
113
+ if $cygwin ; then
114
+ APP_HOME=`cygpath --path --mixed "$APP_HOME"`
115
+ CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
116
+ JAVACMD=`cygpath --unix "$JAVACMD"`
117
+
118
+ # We build the pattern for arguments to be converted via cygpath
119
+ ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
120
+ SEP=""
121
+ for dir in $ROOTDIRSRAW ; do
122
+ ROOTDIRS="$ROOTDIRS$SEP$dir"
123
+ SEP="|"
124
+ done
125
+ OURCYGPATTERN="(^($ROOTDIRS))"
126
+ # Add a user-defined pattern to the cygpath arguments
127
+ if [ "$GRADLE_CYGPATTERN" != "" ] ; then
128
+ OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
129
+ fi
130
+ # Now convert the arguments - kludge to limit ourselves to /bin/sh
131
+ i=0
132
+ for arg in "$@" ; do
133
+ CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
134
+ CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
135
+
136
+ if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
137
+ eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
138
+ else
139
+ eval `echo args$i`="\"$arg\""
140
+ fi
141
+ i=$((i+1))
142
+ done
143
+ case $i in
144
+ (0) set -- ;;
145
+ (1) set -- "$args0" ;;
146
+ (2) set -- "$args0" "$args1" ;;
147
+ (3) set -- "$args0" "$args1" "$args2" ;;
148
+ (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
149
+ (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
150
+ (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
151
+ (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
152
+ (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
153
+ (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
154
+ esac
155
+ fi
156
+
157
+ # Escape application args
158
+ save () {
159
+ for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
160
+ echo " "
161
+ }
162
+ APP_ARGS=$(save "$@")
163
+
164
+ # Collect all arguments for the java command, following the shell quoting and substitution rules
165
+ eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
166
+
167
+ # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
168
+ if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
169
+ cd "$(dirname "$0")"
170
+ fi
171
+
172
+ exec "$JAVACMD" "$@"
@@ -0,0 +1,84 @@
1
+ @if "%DEBUG%" == "" @echo off
2
+ @rem ##########################################################################
3
+ @rem
4
+ @rem Gradle startup script for Windows
5
+ @rem
6
+ @rem ##########################################################################
7
+
8
+ @rem Set local scope for the variables with windows NT shell
9
+ if "%OS%"=="Windows_NT" setlocal
10
+
11
+ set DIRNAME=%~dp0
12
+ if "%DIRNAME%" == "" set DIRNAME=.
13
+ set APP_BASE_NAME=%~n0
14
+ set APP_HOME=%DIRNAME%
15
+
16
+ @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
17
+ set DEFAULT_JVM_OPTS=
18
+
19
+ @rem Find java.exe
20
+ if defined JAVA_HOME goto findJavaFromJavaHome
21
+
22
+ set JAVA_EXE=java.exe
23
+ %JAVA_EXE% -version >NUL 2>&1
24
+ if "%ERRORLEVEL%" == "0" goto init
25
+
26
+ echo.
27
+ echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
28
+ echo.
29
+ echo Please set the JAVA_HOME variable in your environment to match the
30
+ echo location of your Java installation.
31
+
32
+ goto fail
33
+
34
+ :findJavaFromJavaHome
35
+ set JAVA_HOME=%JAVA_HOME:"=%
36
+ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
37
+
38
+ if exist "%JAVA_EXE%" goto init
39
+
40
+ echo.
41
+ echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
42
+ echo.
43
+ echo Please set the JAVA_HOME variable in your environment to match the
44
+ echo location of your Java installation.
45
+
46
+ goto fail
47
+
48
+ :init
49
+ @rem Get command-line arguments, handling Windows variants
50
+
51
+ if not "%OS%" == "Windows_NT" goto win9xME_args
52
+
53
+ :win9xME_args
54
+ @rem Slurp the command line arguments.
55
+ set CMD_LINE_ARGS=
56
+ set _SKIP=2
57
+
58
+ :win9xME_args_slurp
59
+ if "x%~1" == "x" goto execute
60
+
61
+ set CMD_LINE_ARGS=%*
62
+
63
+ :execute
64
+ @rem Setup the command line
65
+
66
+ set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
67
+
68
+ @rem Execute Gradle
69
+ "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
70
+
71
+ :end
72
+ @rem End local scope for the variables with windows NT shell
73
+ if "%ERRORLEVEL%"=="0" goto mainEnd
74
+
75
+ :fail
76
+ rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
77
+ rem the _cmd.exe /c_ return code!
78
+ if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
79
+ exit /b 1
80
+
81
+ :mainEnd
82
+ if "%OS%"=="Windows_NT" endlocal
83
+
84
+ :omega
@@ -0,0 +1,4 @@
1
+ <manifest xmlns:android="http://schemas.android.com/apk/res/android"
2
+ package="com.steerpath.rnsmartmap">
3
+
4
+ </manifest>
@@ -53,7 +53,7 @@ repositories {
53
53
 
54
54
  dependencies {
55
55
  implementation "com.facebook.react:react-native:${safeExtGet('reactnativeVersion', '+')}"
56
- implementation "com.steerpath:smart:android-smart-1.15.2"
56
+ implementation "com.steerpath:smart:android-smart-1.17.1"
57
57
  implementation 'androidx.lifecycle:lifecycle-extensions:2.2.0'
58
58
  implementation "androidx.lifecycle:lifecycle-viewmodel:2.2.0"
59
59
  }
@@ -14,6 +14,7 @@ import com.facebook.react.bridge.WritableNativeMap;
14
14
  import com.facebook.react.uimanager.NativeViewHierarchyManager;
15
15
  import com.facebook.react.uimanager.UIManagerModule;
16
16
  import com.steerpath.smart.ObjectSource;
17
+ import com.steerpath.smart.SmartMapCameraOptions;
17
18
  import com.steerpath.smart.UserTask;
18
19
 
19
20
  import org.json.JSONException;
@@ -181,6 +182,25 @@ public class RNSmartMapModule extends ReactContextBaseJavaModule {
181
182
  });
182
183
  }
183
184
 
185
+ @ReactMethod
186
+ public void getSmartMapCameraOptions(final int tag, final Callback callback) {
187
+ getUiManager().addUIBlock(nvhm -> {
188
+ RNSmartMapView mapView = resolveMapView(nvhm, tag, callback);
189
+ if (mapView == null) {
190
+ return;
191
+ }
192
+
193
+ SmartMapCameraOptions opts = mapView.getMap().getSmartMapCameraOptions();
194
+ WritableMap map = new WritableNativeMap();
195
+ map.putDouble("latitude", opts.getLatitude());
196
+ map.putDouble("longitude", opts.getLongitude());
197
+ map.putDouble("bearing", opts.getBearing());
198
+ map.putDouble("pitch", opts.getTilt());
199
+ map.putDouble("zoomLevel", opts.getZoomLevel());
200
+ callback.invoke(map);
201
+ });
202
+ }
203
+
184
204
  @ReactMethod
185
205
  public void getWidgetPadding(final int tag, final Callback callback) {
186
206
  getUiManager().addUIBlock(nvhm -> {
@@ -227,6 +227,14 @@ export var SmartMapView = forwardRef(function _SmartMapViewFC(props, ref) {
227
227
  ]);
228
228
  }
229
229
  },
230
+ getSmartMapCameraOptions: function (callback) {
231
+ if (Platform.OS === 'android') {
232
+ NativeModules.RNSmartMapModule.getSmartMapCameraOptions(findNodeHandle(smartMapRef.current), callback);
233
+ }
234
+ else {
235
+ runCommand(smartMapRef.current, "getSmartMapCameraOptions", [callback]);
236
+ }
237
+ }
230
238
  }); });
231
239
  return (React.createElement(View, { style: props.style },
232
240
  React.createElement(RNSmartMapView, { ref: smartMapRef, style: { flex: 1 }, onMapLoaded: function () {
@@ -161,6 +161,10 @@ export var SmartMapView = forwardRef(function (props, ref) {
161
161
  removeAllMarkers: function () {
162
162
  runCommand(smartMapRef.current, "removeAllMarkers", []);
163
163
  },
164
+ getSmartMapCameraOptions: function () {
165
+ var smartMapCameraOptions = smartMapRef.current ? smartMapRef.current.getSmartMapCameraOptions() : null;
166
+ return smartMapCameraOptions;
167
+ },
164
168
  animateCamera: function (_a) {
165
169
  var latitude = _a.latitude, longitude = _a.longitude, zoomLevel = _a.zoomLevel, bearing = _a.bearing, pitch = _a.pitch, floorIndex = _a.floorIndex, buildingRef = _a.buildingRef;
166
170
  runCommand(smartMapRef.current, "animateCamera", [
@@ -49,6 +49,7 @@ export interface SmartMapViewMethods {
49
49
  start(): void;
50
50
  startUserTask(userTask: SmartMapUserTask): void;
51
51
  stop(): void;
52
+ getSmartMapCameraOptions(callback: (options: SmartMapCameraOptions) => void): void;
52
53
  }
53
54
  export declare enum SmartMapMode {
54
55
  MAP_ONLY = "mapOnly",
@@ -255,3 +256,10 @@ export interface SmartMapUserTask {
255
256
  type: SmartMapUserTaskType;
256
257
  payload: SmartMapNavigationUserTask | SmartMapPOISelectionUserTask;
257
258
  }
259
+ export interface SmartMapCameraOptions {
260
+ pitch: number;
261
+ bearing: number;
262
+ zoomLevel: number;
263
+ latitude: number;
264
+ longitude: number;
265
+ }
@@ -28,6 +28,7 @@
28
28
  + (NSString*)SPSmartMapBottomSheetViewState:(SPSmartMapBottomSheetViewState)state;
29
29
  + (NSString*)SPNavigationError:(SPNavigationError)error;
30
30
  + (NSString*)SPSmartMapUserTaskResponse:(SPSmartMapUserTaskResponse)response;
31
+ + (NSDictionary*)convertSmartMapCameraOptionsToJSONWith:(SPSmartMapCameraOptions*)opts;
31
32
 
32
33
  @end
33
34
 
@@ -275,5 +275,20 @@
275
275
  return guarded;
276
276
  }
277
277
 
278
+ + (NSDictionary*)convertSmartMapCameraOptionsToJSONWith:(SPSmartMapCameraOptions*)opts
279
+ {
280
+ if (opts == nil) {
281
+ return @{};
282
+ }
283
+
284
+ return @{
285
+ @"pitch": [NSNumber numberWithDouble:opts.getPitch],
286
+ @"bearing": [NSNumber numberWithDouble:opts.getBearing],
287
+ @"zoomLevel": [NSNumber numberWithDouble:opts.getZoomLevel],
288
+ @"latitude:": [NSNumber numberWithDouble:opts.getLatitude],
289
+ @"longitude": [NSNumber numberWithDouble:opts.getLongitude]
290
+ };
291
+ }
292
+
278
293
  @end
279
294
 
@@ -459,6 +459,20 @@ RCT_EXPORT_METHOD(cancelCurrentUserTask:(nonnull NSNumber*) reactTag)
459
459
  }];
460
460
  }
461
461
 
462
+ RCT_EXPORT_METHOD(getSmartMapCameraOptions:(nonnull NSNumber*) reactTag
463
+ callback:(RCTResponseSenderBlock)callback)
464
+ {
465
+ [self.bridge.uiManager addUIBlock:^(RCTUIManager *uiManager, NSDictionary<NSNumber *,UIView *> *viewRegistry) {
466
+ RNSmartMapView* view = (RNSmartMapView*)viewRegistry[reactTag];
467
+ if (!view || ![view isKindOfClass:[RNSmartMapView class]]) {
468
+ RCTLogError(@"Cannot find SPSmartMapView with tag #%@", reactTag);
469
+ return;
470
+ }
471
+ SPSmartMapCameraOptions* opts = view.getSmartMapCameraOptions;
472
+ callback(@[[RCTConvert convertSmartMapCameraOptionsToJSONWith:opts]]);
473
+ }];
474
+ }
475
+
462
476
  #pragma MAP Events
463
477
 
464
478
  -(void)spSmartMapViewOnMapLoaded:(RNSmartMapView*)smartMap;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "react-native-steerpath-smart-map",
3
3
  "title": "React Native Steerpath Smart Map",
4
- "version": "1.17.8",
4
+ "version": "1.19.0",
5
5
  "description": "Steerpath SmartMapView for React Native",
6
6
  "main": "dist/index.js",
7
7
  "scripts": {
@@ -24,7 +24,7 @@
24
24
  "licenseFilename": "LICENSE",
25
25
  "readmeFilename": "README.md",
26
26
  "dependencies": {
27
- "steerpath-smart-sdk": "^2.2.5"
27
+ "steerpath-smart-sdk": "^2.2.6"
28
28
  },
29
29
  "peerDependencies": {
30
30
  "react": "^16.5.0",
@@ -20,7 +20,7 @@ Pod::Spec.new do |s|
20
20
  s.requires_arc = true
21
21
 
22
22
  s.dependency "React"
23
- s.dependency 'SteerpathSmartSDK', '~> 1.15.14'
23
+ s.dependency 'SteerpathSmartSDK', '~> 1.16.1'
24
24
  # s.dependency "..."
25
25
  end
26
26
 
@@ -299,6 +299,16 @@ export const SmartMapView = forwardRef<SmartMapViewMethods, SmartMapViewProps>(
299
299
  ]);
300
300
  }
301
301
  },
302
+ getSmartMapCameraOptions(callback) {
303
+ if (Platform.OS === 'android') {
304
+ NativeModules.RNSmartMapModule.getSmartMapCameraOptions(
305
+ findNodeHandle(smartMapRef.current),
306
+ callback
307
+ );
308
+ } else {
309
+ runCommand(smartMapRef.current, "getSmartMapCameraOptions", [callback]);
310
+ }
311
+ }
302
312
  }));
303
313
 
304
314
  return (
@@ -12,6 +12,7 @@ import {
12
12
  SmartMapViewMethods,
13
13
  SmartMapUserTask,
14
14
  SmartMapPOISelectionUserTask,
15
+ SmartMapCameraOptions,
15
16
  } from "./SmartMapViewProps";
16
17
  import { steerpath } from "steerpath-smart-sdk";
17
18
 
@@ -24,6 +25,7 @@ const COMPONENT_ID_PREFIX = "map_container_id";
24
25
  // Implementation for the smart map reference
25
26
  interface SmartMapRef {
26
27
  removeMap: Function;
28
+ getSmartMapCameraOptions: Function;
27
29
  }
28
30
 
29
31
  function runCommand<ArgsT extends Array<unknown>>(
@@ -223,6 +225,10 @@ export const SmartMapView = forwardRef<SmartMapViewMethods, SmartMapViewProps>(
223
225
  removeAllMarkers() {
224
226
  runCommand(smartMapRef.current, "removeAllMarkers", []);
225
227
  },
228
+ getSmartMapCameraOptions(): SmartMapCameraOptions | null {
229
+ const smartMapCameraOptions: SmartMapCameraOptions | null = smartMapRef.current ? smartMapRef.current.getSmartMapCameraOptions() : null
230
+ return smartMapCameraOptions;
231
+ },
226
232
  animateCamera({
227
233
  latitude,
228
234
  longitude,
@@ -102,6 +102,7 @@ export interface SmartMapViewMethods {
102
102
  start(): void; // Android only
103
103
  startUserTask(userTask: SmartMapUserTask): void;
104
104
  stop(): void; // Android only
105
+ getSmartMapCameraOptions(callback: (options: SmartMapCameraOptions) => void): void;
105
106
  }
106
107
 
107
108
  export enum SmartMapMode {
@@ -327,3 +328,11 @@ export interface SmartMapUserTask {
327
328
  type: SmartMapUserTaskType;
328
329
  payload: SmartMapNavigationUserTask | SmartMapPOISelectionUserTask;
329
330
  }
331
+
332
+ export interface SmartMapCameraOptions {
333
+ pitch: number;
334
+ bearing: number;
335
+ zoomLevel: number;
336
+ latitude: number;
337
+ longitude: number;
338
+ }