@maplibre/maplibre-react-native 10.0.0-alpha.2 → 10.0.0-alpha.21

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 (400) hide show
  1. package/.sonarcloud.properties +1 -1
  2. package/CHANGELOG.md +141 -50
  3. package/CONTRIBUTING.md +10 -9
  4. package/README.md +1 -1
  5. package/android/build.gradle +1 -1
  6. package/android/rctmln/.settings/org.eclipse.buildship.core.prefs +2 -0
  7. package/android/{rctmgl → rctmln}/build.gradle +5 -5
  8. package/android/{rctmgl → rctmln}/src/main/AndroidManifest.xml +1 -1
  9. package/android/rctmln/src/main/java/com/maplibre/rctmln/RCTMLNPackage.java +99 -0
  10. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/AbstractEvent.java +1 -1
  11. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/AbstractEventEmitter.java +2 -2
  12. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/AbstractMapFeature.java +4 -4
  13. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/annotation/MarkerView.java +3 -3
  14. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/annotation/MarkerViewManager.java +12 -10
  15. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/annotation/RCTMGLCallout.java → rctmln/src/main/java/com/maplibre/rctmln/components/annotation/RCTMLNCallout.java} +3 -3
  16. package/android/rctmln/src/main/java/com/maplibre/rctmln/components/annotation/RCTMLNCalloutManager.java +22 -0
  17. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/annotation/RCTMGLMarkerView.java → rctmln/src/main/java/com/maplibre/rctmln/components/annotation/RCTMLNMarkerView.java} +18 -18
  18. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/annotation/RCTMGLMarkerViewManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/annotation/RCTMLNMarkerViewManager.java} +10 -10
  19. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/annotation/RCTMGLPointAnnotation.java → rctmln/src/main/java/com/maplibre/rctmln/components/annotation/RCTMLNPointAnnotation.java} +27 -26
  20. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/annotation/RCTMGLPointAnnotationManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/annotation/RCTMLNPointAnnotationManager.java} +14 -14
  21. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/camera/CameraStop.java +21 -19
  22. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/camera/CameraUpdateItem.java +12 -12
  23. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/camera/CameraUpdateQueue.java +4 -4
  24. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/camera/RCTMGLCamera.java → rctmln/src/main/java/com/maplibre/rctmln/components/camera/RCTMLNCamera.java} +50 -50
  25. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/camera/RCTMGLCameraManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/camera/RCTMLNCameraManager.java} +19 -19
  26. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/camera/constants/CameraMode.java +1 -1
  27. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/images/RCTMGLImages.java → rctmln/src/main/java/com/maplibre/rctmln/components/images/RCTMLNImages.java} +27 -27
  28. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/images/RCTMGLImagesManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/images/RCTMLNImagesManager.java} +17 -17
  29. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/location/LocationComponentManager.java +25 -16
  30. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/location/RCTMGLNativeUserLocation.java → rctmln/src/main/java/com/maplibre/rctmln/components/location/RCTMLNNativeUserLocation.java} +25 -15
  31. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/location/RCTMGLNativeUserLocationManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/location/RCTMLNNativeUserLocationManager.java} +12 -7
  32. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/mapview/LayerSourceInfo.java +10 -10
  33. package/android/rctmln/src/main/java/com/maplibre/rctmln/components/mapview/RCTMLNAndroidTextureMapView.java +16 -0
  34. package/android/rctmln/src/main/java/com/maplibre/rctmln/components/mapview/RCTMLNAndroidTextureMapViewManager.java +31 -0
  35. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/mapview/RCTMGLMapView.java → rctmln/src/main/java/com/maplibre/rctmln/components/mapview/RCTMLNMapView.java} +171 -171
  36. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/mapview/RCTMGLMapViewManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/mapview/RCTMLNMapViewManager.java} +46 -46
  37. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/mapview/helpers/CameraChangeTracker.java +1 -1
  38. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/RCTMGLStyle.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/RCTMLNStyle.java} +12 -12
  39. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/RCTMGLStyleFactory.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/RCTMLNStyleFactory.java} +434 -423
  40. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/RCTMGLStyleFunctionParser.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/RCTMLNStyleFunctionParser.java} +8 -9
  41. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/RCTMGLStyleValue.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/RCTMLNStyleValue.java} +9 -9
  42. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/styles/layers/RCTLayer.java +17 -17
  43. package/android/rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNBackgroundLayer.java +27 -0
  44. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLBackgroundLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNBackgroundLayerManager.java} +13 -13
  45. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLCircleLayer.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNCircleLayer.java} +10 -10
  46. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLCircleLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNCircleLayerManager.java} +15 -15
  47. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLFillExtrusionLayer.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNFillExtrusionLayer.java} +10 -10
  48. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLFillExtrusionLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNFillExtrusionLayerManager.java} +16 -16
  49. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLFillLayer.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNFillLayer.java} +10 -10
  50. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLFillLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNFillLayerManager.java} +16 -16
  51. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLHeatmapLayer.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNHeatmapLayer.java} +10 -10
  52. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLHeatmapLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNHeatmapLayerManager.java} +15 -15
  53. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLLineLayer.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNLineLayer.java} +10 -10
  54. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLLineLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNLineLayerManager.java} +17 -17
  55. package/android/rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNRasterLayer.java +27 -0
  56. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLRasterLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNRasterLayerManager.java} +13 -13
  57. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLSymbolLayer.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNSymbolLayer.java} +10 -10
  58. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLSymbolLayerManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/layers/RCTMLNSymbolLayerManager.java} +15 -15
  59. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/light/RCTMGLLight.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/light/RCTMLNLight.java} +16 -16
  60. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/light/RCTMGLLightManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/light/RCTMLNLightManager.java} +6 -6
  61. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLImageSource.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNImageSource.java} +7 -7
  62. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLImageSourceManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNImageSourceManager.java} +15 -15
  63. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLRasterSource.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNRasterSource.java} +6 -6
  64. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLRasterSourceManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNRasterSourceManager.java} +7 -7
  65. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLShapeSource.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNShapeSource.java} +22 -22
  66. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLShapeSourceManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNShapeSourceManager.java} +35 -35
  67. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLTileSource.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNTileSource.java} +5 -5
  68. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLTileSourceManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNTileSourceManager.java} +4 -4
  69. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLVectorSource.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNVectorSource.java} +10 -10
  70. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/sources/RCTMGLVectorSourceManager.java → rctmln/src/main/java/com/maplibre/rctmln/components/styles/sources/RCTMLNVectorSourceManager.java} +12 -12
  71. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/components/styles/sources/RCTSource.java +14 -14
  72. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/AbstractEvent.java +1 -1
  73. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/AndroidCallbackEvent.java +2 -2
  74. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/EventEmitter.java +1 -1
  75. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/FeatureClickEvent.java +8 -8
  76. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/IEvent.java +1 -1
  77. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/ImageMissingEvent.java +3 -3
  78. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/LocationEvent.java +6 -6
  79. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/MapChangeEvent.java +3 -3
  80. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/MapClickEvent.java +5 -5
  81. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/MapUserTrackingModeEvent.java +4 -4
  82. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/OfflineEvent.java +1 -1
  83. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/PointAnnotationClickEvent.java +10 -10
  84. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/PointAnnotationDragEvent.java +10 -10
  85. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/constants/EventKeys.java +1 -1
  86. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/events/constants/EventTypes.java +1 -1
  87. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/http/CustomHeadersInterceptor.java +1 -1
  88. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/location/LocationManager.java +7 -7
  89. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/location/UserLocation.java +2 -2
  90. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/location/UserLocationVerticalAlignment.java +1 -1
  91. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/location/UserTrackingMode.java +4 -4
  92. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/location/UserTrackingState.java +1 -1
  93. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/modules/RCTMGLLocationModule.java → rctmln/src/main/java/com/maplibre/rctmln/modules/RCTMLNLocationModule.java} +11 -11
  94. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/modules/RCTMGLLogging.java → rctmln/src/main/java/com/maplibre/rctmln/modules/RCTMLNLogging.java} +7 -7
  95. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/modules/RCTMGLModule.java → rctmln/src/main/java/com/maplibre/rctmln/modules/RCTMLNModule.java} +30 -30
  96. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/modules/RCTMGLOfflineModule.java → rctmln/src/main/java/com/maplibre/rctmln/modules/RCTMLNOfflineModule.java} +21 -21
  97. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl/modules/RCTMGLSnapshotModule.java → rctmln/src/main/java/com/maplibre/rctmln/modules/RCTMLNSnapshotModule.java} +14 -14
  98. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/BitmapUtils.java +1 -1
  99. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/ClusterPropertyEntry.java +2 -2
  100. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/ConvertUtils.java +1 -1
  101. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/DownloadMapImageTask.java +6 -6
  102. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/ExpressionParser.java +3 -3
  103. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/GeoJSONUtils.java +14 -14
  104. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/GeoViewport.java +4 -4
  105. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/ImageEntry.java +1 -1
  106. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/ResourceUtils.java +1 -1
  107. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/SimpleEventCallback.java +5 -5
  108. package/android/{rctmgl/src/main/java/com/mapbox/rctmgl → rctmln/src/main/java/com/maplibre/rctmln}/utils/SphericalMercator.java +2 -2
  109. package/android/rctmln/src/main/res/values/strings.xml +3 -0
  110. package/android/settings.gradle +1 -1
  111. package/docs/Annotations.md +1 -1
  112. package/docs/Callout.md +1 -1
  113. package/docs/Camera.md +4 -4
  114. package/docs/CustomHttpHeaders.md +4 -4
  115. package/docs/FillExtrusionLayer.md +19 -0
  116. package/docs/MapView.md +12 -36
  117. package/docs/MarkerView.md +1 -1
  118. package/docs/NativeUserLocation.md +2 -1
  119. package/docs/PointAnnotation.md +2 -2
  120. package/docs/RasterLayer.md +1 -1
  121. package/docs/SymbolLayer.md +7 -5
  122. package/docs/UserLocation.md +13 -4
  123. package/docs/docs.json +79 -52
  124. package/docs/offlineManager.md +246 -0
  125. package/ios/{RCTMGL → RCTMLN}/CameraMode.h +1 -1
  126. package/ios/{RCTMGL → RCTMLN}/CameraMode.m +1 -1
  127. package/ios/{RCTMGL → RCTMLN}/CameraStop.h +4 -4
  128. package/ios/{RCTMGL → RCTMLN}/CameraStop.m +7 -7
  129. package/ios/{RCTMGL → RCTMLN}/CameraUpdateItem.h +3 -3
  130. package/ios/{RCTMGL → RCTMLN}/CameraUpdateItem.m +19 -19
  131. package/ios/{RCTMGL → RCTMLN}/CameraUpdateQueue.h +3 -3
  132. package/ios/{RCTMGL → RCTMLN}/CameraUpdateQueue.m +3 -3
  133. package/ios/{RCTMGL → RCTMLN}/FilterParser.h +1 -1
  134. package/ios/{RCTMGL → RCTMLN}/FilterParser.m +3 -3
  135. package/ios/{RCTMGL/MGLCustomHeaders.h → RCTMLN/MLNCustomHeaders.h} +3 -3
  136. package/ios/{RCTMGL/MGLCustomHeaders.m → RCTMLN/MLNCustomHeaders.m} +11 -11
  137. package/ios/RCTMLN/MLNFaux3DUserLocationAnnotationView.h +23 -0
  138. package/ios/{RCTMGL/MGLFaux3DUserLocationAnnotationView.m → RCTMLN/MLNFaux3DUserLocationAnnotationView.m} +38 -38
  139. package/ios/{RCTMGL/MGLModule.h → RCTMLN/MLNModule.h} +3 -3
  140. package/ios/{RCTMGL/MGLModule.m → RCTMLN/MLNModule.m} +91 -91
  141. package/ios/{RCTMGL/MGLOfflineModule.h → RCTMLN/MLNOfflineModule.h} +4 -4
  142. package/ios/{RCTMGL/MGLOfflineModule.m → RCTMLN/MLNOfflineModule.m} +120 -99
  143. package/ios/{RCTMGL/MGLSnapshotModule.h → RCTMLN/MLNSnapshotModule.h} +3 -3
  144. package/ios/{RCTMGL/MGLSnapshotModule.m → RCTMLN/MLNSnapshotModule.m} +14 -14
  145. package/ios/{RCTMGL/MGLUserLocationHeadingArrowLayer.h → RCTMLN/MLNUserLocationHeadingArrowLayer.h} +4 -4
  146. package/ios/{RCTMGL/MGLUserLocationHeadingArrowLayer.m → RCTMLN/MLNUserLocationHeadingArrowLayer.m} +7 -7
  147. package/ios/RCTMLN/MLNUserLocationHeadingBeamLayer.h +11 -0
  148. package/ios/{RCTMGL/MGLUserLocationHeadingBeamLayer.m → RCTMLN/MLNUserLocationHeadingBeamLayer.m} +10 -10
  149. package/ios/{RCTMGL/MGLUserLocationHeadingIndicator.h → RCTMLN/MLNUserLocationHeadingIndicator.h} +3 -3
  150. package/ios/{RCTMGL → RCTMLN}/RCTConvert+Mapbox.h +1 -1
  151. package/ios/{RCTMGL → RCTMLN}/RCTConvert+Mapbox.m +1 -1
  152. package/ios/{RCTMGL/RCTMGL.h → RCTMLN/RCTMLN.h} +3 -3
  153. package/ios/{RCTMGL/RCTMGL.m → RCTMLN/RCTMLN.m} +4 -4
  154. package/ios/RCTMLN/RCTMLNBackgroundLayer.h +14 -0
  155. package/ios/RCTMLN/RCTMLNBackgroundLayer.m +27 -0
  156. package/ios/{RCTMGL/RCTMGLBackgroundLayerManager.h → RCTMLN/RCTMLNBackgroundLayerManager.h} +3 -3
  157. package/ios/{RCTMGL/RCTMGLBackgroundLayerManager.m → RCTMLN/RCTMLNBackgroundLayerManager.m} +6 -6
  158. package/ios/{RCTMGL/RCTMGLCallout.h → RCTMLN/RCTMLNCallout.h} +4 -4
  159. package/ios/{RCTMGL/RCTMGLCallout.m → RCTMLN/RCTMLNCallout.m} +6 -6
  160. package/ios/{RCTMGL/RCTMGLCalloutManager.h → RCTMLN/RCTMLNCalloutManager.h} +3 -3
  161. package/ios/RCTMLN/RCTMLNCalloutManager.m +21 -0
  162. package/ios/{RCTMGL/RCTMGLCamera.h → RCTMLN/RCTMLNCamera.h} +6 -6
  163. package/ios/{RCTMGL/RCTMGLCamera.m → RCTMLN/RCTMLNCamera.m} +30 -30
  164. package/ios/{RCTMGL/RCTMGLCameraManager.h → RCTMLN/RCTMLNCameraManager.h} +3 -3
  165. package/ios/{RCTMGL/RCTMGLCameraManager.m → RCTMLN/RCTMLNCameraManager.m} +7 -7
  166. package/ios/RCTMLN/RCTMLNCircleLayer.h +13 -0
  167. package/ios/{RCTMGL/RCTMGLCircleLayer.m → RCTMLN/RCTMLNCircleLayer.m} +10 -10
  168. package/ios/{RCTMGL/RCTMGLCircleLayerManager.h → RCTMLN/RCTMLNCircleLayerManager.h} +3 -3
  169. package/ios/{RCTMGL/RCTMGLCircleLayerManager.m → RCTMLN/RCTMLNCircleLayerManager.m} +6 -6
  170. package/ios/{RCTMGL/RCTMGLEvent.h → RCTMLN/RCTMLNEvent.h} +6 -6
  171. package/ios/{RCTMGL/RCTMGLEvent.m → RCTMLN/RCTMLNEvent.m} +8 -8
  172. package/ios/{RCTMGL/RCTMGLEventProtocol.h → RCTMLN/RCTMLNEventProtocol.h} +3 -3
  173. package/ios/{RCTMGL/RCTMGLEventTypes.h → RCTMLN/RCTMLNEventTypes.h} +3 -3
  174. package/ios/{RCTMGL/RCTMGLEventTypes.m → RCTMLN/RCTMLNEventTypes.m} +4 -4
  175. package/ios/RCTMLN/RCTMLNFillExtrusionLayer.h +14 -0
  176. package/ios/{RCTMGL/RCTMGLFillExtrusionLayer.m → RCTMLN/RCTMLNFillExtrusionLayer.m} +10 -10
  177. package/ios/{RCTMGL/RCTMGLFillExtrusionLayerManager.h → RCTMLN/RCTMLNFillExtrusionLayerManager.h} +3 -3
  178. package/ios/{RCTMGL/RCTMGLFillExtrusionLayerManager.m → RCTMLN/RCTMLNFillExtrusionLayerManager.m} +6 -6
  179. package/ios/RCTMLN/RCTMLNFillLayer.h +14 -0
  180. package/ios/{RCTMGL/RCTMGLFillLayer.m → RCTMLN/RCTMLNFillLayer.m} +10 -10
  181. package/ios/{RCTMGL/RCTMGLFillLayerManager.h → RCTMLN/RCTMLNFillLayerManager.h} +3 -3
  182. package/ios/{RCTMGL/RCTMGLFillLayerManager.m → RCTMLN/RCTMLNFillLayerManager.m} +6 -6
  183. package/ios/RCTMLN/RCTMLNHeatmapLayer.h +12 -0
  184. package/ios/RCTMLN/RCTMLNHeatmapLayer.m +30 -0
  185. package/ios/RCTMLN/RCTMLNHeatmapLayerManager.h +12 -0
  186. package/ios/{RCTMGL/RCTMGLHeatmapLayerManager.m → RCTMLN/RCTMLNHeatmapLayerManager.m} +6 -6
  187. package/ios/{RCTMGL/RCTMGLImageQueue.h → RCTMLN/RCTMLNImageQueue.h} +3 -3
  188. package/ios/{RCTMGL/RCTMGLImageQueue.m → RCTMLN/RCTMLNImageQueue.m} +10 -10
  189. package/ios/{RCTMGL/RCTMGLImageQueueOperation.h → RCTMLN/RCTMLNImageQueueOperation.h} +3 -3
  190. package/ios/{RCTMGL/RCTMGLImageQueueOperation.m → RCTMLN/RCTMLNImageQueueOperation.m} +12 -12
  191. package/ios/{RCTMGL/RCTMGLImageSource.h → RCTMLN/RCTMLNImageSource.h} +4 -4
  192. package/ios/{RCTMGL/RCTMGLImageSource.m → RCTMLN/RCTMLNImageSource.m} +11 -11
  193. package/ios/{RCTMGL/RCTMGLImageSourceManager.h → RCTMLN/RCTMLNImageSourceManager.h} +3 -3
  194. package/ios/{RCTMGL/RCTMGLImageSourceManager.m → RCTMLN/RCTMLNImageSourceManager.m} +6 -6
  195. package/ios/{RCTMGL/RCTMGLImages.h → RCTMLN/RCTMLNImages.h} +4 -4
  196. package/ios/{RCTMGL/RCTMGLImages.m → RCTMLN/RCTMLNImages.m} +10 -10
  197. package/ios/RCTMLN/RCTMLNImagesManager.h +5 -0
  198. package/ios/{RCTMGL/RCTMGLImagesManager.m → RCTMLN/RCTMLNImagesManager.m} +4 -4
  199. package/ios/{RCTMGL/RCTMGLLayer.h → RCTMLN/RCTMLNLayer.h} +11 -11
  200. package/ios/{RCTMGL/RCTMGLLayer.m → RCTMLN/RCTMLNLayer.m} +17 -17
  201. package/ios/{RCTMGL/RCTMGLLight.h → RCTMLN/RCTMLNLight.h} +5 -5
  202. package/ios/{RCTMGL/RCTMGLLight.m → RCTMLN/RCTMLNLight.m} +9 -9
  203. package/ios/{RCTMGL/RCTMGLLightManager.h → RCTMLN/RCTMLNLightManager.h} +3 -3
  204. package/ios/{RCTMGL/RCTMGLLightManager.m → RCTMLN/RCTMLNLightManager.m} +6 -6
  205. package/ios/RCTMLN/RCTMLNLineLayer.h +14 -0
  206. package/ios/{RCTMGL/RCTMGLLineLayer.m → RCTMLN/RCTMLNLineLayer.m} +10 -10
  207. package/ios/{RCTMGL/RCTMGLLineLayerManager.h → RCTMLN/RCTMLNLineLayerManager.h} +3 -3
  208. package/ios/{RCTMGL/RCTMGLLineLayerManager.m → RCTMLN/RCTMLNLineLayerManager.m} +6 -6
  209. package/ios/{RCTMGL/RCTMGLLocation.h → RCTMLN/RCTMLNLocation.h} +3 -3
  210. package/ios/{RCTMGL/RCTMGLLocation.m → RCTMLN/RCTMLNLocation.m} +4 -4
  211. package/ios/RCTMLN/RCTMLNLocationManager.h +30 -0
  212. package/ios/{RCTMGL/RCTMGLLocationManager.m → RCTMLN/RCTMLNLocationManager.m} +16 -16
  213. package/ios/RCTMLN/RCTMLNLocationManagerDelegate.h +20 -0
  214. package/ios/{RCTMGL/RCTMGLLocationModule.h → RCTMLN/RCTMLNLocationModule.h} +3 -3
  215. package/ios/{RCTMGL/RCTMGLLocationModule.m → RCTMLN/RCTMLNLocationModule.m} +13 -13
  216. package/ios/RCTMLN/RCTMLNLogging.h +18 -0
  217. package/ios/{RCTMGL/RCTMGLLogging.m → RCTMLN/RCTMLNLogging.m} +29 -29
  218. package/ios/{RCTMGL/RCTMGLMapTouchEvent.h → RCTMLN/RCTMLNMapTouchEvent.h} +10 -10
  219. package/ios/{RCTMGL/RCTMGLMapTouchEvent.m → RCTMLN/RCTMLNMapTouchEvent.m} +18 -18
  220. package/ios/{RCTMGL/RCTMGLMapView.h → RCTMLN/RCTMLNMapView.h} +30 -30
  221. package/ios/{RCTMGL/RCTMGLMapView.m → RCTMLN/RCTMLNMapView.m} +82 -82
  222. package/ios/{RCTMGL/RCTMGLMapViewManager.h → RCTMLN/RCTMLNMapViewManager.h} +4 -4
  223. package/ios/{RCTMGL/RCTMGLMapViewManager.m → RCTMLN/RCTMLNMapViewManager.m} +117 -117
  224. package/ios/{RCTMGL/RCTMGLNativeUserLocation.h → RCTMLN/RCTMLNNativeUserLocation.h} +5 -5
  225. package/ios/{RCTMGL/RCTMGLNativeUserLocation.m → RCTMLN/RCTMLNNativeUserLocation.m} +10 -10
  226. package/ios/RCTMLN/RCTMLNNativeUserLocationManager.h +5 -0
  227. package/ios/RCTMLN/RCTMLNNativeUserLocationManager.m +25 -0
  228. package/ios/{RCTMGL/RCTMGLPointAnnotation.h → RCTMLN/RCTMLNPointAnnotation.h} +8 -8
  229. package/ios/{RCTMGL/RCTMGLPointAnnotation.m → RCTMLN/RCTMLNPointAnnotation.m} +21 -21
  230. package/ios/{RCTMGL/RCTMGLPointAnnotationManager.h → RCTMLN/RCTMLNPointAnnotationManager.h} +3 -3
  231. package/ios/{RCTMGL/RCTMGLPointAnnotationManager.m → RCTMLN/RCTMLNPointAnnotationManager.m} +6 -6
  232. package/ios/RCTMLN/RCTMLNRasterLayer.h +14 -0
  233. package/ios/RCTMLN/RCTMLNRasterLayer.m +30 -0
  234. package/ios/{RCTMGL/RCTMGLRasterLayerManager.h → RCTMLN/RCTMLNRasterLayerManager.h} +3 -3
  235. package/ios/{RCTMGL/RCTMGLRasterLayerManager.m → RCTMLN/RCTMLNRasterLayerManager.m} +6 -6
  236. package/ios/{RCTMGL/RCTMGLRasterSource.h → RCTMLN/RCTMLNRasterSource.h} +5 -5
  237. package/ios/{RCTMGL/RCTMGLRasterSource.m → RCTMLN/RCTMLNRasterSource.m} +11 -11
  238. package/ios/{RCTMGL/RCTMGLRasterSourceManager.h → RCTMLN/RCTMLNRasterSourceManager.h} +3 -3
  239. package/ios/{RCTMGL/RCTMGLRasterSourceManager.m → RCTMLN/RCTMLNRasterSourceManager.m} +6 -6
  240. package/ios/{RCTMGL/RCTMGLShapeSource.h → RCTMLN/RCTMLNShapeSource.h} +10 -10
  241. package/ios/{RCTMGL/RCTMGLShapeSource.m → RCTMLN/RCTMLNShapeSource.m} +50 -50
  242. package/ios/{RCTMGL/RCTMGLShapeSourceManager.h → RCTMLN/RCTMLNShapeSourceManager.h} +3 -3
  243. package/ios/{RCTMGL/RCTMGLShapeSourceManager.m → RCTMLN/RCTMLNShapeSourceManager.m} +25 -25
  244. package/ios/{RCTMGL/RCTMGLSource.h → RCTMLN/RCTMLNSource.h} +8 -8
  245. package/ios/{RCTMGL/RCTMGLSource.m → RCTMLN/RCTMLNSource.m} +15 -15
  246. package/ios/RCTMLN/RCTMLNStyle.h +223 -0
  247. package/ios/{RCTMGL/RCTMGLStyle.m → RCTMLN/RCTMLNStyle.m} +352 -345
  248. package/ios/{RCTMGL/RCTMGLStyleValue.h → RCTMLN/RCTMLNStyleValue.h} +7 -7
  249. package/ios/{RCTMGL/RCTMGLStyleValue.m → RCTMLN/RCTMLNStyleValue.m} +24 -24
  250. package/ios/{RCTMGL/RCTMGLSymbolLayer.h → RCTMLN/RCTMLNSymbolLayer.h} +4 -4
  251. package/ios/{RCTMGL/RCTMGLSymbolLayer.m → RCTMLN/RCTMLNSymbolLayer.m} +12 -12
  252. package/ios/{RCTMGL/RCTMGLSymbolLayerManager.h → RCTMLN/RCTMLNSymbolLayerManager.h} +3 -3
  253. package/ios/{RCTMGL/RCTMGLSymbolLayerManager.m → RCTMLN/RCTMLNSymbolLayerManager.m} +6 -6
  254. package/ios/{RCTMGL/RCTMGLTileSource.h → RCTMLN/RCTMLNTileSource.h} +6 -6
  255. package/ios/RCTMLN/RCTMLNTileSource.m +31 -0
  256. package/ios/RCTMLN/RCTMLNUserLocation.h +15 -0
  257. package/ios/{RCTMGL/RCTMGLUserLocation.m → RCTMLN/RCTMLNUserLocation.m} +8 -8
  258. package/ios/{RCTMGL/RCTMGLUtils.h → RCTMLN/RCTMLNUtils.h} +7 -7
  259. package/ios/{RCTMGL/RCTMGLUtils.m → RCTMLN/RCTMLNUtils.m} +20 -20
  260. package/ios/{RCTMGL/RCTMGLVectorLayer.h → RCTMLN/RCTMLNVectorLayer.h} +4 -4
  261. package/ios/{RCTMGL/RCTMGLVectorLayer.m → RCTMLN/RCTMLNVectorLayer.m} +7 -7
  262. package/ios/{RCTMGL/RCTMGLVectorSource.h → RCTMLN/RCTMLNVectorSource.h} +6 -6
  263. package/ios/{RCTMGL/RCTMGLVectorSource.m → RCTMLN/RCTMLNVectorSource.m} +9 -9
  264. package/ios/{RCTMGL/RCTMGLVectorSourceManager.h → RCTMLN/RCTMLNVectorSourceManager.h} +3 -3
  265. package/ios/{RCTMGL/RCTMGLVectorSourceManager.m → RCTMLN/RCTMLNVectorSourceManager.m} +11 -11
  266. package/ios/{RCTMGL → RCTMLN}/RNMBImageUtils.h +1 -1
  267. package/ios/{RCTMGL → RCTMLN}/RNMBImageUtils.m +2 -2
  268. package/ios/{RCTMGL → RCTMLN}/ViewManager.h +3 -3
  269. package/ios/{RCTMGL → RCTMLN}/ViewManager.m +4 -4
  270. package/ios/RCTMLN.xcodeproj/project.pbxproj +775 -0
  271. package/ios/install.md +6 -7
  272. package/javascript/{MGLModule.ts → MLNModule.ts} +4 -4
  273. package/javascript/Maplibre.ts +44 -39
  274. package/javascript/components/BackgroundLayer.tsx +34 -27
  275. package/javascript/components/Callout.tsx +59 -59
  276. package/javascript/components/Camera.tsx +436 -493
  277. package/javascript/components/CircleLayer.tsx +35 -28
  278. package/javascript/components/FillExtrusionLayer.tsx +29 -29
  279. package/javascript/components/FillLayer.tsx +28 -25
  280. package/javascript/components/HeadingIndicator.tsx +8 -8
  281. package/javascript/components/HeatmapLayer.tsx +28 -26
  282. package/javascript/components/ImageSource.tsx +31 -38
  283. package/javascript/components/Images.tsx +54 -54
  284. package/javascript/components/Light.tsx +25 -52
  285. package/javascript/components/LineLayer.tsx +29 -26
  286. package/javascript/components/MapView.tsx +635 -580
  287. package/javascript/components/MarkerView.tsx +34 -49
  288. package/javascript/components/NativeUserLocation.tsx +12 -10
  289. package/javascript/components/PointAnnotation.tsx +121 -97
  290. package/javascript/components/RasterLayer.tsx +28 -25
  291. package/javascript/components/RasterSource.tsx +45 -48
  292. package/javascript/components/ShapeSource.tsx +300 -250
  293. package/javascript/components/Style.tsx +69 -59
  294. package/javascript/components/SymbolLayer.tsx +41 -35
  295. package/javascript/components/UserLocation.tsx +189 -168
  296. package/javascript/components/VectorSource.tsx +139 -128
  297. package/javascript/components/annotations/Annotation.tsx +119 -89
  298. package/javascript/hooks/useAbstractLayer.ts +127 -0
  299. package/javascript/hooks/useAbstractSource.ts +34 -0
  300. package/javascript/hooks/useNativeBridge.ts +125 -0
  301. package/javascript/hooks/useNativeRef.ts +13 -0
  302. package/javascript/hooks/useOnce.ts +12 -0
  303. package/javascript/index.ts +2 -2
  304. package/javascript/modules/location/locationManager.ts +6 -6
  305. package/javascript/modules/offline/OfflineCreatePackOptions.ts +5 -5
  306. package/javascript/modules/offline/OfflinePack.ts +5 -5
  307. package/javascript/modules/offline/offlineManager.ts +13 -14
  308. package/javascript/modules/snapshot/SnapshotOptions.ts +5 -5
  309. package/javascript/modules/snapshot/snapshotManager.ts +3 -3
  310. package/javascript/requestAndroidLocationPermissions.ts +3 -3
  311. package/javascript/types/OnPressEvent.ts +1 -1
  312. package/javascript/types/index.ts +6 -2
  313. package/javascript/utils/BridgeValue.ts +20 -20
  314. package/javascript/utils/Logger.ts +17 -17
  315. package/javascript/utils/MaplibreStyles.d.ts +399 -393
  316. package/javascript/utils/StyleValue.ts +12 -12
  317. package/javascript/utils/animated/AbstractAnimatedCoordinates.ts +6 -6
  318. package/javascript/utils/animated/Animated.ts +38 -16
  319. package/javascript/utils/animated/AnimatedCoordinatesArray.ts +7 -11
  320. package/javascript/utils/animated/AnimatedExtractCoordinateFromArray.ts +3 -3
  321. package/javascript/utils/animated/AnimatedPoint.ts +7 -7
  322. package/javascript/utils/animated/AnimatedRouteCoordinatesArray.ts +16 -20
  323. package/javascript/utils/animated/AnimatedShape.ts +16 -16
  324. package/javascript/utils/deprecation.ts +6 -3
  325. package/javascript/utils/filterUtils.ts +1 -1
  326. package/javascript/utils/geoUtils.ts +8 -8
  327. package/javascript/utils/index.ts +14 -14
  328. package/javascript/utils/styleMap.ts +19 -18
  329. package/maplibre-react-native.podspec +8 -8
  330. package/package.json +58 -39
  331. package/plugin/build/withMapLibre.d.ts +2 -2
  332. package/plugin/build/withMapLibre.js +33 -34
  333. package/react-native.config.js +1 -1
  334. package/scripts/autogenHelpers/globals.js +11 -10
  335. package/scripts/autogenerate.js +24 -17
  336. package/scripts/templates/{RCTMGLStyle.h.ejs → RCTMLNStyle.h.ejs} +8 -8
  337. package/scripts/templates/{RCTMGLStyle.m.ejs → RCTMLNStyle.m.ejs} +10 -10
  338. package/scripts/templates/{RCTMGLStyleFactory.java.ejs → RCTMLNStyleFactory.java.ejs} +24 -24
  339. package/setup-jest.js +4 -10
  340. package/style-spec/v8.json +1248 -655
  341. package/tsconfig.json +0 -1
  342. package/.eslintignore +0 -3
  343. package/.eslintrc.js +0 -166
  344. package/.prettierrc.js +0 -7
  345. package/.yarn/plugins/@yarnpkg/plugin-typescript.cjs +0 -9
  346. package/.yarn/sdks/eslint/bin/eslint.js +0 -20
  347. package/.yarn/sdks/eslint/lib/api.js +0 -20
  348. package/.yarn/sdks/eslint/package.json +0 -6
  349. package/.yarn/sdks/integrations.yml +0 -5
  350. package/.yarn/sdks/prettier/index.js +0 -20
  351. package/.yarn/sdks/prettier/package.json +0 -6
  352. package/.yarn/sdks/typescript/bin/tsc +0 -20
  353. package/.yarn/sdks/typescript/bin/tsserver +0 -20
  354. package/.yarn/sdks/typescript/lib/tsc.js +0 -20
  355. package/.yarn/sdks/typescript/lib/tsserver.js +0 -225
  356. package/.yarn/sdks/typescript/lib/tsserverlibrary.js +0 -225
  357. package/.yarn/sdks/typescript/lib/typescript.js +0 -20
  358. package/.yarn/sdks/typescript/package.json +0 -6
  359. package/android/rctmgl/.settings/org.eclipse.buildship.core.prefs +0 -2
  360. package/android/rctmgl/src/main/java/com/mapbox/rctmgl/RCTMGLPackage.java +0 -99
  361. package/android/rctmgl/src/main/java/com/mapbox/rctmgl/components/annotation/RCTMGLCalloutManager.java +0 -22
  362. package/android/rctmgl/src/main/java/com/mapbox/rctmgl/components/mapview/RCTMGLAndroidTextureMapView.java +0 -16
  363. package/android/rctmgl/src/main/java/com/mapbox/rctmgl/components/mapview/RCTMGLAndroidTextureMapViewManager.java +0 -31
  364. package/android/rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLBackgroundLayer.java +0 -27
  365. package/android/rctmgl/src/main/java/com/mapbox/rctmgl/components/styles/layers/RCTMGLRasterLayer.java +0 -27
  366. package/android/rctmgl/src/main/res/values/strings.xml +0 -3
  367. package/ios/RCTMGL/MGLFaux3DUserLocationAnnotationView.h +0 -23
  368. package/ios/RCTMGL/MGLUserLocationHeadingBeamLayer.h +0 -11
  369. package/ios/RCTMGL/RCTMGLBackgroundLayer.h +0 -14
  370. package/ios/RCTMGL/RCTMGLBackgroundLayer.m +0 -27
  371. package/ios/RCTMGL/RCTMGLCalloutManager.m +0 -21
  372. package/ios/RCTMGL/RCTMGLCircleLayer.h +0 -13
  373. package/ios/RCTMGL/RCTMGLFillExtrusionLayer.h +0 -14
  374. package/ios/RCTMGL/RCTMGLFillLayer.h +0 -14
  375. package/ios/RCTMGL/RCTMGLHeatmapLayer.h +0 -12
  376. package/ios/RCTMGL/RCTMGLHeatmapLayer.m +0 -30
  377. package/ios/RCTMGL/RCTMGLHeatmapLayerManager.h +0 -12
  378. package/ios/RCTMGL/RCTMGLImagesManager.h +0 -5
  379. package/ios/RCTMGL/RCTMGLLineLayer.h +0 -14
  380. package/ios/RCTMGL/RCTMGLLocationManager.h +0 -30
  381. package/ios/RCTMGL/RCTMGLLocationManagerDelegate.h +0 -20
  382. package/ios/RCTMGL/RCTMGLLogging.h +0 -18
  383. package/ios/RCTMGL/RCTMGLNativeUserLocationManager.h +0 -5
  384. package/ios/RCTMGL/RCTMGLNativeUserLocationManager.m +0 -25
  385. package/ios/RCTMGL/RCTMGLRasterLayer.h +0 -14
  386. package/ios/RCTMGL/RCTMGLRasterLayer.m +0 -30
  387. package/ios/RCTMGL/RCTMGLStyle.h +0 -222
  388. package/ios/RCTMGL/RCTMGLTileSource.m +0 -31
  389. package/ios/RCTMGL/RCTMGLUserLocation.h +0 -15
  390. package/ios/RCTMGL.xcodeproj/project.pbxproj +0 -775
  391. package/javascript/@types/assets.d.ts +0 -4
  392. package/javascript/components/AbstractLayer.tsx +0 -107
  393. package/javascript/components/AbstractSource.tsx +0 -27
  394. package/javascript/components/NativeBridgeComponent.tsx +0 -117
  395. /package/android/{rctmgl → rctmln}/proguard-rules.pro +0 -0
  396. /package/android/{rctmgl → rctmln}/src/main/res/drawable/empty.xml +0 -0
  397. /package/android/{rctmgl → rctmln}/src/main/res/drawable/empty_drawable.png +0 -0
  398. /package/android/{rctmgl → rctmln}/src/main/res/drawable-xxhdpi/red_marker.png +0 -0
  399. /package/android/{rctmgl → rctmln}/src/main/res/layout/annotation.xml +0 -0
  400. /package/ios/{RCTMGL → RCTMLN}/index.d.ts +0 -0
