@lugg/maps 0.2.0-alpha.5 → 0.2.0-alpha.7

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 (61) hide show
  1. package/README.md +17 -4
  2. package/android/src/main/java/com/luggmaps/LuggGoogleMapView.kt +2 -5
  3. package/android/src/main/java/com/luggmaps/LuggMarkerView.kt +7 -1
  4. package/android/src/main/java/com/luggmaps/LuggMarkerViewManager.kt +6 -0
  5. package/ios/LuggAppleMapView.mm +8 -0
  6. package/ios/LuggGoogleMapView.mm +2 -0
  7. package/ios/LuggMarkerView.h +2 -0
  8. package/ios/LuggMarkerView.mm +13 -0
  9. package/lib/module/MapProvider.js +13 -0
  10. package/lib/module/MapProvider.js.map +1 -0
  11. package/lib/module/MapProvider.types.js +4 -0
  12. package/lib/module/MapProvider.types.js.map +1 -0
  13. package/lib/module/MapProvider.web.js +14 -0
  14. package/lib/module/MapProvider.web.js.map +1 -0
  15. package/lib/module/MapView.web.js +212 -0
  16. package/lib/module/MapView.web.js.map +1 -0
  17. package/lib/module/components/Marker.js +4 -1
  18. package/lib/module/components/Marker.js.map +1 -1
  19. package/lib/module/components/Marker.web.js +34 -0
  20. package/lib/module/components/Marker.web.js.map +1 -0
  21. package/lib/module/components/Polyline.web.js +171 -0
  22. package/lib/module/components/Polyline.web.js.map +1 -0
  23. package/lib/module/components/index.js +2 -2
  24. package/lib/module/components/index.js.map +1 -1
  25. package/lib/module/components/index.web.js +5 -0
  26. package/lib/module/components/index.web.js.map +1 -0
  27. package/lib/module/index.js +3 -2
  28. package/lib/module/index.js.map +1 -1
  29. package/lib/module/index.web.js +6 -0
  30. package/lib/module/index.web.js.map +1 -0
  31. package/lib/typescript/src/MapProvider.d.ts +8 -0
  32. package/lib/typescript/src/MapProvider.d.ts.map +1 -0
  33. package/lib/typescript/src/MapProvider.types.d.ts +16 -0
  34. package/lib/typescript/src/MapProvider.types.d.ts.map +1 -0
  35. package/lib/typescript/src/MapProvider.web.d.ts +3 -0
  36. package/lib/typescript/src/MapProvider.web.d.ts.map +1 -0
  37. package/lib/typescript/src/MapView.web.d.ts +12 -0
  38. package/lib/typescript/src/MapView.web.d.ts.map +1 -0
  39. package/lib/typescript/src/components/Marker.d.ts +4 -0
  40. package/lib/typescript/src/components/Marker.d.ts.map +1 -1
  41. package/lib/typescript/src/components/Marker.web.d.ts +6 -0
  42. package/lib/typescript/src/components/Marker.web.d.ts.map +1 -0
  43. package/lib/typescript/src/components/Polyline.web.d.ts +6 -0
  44. package/lib/typescript/src/components/Polyline.web.d.ts.map +1 -0
  45. package/lib/typescript/src/components/index.web.d.ts +5 -0
  46. package/lib/typescript/src/components/index.web.d.ts.map +1 -0
  47. package/lib/typescript/src/index.d.ts +3 -1
  48. package/lib/typescript/src/index.d.ts.map +1 -1
  49. package/lib/typescript/src/index.web.d.ts +7 -0
  50. package/lib/typescript/src/index.web.d.ts.map +1 -0
  51. package/package.json +13 -1
  52. package/src/MapProvider.tsx +10 -0
  53. package/src/MapProvider.types.ts +16 -0
  54. package/src/MapProvider.web.tsx +6 -0
  55. package/src/MapView.web.tsx +255 -0
  56. package/src/components/Marker.tsx +6 -2
  57. package/src/components/Marker.web.tsx +32 -0
  58. package/src/components/Polyline.web.tsx +206 -0
  59. package/src/components/index.web.ts +4 -0
  60. package/src/index.ts +8 -1
  61. package/src/index.web.ts +17 -0