@@ -1,28 +1,32 @@
1
- import {toJSONString, existenceChange} from '../utils';
2
- import * as geoUtils from '../utils/geoUtils';
3
- import {MaplibreGLEvent} from '../types';
4
-
5
- import {
6
- NativeMethods,
7
- NativeModules,
8
- requireNativeComponent,
9
- ViewProps,
10
- } from 'react-native';
11
- import React, {Component, MutableRefObject, ReactElement} from 'react';
12
-
13
- const MapLibreGL = NativeModules.MGLModule;
14
-
15
- export const NATIVE_MODULE_NAME = 'RCTMGLCamera';
1
+ import React, {
2
+ memo,
3
+ RefObject,
4
+ useEffect,
5
+ useImperativeHandle,
6
+ useMemo,
7
+ useRef,
8
+ useCallback,
9
+ } from "react";
10
+ import { NativeModules, requireNativeComponent, ViewProps } from "react-native";
11
+
12
+ import { useNativeRef } from "../hooks/useNativeRef";
13
+ import { MaplibreGLEvent } from "../types";
14
+ import { toJSONString } from "../utils";
15
+ import * as geoUtils from "../utils/geoUtils";
16
+
17
+ const MapLibreGL = NativeModules.MLNModule;
18
+
19
+ export const NATIVE_MODULE_NAME = "RCTMLNCamera";
16
20
 