@@ -0,0 +1,171 @@
1
+ "use strict";
2
+
3
+ import { Component, useCallback, useEffect, useMemo, useRef, useState } from 'react';
4
+ import { useMap } from '@vis.gl/react-google-maps';
5
+ import { jsx as _jsx } from "react/jsx-runtime";
6
+ const ANIMATION_DURATION = 1500;
7
+ function interpolateColor(color1, color2, t) {
8
+ const hex = c => parseInt(c, 16);
9
+ const r1 = hex(color1.slice(1, 3));
10
+ const g1 = hex(color1.slice(3, 5));
11
+ const b1 = hex(color1.slice(5, 7));
12
+ const r2 = hex(color2.slice(1, 3));
13
+ const g2 = hex(color2.slice(3, 5));
14
+ const b2 = hex(color2.slice(5, 7));
15
+ const r = Math.round(r1 + (r2 - r1) * t);
16
+ const g = Math.round(g1 + (g2 - g1) * t);
17
+ const b = Math.round(b1 + (b2 - b1) * t);
18
+ return `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;
19
+ }
20
+ function getGradientColor(colors, position) {
21
+ if (colors.length === 0) return '#000000';
22
+ if (colors.length === 1 || position <= 0) return colors[0];
23
+ if (position >= 1) return colors[colors.length - 1];
24
+ const scaledPos = position * (colors.length - 1);
25
+ const index = Math.floor(scaledPos);
26
+ const t = scaledPos - index;
27
+ return interpolateColor(colors[index], colors[index + 1], t);
28
+ }
29
+ function PolylineImpl({
30
+ coordinates,
31
+ strokeColors,
32
+ strokeWidth = 1,
33
+ animated
34
+ }) {
35
+ const map = useMap();
36
+ const polylinesRef = useRef([]);
37
+ const animationRef = useRef(0);
38
+ const colors = useMemo(() => strokeColors && strokeColors.length > 0 ? strokeColors : ['#000000'], [strokeColors]);
39
+ const hasGradient = colors.length > 1;
40
+
41
+ // Refs for animation loop access
42
+ const propsRef = useRef({
43
+ map,
44
+ colors,
45
+ strokeWidth,
46
+ hasGradient
47
+ });
48
+ const [mapReady, setMapReady] = useState(!!map);
49
+ useEffect(() => {
50
+ propsRef.current = {
51
+ map,
52
+ colors,
53
+ strokeWidth,
54
+ hasGradient
55
+ };
56
+ if (map && !mapReady) setMapReady(true);
57
+ }, [map, colors, strokeWidth, hasGradient, mapReady]);
58
+ const updatePath = useCallback(path => {
59
+ const {
60
+ map: currentMap,
61
+ colors: currentColors,
62
+ strokeWidth: currentStrokeWidth,
63
+ hasGradient: currentHasGradient
64
+ } = propsRef.current;
65
+ if (!currentMap || path.length < 2) return;
66
+ const neededSegments = currentHasGradient ? path.length - 1 : 1;
67
+ const existing = polylinesRef.current;
68
+
69
+ // Update or create segments
70
+ for (let i = 0; i < neededSegments; i++) {
71
+ const segmentPath = currentHasGradient ? [path[i], path[i + 1]] : path;
72
+ const color = currentHasGradient ? getGradientColor(currentColors, i / (path.length - 1)) : currentColors[0];
73
+ const segment = existing[i];
74
+ if (segment) {
75
+ segment.setPath(segmentPath);
76
+ segment.setOptions({
77
+ strokeColor: color
78
+ });
79
+ } else {
80
+ existing.push(new google.maps.Polyline({
81
+ path: segmentPath,
82
+ strokeColor: color,
83
+ strokeWeight: currentStrokeWidth,
84
+ strokeOpacity: 1,
85
+ map: currentMap
86
+ }));
87
+ }
88
+ }
89
+
90
+ // Remove extra segments
91
+ for (let i = neededSegments; i < existing.length; i++) {
92
+ existing[i]?.setMap(null);
93
+ }
94
+ existing.length = neededSegments;
95
+ }, []);
96
+
97
+ // Cleanup on unmount
98
+ useEffect(() => {
99
+ const polylines = polylinesRef.current;
100
+ return () => {
101
+ cancelAnimationFrame(animationRef.current);
102
+ polylines.forEach(p => p.setMap(null));
103
+ };
104
+ }, []);
105
+
106
+ // Main effect
107
+ useEffect(() => {
108
+ if (!propsRef.current.map || coordinates.length === 0) return;
109
+ const fullPath = coordinates.map(c => ({
110
+ lat: c.latitude,
111
+ lng: c.longitude
112
+ }));
113
+ cancelAnimationFrame(animationRef.current);
114
+ if (!animated) {
115
+ updatePath(fullPath);
116
+ return;
117
+ }
118
+ const totalPoints = fullPath.length;
119
+ const cycleDuration = ANIMATION_DURATION * 2;
120
+ const animate = time => {
121
+ const progress = time % cycleDuration / ANIMATION_DURATION;
122
+ const startIdx = progress <= 1 ? 0 : (progress - 1) * totalPoints;
123
+ const endIdx = progress <= 1 ? progress * totalPoints : totalPoints;
124
+ const partialPath = [];
125
+ const startFloor = Math.floor(startIdx);
126
+ const endFloor = Math.floor(endIdx);
127
+
128
+ // Start point (interpolated)
129
+ if (startFloor < totalPoints) {
130
+ const frac = startIdx - startFloor;
131
+ const from = fullPath[startFloor];
132
+ const to = fullPath[Math.min(startFloor + 1, totalPoints - 1)];
133
+ partialPath.push(frac > 0 ? {
134
+ lat: from.lat + (to.lat - from.lat) * frac,
135
+ lng: from.lng + (to.lng - from.lng) * frac
136
+ } : from);
137
+ }
138
+
139
+ // Middle points
140
+ for (let i = startFloor + 1; i <= Math.min(endFloor, totalPoints - 1); i++) {
141
+ partialPath.push(fullPath[i]);
142
+ }
143
+
144
+ // End point (interpolated)
145
+ if (endFloor < totalPoints - 1) {
146
+ const frac = endIdx - endFloor;
147
+ const from = fullPath[endFloor];
148
+ const to = fullPath[endFloor + 1];
149
+ if (frac > 0) {
150
+ partialPath.push({
151
+ lat: from.lat + (to.lat - from.lat) * frac,
152
+ lng: from.lng + (to.lng - from.lng) * frac
153
+ });
154
+ }
155
+ }
156
+ updatePath(partialPath);
157
+ animationRef.current = requestAnimationFrame(animate);
158
+ };
159
+ animationRef.current = requestAnimationFrame(animate);
160
+ return () => cancelAnimationFrame(animationRef.current);
161
+ }, [coordinates, animated, hasGradient, updatePath, mapReady]);
162
+ return null;
163
+ }
164
+ export class Polyline extends Component {
165
+ render() {
166
+ return /*#__PURE__*/_jsx(PolylineImpl, {
167
+ ...this.props
168
+ });
169
+ }
170
+ }
171
+ //# sourceMappingURL=Polyline.web.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Component","useCallback","useEffect","useMemo","useRef","useState","useMap","jsx","_jsx","ANIMATION_DURATION","interpolateColor","color1","color2","t","hex","c","parseInt","r1","slice","g1","b1","r2","g2","b2","r","Math","round","g","b","toString","padStart","getGradientColor","colors","position","length","scaledPos","index","floor","PolylineImpl","coordinates","strokeColors","strokeWidth","animated","map","polylinesRef","animationRef","hasGradient","propsRef","mapReady","setMapReady","current","updatePath","path","currentMap","currentColors","currentStrokeWidth","currentHasGradient","neededSegments","existing","i","segmentPath","color","segment","setPath","setOptions","strokeColor","push","google","maps","Polyline","strokeWeight","strokeOpacity","setMap","polylines","cancelAnimationFrame","forEach","p","fullPath","lat","latitude","lng","longitude","totalPoints","cycleDuration","animate","time","progress","startIdx","endIdx","partialPath","startFloor","endFloor","frac","from","to","min","requestAnimationFrame","render","props"],"sourceRoot":"../../../src","sources":["components/Polyline.web.tsx"],"mappings":";;AAAA,SACEA,SAAS,EACTC,WAAW,EACXC,SAAS,EACTC,OAAO,EACPC,MAAM,EACNC,QAAQ,QACH,OAAO;AACd,SAASC,MAAM,QAAQ,2BAA2B;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAGnD,MAAMC,kBAAkB,GAAG,IAAI;AAE/B,SAASC,gBAAgBA,CAACC,MAAc,EAAEC,MAAc,EAAEC,CAAS,EAAU;EAC3E,MAAMC,GAAG,GAAIC,CAAS,IAAKC,QAAQ,CAACD,CAAC,EAAE,EAAE,CAAC;EAC1C,MAAME,EAAE,GAAGH,GAAG,CAACH,MAAM,CAACO,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAClC,MAAMC,EAAE,GAAGL,GAAG,CAACH,MAAM,CAACO,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAClC,MAAME,EAAE,GAAGN,GAAG,CAACH,MAAM,CAACO,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAClC,MAAMG,EAAE,GAAGP,GAAG,CAACF,MAAM,CAACM,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAClC,MAAMI,EAAE,GAAGR,GAAG,CAACF,MAAM,CAACM,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAClC,MAAMK,EAAE,GAAGT,GAAG,CAACF,MAAM,CAACM,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAElC,MAAMM,CAAC,GAAGC,IAAI,CAACC,KAAK,CAACT,EAAE,GAAG,CAACI,EAAE,GAAGJ,EAAE,IAAIJ,CAAC,CAAC;EACxC,MAAMc,CAAC,GAAGF,IAAI,CAACC,KAAK,CAACP,EAAE,GAAG,CAACG,EAAE,GAAGH,EAAE,IAAIN,CAAC,CAAC;EACxC,MAAMe,CAAC,GAAGH,IAAI,CAACC,KAAK,CAACN,EAAE,GAAG,CAACG,EAAE,GAAGH,EAAE,IAAIP,CAAC,CAAC;EAExC,OAAO,IAAIW,CAAC,CAACK,QAAQ,CAAC,EAAE,CAAC,CAACC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAGH,CAAC,CAC3CE,QAAQ,CAAC,EAAE,CAAC,CACZC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAGF,CAAC,CAACC,QAAQ,CAAC,EAAE,CAAC,CAACC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE;AACzD;AAEA,SAASC,gBAAgBA,CAACC,MAAgB,EAAEC,QAAgB,EAAU;EACpE,IAAID,MAAM,CAACE,MAAM,KAAK,CAAC,EAAE,OAAO,SAAS;EACzC,IAAIF,MAAM,CAACE,MAAM,KAAK,CAAC,IAAID,QAAQ,IAAI,CAAC,EAAE,OAAOD,MAAM,CAAC,CAAC,CAAC;EAC1D,IAAIC,QAAQ,IAAI,CAAC,EAAE,OAAOD,MAAM,CAACA,MAAM,CAACE,MAAM,GAAG,CAAC,CAAC;EAEnD,MAAMC,SAAS,GAAGF,QAAQ,IAAID,MAAM,CAACE,MAAM,GAAG,CAAC,CAAC;EAChD,MAAME,KAAK,GAAGX,IAAI,CAACY,KAAK,CAACF,SAAS,CAAC;EACnC,MAAMtB,CAAC,GAAGsB,SAAS,GAAGC,KAAK;EAE3B,OAAO1B,gBAAgB,CAACsB,MAAM,CAACI,KAAK,CAAC,EAAGJ,MAAM,CAACI,KAAK,GAAG,CAAC,CAAC,EAAGvB,CAAC,CAAC;AAChE;AAEA,SAASyB,YAAYA,CAAC;EACpBC,WAAW;EACXC,YAAY;EACZC,WAAW,GAAG,CAAC;EACfC;AACa,CAAC,EAAE;EAChB,MAAMC,GAAG,GAAGrC,MAAM,CAAC,CAAC;EACpB,MAAMsC,YAAY,GAAGxC,MAAM,CAAyB,EAAE,CAAC;EACvD,MAAMyC,YAAY,GAAGzC,MAAM,CAAS,CAAC,CAAC;EAEtC,MAAM4B,MAAM,GAAG7B,OAAO,CACpB,MACEqC,YAAY,IAAIA,YAAY,CAACN,MAAM,GAAG,CAAC,GAClCM,YAAY,GACb,CAAC,SAAS,CAAC,EACjB,CAACA,YAAY,CACf,CAAC;EAED,MAAMM,WAAW,GAAGd,MAAM,CAACE,MAAM,GAAG,CAAC;;EAErC;EACA,MAAMa,QAAQ,GAAG3C,MAAM,CAAC;IAAEuC,GAAG;IAAEX,MAAM;IAAES,WAAW;IAAEK;EAAY,CAAC,CAAC;EAClE,MAAM,CAACE,QAAQ,EAAEC,WAAW,CAAC,GAAG5C,QAAQ,CAAC,CAAC,CAACsC,GAAG,CAAC;EAE/CzC,SAAS,CAAC,MAAM;IACd6C,QAAQ,CAACG,OAAO,GAAG;MAAEP,GAAG;MAAEX,MAAM;MAAES,WAAW;MAAEK;IAAY,CAAC;IAC5D,IAAIH,GAAG,IAAI,CAACK,QAAQ,EAAEC,WAAW,CAAC,IAAI,CAAC;EACzC,CAAC,EAAE,CAACN,GAAG,EAAEX,MAAM,EAAES,WAAW,EAAEK,WAAW,EAAEE,QAAQ,CAAC,CAAC;EAErD,MAAMG,UAAU,GAAGlD,WAAW,CAAEmD,IAAiC,IAAK;IACpE,MAAM;MACJT,GAAG,EAAEU,UAAU;MACfrB,MAAM,EAAEsB,aAAa;MACrBb,WAAW,EAAEc,kBAAkB;MAC/BT,WAAW,EAAEU;IACf,CAAC,GAAGT,QAAQ,CAACG,OAAO;IACpB,IAAI,CAACG,UAAU,IAAID,IAAI,CAAClB,MAAM,GAAG,CAAC,EAAE;IAEpC,MAAMuB,cAAc,GAAGD,kBAAkB,GAAGJ,IAAI,CAAClB,MAAM,GAAG,CAAC,GAAG,CAAC;IAC/D,MAAMwB,QAAQ,GAAGd,YAAY,CAACM,OAAO;;IAErC;IACA,KAAK,IAAIS,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,cAAc,EAAEE,CAAC,EAAE,EAAE;MACvC,MAAMC,WAAW,GAAGJ,kBAAkB,GAAG,CAACJ,IAAI,CAACO,CAAC,CAAC,EAAGP,IAAI,CAACO,CAAC,GAAG,CAAC,CAAC,CAAE,GAAGP,IAAI;MACxE,MAAMS,KAAK,GAAGL,kBAAkB,GAC5BzB,gBAAgB,CAACuB,aAAa,EAAEK,CAAC,IAAIP,IAAI,CAAClB,MAAM,GAAG,CAAC,CAAC,CAAC,GACtDoB,aAAa,CAAC,CAAC,CAAE;MAErB,MAAMQ,OAAO,GAAGJ,QAAQ,CAACC,CAAC,CAAC;MAC3B,IAAIG,OAAO,EAAE;QACXA,OAAO,CAACC,OAAO,CAACH,WAAW,CAAC;QAC5BE,OAAO,CAACE,UAAU,CAAC;UAAEC,WAAW,EAAEJ;QAAM,CAAC,CAAC;MAC5C,CAAC,MAAM;QACLH,QAAQ,CAACQ,IAAI,CACX,IAAIC,MAAM,CAACC,IAAI,CAACC,QAAQ,CAAC;UACvBjB,IAAI,EAAEQ,WAAW;UACjBK,WAAW,EAAEJ,KAAK;UAClBS,YAAY,EAAEf,kBAAkB;UAChCgB,aAAa,EAAE,CAAC;UAChB5B,GAAG,EAAEU;QACP,CAAC,CACH,CAAC;MACH;IACF;;IAEA;IACA,KAAK,IAAIM,CAAC,GAAGF,cAAc,EAAEE,CAAC,GAAGD,QAAQ,CAACxB,MAAM,EAAEyB,CAAC,EAAE,EAAE;MACrDD,QAAQ,CAACC,CAAC,CAAC,EAAEa,MAAM,CAAC,IAAI,CAAC;IAC3B;IACAd,QAAQ,CAACxB,MAAM,GAAGuB,cAAc;EAClC,CAAC,EAAE,EAAE,CAAC;;EAEN;EACAvD,SAAS,CAAC,MAAM;IACd,MAAMuE,SAAS,GAAG7B,YAAY,CAACM,OAAO;IACtC,OAAO,MAAM;MACXwB,oBAAoB,CAAC7B,YAAY,CAACK,OAAO,CAAC;MAC1CuB,SAAS,CAACE,OAAO,CAAEC,CAAC,IAAKA,CAAC,CAACJ,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;;EAEN;EACAtE,SAAS,CAAC,MAAM;IACd,IAAI,CAAC6C,QAAQ,CAACG,OAAO,CAACP,GAAG,IAAIJ,WAAW,CAACL,MAAM,KAAK,CAAC,EAAE;IAEvD,MAAM2C,QAAQ,GAAGtC,WAAW,CAACI,GAAG,CAAE5B,CAAC,KAAM;MACvC+D,GAAG,EAAE/D,CAAC,CAACgE,QAAQ;MACfC,GAAG,EAAEjE,CAAC,CAACkE;IACT,CAAC,CAAC,CAAC;IAEHP,oBAAoB,CAAC7B,YAAY,CAACK,OAAO,CAAC;IAE1C,IAAI,CAACR,QAAQ,EAAE;MACbS,UAAU,CAAC0B,QAAQ,CAAC;MACpB;IACF;IAEA,MAAMK,WAAW,GAAGL,QAAQ,CAAC3C,MAAM;IACnC,MAAMiD,aAAa,GAAG1E,kBAAkB,GAAG,CAAC;IAE5C,MAAM2E,OAAO,GAAIC,IAAY,IAAK;MAChC,MAAMC,QAAQ,GAAID,IAAI,GAAGF,aAAa,GAAI1E,kBAAkB;MAC5D,MAAM8E,QAAQ,GAAGD,QAAQ,IAAI,CAAC,GAAG,CAAC,GAAG,CAACA,QAAQ,GAAG,CAAC,IAAIJ,WAAW;MACjE,MAAMM,MAAM,GAAGF,QAAQ,IAAI,CAAC,GAAGA,QAAQ,GAAGJ,WAAW,GAAGA,WAAW;MAEnE,MAAMO,WAAwC,GAAG,EAAE;MACnD,MAAMC,UAAU,GAAGjE,IAAI,CAACY,KAAK,CAACkD,QAAQ,CAAC;MACvC,MAAMI,QAAQ,GAAGlE,IAAI,CAACY,KAAK,CAACmD,MAAM,CAAC;;MAEnC;MACA,IAAIE,UAAU,GAAGR,WAAW,EAAE;QAC5B,MAAMU,IAAI,GAAGL,QAAQ,GAAGG,UAAU;QAClC,MAAMG,IAAI,GAAGhB,QAAQ,CAACa,UAAU,CAAE;QAClC,MAAMI,EAAE,GAAGjB,QAAQ,CAACpD,IAAI,CAACsE,GAAG,CAACL,UAAU,GAAG,CAAC,EAAER,WAAW,GAAG,CAAC,CAAC,CAAE;QAC/DO,WAAW,CAACvB,IAAI,CACd0B,IAAI,GAAG,CAAC,GACJ;UACEd,GAAG,EAAEe,IAAI,CAACf,GAAG,GAAG,CAACgB,EAAE,CAAChB,GAAG,GAAGe,IAAI,CAACf,GAAG,IAAIc,IAAI;UAC1CZ,GAAG,EAAEa,IAAI,CAACb,GAAG,GAAG,CAACc,EAAE,CAACd,GAAG,GAAGa,IAAI,CAACb,GAAG,IAAIY;QACxC,CAAC,GACDC,IACN,CAAC;MACH;;MAEA;MACA,KACE,IAAIlC,CAAC,GAAG+B,UAAU,GAAG,CAAC,EACtB/B,CAAC,IAAIlC,IAAI,CAACsE,GAAG,CAACJ,QAAQ,EAAET,WAAW,GAAG,CAAC,CAAC,EACxCvB,CAAC,EAAE,EACH;QACA8B,WAAW,CAACvB,IAAI,CAACW,QAAQ,CAAClB,CAAC,CAAE,CAAC;MAChC;;MAEA;MACA,IAAIgC,QAAQ,GAAGT,WAAW,GAAG,CAAC,EAAE;QAC9B,MAAMU,IAAI,GAAGJ,MAAM,GAAGG,QAAQ;QAC9B,MAAME,IAAI,GAAGhB,QAAQ,CAACc,QAAQ,CAAE;QAChC,MAAMG,EAAE,GAAGjB,QAAQ,CAACc,QAAQ,GAAG,CAAC,CAAE;QAClC,IAAIC,IAAI,GAAG,CAAC,EAAE;UACZH,WAAW,CAACvB,IAAI,CAAC;YACfY,GAAG,EAAEe,IAAI,CAACf,GAAG,GAAG,CAACgB,EAAE,CAAChB,GAAG,GAAGe,IAAI,CAACf,GAAG,IAAIc,IAAI;YAC1CZ,GAAG,EAAEa,IAAI,CAACb,GAAG,GAAG,CAACc,EAAE,CAACd,GAAG,GAAGa,IAAI,CAACb,GAAG,IAAIY;UACxC,CAAC,CAAC;QACJ;MACF;MAEAzC,UAAU,CAACsC,WAAW,CAAC;MACvB5C,YAAY,CAACK,OAAO,GAAG8C,qBAAqB,CAACZ,OAAO,CAAC;IACvD,CAAC;IAEDvC,YAAY,CAACK,OAAO,GAAG8C,qBAAqB,CAACZ,OAAO,CAAC;IAErD,OAAO,MAAMV,oBAAoB,CAAC7B,YAAY,CAACK,OAAO,CAAC;EACzD,CAAC,EAAE,CAACX,WAAW,EAAEG,QAAQ,EAAEI,WAAW,EAAEK,UAAU,EAAEH,QAAQ,CAAC,CAAC;EAE9D,OAAO,IAAI;AACb;AAEA,OAAO,MAAMqB,QAAQ,SAASrE,SAAS,CAAgB;EACrDiG,MAAMA,CAAA,EAAG;IACP,oBAAOzF,IAAA,CAAC8B,YAAY;MAAA,GAAK,IAAI,CAAC4D;IAAK,CAAG,CAAC;EACzC;AACF","ignoreList":[]}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
2
 
3
- export * from "./Marker.js";
4
- export * from "./Polyline.js";
3
+ export * from './Marker';
4
+ export * from './Polyline';
5
5
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":[],"sourceRoot":"../../../src","sources":["components/index.ts"],"mappings":";;AAAA,cAAc,aAAU;AACxB,cAAc,eAAY","ignoreList":[]}
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["components/index.ts"],"mappings":";;AAAA,cAAc,UAAU;AACxB,cAAc,YAAY","ignoreList":[]}
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ export { Marker } from "./Marker.web.js";
4
+ export { Polyline } from "./Polyline.web.js";
5
+ //# sourceMappingURL=index.web.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Marker","Polyline"],"sourceRoot":"../../../src","sources":["components/index.web.ts"],"mappings":";;AAAA,SAASA,MAAM,QAAQ,iBAAc;AACrC,SAASC,QAAQ,QAAQ,mBAAgB","ignoreList":[]}
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
 
3
- export { MapView } from "./MapView.js";
4
- export * from "./components/index.js";
3
+ export { MapView } from './MapView';
4
+ export { MapProvider } from './MapProvider';
5
+ export * from './components';
5
6
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["MapView"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;AAAA,SAASA,OAAO,QAAQ,cAAW;AACnC,cAAc,uBAAc","ignoreList":[]}
1
+ {"version":3,"names":["MapView","MapProvider"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;AAAA,SAASA,OAAO,QAAQ,WAAW;AACnC,SAASC,WAAW,QAAQ,eAAe;AAE3C,cAAc,cAAc","ignoreList":[]}
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+
3
+ export { MapView } from "./MapView.web.js";
4
+ export { MapProvider } from "./MapProvider.web.js";
5
+ export * from "./components/index.web.js";
6
+ //# sourceMappingURL=index.web.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["MapView","MapProvider"],"sourceRoot":"../../src","sources":["index.web.ts"],"mappings":";;AAAA,SAASA,OAAO,QAAQ,kBAAe;AACvC,SAASC,WAAW,QAAQ,sBAAmB;AAE/C,cAAc,2BAAwB","ignoreList":[]}
@@ -0,0 +1,8 @@
1
+ import type { MapProviderProps } from './MapProvider.types';
2
+ /**
3
+ * Provider component for map configuration.
4
+ * On web, wraps children with Google Maps APIProvider.
5
+ * On native, passes children through.
6
+ */
7
+ export declare function MapProvider({ children }: MapProviderProps): import("react").ReactNode;
8
+ //# sourceMappingURL=MapProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MapProvider.d.ts","sourceRoot":"","sources":["../../../src/MapProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAE5D;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,EAAE,QAAQ,EAAE,EAAE,gBAAgB,6BAEzD"}
@@ -0,0 +1,16 @@
1
+ import type { ReactNode } from 'react';
2
+ /**
3
+ * MapProvider props
4
+ */
5
+ export interface MapProviderProps {
6
+ /**
7
+ * Google Maps API key
8
+ * @platform web
9
+ */
10
+ apiKey?: string;
11
+ /**
12
+ * Map children
13
+ */
14
+ children: ReactNode;
15
+ }
16
+ //# sourceMappingURL=MapProvider.types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MapProvider.types.d.ts","sourceRoot":"","sources":["../../../src/MapProvider.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,QAAQ,EAAE,SAAS,CAAC;CACrB"}
@@ -0,0 +1,3 @@
1
+ import type { MapProviderProps } from './MapProvider.types';
2
+ export declare function MapProvider({ apiKey, children }: MapProviderProps): import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=MapProvider.web.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MapProvider.web.d.ts","sourceRoot":"","sources":["../../../src/MapProvider.web.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAE5D,wBAAgB,WAAW,CAAC,EAAE,MAAW,EAAE,QAAQ,EAAE,EAAE,gBAAgB,2CAEtE"}
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ import type { MapViewProps, MapViewRef, MoveCameraOptions, FitCoordinatesOptions } from './MapView.types';
3
+ import type { Coordinate } from './types';
4
+ export declare class MapView extends React.Component<MapViewProps> implements MapViewRef {
5
+ static defaultProps: Partial<MapViewProps>;
6
+ private mapInstance;
7
+ private handleMapReady;
8
+ moveCamera(coordinate: Coordinate, options: MoveCameraOptions): void;
9
+ fitCoordinates(coordinates: Coordinate[], options?: FitCoordinatesOptions): void;
10
+ render(): import("react/jsx-runtime").JSX.Element;
11
+ }
12
+ //# sourceMappingURL=MapView.web.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MapView.web.d.ts","sourceRoot":"","sources":["../../../src/MapView.web.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,OAAO,KAAK,EACV,YAAY,EACZ,UAAU,EACV,iBAAiB,EACjB,qBAAqB,EAEtB,MAAM,iBAAiB,CAAC;AACzB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAiG1C,qBAAa,OACX,SAAQ,KAAK,CAAC,SAAS,CAAC,YAAY,CACpC,YAAW,UAAU;IAErB,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,YAAY,CAAC,CAOxC;IAEF,OAAO,CAAC,WAAW,CAAgC;IAEnD,OAAO,CAAC,cAAc,CAEpB;IAEF,UAAU,CAAC,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,iBAAiB;IAgB7D,cAAc,CAAC,WAAW,EAAE,UAAU,EAAE,EAAE,OAAO,CAAC,EAAE,qBAAqB;IA0BzE,MAAM;CAkFP"}
@@ -22,6 +22,10 @@ export interface MarkerProps {
22
22
  * Anchor point for custom marker views
23
23
  */
24
24
  anchor?: Point;
25
+ /**
26
+ * Z-index for marker ordering. Higher values render on top.
27
+ */
28
+ zIndex?: number;
25
29
  /**
26
30
  * Custom marker view
27
31
  */
@@ -1 +1 @@
1
- {"version":3,"file":"Marker.d.ts","sourceRoot":"","sources":["../../../../src/components/Marker.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC,OAAO,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAElD,MAAM,WAAW,WAAW;IAC1B;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;;OAEG;IACH,UAAU,EAAE,UAAU,CAAC;IACvB;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB;;OAEG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC;IACf;;OAEG;IACH,QAAQ,CAAC,EAAE,SAAS,CAAC;CACtB;AAED,qBAAa,MAAO,SAAQ,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC;IACtD,MAAM;CAiBP"}
1
+ {"version":3,"file":"Marker.d.ts","sourceRoot":"","sources":["../../../../src/components/Marker.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC,OAAO,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAElD,MAAM,WAAW,WAAW;IAC1B;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;;OAEG;IACH,UAAU,EAAE,UAAU,CAAC;IACvB;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB;;OAEG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC;IACf;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,QAAQ,CAAC,EAAE,SAAS,CAAC;CACtB;AAED,qBAAa,MAAO,SAAQ,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC;IACtD,MAAM;CAiBP"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import type { MarkerProps } from './Marker';
3
+ export declare class Marker extends React.Component<MarkerProps> {
4
+ render(): import("react/jsx-runtime").JSX.Element;
5
+ }
6
+ //# sourceMappingURL=Marker.web.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Marker.web.d.ts","sourceRoot":"","sources":["../../../../src/components/Marker.web.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAQ5C,qBAAa,MAAO,SAAQ,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC;IACtD,MAAM;CAoBP"}
@@ -0,0 +1,6 @@
1
+ import { Component } from 'react';
2
+ import type { PolylineProps } from './Polyline';
3
+ export declare class Polyline extends Component<PolylineProps> {
4
+ render(): import("react/jsx-runtime").JSX.Element;
5
+ }
6
+ //# sourceMappingURL=Polyline.web.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Polyline.web.d.ts","sourceRoot":"","sources":["../../../../src/components/Polyline.web.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAMV,MAAM,OAAO,CAAC;AAEf,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAgMhD,qBAAa,QAAS,SAAQ,SAAS,CAAC,aAAa,CAAC;IACpD,MAAM;CAGP"}
@@ -0,0 +1,5 @@
1
+ export { Marker } from './Marker.web';
2
+ export { Polyline } from './Polyline.web';
3
+ export type { MarkerProps } from './Marker';
4
+ export type { PolylineProps } from './Polyline';
5
+ //# sourceMappingURL=index.web.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.web.d.ts","sourceRoot":"","sources":["../../../../src/components/index.web.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,YAAY,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC5C,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC"}
@@ -1,5 +1,7 @@
1
1
  export { MapView } from './MapView';
2
+ export { MapProvider } from './MapProvider';
3
+ export type { MapProviderProps } from './MapProvider.types';
2
4
  export * from './components';
3
5
  export type { MapViewProps, MapViewRef, MoveCameraOptions, FitCoordinatesOptions, CameraEventPayload, } from './MapView.types';
4
- export type { MapProvider, Coordinate, Point, EdgeInsets } from './types';
6
+ export type { MapProvider as MapProviderType, Coordinate, Point, EdgeInsets, } from './types';
5
7
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,cAAc,cAAc,CAAC;AAC7B,YAAY,EACV,YAAY,EACZ,UAAU,EACV,iBAAiB,EACjB,qBAAqB,EACrB,kBAAkB,GACnB,MAAM,iBAAiB,CAAC;AACzB,YAAY,EAAE,WAAW,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,YAAY,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,cAAc,cAAc,CAAC;AAC7B,YAAY,EACV,YAAY,EACZ,UAAU,EACV,iBAAiB,EACjB,qBAAqB,EACrB,kBAAkB,GACnB,MAAM,iBAAiB,CAAC;AACzB,YAAY,EACV,WAAW,IAAI,eAAe,EAC9B,UAAU,EACV,KAAK,EACL,UAAU,GACX,MAAM,SAAS,CAAC"}
@@ -0,0 +1,7 @@
1
+ export { MapView } from './MapView.web';
2
+ export { MapProvider } from './MapProvider.web';
3
+ export type { MapProviderProps } from './MapProvider.types';
4
+ export * from './components/index.web';
5
+ export type { MapViewProps, MapViewRef, MoveCameraOptions, FitCoordinatesOptions, CameraEventPayload, } from './MapView.types';
6
+ export type { MapProvider as MapProviderType, Coordinate, Point, EdgeInsets, } from './types';
7
+ //# sourceMappingURL=index.web.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.web.d.ts","sourceRoot":"","sources":["../../../src/index.web.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,YAAY,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,cAAc,wBAAwB,CAAC;AACvC,YAAY,EACV,YAAY,EACZ,UAAU,EACV,iBAAiB,EACjB,qBAAqB,EACrB,kBAAkB,GACnB,MAAM,iBAAiB,CAAC;AACzB,YAAY,EACV,WAAW,IAAI,eAAe,EAC9B,UAAU,EACV,KAAK,EACL,UAAU,GACX,MAAM,SAAS,CAAC"}
package/package.json CHANGED
@@ -1,12 +1,17 @@
1
1
  {
2
2
  "name": "@lugg/maps",
3
- "version": "0.2.0-alpha.5",
3
+ "version": "0.2.0-alpha.7",
4
4
  "description": "Universal maps for React Native.",
5
5
  "main": "./lib/module/index.js",
6
6
  "types": "./lib/typescript/src/index.d.ts",
7
7
  "exports": {
8
8
  ".": {
9
9
  "source": "./src/index.ts",
10
+ "react-native": "./lib/module/index.js",
11
+ "web": {
12
+ "types": "./lib/typescript/src/index.web.d.ts",
13
+ "default": "./lib/module/index.web.js"
14
+ },
10
15
  "types": "./lib/typescript/src/index.d.ts",
11
16
  "default": "./lib/module/index.js"
12
17
  },
@@ -75,6 +80,7 @@
75
80
  "@release-it/conventional-changelog": "^10.0.1",
76
81
  "@types/jest": "^29.5.14",
77
82
  "@types/react": "^19.2.0",
83
+ "@vis.gl/react-google-maps": "^1.7.1",
78
84
  "commitlint": "^19.8.1",
79
85
  "del-cli": "^6.0.0",
80
86
  "eslint": "^9.35.0",
@@ -91,9 +97,15 @@
91
97
  "typescript": "^5.9.2"
92
98
  },
93
99
  "peerDependencies": {
100
+ "@vis.gl/react-google-maps": ">=1.0.0",
94
101
  "react": "*",
95
102
  "react-native": "*"
96
103
  },
104
+ "peerDependenciesMeta": {
105
+ "@vis.gl/react-google-maps": {
106
+ "optional": true
107
+ }
108
+ },
97
109
  "dependencies": {
98
110
  "@expo/config-plugins": "^9.0.0"
99
111
  },
@@ -0,0 +1,10 @@
1
+ import type { MapProviderProps } from './MapProvider.types';
2
+
3
+ /**
4
+ * Provider component for map configuration.
5
+ * On web, wraps children with Google Maps APIProvider.
6
+ * On native, passes children through.
7
+ */
8
+ export function MapProvider({ children }: MapProviderProps) {
9
+ return children;
10
+ }
@@ -0,0 +1,16 @@
1
+ import type { ReactNode } from 'react';
2
+
3
+ /**
4
+ * MapProvider props
5
+ */
6
+ export interface MapProviderProps {
7
+ /**
8
+ * Google Maps API key
9
+ * @platform web
10
+ */
11
+ apiKey?: string;
12
+ /**
13
+ * Map children
14
+ */
15
+ children: ReactNode;
16
+ }
@@ -0,0 +1,6 @@
1
+ import { APIProvider } from '@vis.gl/react-google-maps';
2
+ import type { MapProviderProps } from './MapProvider.types';
3
+
4
+ export function MapProvider({ apiKey = '', children }: MapProviderProps) {
5
+ return <APIProvider apiKey={apiKey}>{children}</APIProvider>;
6
+ }