17
21
  export enum UserTrackingMode {
18
- Follow = 'normal',
19
- FollowWithHeading = 'compass',
20
- FollowWithCourse = 'course',
22
+ Follow = "normal",
23
+ FollowWithHeading = "compass",
24
+ FollowWithCourse = "course",
21
25
  }
22
26
 
23
27
  export type UserTrackingModeChangeCallback = (
24
28
  event: MaplibreGLEvent<
25
- 'usertrackingmodechange',
29
+ "usertrackingmodechange",
26
30
  {
27
31
  followUserLocation: boolean;
28
32
  followUserMode: UserTrackingMode | null;
@@ -47,6 +51,15 @@ export interface CameraRef {
47
51
  animationDuration?: number,
48
52
  ) => void;
49
53
  zoomTo: (zoomLevel: number, animationDuration?: number) => void;
54
+
55
+ _defaultCamera: RefObject<NativeCameraStop | null>;
56
+ _getMaxBounds: () => string | null;
57
+ _getNativeCameraMode: (config: CameraStop) => NativeAnimationMode;
58
+ _createStopConfig: (
59
+ config: CameraStop,
60
+ ignoreFollowUserLocation?: boolean,
61
+ ) => NativeCameraStop | null;
62
+ _createDefaultCamera: () => NativeCameraStop | null;
50
63
  }
51
64
 
52
65
  export interface CameraPadding {
@@ -83,8 +96,8 @@ interface CameraBoundsWithPadding
83
96
  extends CameraBounds,
84
97
  Partial<CameraPadding> {}
85
98
 
86
- type NativeAnimationMode = 'flight' | 'ease' | 'linear' | 'none' | 'move';
87
- export type CameraAnimationMode = 'flyTo' | 'easeTo' | 'linearTo' | 'moveTo';
99
+ type NativeAnimationMode = "flight" | "ease" | "linear" | "none" | "move";
100
+ export type CameraAnimationMode = "flyTo" | "easeTo" | "linearTo" | "moveTo";
88
101
 
89
102
  export interface NativeCameraStop extends Required<CameraPadding> {
90
103
  mode: NativeAnimationMode;
@@ -120,7 +133,7 @@ export type CameraStops = {
120
133
  stops: CameraStop[];
121
134
  };
122
135
 
123
- interface CameraProps extends Omit<ViewProps, 'style'>, CameraStop {
136
+ interface CameraProps extends Omit<ViewProps, "style">, CameraStop {
124
137
  /**
125
138
  * If false, the camera will not send any props to the native module. Intended to be used to prevent unnecessary tile fetching and improve performance when the map is not visible. Defaults to true.
126
139
  */
@@ -180,501 +193,431 @@ interface CameraProps extends Omit<ViewProps, 'style'>, CameraStop {
180
193
  onUserTrackingModeChange?: UserTrackingModeChangeCallback;
181
194
  }
182
195
 
183
- interface NativeProps extends Omit<CameraProps, 'maxBounds'> {
196
+ interface NativeProps extends Omit<CameraProps, "maxBounds"> {
184
197
  maxBounds: string | null;
185
198
  stop: NativeCameraStop | null;
186
199
  defaultStop: NativeCameraStop | null;
187
200
  }
188
201
 
189
- class Camera extends React.Component<CameraProps> {
190
- static defaultProps = {
191
- allowUpdates: true,
192
- animationMode: 'easeTo',
193
- animationDuration: 2000,
194
- };
195
-
196
- defaultCamera: NativeCameraStop | null = null;
197
- cameraRef: MutableRefObject<
198
- (Component<NativeProps> & Readonly<NativeMethods>) | null
199
- >;
200
-
201
- constructor(props: CameraProps) {
202
- super(props);
203
- this.cameraRef = React.createRef<
204
- Component<NativeProps> & Readonly<NativeMethods>
205
- >();
206
- }
207
-
208
- UNSAFE_componentWillReceiveProps(nextProps: CameraProps): void {
209
- this._handleCameraChange(this.props, nextProps);
210
- }
211
-
212
- shouldComponentUpdate(): boolean {
213
- return false;
214
- }
215
-
216
- _handleCameraChange(
217
- currentCamera: CameraProps,
218
- nextCamera: CameraProps,
219
- ): void {
220
- const c = currentCamera;
221
- const n = nextCamera;
222
-
223
- if (!n.allowUpdates) {
224
- return;
225
- }
226
-
227
- const hasCameraChanged = this._hasCameraChanged(c, n);
228
- if (!hasCameraChanged) {
229
- return;
230
- }
231
-
232
- if (c.followUserLocation && !n.followUserLocation) {
233
- this.cameraRef.current?.setNativeProps({followUserLocation: false});
234
- return;
235
- }
236
- if (!c.followUserLocation && n.followUserLocation) {
237
- this.cameraRef.current?.setNativeProps({followUserLocation: true});
238
- }
239
-
240
- if (n.followUserLocation) {
241
- this.cameraRef.current?.setNativeProps({
242
- followUserMode: n.followUserMode,
243
- followPitch: n.followPitch || n.pitch,
244
- followHeading: n.followHeading || n.heading,
245
- followZoomLevel: n.followZoomLevel || n.zoomLevel,
246
- });
247
- return;
248
- }
249
-
250
- if (n.maxBounds) {
251
- this.cameraRef.current?.setNativeProps({
252
- maxBounds: this._getMaxBounds(),
253
- });
254
- }
255
- if (n.minZoomLevel) {
256
- this.cameraRef.current?.setNativeProps({
257
- minZoomLevel: this.props.minZoomLevel,
258
- });
259
- }
260
- if (n.maxZoomLevel) {
261
- this.cameraRef.current?.setNativeProps({
262
- maxZoomLevel: this.props.maxZoomLevel,
263
- });
264
- }
265
-
266
- const cameraConfig: CameraStop = {
267
- bounds: undefined,
268
- centerCoordinate: undefined,
269
- padding: n.padding,
270
- zoomLevel: n.zoomLevel,
271
- pitch: n.pitch,
272
- heading: n.heading,
273
- animationMode: n.animationMode,
274
- animationDuration: n.animationDuration,
275
- };
276
-
277
- const boundsChanged = this._hasBoundsChanged(c.bounds, n.bounds);
278
- const centerCoordinateChanged = this._hasCenterCoordinateChanged(
279
- c.centerCoordinate,
280
- n.centerCoordinate,
281
- );
282
- const paddingChanged = this._hasPaddingChanged(c.padding, n.padding);
283
- const zoomChanged = this._hasNumberChanged(c.zoomLevel, n.zoomLevel);
284
- const pitchChanged = this._hasNumberChanged(c.pitch, n.pitch);
285
- const headingChanged = this._hasNumberChanged(c.heading, n.heading);
286
-
287
- let shouldUpdate = false;
288
-
289
- if (n.bounds && boundsChanged) {
290
- cameraConfig.bounds = n.bounds;
291
- shouldUpdate = true;
292
- } else if (n.centerCoordinate && centerCoordinateChanged) {
293
- cameraConfig.centerCoordinate = n.centerCoordinate;
294
- shouldUpdate = true;
295
- }
296
-
297
- if (paddingChanged || zoomChanged || pitchChanged || headingChanged) {
298
- shouldUpdate = true;
299
- }
300
-
301
- if (shouldUpdate) {
302
- this._setCamera(cameraConfig);
303
- }
304
- }
305
-
306
- _hasCameraChanged(
307
- currentCamera: CameraProps,
308
- nextCamera: CameraProps,
309
- ): boolean {
310
- const c = currentCamera;
311
- const n = nextCamera;
312
-
313
- const hasDefaultPropsChanged =
314
- c.heading !== n.heading ||
315
- this._hasCenterCoordinateChanged(
316
- c?.centerCoordinate,
317
- n?.centerCoordinate,
318
- ) ||
319
- this._hasBoundsChanged(c.bounds, n.bounds) ||
320
- this._hasPaddingChanged(c.padding, n.padding) ||
321
- c.pitch !== n.pitch ||
322
- c.zoomLevel !== n.zoomLevel ||
323
- c.triggerKey !== n.triggerKey;
324
-
325
- const hasFollowPropsChanged =
326
- c.followUserLocation !== n.followUserLocation ||
327
- c.followUserMode !== n.followUserMode ||
328
- c.followZoomLevel !== n.followZoomLevel ||
329
- c.followHeading !== n.followHeading ||
330
- c.followPitch !== n.followPitch;
331
-
332
- const hasAnimationPropsChanged =
333
- c.animationMode !== n.animationMode ||
334
- c.animationDuration !== n.animationDuration;
335
-
336
- const hasNavigationConstraintsPropsChanged =
337
- this._hasBoundsChanged(c.maxBounds, n.maxBounds) ||
338
- c.minZoomLevel !== n.minZoomLevel ||
339
- c.maxZoomLevel !== n.maxZoomLevel;
340
-
341
- return (
342
- hasDefaultPropsChanged ||
343
- hasFollowPropsChanged ||
344
- hasAnimationPropsChanged ||
345
- hasNavigationConstraintsPropsChanged
346
- );
347
- }
348
-
349
- _hasCenterCoordinateChanged(
350
- cC?: GeoJSON.Position,
351
- nC?: GeoJSON.Position,
352
- ): boolean {
353
- if (!cC && !nC) {
354
- return false;
355
- }
202
+ const Camera = memo(
203
+ React.forwardRef<CameraRef, CameraProps>(
204
+ (
205
+ {
206
+ allowUpdates = true,
207
+ animationMode = "easeTo",
208
+ animationDuration = 2000,
209
+ ...rest
210
+ }: CameraProps,
211
+ ref,
212
+ ) => {
213
+ const props = useMemo(() => {
214
+ return {
215
+ allowUpdates,
216
+ animationMode,
217
+ animationDuration,
218
+ ...rest,
219
+ };
220
+ }, [allowUpdates, animationMode, animationDuration, rest]);
221
+
222
+ useImperativeHandle(
223
+ ref,
224
+ (): CameraRef => ({
225
+ /**
226
+ * Map camera transitions to fit provided bounds
227
+ *
228
+ * @example
229
+ * this.camera.fitBounds([lng, lat], [lng, lat])
230
+ * this.camera.fitBounds([lng, lat], [lng, lat], 20, 1000) // padding for all sides
231
+ * this.camera.fitBounds([lng, lat], [lng, lat], [verticalPadding, horizontalPadding], 1000)
232
+ * this.camera.fitBounds([lng, lat], [lng, lat], [top, right, bottom, left], 1000)
233
+ *
234
+ * @param {Array<Number>} northEastCoordinates - North east coordinate of bound
235
+ * @param {Array<Number>} southWestCoordinates - South west coordinate of bound
236
+ * @param {Number|Array<Number>|undefined} padding - Padding for the bounds
237
+ * @param {Number=} animationDuration - Duration of camera animation
238
+ * @return {void}
239
+ */
240
+ fitBounds,
241
+ /**
242
+ * Map camera will fly to new coordinate
243
+ *
244
+ * @example
245
+ * this.camera.flyTo([lng, lat])
246
+ * this.camera.flyTo([lng, lat], 12000)
247
+ *
248
+ * @param {Array<Number>} coordinates - Coordinates that map camera will jump too
249
+ * @param {Number=} animationDuration - Duration of camera animation
250
+ * @return {void}
251
+ */
252
+ flyTo,
253
+ /**
254
+ * Map camera will move to new coordinate at the same zoom level
255
+ *
256
+ * @example
257
+ * this.camera.moveTo([lng, lat], 200) // eases camera to new location based on duration
258
+ * this.camera.moveTo([lng, lat]) // snaps camera to new location without any easing
259
+ *
260
+ * @param {Array<Number>} coordinates - Coordinates that map camera will move too
261
+ * @param {Number=} animationDuration - Duration of camera animation
262
+ * @return {void}
263
+ */
264
+ moveTo,
265
+ /**
266
+ * Map camera will zoom to specified level
267
+ *
268
+ * @example
269
+ * this.camera.zoomTo(16)
270
+ * this.camera.zoomTo(16, 100)
271
+ *
272
+ * @param {Number} zoomLevel - Zoom level that the map camera will animate too
273
+ * @param {Number=} animationDuration - Duration of camera animation
274
+ * @return {void}
275
+ */
276
+ zoomTo,
277
+ /**
278
+ * Map camera will perform updates based on provided config. Advanced use only!
279
+ *
280
+ * @example
281
+ * this.camera.setCamera({
282
+ * centerCoordinate: [lng, lat],
283
+ * zoomLevel: 16,
284
+ * animationDuration: 2000,
285
+ * })
286
+ *
287
+ * this.camera.setCamera({
288
+ * stops: [
289
+ * { pitch: 45, animationDuration: 200 },
290
+ * { heading: 180, animationDuration: 300 },
291
+ * ]
292
+ * })
293
+ *
294
+ * @param {Object} config - Camera configuration
295
+ */
296
+ setCamera,
297
+ _defaultCamera,
298
+ _getMaxBounds,
299
+ _getNativeCameraMode,
300
+ _createStopConfig,
301
+ _createDefaultCamera,
302
+ }),
303
+ );
356
304
 
357
- if (existenceChange(!!cC, !!nC)) {
358
- return true;
359
- }
305
+ const _defaultCamera = useRef<NativeCameraStop | null>(null);
306
+
307
+ const cameraRef = useNativeRef<NativeProps>();
308
+
309
+ const _createStopConfig = useCallback(
310
+ (
311
+ config: CameraStop = {},
312
+ ignoreFollowUserLocation = false,
313
+ ): NativeCameraStop | null => {
314
+ if (props.followUserLocation && !ignoreFollowUserLocation) {
315
+ return null;
316
+ }
317
+
318
+ const stopConfig: NativeCameraStop = {
319
+ mode: _getNativeCameraMode(config),
320
+ pitch: config.pitch,
321
+ heading: config.heading,
322
+ duration: config.animationDuration || 0,
323
+ zoom: config.zoomLevel,
324
+ paddingTop:
325
+ config.padding?.paddingTop || config.bounds?.paddingTop || 0,
326
+ paddingRight:
327
+ config.padding?.paddingRight || config.bounds?.paddingRight || 0,
328
+ paddingBottom:
329
+ config.padding?.paddingBottom ||
330
+ config.bounds?.paddingBottom ||
331
+ 0,
332
+ paddingLeft:
333
+ config.padding?.paddingLeft || config.bounds?.paddingLeft || 0,
334
+ };
335
+
336
+ if (config.centerCoordinate) {
337
+ stopConfig.centerCoordinate = toJSONString(
338
+ geoUtils.makePoint(config.centerCoordinate),
339
+ );
340
+ }
341
+
342
+ if (config.bounds && config.bounds.ne && config.bounds.sw) {
343
+ const { ne, sw } = config.bounds;
344
+ stopConfig.bounds = toJSONString(geoUtils.makeLatLngBounds(ne, sw));
345
+ }
346
+
347
+ return stopConfig;
348
+ },
349
+ [props.followUserLocation],
350
+ );
360
351
 
361
- const isLngDiff = cC?.[0] !== nC?.[0];
362
- const isLatDiff = cC?.[1] !== nC?.[1];
363
- return isLngDiff || isLatDiff;
364
- }
365
-
366
- _hasBoundsChanged(
367
- cB?: CameraBoundsWithPadding,
368
- nB?: CameraBoundsWithPadding,
369
- ): boolean {
370
- if (!cB && !nB) {
371
- return false;
372
- }
352
+ const _setCamera = useCallback(
353
+ (config: CameraStop | CameraStops = {}): void => {
354
+ if ("stops" in config) {
355
+ let nativeStops: NativeCameraStop[] = [];
356
+
357
+ for (const stop of config.stops) {
358
+ const nativeStop = _createStopConfig(stop);
359
+ if (nativeStop) {
360
+ nativeStops = [...nativeStops, nativeStop];
361
+ }
362
+ }
363
+ cameraRef.current?.setNativeProps({ stop: { stops: nativeStops } });
364
+ } else {
365
+ const nativeStop = _createStopConfig(config);
366
+
367
+ if (nativeStop) {
368
+ cameraRef.current?.setNativeProps({ stop: nativeStop });
369
+ }
370
+ }
371
+ },
372
+ [cameraRef.current, _createStopConfig],
373
+ );
373
374
 
374
- if (existenceChange(!!cB, !!nB)) {
375
- return true;
376
- }
375
+ const _getMaxBounds = useCallback((): string | null => {
376
+ const bounds = props.maxBounds;
377
+ if (!bounds || !bounds.ne || !bounds.sw) {
378
+ return null;
379
+ }
380
+ return toJSONString(geoUtils.makeLatLngBounds(bounds.ne, bounds.sw));
381
+ }, [props.maxBounds]);
377
382
 
378
- return (
379
- cB?.ne[0] !== nB?.ne[0] ||
380
- cB?.ne[1] !== nB?.ne[1] ||
381
- cB?.sw[0] !== nB?.sw[0] ||
382
- cB?.sw[1] !== nB?.sw[1] ||
383
- cB?.paddingTop !== nB?.paddingTop ||
384
- cB?.paddingLeft !== nB?.paddingLeft ||
385
- cB?.paddingRight !== nB?.paddingRight ||
386
- cB?.paddingBottom !== nB?.paddingBottom
387
- );
388
- }
389
-
390
- _hasPaddingChanged(cP?: CameraPadding, nP?: CameraPadding): boolean {
391
- if (!cP && !nP) {
392
- return false;
393
- }
383
+ useEffect(() => {
384
+ if (!props.allowUpdates) {
385
+ return;
386
+ }
394
387
 
395
- if (existenceChange(!!cP, !!nP)) {
396
- return true;
397
- }
388
+ cameraRef.current?.setNativeProps({
389
+ followUserLocation: props.followUserLocation,
390
+ });
391
+ }, [cameraRef.current, props.followUserLocation]);
398
392
 
399
- return (
400
- cP?.paddingTop !== nP?.paddingTop ||
401
- cP?.paddingLeft !== nP?.paddingLeft ||
402
- cP?.paddingRight !== nP?.paddingRight ||
403
- cP?.paddingBottom !== nP?.paddingBottom
404
- );
405
- }
406
-
407
- _hasNumberChanged(prev?: number, next?: number): boolean {
408
- if (existenceChange(!!prev, !!next)) {
409
- return true;
410
- }
393
+ useEffect(() => {
394
+ if (!props.maxBounds || !props.allowUpdates) {
395
+ return;
396
+ }
411
397
 
412
- if (!prev && !next) {
413
- return false;
414
- }
398
+ cameraRef.current?.setNativeProps({
399
+ maxBounds: _getMaxBounds(),
400
+ });
401
+ }, [cameraRef.current, props.maxBounds, _getMaxBounds]);
415
402
 
416
- return prev !== next;
417
- }
403
+ useEffect(() => {
404
+ if (!props.minZoomLevel || !props.allowUpdates) {
405
+ return;
406
+ }
418
407
 
419
- /**
420
- * Map camera transitions to fit provided bounds
421
- *
422
- * @example
423
- * this.camera.fitBounds([lng, lat], [lng, lat])
424
- * this.camera.fitBounds([lng, lat], [lng, lat], 20, 1000) // padding for all sides
425
- * this.camera.fitBounds([lng, lat], [lng, lat], [verticalPadding, horizontalPadding], 1000)
426
- * this.camera.fitBounds([lng, lat], [lng, lat], [top, right, bottom, left], 1000)
427
- *
428
- * @param {Array<Number>} northEastCoordinates - North east coordinate of bound
429
- * @param {Array<Number>} southWestCoordinates - South west coordinate of bound
430
- * @param {Number=} padding - Camera padding for bound
431
- * @param {Number=} animationDuration - Duration of camera animation
432
- * @return {void}
433
- */
434
- fitBounds(
435
- northEastCoordinates: number[],
436
- southWestCoordinates: number[],
437
- padding = 0,
438
- animationDuration = 0.0,
439
- ): void {
440
- const pad = {
441
- paddingLeft: 0,
442
- paddingRight: 0,
443
- paddingTop: 0,
444
- paddingBottom: 0,
445
- };
446
-
447
- if (Array.isArray(padding)) {
448
- if (padding.length === 2) {
449
- pad.paddingTop = padding[0];
450
- pad.paddingBottom = padding[0];
451
- pad.paddingLeft = padding[1];
452
- pad.paddingRight = padding[1];
453
- } else if (padding.length === 4) {
454
- pad.paddingTop = padding[0];
455
- pad.paddingRight = padding[1];
456
- pad.paddingBottom = padding[2];
457
- pad.paddingLeft = padding[3];
458
- }
459
- } else {
460
- pad.paddingLeft = padding;
461
- pad.paddingRight = padding;
462
- pad.paddingTop = padding;
463
- pad.paddingBottom = padding;
464
- }
408
+ cameraRef.current?.setNativeProps({
409
+ minZoomLevel: props.minZoomLevel,
410
+ });
411
+ }, [cameraRef.current, props.minZoomLevel]);
465
412
 
466
- this.setCamera({
467
- bounds: {
468
- ne: northEastCoordinates,
469
- sw: southWestCoordinates,
470
- },
471
- padding: pad,
472
- animationDuration,
473
- animationMode: 'easeTo',
474
- });
475
- }
413
+ useEffect(() => {
414
+ if (!props.maxZoomLevel || !props.allowUpdates) {
415
+ return;
416
+ }
476
417
 
477
- /**
478
- * Map camera will fly to new coordinate
479
- *
480
- * @example
481
- * this.camera.flyTo([lng, lat])
482
- * this.camera.flyTo([lng, lat], 12000)
483
- *
484
- * @param {Array<Number>} coordinates - Coordinates that map camera will jump too
485
- * @param {Number=} animationDuration - Duration of camera animation
486
- * @return {void}
487
- */
488
- flyTo(coordinates: GeoJSON.Position, animationDuration = 2000): void {
489
- this.setCamera({
490
- centerCoordinate: coordinates,
491
- animationDuration,
492
- animationMode: 'flyTo',
493
- });
494
- }
418
+ cameraRef.current?.setNativeProps({
419
+ maxZoomLevel: props.maxZoomLevel,
420
+ });
421
+ }, [cameraRef.current, props.maxZoomLevel]);
495
422
 
496
- /**
497
- * Map camera will move to new coordinate at the same zoom level
498
- *
499
- * @example
500
- * this.camera.moveTo([lng, lat], 200) // eases camera to new location based on duration
501
- * this.camera.moveTo([lng, lat]) // snaps camera to new location without any easing
502
- *
503
- * @param {Array<Number>} coordinates - Coordinates that map camera will move too
504
- * @param {Number=} animationDuration - Duration of camera animation
505
- * @return {void}
506
- */
507
- moveTo(coordinates: GeoJSON.Position, animationDuration = 0): void {
508
- this.setCamera({
509
- centerCoordinate: coordinates,
510
- animationDuration,
511
- });
512
- }
423
+ useEffect(() => {
424
+ if (!props.allowUpdates) {
425
+ return;
426
+ }
513
427
 
514
- /**
515
- * Map camera will zoom to specified level
516
- *
517
- * @example
518
- * this.camera.zoomTo(16)
519
- * this.camera.zoomTo(16, 100)
520
- *
521
- * @param {Number} zoomLevel - Zoom level that the map camera will animate too
522
- * @param {Number=} animationDuration - Duration of camera animation
523
- * @return {void}
524
- */
525
- zoomTo(zoomLevel: number, animationDuration = 2000): void {
526
- this.setCamera({
527
- zoomLevel,
528
- animationDuration,
529
- animationMode: 'flyTo',
530
- });
531
- }
428
+ if (!props.followUserLocation) {
429
+ return;
430
+ }
532
431
 
533
- /**
534
- * Map camera will perform updates based on provided config. Advanced use only!
535
- *
536
- * @example
537
- * this.camera.setCamera({
538
- * centerCoordinate: [lng, lat],
539
- * zoomLevel: 16,
540
- * animationDuration: 2000,
541
- * })
542
- *
543
- * this.camera.setCamera({
544
- * stops: [
545
- * { pitch: 45, animationDuration: 200 },
546
- * { heading: 180, animationDuration: 300 },
547
- * ]
548
- * })
549
- *
550
- * @param {Object} config - Camera configuration
551
- */
552
- setCamera(config: CameraStop | CameraStops = {}): void {
553
- this._setCamera(config);
554
- }
555
-
556
- _setCamera(config: CameraStop | CameraStops = {}): void {
557
- if ('stops' in config) {
558
- let nativeStops: NativeCameraStop[] = [];
559
-
560
- for (const stop of config.stops) {
561
- const nativeStop = this._createStopConfig(stop);
562
- if (nativeStop) {
563
- nativeStops = [...nativeStops, nativeStop];
432
+ cameraRef.current?.setNativeProps({
433
+ followUserMode: props.followUserMode,
434
+ followPitch: props.followPitch || props.pitch,
435
+ followHeading: props.followHeading || props.heading,
436
+ followZoomLevel: props.followZoomLevel || props.zoomLevel,
437
+ });
438
+ }, [
439
+ cameraRef.current,
440
+ props.allowUpdates,
441
+ props.followUserLocation,
442
+ props.followUserMode,
443
+ props.followPitch,
444
+ props.pitch,
445
+ props.followHeading,
446
+ props.heading,
447
+ props.followZoomLevel,
448
+ props.zoomLevel,
449
+ ]);
450
+
451
+ const cameraConfig: CameraStop = useMemo(() => {
452
+ return {
453
+ bounds: props.bounds,
454
+ centerCoordinate: props.centerCoordinate,
455
+ padding: props.padding,
456
+ zoomLevel: props.zoomLevel,
457
+ minZoomLevel: props.minZoomLevel,
458
+ maxZoomLevel: props.maxZoomLevel,
459
+ pitch: props.pitch,
460
+ heading: props.heading,
461
+ animationMode: props.animationMode,
462
+ animationDuration: props.animationDuration,
463
+ };
464
+ }, [
465
+ props.bounds,
466
+ props.centerCoordinate,
467
+ props.padding,
468
+ props.zoomLevel,
469
+ props.minZoomLevel,
470
+ props.maxZoomLevel,
471
+ props.pitch,
472
+ props.heading,
473
+ props.animationMode,
474
+ props.animationDuration,
475
+ ]);
476
+
477
+ useEffect(() => {
478
+ if (!props.allowUpdates) {
479
+ return;
564
480
  }
565
- }
566
- this.cameraRef.current?.setNativeProps({stop: {stops: nativeStops}});
567
- } else {
568
- const nativeStop = this._createStopConfig(config);
569
- if (nativeStop) {
570
- this.cameraRef.current?.setNativeProps({stop: nativeStop});
571
- }
572
- }
573
- }
574
481
 
575
- _createDefaultCamera(): NativeCameraStop | null {
576
- if (this.defaultCamera) {
577
- return this.defaultCamera;
578
- }
579
- if (!this.props.defaultSettings) {
580
- return null;
581
- }
482
+ _setCamera(cameraConfig);
483
+ }, [_setCamera, cameraConfig]);
484
+
485
+ const fitBounds = (
486
+ northEastCoordinates: GeoJSON.Position,
487
+ southWestCoordinates: GeoJSON.Position,
488
+ padding: number | number[] = 0,
489
+ animationDuration: number = 0.0,
490
+ ): void => {
491
+ const pad = {
492
+ paddingLeft: 0,
493
+ paddingRight: 0,
494
+ paddingTop: 0,
495
+ paddingBottom: 0,
496
+ };
497
+
498
+ if (Array.isArray(padding)) {
499
+ if (padding.length === 2) {
500
+ pad.paddingTop = padding[0];
501
+ pad.paddingBottom = padding[0];
502
+ pad.paddingLeft = padding[1];
503
+ pad.paddingRight = padding[1];
504
+ } else if (padding.length === 4) {
505
+ pad.paddingTop = padding[0];
506
+ pad.paddingRight = padding[1];
507
+ pad.paddingBottom = padding[2];
508
+ pad.paddingLeft = padding[3];
509
+ }
510
+ } else {
511
+ pad.paddingLeft = padding;
512
+ pad.paddingRight = padding;
513
+ pad.paddingTop = padding;
514
+ pad.paddingBottom = padding;
515
+ }
582
516
 
583
- this.defaultCamera = this._createStopConfig(
584
- {
585
- ...this.props.defaultSettings,
586
- animationMode: 'moveTo',
587
- },
588
- true,
589
- );
590
- return this.defaultCamera;
591
- }
592
-
593
- _createStopConfig(
594
- config: CameraStop = {},
595
- ignoreFollowUserLocation = false,
596
- ): NativeCameraStop | null {
597
- if (this.props.followUserLocation && !ignoreFollowUserLocation) {
598
- return null;
599
- }
517
+ setCamera({
518
+ bounds: {
519
+ ne: northEastCoordinates,
520
+ sw: southWestCoordinates,
521
+ },
522
+ padding: pad,
523
+ animationDuration,
524
+ animationMode: "easeTo",
525
+ });
526
+ };
527
+
528
+ const flyTo = (
529
+ coordinates: GeoJSON.Position,
530
+ animationDuration = 2000,
531
+ ): void => {
532
+ setCamera({
533
+ centerCoordinate: coordinates,
534
+ animationDuration,
535
+ animationMode: "flyTo",
536
+ });
537
+ };
538
+
539
+ const moveTo = (
540
+ coordinates: GeoJSON.Position,
541
+ animationDuration = 0,
542
+ ): void => {
543
+ setCamera({
544
+ centerCoordinate: coordinates,
545
+ animationDuration,
546
+ });
547
+ };
548
+
549
+ const zoomTo = (zoomLevel: number, animationDuration = 2000): void => {
550
+ setCamera({
551
+ zoomLevel,
552
+ animationDuration,
553
+ animationMode: "flyTo",
554
+ });
555
+ };
556
+
557
+ const setCamera = (config: CameraStop | CameraStops = {}): void => {
558
+ _setCamera(config);
559
+ };
560
+
561
+ const _createDefaultCamera = (): NativeCameraStop | null => {
562
+ if (_defaultCamera.current) {
563
+ return _defaultCamera.current;
564
+ }
565
+ if (!props.defaultSettings) {
566
+ return null;
567
+ }
600
568
 
601
- const stopConfig: NativeCameraStop = {
602
- mode: this._getNativeCameraMode(config),
603
- pitch: config.pitch,
604
- heading: config.heading,
605
- duration: config.animationDuration || 0,
606
- zoom: config.zoomLevel,
607
- paddingTop: config.padding?.paddingTop || config.bounds?.paddingTop || 0,
608
- paddingRight:
609
- config.padding?.paddingRight || config.bounds?.paddingRight || 0,
610
- paddingBottom:
611
- config.padding?.paddingBottom || config.bounds?.paddingBottom || 0,
612
- paddingLeft:
613
- config.padding?.paddingLeft || config.bounds?.paddingLeft || 0,
614
- };
615
-
616
- if (config.centerCoordinate) {
617
- stopConfig.centerCoordinate = toJSONString(
618
- geoUtils.makePoint(config.centerCoordinate),
569
+ _defaultCamera.current = _createStopConfig(
570
+ {
571
+ ...props.defaultSettings,
572
+ animationMode: "moveTo",
573
+ },
574
+ true,
575
+ );
576
+ return _defaultCamera.current;
577
+ };
578
+
579
+ const _getNativeCameraMode = (
580
+ config: CameraStop,
581
+ ): NativeAnimationMode => {
582
+ switch (config.animationMode) {
583
+ case "flyTo":
584
+ return MapLibreGL.CameraModes.Flight;
585
+ case "moveTo":
586
+ return MapLibreGL.CameraModes.None;
587
+ case "linearTo":
588
+ return MapLibreGL.CameraModes.Linear;
589
+ default:
590
+ return MapLibreGL.CameraModes.Ease;
591
+ }
592
+ };
593
+
594
+ const nativeProps = Object.assign({}, props);
595
+
596
+ const callbacks = {
597
+ onUserTrackingModeChange: nativeProps.onUserTrackingModeChange,
598
+ };
599
+
600
+ return (
601
+ <RCTMLNCamera
602
+ testID="Camera"
603
+ ref={cameraRef}
604
+ followUserLocation={props.followUserLocation}
605
+ followUserMode={props.followUserMode}
606
+ followPitch={props.followPitch}
607
+ followHeading={props.followHeading}
608
+ followZoomLevel={props.followZoomLevel}
609
+ stop={_createStopConfig(nativeProps)}
610
+ maxZoomLevel={props.maxZoomLevel}
611
+ minZoomLevel={props.minZoomLevel}
612
+ maxBounds={_getMaxBounds()}
613
+ defaultStop={_createDefaultCamera()}
614
+ {...callbacks}
615
+ />
619
616
  );
620
- }
621
-
622
- if (config.bounds && config.bounds.ne && config.bounds.sw) {
623
- const {ne, sw} = config.bounds;
624
- stopConfig.bounds = toJSONString(geoUtils.makeLatLngBounds(ne, sw));
625
- }
626
-
627
- return stopConfig;
628
- }
629
-
630
- _getNativeCameraMode(config: CameraStop): NativeAnimationMode {
631
- switch (config.animationMode) {
632
- case 'flyTo':
633
- return MapLibreGL.CameraModes.Flight;
634
- case 'moveTo':
635
- return MapLibreGL.CameraModes.None;
636
- case 'linearTo':
637
- return MapLibreGL.CameraModes.Linear;
638
- default:
639
- return MapLibreGL.CameraModes.Ease;
640
- }
641
- }
642
-
643
- _getMaxBounds(): string | null {
644
- const bounds = this.props.maxBounds;
645
- if (!bounds || !bounds.ne || !bounds.sw) {
646
- return null;
647
- }
648
- return toJSONString(geoUtils.makeLatLngBounds(bounds.ne, bounds.sw));
649
- }
650
-
651
- render(): ReactElement {
652
- const props = Object.assign({}, this.props);
653
-
654
- const callbacks = {
655
- onUserTrackingModeChange: props.onUserTrackingModeChange,
656
- };
657
-
658
- return (
659
- <RCTMGLCamera
660
- testID="Camera"
661
- ref={this.cameraRef}
662
- followUserLocation={this.props.followUserLocation}
663
- followUserMode={this.props.followUserMode}
664
- followPitch={this.props.followPitch}
665
- followHeading={this.props.followHeading}
666
- followZoomLevel={this.props.followZoomLevel}
667
- stop={this._createStopConfig(props)}
668
- maxZoomLevel={this.props.maxZoomLevel}
669
- minZoomLevel={this.props.minZoomLevel}
670
- maxBounds={this._getMaxBounds()}
671
- defaultStop={this._createDefaultCamera()}
672
- {...callbacks}
673
- />
674
- );
675
- }
676
- }
617
+ },
618
+ ),
619
+ );
677
620
 
678
- const RCTMGLCamera = requireNativeComponent<NativeProps>(NATIVE_MODULE_NAME);
621
+ const RCTMLNCamera = requireNativeComponent<NativeProps>(NATIVE_MODULE_NAME);
679
622
 
680
623
  export default Camera;