@nuxt/scripts 1.0.0-beta.6 → 1.0.0-rc.1

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 (256) hide show
  1. package/dist/devtools-client/200.html +1 -0
  2. package/dist/devtools-client/404.html +1 -0
  3. package/dist/devtools-client/_fonts/4ppnHhMi-pBsWSPo7mY0avYxlDoAg1N3PTzCwXLZ5rA-d9oibkGnTd1JL3tc_xnaVgBLYmOB8kjrK2cvZaqwj9s.woff2 +0 -0
  4. package/dist/devtools-client/_fonts/4qBuU9MRVUlPZNPSF7Xom_sK8RBEnfYu-9VXFrdq8A8-8TDwLE1HAj1sQn7XxVWtM_7sIaPM-DTdO3Pf8U2DF1U.woff2 +0 -0
  5. package/dist/devtools-client/_fonts/6dYsbWUd_BpKJ7mdDihgOcya1gHXLpJBuMYXux3WMjE-q3fYNS8YbW5n7ZeXI2vSNgkRWW5VDPKAl51SNTjG2qk.woff2 +0 -0
  6. package/dist/devtools-client/_fonts/Lr-hqqZZsYmCt0ITUlr1CUrWim9fsKvoDFZliMxgNHY-iTa_Yt_PzhOY9TX7ZXdSlEPim6iRt92xhECwaxWxd5w.woff2 +0 -0
  7. package/dist/devtools-client/_fonts/OknHvWI6KtYn1JQBzX7eSpNDBQ8520F9TvSUJYkVf6A-xeZn9253svK_8Q2LD0XEruY_MnEsuCRO5LenPoggC0Y.woff2 +0 -0
  8. package/dist/devtools-client/_fonts/PV2hrQG6wq5BlIPDjdL1IcOflycaghyt5MHzlBqZtlo-lb_WexLz3VZqfTN0oi554iBH5tT2j2UFEV-XErCAS3E.woff2 +0 -0
  9. package/dist/devtools-client/_fonts/UA7OtwYHwGN_HjcVGTdmiQxUit7FlqkCwxVUWSeXVnQ-B4OXCFOL_tWrYODpQTc07aMaj0c2cewTOmBRWR9tD-A.woff2 +0 -0
  10. package/dist/devtools-client/_fonts/VE4cDVCv5MxbFM7ZLoLCGbIpNd71zhp7MDI9lmN5Y7I-xZyDYCUVrd6LV8eVGF3Um3UZjBFuUtDGtvdyTBBRYBo.woff2 +0 -0
  11. package/dist/devtools-client/_fonts/fVoGbnMbBFd5L9BBp9fUPavUSkZ_EmsQNSyadkT-108-U4T0khaeLQSIhtt9eVvaCEKJjtWJ4ioRJOf8hvqkWY0.woff2 +0 -0
  12. package/dist/devtools-client/_fonts/lQAxeCEs1R0Lw-H9XRU1RlOARQN8J6npRsPjyEDMe5s-_DUSLEkO3tKTuun_gSnDLoQPVEnpOnyqZMOw0ByZ6PA.woff2 +0 -0
  13. package/dist/devtools-client/_fonts/lntlqNHKLV2n82yTwMde70QqOjcfLE2XJ5oKZ3vRPWc-z6TxpIZQdWXztWLr9_OFWqt_WJJoeGtuK_-XQMZGQwE.woff2 +0 -0
  14. package/dist/devtools-client/_fonts/qxAYvKsXWeYv731eb-h5TRurcdIP_W44mpNdX-HABAk-zUDeMEFlNtNbrwvT9JxLEBg0TphGy70O6RfIoIX_ZwU.woff2 +0 -0
  15. package/dist/devtools-client/_nuxt/B3kN3DAy.js +1 -0
  16. package/dist/devtools-client/_nuxt/B8PEiB0p.js +1 -0
  17. package/dist/devtools-client/_nuxt/C8jhSQ8l.js +1 -0
  18. package/dist/devtools-client/_nuxt/CJD6wrkT.js +188 -0
  19. package/dist/devtools-client/_nuxt/CfOsp0mU.js +1 -0
  20. package/dist/devtools-client/_nuxt/DKL6PHO3.js +1 -0
  21. package/dist/devtools-client/_nuxt/ajngqPCs.js +1 -0
  22. package/dist/devtools-client/_nuxt/builds/latest.json +1 -0
  23. package/dist/devtools-client/_nuxt/builds/meta/b800a0be-5cab-4ea6-89e3-dd3a85690a73.json +1 -0
  24. package/dist/devtools-client/_nuxt/dlaR8P-P.js +1 -0
  25. package/dist/devtools-client/_nuxt/entry.BwpOBArY.css +1 -0
  26. package/dist/devtools-client/_nuxt/error-404.CvOVjXeC.css +1 -0
  27. package/dist/devtools-client/_nuxt/error-500.BIm53nmx.css +1 -0
  28. package/dist/devtools-client/_nuxt/first-party.C8Ha4JLM.css +1 -0
  29. package/dist/devtools-client/_nuxt/index.CA-OpSj0.css +1 -0
  30. package/dist/devtools-client/_nuxt/registry.B9lnjF_b.css +1 -0
  31. package/dist/devtools-client/_nuxt/wDzz0qaB.js +1 -0
  32. package/dist/devtools-client/docs/index.html +1 -0
  33. package/dist/devtools-client/first-party/index.html +1 -0
  34. package/dist/devtools-client/index.html +1 -0
  35. package/dist/devtools-client/registry/index.html +1 -0
  36. package/dist/module.d.mts +29 -84
  37. package/dist/module.d.ts +121 -0
  38. package/dist/module.json +1 -1
  39. package/dist/module.mjs +941 -757
  40. package/dist/registry.d.mts +91 -4
  41. package/dist/registry.d.ts +93 -0
  42. package/dist/registry.mjs +669 -324
  43. package/dist/runtime/components/GoogleMaps/ScriptGoogleMaps.d.vue.ts +15 -79
  44. package/dist/runtime/components/GoogleMaps/ScriptGoogleMaps.vue +78 -180
  45. package/dist/runtime/components/GoogleMaps/ScriptGoogleMaps.vue.d.ts +15 -79
  46. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsAdvancedMarkerElement.d.vue.ts +6 -55
  47. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsAdvancedMarkerElement.vue +12 -83
  48. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsAdvancedMarkerElement.vue.d.ts +6 -55
  49. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsCircle.d.vue.ts +5 -1
  50. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsCircle.vue +24 -38
  51. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsCircle.vue.d.ts +5 -1
  52. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsGeoJson.d.vue.ts +43 -0
  53. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsGeoJson.vue +60 -0
  54. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsGeoJson.vue.d.ts +43 -0
  55. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsHeatmapLayer.d.vue.ts +4 -0
  56. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsHeatmapLayer.vue +22 -26
  57. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsHeatmapLayer.vue.d.ts +4 -0
  58. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsInfoWindow.d.vue.ts +9 -5
  59. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsInfoWindow.vue +56 -57
  60. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsInfoWindow.vue.d.ts +9 -5
  61. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarker.d.vue.ts +24 -41
  62. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarker.vue +69 -73
  63. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarker.vue.d.ts +24 -41
  64. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarkerClusterer.d.vue.ts +36 -4
  65. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarkerClusterer.vue +82 -37
  66. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarkerClusterer.vue.d.ts +36 -4
  67. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsOverlayView.d.vue.ts +78 -0
  68. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsOverlayView.vue +222 -0
  69. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsOverlayView.vue.d.ts +78 -0
  70. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPinElement.d.vue.ts +10 -3
  71. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPinElement.vue +9 -41
  72. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPinElement.vue.d.ts +10 -3
  73. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolygon.d.vue.ts +7 -3
  74. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolygon.vue +23 -38
  75. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolygon.vue.d.ts +7 -3
  76. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolyline.d.vue.ts +7 -3
  77. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolyline.vue +23 -38
  78. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolyline.vue.d.ts +7 -3
  79. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsRectangle.d.vue.ts +7 -3
  80. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsRectangle.vue +24 -38
  81. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsRectangle.vue.d.ts +7 -3
  82. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsStaticMap.d.vue.ts +200 -0
  83. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsStaticMap.vue +165 -0
  84. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsStaticMap.vue.d.ts +200 -0
  85. package/dist/runtime/components/GoogleMaps/bindGoogleMapsEvents.d.ts +13 -0
  86. package/dist/runtime/components/GoogleMaps/bindGoogleMapsEvents.js +8 -0
  87. package/dist/runtime/components/GoogleMaps/injectionKeys.d.ts +10 -0
  88. package/dist/runtime/components/GoogleMaps/injectionKeys.js +2 -0
  89. package/dist/runtime/components/GoogleMaps/useGoogleMapsResource.d.ts +48 -0
  90. package/dist/runtime/components/GoogleMaps/useGoogleMapsResource.js +51 -0
  91. package/dist/runtime/components/ScriptBlueskyEmbed.d.vue.ts +85 -0
  92. package/dist/runtime/components/ScriptBlueskyEmbed.vue +88 -0
  93. package/dist/runtime/components/ScriptBlueskyEmbed.vue.d.ts +85 -0
  94. package/dist/runtime/components/ScriptCrisp.vue +1 -1
  95. package/dist/runtime/components/ScriptGoogleAdsense.vue +1 -1
  96. package/dist/runtime/components/ScriptGravatar.d.vue.ts +22 -0
  97. package/dist/runtime/components/ScriptGravatar.vue +46 -0
  98. package/dist/runtime/components/ScriptGravatar.vue.d.ts +22 -0
  99. package/dist/runtime/components/ScriptInstagramEmbed.d.vue.ts +1 -2
  100. package/dist/runtime/components/ScriptInstagramEmbed.vue +8 -3
  101. package/dist/runtime/components/ScriptInstagramEmbed.vue.d.ts +1 -2
  102. package/dist/runtime/components/ScriptIntercom.vue +4 -3
  103. package/dist/runtime/components/ScriptPayPalButtons.d.vue.ts +43 -32
  104. package/dist/runtime/components/ScriptPayPalButtons.vue +48 -79
  105. package/dist/runtime/components/ScriptPayPalButtons.vue.d.ts +43 -32
  106. package/dist/runtime/components/ScriptPayPalMessages.d.vue.ts +37 -23
  107. package/dist/runtime/components/ScriptPayPalMessages.vue +46 -50
  108. package/dist/runtime/components/ScriptPayPalMessages.vue.d.ts +37 -23
  109. package/dist/runtime/components/ScriptStripePricingTable.vue +2 -2
  110. package/dist/runtime/components/ScriptVimeoPlayer.d.vue.ts +9 -0
  111. package/dist/runtime/components/ScriptVimeoPlayer.vue +13 -10
  112. package/dist/runtime/components/ScriptVimeoPlayer.vue.d.ts +9 -0
  113. package/dist/runtime/components/ScriptXEmbed.d.vue.ts +0 -2
  114. package/dist/runtime/components/ScriptXEmbed.vue +14 -8
  115. package/dist/runtime/components/ScriptXEmbed.vue.d.ts +0 -2
  116. package/dist/runtime/components/ScriptYouTubePlayer.d.vue.ts +2 -2
  117. package/dist/runtime/components/ScriptYouTubePlayer.vue +11 -5
  118. package/dist/runtime/components/ScriptYouTubePlayer.vue.d.ts +2 -2
  119. package/dist/runtime/composables/useScript.js +148 -8
  120. package/dist/runtime/composables/useScriptEventPage.js +2 -2
  121. package/dist/runtime/composables/useScriptTriggerConsent.d.ts +10 -0
  122. package/dist/runtime/composables/useScriptTriggerConsent.js +33 -20
  123. package/dist/runtime/composables/useScriptTriggerElement.js +1 -1
  124. package/dist/runtime/composables/useScriptTriggerIdleTimeout.js +1 -1
  125. package/dist/runtime/devtools-standalone-bridge.client.d.ts +8 -0
  126. package/dist/runtime/devtools-standalone-bridge.client.js +50 -0
  127. package/dist/runtime/registry/bing-uet.d.ts +20 -0
  128. package/dist/runtime/registry/bing-uet.js +29 -0
  129. package/dist/runtime/registry/bluesky-embed.d.ts +116 -0
  130. package/dist/runtime/registry/bluesky-embed.js +72 -0
  131. package/dist/runtime/registry/clarity.d.ts +10 -15
  132. package/dist/runtime/registry/clarity.js +22 -31
  133. package/dist/runtime/registry/cloudflare-web-analytics.d.ts +2 -13
  134. package/dist/runtime/registry/cloudflare-web-analytics.js +2 -14
  135. package/dist/runtime/registry/crisp.d.ts +10 -40
  136. package/dist/runtime/registry/crisp.js +2 -33
  137. package/dist/runtime/registry/databuddy-analytics.d.ts +2 -35
  138. package/dist/runtime/registry/databuddy-analytics.js +20 -45
  139. package/dist/runtime/registry/fathom-analytics.d.ts +7 -26
  140. package/dist/runtime/registry/fathom-analytics.js +3 -25
  141. package/dist/runtime/registry/google-adsense.d.ts +3 -11
  142. package/dist/runtime/registry/google-adsense.js +2 -11
  143. package/dist/runtime/registry/google-analytics.d.ts +3 -5
  144. package/dist/runtime/registry/google-analytics.js +3 -8
  145. package/dist/runtime/registry/google-maps.d.ts +3 -9
  146. package/dist/runtime/registry/google-maps.js +2 -8
  147. package/dist/runtime/registry/google-recaptcha.d.ts +2 -6
  148. package/dist/runtime/registry/google-recaptcha.js +4 -12
  149. package/dist/runtime/registry/google-sign-in.d.ts +2 -13
  150. package/dist/runtime/registry/google-sign-in.js +2 -22
  151. package/dist/runtime/registry/google-tag-manager.d.ts +3 -28
  152. package/dist/runtime/registry/google-tag-manager.js +4 -27
  153. package/dist/runtime/registry/gravatar.d.ts +26 -0
  154. package/dist/runtime/registry/gravatar.js +36 -0
  155. package/dist/runtime/registry/hotjar.d.ts +4 -6
  156. package/dist/runtime/registry/hotjar.js +2 -5
  157. package/dist/runtime/registry/instagram-embed.d.ts +3 -18
  158. package/dist/runtime/registry/instagram-embed.js +4 -19
  159. package/dist/runtime/registry/intercom.d.ts +5 -13
  160. package/dist/runtime/registry/intercom.js +2 -12
  161. package/dist/runtime/registry/matomo-analytics.d.ts +3 -12
  162. package/dist/runtime/registry/matomo-analytics.js +3 -12
  163. package/dist/runtime/registry/meta-pixel.d.ts +4 -6
  164. package/dist/runtime/registry/meta-pixel.js +2 -4
  165. package/dist/runtime/registry/mixpanel-analytics.d.ts +22 -0
  166. package/dist/runtime/registry/mixpanel-analytics.js +46 -0
  167. package/dist/runtime/registry/npm.d.ts +3 -7
  168. package/dist/runtime/registry/npm.js +2 -9
  169. package/dist/runtime/registry/paypal.d.ts +4 -25
  170. package/dist/runtime/registry/paypal.js +3 -66
  171. package/dist/runtime/registry/plausible-analytics.js +19 -14
  172. package/dist/runtime/registry/posthog.d.ts +10 -12
  173. package/dist/runtime/registry/posthog.js +4 -13
  174. package/dist/runtime/registry/reddit-pixel.d.ts +5 -6
  175. package/dist/runtime/registry/reddit-pixel.js +2 -4
  176. package/dist/runtime/registry/rybbit-analytics.d.ts +2 -14
  177. package/dist/runtime/registry/rybbit-analytics.js +10 -20
  178. package/dist/runtime/registry/schemas.d.ts +982 -0
  179. package/dist/runtime/registry/schemas.js +937 -0
  180. package/dist/runtime/registry/segment.d.ts +2 -5
  181. package/dist/runtime/registry/segment.js +2 -5
  182. package/dist/runtime/registry/snapchat-pixel.d.ts +5 -34
  183. package/dist/runtime/registry/snapchat-pixel.js +2 -20
  184. package/dist/runtime/registry/stripe.d.ts +3 -4
  185. package/dist/runtime/registry/stripe.js +2 -4
  186. package/dist/runtime/registry/tiktok-pixel.d.ts +4 -7
  187. package/dist/runtime/registry/tiktok-pixel.js +2 -6
  188. package/dist/runtime/registry/umami-analytics.d.ts +2 -31
  189. package/dist/runtime/registry/umami-analytics.js +2 -36
  190. package/dist/runtime/registry/vercel-analytics.d.ts +29 -0
  191. package/dist/runtime/registry/vercel-analytics.js +84 -0
  192. package/dist/runtime/registry/vimeo-player.d.ts +2 -2
  193. package/dist/runtime/registry/vimeo-player.js +1 -1
  194. package/dist/runtime/registry/x-embed.d.ts +3 -17
  195. package/dist/runtime/registry/x-embed.js +3 -18
  196. package/dist/runtime/registry/x-pixel.d.ts +4 -7
  197. package/dist/runtime/registry/x-pixel.js +2 -5
  198. package/dist/runtime/registry/youtube-player.d.ts +7 -7
  199. package/dist/runtime/registry/youtube-player.js +1 -1
  200. package/dist/runtime/server/bluesky-embed-image.d.ts +2 -0
  201. package/dist/runtime/server/bluesky-embed-image.js +7 -0
  202. package/dist/runtime/server/bluesky-embed.d.ts +16 -0
  203. package/dist/runtime/server/bluesky-embed.js +59 -0
  204. package/dist/runtime/server/google-maps-geocode-proxy.d.ts +2 -0
  205. package/dist/runtime/server/google-maps-geocode-proxy.js +34 -0
  206. package/dist/runtime/server/google-static-maps-proxy.js +2 -13
  207. package/dist/runtime/server/gravatar-proxy.d.ts +2 -0
  208. package/dist/runtime/server/gravatar-proxy.js +46 -0
  209. package/dist/runtime/server/instagram-embed-asset.js +8 -41
  210. package/dist/runtime/server/instagram-embed-image.js +6 -53
  211. package/dist/runtime/server/instagram-embed.d.ts +16 -0
  212. package/dist/runtime/server/instagram-embed.js +176 -35
  213. package/dist/runtime/server/proxy-handler.js +142 -95
  214. package/dist/runtime/server/utils/image-proxy.d.ts +12 -0
  215. package/dist/runtime/server/utils/image-proxy.js +70 -0
  216. package/dist/runtime/server/utils/privacy.d.ts +1 -10
  217. package/dist/runtime/server/utils/privacy.js +60 -40
  218. package/dist/runtime/server/x-embed-image.js +5 -49
  219. package/dist/runtime/server/x-embed.js +3 -2
  220. package/dist/runtime/types.d.ts +272 -51
  221. package/dist/runtime/types.js +0 -2
  222. package/dist/runtime/utils/pure.d.ts +1 -1
  223. package/dist/runtime/utils.d.ts +6 -4
  224. package/dist/runtime/utils.js +31 -14
  225. package/dist/stats.d.mts +202 -0
  226. package/dist/stats.d.ts +202 -0
  227. package/dist/stats.mjs +3875 -0
  228. package/dist/types-source.d.mts +17 -0
  229. package/dist/types-source.d.ts +17 -0
  230. package/dist/types-source.mjs +3414 -0
  231. package/dist/types.d.mts +4 -2
  232. package/package.json +35 -61
  233. package/README.md +0 -86
  234. package/dist/client/200.html +0 -1
  235. package/dist/client/404.html +0 -1
  236. package/dist/client/_nuxt/BPQ3VLAy.js +0 -1
  237. package/dist/client/_nuxt/BpR-tlZc.js +0 -1
  238. package/dist/client/_nuxt/CBbMDhE2.js +0 -162
  239. package/dist/client/_nuxt/CEMAW3aB.js +0 -1
  240. package/dist/client/_nuxt/MWkREqzj.js +0 -1
  241. package/dist/client/_nuxt/builds/latest.json +0 -1
  242. package/dist/client/_nuxt/builds/meta/762d443a-0880-424f-bda8-2b32b39d43ec.json +0 -1
  243. package/dist/client/_nuxt/entry.D45OuV0w.css +0 -1
  244. package/dist/client/_nuxt/error-404.B57D-jUQ.css +0 -1
  245. package/dist/client/_nuxt/error-500.DTHUW7BI.css +0 -1
  246. package/dist/client/index.html +0 -1
  247. package/dist/runtime/components/ScriptPayPalMarks.d.vue.ts +0 -52
  248. package/dist/runtime/components/ScriptPayPalMarks.vue +0 -69
  249. package/dist/runtime/components/ScriptPayPalMarks.vue.d.ts +0 -52
  250. package/dist/runtime/validation/mock.d.ts +0 -42
  251. package/dist/runtime/validation/mock.js +0 -21
  252. package/dist/runtime/validation/valibot.d.ts +0 -1
  253. package/dist/runtime/validation/valibot.js +0 -1
  254. /package/dist/{client → devtools-client}/_nuxt/CVO1_9PV.js +0 -0
  255. /package/dist/{client → devtools-client}/_nuxt/Cp-IABpG.js +0 -0
  256. /package/dist/{client → devtools-client}/_nuxt/D0r3Knsf.js +0 -0
@@ -0,0 +1,78 @@
1
+ type OverlayAnchor = 'center' | 'top-left' | 'top-center' | 'top-right' | 'bottom-left' | 'bottom-center' | 'bottom-right' | 'left-center' | 'right-center';
2
+ type OverlayPane = 'mapPane' | 'overlayLayer' | 'markerLayer' | 'overlayMouseTarget' | 'floatPane';
3
+ type __VLS_Props = {
4
+ /**
5
+ * Geographic position for the overlay. Falls back to parent marker position if omitted.
6
+ * @see https://developers.google.com/maps/documentation/javascript/reference/overlay-view#OverlayView
7
+ */
8
+ position?: google.maps.LatLngLiteral;
9
+ /**
10
+ * Anchor point of the overlay relative to its position.
11
+ * @default 'bottom-center'
12
+ */
13
+ anchor?: OverlayAnchor;
14
+ /**
15
+ * Pixel offset from the anchor position.
16
+ */
17
+ offset?: {
18
+ x: number;
19
+ y: number;
20
+ };
21
+ /**
22
+ * The map pane on which to render the overlay.
23
+ * @default 'floatPane'
24
+ * @see https://developers.google.com/maps/documentation/javascript/reference/overlay-view#MapPanes
25
+ */
26
+ pane?: OverlayPane;
27
+ /**
28
+ * CSS z-index for the overlay element.
29
+ */
30
+ zIndex?: number;
31
+ /**
32
+ * Whether to block map click and gesture events from passing through the overlay.
33
+ * @default true
34
+ */
35
+ blockMapInteraction?: boolean;
36
+ /**
37
+ * Pan the map so the overlay is fully visible when opened, similar to InfoWindow behavior.
38
+ * Set to `true` for default 40px padding, or a number for custom padding.
39
+ * @default true
40
+ */
41
+ panOnOpen?: boolean | number;
42
+ /**
43
+ * Automatically hide the overlay when its parent marker joins a cluster (on zoom out).
44
+ * Only applies when nested inside a ScriptGoogleMapsMarkerClusterer.
45
+ * @default true
46
+ */
47
+ hideWhenClustered?: boolean;
48
+ };
49
+ type __VLS_ModelProps = {
50
+ 'open'?: boolean;
51
+ };
52
+ type __VLS_PublicProps = __VLS_Props & __VLS_ModelProps;
53
+ declare var __VLS_1: {};
54
+ type __VLS_Slots = {} & {
55
+ default?: (props: typeof __VLS_1) => any;
56
+ };
57
+ declare const __VLS_base: import("vue").DefineComponent<__VLS_PublicProps, {
58
+ overlay: import("vue").ShallowRef<google.maps.OverlayView | undefined>;
59
+ dataState: import("vue").ComputedRef<"open" | "closed">;
60
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
61
+ "update:open": (value: boolean) => any;
62
+ }, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
63
+ "onUpdate:open"?: ((value: boolean) => any) | undefined;
64
+ }>, {
65
+ anchor: OverlayAnchor;
66
+ pane: OverlayPane;
67
+ blockMapInteraction: boolean;
68
+ panOnOpen: boolean | number;
69
+ hideWhenClustered: boolean;
70
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
71
+ declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
72
+ declare const _default: typeof __VLS_export;
73
+ export default _default;
74
+ type __VLS_WithSlots<T, S> = T & {
75
+ new (): {
76
+ $slots: S;
77
+ };
78
+ };
@@ -1,6 +1,13 @@
1
- type __VLS_Props = {
2
- options?: Omit<google.maps.marker.PinElementOptions, 'map'>;
1
+ declare var __VLS_1: {};
2
+ type __VLS_Slots = {} & {
3
+ default?: (props: typeof __VLS_1) => any;
3
4
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const __VLS_base: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
6
+ declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
5
7
  declare const _default: typeof __VLS_export;
6
8
  export default _default;
9
+ type __VLS_WithSlots<T, S> = T & {
10
+ new (): {
11
+ $slots: S;
12
+ };
13
+ };
@@ -1,43 +1,11 @@
1
- <template>
2
-
3
- </template>
4
-
5
1
  <script setup>
6
- import { inject, onUnmounted, shallowRef } from "vue";
7
- import { whenever } from "@vueuse/core";
8
- import { MAP_INJECTION_KEY } from "./ScriptGoogleMaps.vue";
9
- import { ADVANCED_MARKER_ELEMENT_INJECTION_KEY } from "./ScriptGoogleMapsAdvancedMarkerElement.vue";
10
- const props = defineProps({
11
- options: { type: Object, required: false }
12
- });
13
- const mapContext = inject(MAP_INJECTION_KEY, void 0);
14
- const advancedMarkerElementContext = inject(ADVANCED_MARKER_ELEMENT_INJECTION_KEY, void 0);
15
- const pinElement = shallowRef(void 0);
16
- whenever(
17
- () => mapContext?.map.value && mapContext.mapsApi.value && advancedMarkerElementContext?.advancedMarkerElement.value,
18
- async () => {
19
- await mapContext.mapsApi.value.importLibrary("marker");
20
- pinElement.value = new mapContext.mapsApi.value.marker.PinElement(props.options);
21
- if (advancedMarkerElementContext?.advancedMarkerElement.value) {
22
- advancedMarkerElementContext.advancedMarkerElement.value.content = pinElement.value.element;
23
- }
24
- whenever(() => props.options, (options) => {
25
- if (pinElement.value && options) {
26
- Object.assign(pinElement.value, options);
27
- }
28
- }, {
29
- deep: true
30
- });
31
- },
32
- {
33
- immediate: true,
34
- once: true
35
- }
36
- );
37
- onUnmounted(() => {
38
- if (advancedMarkerElementContext?.advancedMarkerElement.value && pinElement.value) {
39
- advancedMarkerElementContext.advancedMarkerElement.value.content = null;
40
- }
41
- pinElement.value = void 0;
42
- });
2
+ if (import.meta.dev) {
3
+ console.warn(
4
+ "[nuxt-scripts] <ScriptGoogleMapsPinElement> was removed in v1. Use the #content slot on <ScriptGoogleMapsMarker> instead. See https://scripts.nuxt.com/docs/migration-guide/v0-to-v1"
5
+ );
6
+ }
43
7
  </script>
8
+
9
+ <template>
10
+ <slot />
11
+ </template>
@@ -1,6 +1,13 @@
1
- type __VLS_Props = {
2
- options?: Omit<google.maps.marker.PinElementOptions, 'map'>;
1
+ declare var __VLS_1: {};
2
+ type __VLS_Slots = {} & {
3
+ default?: (props: typeof __VLS_1) => any;
3
4
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const __VLS_base: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
6
+ declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
5
7
  declare const _default: typeof __VLS_export;
6
8
  export default _default;
9
+ type __VLS_WithSlots<T, S> = T & {
10
+ new (): {
11
+ $slots: S;
12
+ };
13
+ };
@@ -1,9 +1,13 @@
1
1
  type __VLS_Props = {
2
+ /**
3
+ * Configuration options for the polygon overlay.
4
+ * @see https://developers.google.com/maps/documentation/javascript/reference/polygon#PolygonOptions
5
+ */
2
6
  options?: Omit<google.maps.PolygonOptions, 'map'>;
3
7
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
5
- click: (payload: google.maps.PolyMouseEvent) => any;
8
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
6
9
  contextmenu: (payload: google.maps.PolyMouseEvent) => any;
10
+ click: (payload: google.maps.PolyMouseEvent) => any;
7
11
  dblclick: (payload: google.maps.PolyMouseEvent) => any;
8
12
  drag: (payload: google.maps.MapMouseEvent) => any;
9
13
  dragend: (payload: google.maps.MapMouseEvent) => any;
@@ -14,8 +18,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {
14
18
  mouseover: (payload: google.maps.PolyMouseEvent) => any;
15
19
  mouseup: (payload: google.maps.PolyMouseEvent) => any;
16
20
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
17
- onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
18
21
  onContextmenu?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
22
+ onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
19
23
  onDblclick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
20
24
  onDrag?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
21
25
  onDragend?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
@@ -1,14 +1,10 @@
1
- <template>
2
-
3
- </template>
4
-
5
1
  <script setup>
6
- import { inject, onUnmounted } from "vue";
7
- import { whenever } from "@vueuse/core";
8
- import { MAP_INJECTION_KEY } from "./ScriptGoogleMaps.vue";
2
+ import { watch } from "vue";
3
+ import { bindGoogleMapsEvents, useGoogleMapsResource } from "./useGoogleMapsResource";
9
4
  const props = defineProps({
10
5
  options: { type: Object, required: false }
11
6
  });
7
+ const emit = defineEmits(["click", "contextmenu", "dblclick", "mousedown", "mousemove", "mouseout", "mouseover", "mouseup", "drag", "dragend", "dragstart"]);
12
8
  const eventsWithPolyMouseEventPayload = [
13
9
  "click",
14
10
  "contextmenu",
@@ -24,37 +20,26 @@ const eventsWithMapMouseEventPayload = [
24
20
  "dragend",
25
21
  "dragstart"
26
22
  ];
27
- const emit = defineEmits([]);
28
- const mapContext = inject(MAP_INJECTION_KEY, void 0);
29
- let polygon = void 0;
30
- whenever(() => mapContext?.map.value && mapContext.mapsApi.value, () => {
31
- polygon = new mapContext.mapsApi.value.Polygon({
32
- map: mapContext.map.value,
33
- ...props.options
34
- });
35
- setupPolygonEventListeners(polygon);
36
- whenever(() => props.options, (options) => {
37
- polygon?.setOptions(options);
38
- }, {
39
- deep: true
40
- });
41
- }, {
42
- immediate: true,
43
- once: true
44
- });
45
- onUnmounted(() => {
46
- if (!polygon || !mapContext?.mapsApi.value) {
47
- return;
23
+ const polygon = useGoogleMapsResource({
24
+ create({ mapsApi, map }) {
25
+ const p = new mapsApi.Polygon({ map, ...props.options });
26
+ bindGoogleMapsEvents(p, emit, {
27
+ withPayload: [...eventsWithPolyMouseEventPayload, ...eventsWithMapMouseEventPayload]
28
+ });
29
+ return p;
30
+ },
31
+ cleanup(p, { mapsApi }) {
32
+ mapsApi.event.clearInstanceListeners(p);
33
+ p.setMap(null);
48
34
  }
49
- mapContext.mapsApi.value.event.clearInstanceListeners(polygon);
50
- polygon.setMap(null);
51
35
  });
52
- function setupPolygonEventListeners(polygon2) {
53
- eventsWithPolyMouseEventPayload.forEach((event) => {
54
- polygon2.addListener(event, (payload) => emit(event, payload));
55
- });
56
- eventsWithMapMouseEventPayload.forEach((event) => {
57
- polygon2.addListener(event, (payload) => emit(event, payload));
58
- });
59
- }
36
+ watch(() => props.options, (options) => {
37
+ if (polygon.value && options) {
38
+ polygon.value.setOptions(options);
39
+ }
40
+ }, { deep: true });
60
41
  </script>
42
+
43
+ <template>
44
+
45
+ </template>
@@ -1,9 +1,13 @@
1
1
  type __VLS_Props = {
2
+ /**
3
+ * Configuration options for the polygon overlay.
4
+ * @see https://developers.google.com/maps/documentation/javascript/reference/polygon#PolygonOptions
5
+ */
2
6
  options?: Omit<google.maps.PolygonOptions, 'map'>;
3
7
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
5
- click: (payload: google.maps.PolyMouseEvent) => any;
8
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
6
9
  contextmenu: (payload: google.maps.PolyMouseEvent) => any;
10
+ click: (payload: google.maps.PolyMouseEvent) => any;
7
11
  dblclick: (payload: google.maps.PolyMouseEvent) => any;
8
12
  drag: (payload: google.maps.MapMouseEvent) => any;
9
13
  dragend: (payload: google.maps.MapMouseEvent) => any;
@@ -14,8 +18,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {
14
18
  mouseover: (payload: google.maps.PolyMouseEvent) => any;
15
19
  mouseup: (payload: google.maps.PolyMouseEvent) => any;
16
20
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
17
- onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
18
21
  onContextmenu?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
22
+ onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
19
23
  onDblclick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
20
24
  onDrag?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
21
25
  onDragend?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
@@ -1,9 +1,13 @@
1
1
  type __VLS_Props = {
2
+ /**
3
+ * Configuration options for the polyline overlay.
4
+ * @see https://developers.google.com/maps/documentation/javascript/reference/polygon#PolylineOptions
5
+ */
2
6
  options?: Omit<google.maps.PolylineOptions, 'map'>;
3
7
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
5
- click: (payload: google.maps.PolyMouseEvent) => any;
8
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
6
9
  contextmenu: (payload: google.maps.PolyMouseEvent) => any;
10
+ click: (payload: google.maps.PolyMouseEvent) => any;
7
11
  dblclick: (payload: google.maps.PolyMouseEvent) => any;
8
12
  drag: (payload: google.maps.MapMouseEvent) => any;
9
13
  dragend: (payload: google.maps.MapMouseEvent) => any;
@@ -14,8 +18,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {
14
18
  mouseover: (payload: google.maps.PolyMouseEvent) => any;
15
19
  mouseup: (payload: google.maps.PolyMouseEvent) => any;
16
20
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
17
- onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
18
21
  onContextmenu?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
22
+ onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
19
23
  onDblclick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
20
24
  onDrag?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
21
25
  onDragend?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
@@ -1,14 +1,10 @@
1
- <template>
2
-
3
- </template>
4
-
5
1
  <script setup>
6
- import { inject, onUnmounted } from "vue";
7
- import { whenever } from "@vueuse/core";
8
- import { MAP_INJECTION_KEY } from "./ScriptGoogleMaps.vue";
2
+ import { watch } from "vue";
3
+ import { bindGoogleMapsEvents, useGoogleMapsResource } from "./useGoogleMapsResource";
9
4
  const props = defineProps({
10
5
  options: { type: Object, required: false }
11
6
  });
7
+ const emit = defineEmits(["click", "contextmenu", "dblclick", "mousedown", "mousemove", "mouseout", "mouseover", "mouseup", "drag", "dragend", "dragstart"]);
12
8
  const eventsWithPolyMouseEventPayload = [
13
9
  "click",
14
10
  "contextmenu",
@@ -24,37 +20,26 @@ const eventsWithMapMouseEventPayload = [
24
20
  "dragend",
25
21
  "dragstart"
26
22
  ];
27
- const emit = defineEmits([]);
28
- const mapContext = inject(MAP_INJECTION_KEY, void 0);
29
- let polyline = void 0;
30
- whenever(() => mapContext?.map.value && mapContext.mapsApi.value, () => {
31
- polyline = new mapContext.mapsApi.value.Polyline({
32
- map: mapContext.map.value,
33
- ...props.options
34
- });
35
- setupPolylineEventListeners(polyline);
36
- whenever(() => props.options, (options) => {
37
- polyline?.setOptions(options);
38
- }, {
39
- deep: true
40
- });
41
- }, {
42
- immediate: true,
43
- once: true
44
- });
45
- onUnmounted(() => {
46
- if (!polyline || !mapContext?.mapsApi.value) {
47
- return;
23
+ const polyline = useGoogleMapsResource({
24
+ create({ mapsApi, map }) {
25
+ const p = new mapsApi.Polyline({ map, ...props.options });
26
+ bindGoogleMapsEvents(p, emit, {
27
+ withPayload: [...eventsWithPolyMouseEventPayload, ...eventsWithMapMouseEventPayload]
28
+ });
29
+ return p;
30
+ },
31
+ cleanup(p, { mapsApi }) {
32
+ mapsApi.event.clearInstanceListeners(p);
33
+ p.setMap(null);
48
34
  }
49
- mapContext.mapsApi.value.event.clearInstanceListeners(polyline);
50
- polyline.setMap(null);
51
35
  });
52
- function setupPolylineEventListeners(polyline2) {
53
- eventsWithPolyMouseEventPayload.forEach((event) => {
54
- polyline2.addListener(event, (payload) => emit(event, payload));
55
- });
56
- eventsWithMapMouseEventPayload.forEach((event) => {
57
- polyline2.addListener(event, (payload) => emit(event, payload));
58
- });
59
- }
36
+ watch(() => props.options, (options) => {
37
+ if (polyline.value && options) {
38
+ polyline.value.setOptions(options);
39
+ }
40
+ }, { deep: true });
60
41
  </script>
42
+
43
+ <template>
44
+
45
+ </template>
@@ -1,9 +1,13 @@
1
1
  type __VLS_Props = {
2
+ /**
3
+ * Configuration options for the polyline overlay.
4
+ * @see https://developers.google.com/maps/documentation/javascript/reference/polygon#PolylineOptions
5
+ */
2
6
  options?: Omit<google.maps.PolylineOptions, 'map'>;
3
7
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
5
- click: (payload: google.maps.PolyMouseEvent) => any;
8
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
6
9
  contextmenu: (payload: google.maps.PolyMouseEvent) => any;
10
+ click: (payload: google.maps.PolyMouseEvent) => any;
7
11
  dblclick: (payload: google.maps.PolyMouseEvent) => any;
8
12
  drag: (payload: google.maps.MapMouseEvent) => any;
9
13
  dragend: (payload: google.maps.MapMouseEvent) => any;
@@ -14,8 +18,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {
14
18
  mouseover: (payload: google.maps.PolyMouseEvent) => any;
15
19
  mouseup: (payload: google.maps.PolyMouseEvent) => any;
16
20
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
17
- onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
18
21
  onContextmenu?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
22
+ onClick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
19
23
  onDblclick?: ((payload: google.maps.PolyMouseEvent) => any) | undefined;
20
24
  onDrag?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
21
25
  onDragend?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
@@ -1,9 +1,13 @@
1
1
  type __VLS_Props = {
2
+ /**
3
+ * Configuration options for the rectangle overlay.
4
+ * @see https://developers.google.com/maps/documentation/javascript/reference/polygon#RectangleOptions
5
+ */
2
6
  options?: Omit<google.maps.RectangleOptions, 'map'>;
3
7
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
5
- click: (payload: google.maps.MapMouseEvent) => any;
8
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
6
9
  contextmenu: (payload: google.maps.MapMouseEvent) => any;
10
+ click: (payload: google.maps.MapMouseEvent) => any;
7
11
  dblclick: (payload: google.maps.MapMouseEvent) => any;
8
12
  drag: (payload: google.maps.MapMouseEvent) => any;
9
13
  dragend: (payload: google.maps.MapMouseEvent) => any;
@@ -15,8 +19,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {
15
19
  mouseup: (payload: google.maps.MapMouseEvent) => any;
16
20
  bounds_changed: () => any;
17
21
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
18
- onClick?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
19
22
  onContextmenu?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
23
+ onClick?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
20
24
  onDblclick?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
21
25
  onDrag?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
22
26
  onDragend?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
@@ -1,14 +1,10 @@
1
- <template>
2
-
3
- </template>
4
-
5
1
  <script setup>
6
- import { inject, onUnmounted } from "vue";
7
- import { whenever } from "@vueuse/core";
8
- import { MAP_INJECTION_KEY } from "./ScriptGoogleMaps.vue";
2
+ import { watch } from "vue";
3
+ import { bindGoogleMapsEvents, useGoogleMapsResource } from "./useGoogleMapsResource";
9
4
  const props = defineProps({
10
5
  options: { type: Object, required: false }
11
6
  });
7
+ const emit = defineEmits(["bounds_changed", "click", "contextmenu", "dblclick", "drag", "dragend", "dragstart", "mousedown", "mousemove", "mouseout", "mouseover", "mouseup"]);
12
8
  const eventsWithoutPayload = [
13
9
  "bounds_changed"
14
10
  ];
@@ -25,37 +21,27 @@ const eventsWithMapMouseEventPayload = [
25
21
  "mouseover",
26
22
  "mouseup"
27
23
  ];
28
- const emit = defineEmits([]);
29
- const mapContext = inject(MAP_INJECTION_KEY, void 0);
30
- let rectangle = void 0;
31
- whenever(() => mapContext?.map.value && mapContext.mapsApi.value, () => {
32
- rectangle = new mapContext.mapsApi.value.Rectangle({
33
- map: mapContext.map.value,
34
- ...props.options
35
- });
36
- setupRectangleEventListeners(rectangle);
37
- whenever(() => props.options, (options) => {
38
- rectangle?.setOptions(options);
39
- }, {
40
- deep: true
41
- });
42
- }, {
43
- immediate: true,
44
- once: true
45
- });
46
- onUnmounted(() => {
47
- if (!rectangle || !mapContext?.mapsApi.value) {
48
- return;
24
+ const rectangle = useGoogleMapsResource({
25
+ create({ mapsApi, map }) {
26
+ const r = new mapsApi.Rectangle({ map, ...props.options });
27
+ bindGoogleMapsEvents(r, emit, {
28
+ noPayload: eventsWithoutPayload,
29
+ withPayload: eventsWithMapMouseEventPayload
30
+ });
31
+ return r;
32
+ },
33
+ cleanup(r, { mapsApi }) {
34
+ mapsApi.event.clearInstanceListeners(r);
35
+ r.setMap(null);
49
36
  }
50
- mapContext.mapsApi.value.event.clearInstanceListeners(rectangle);
51
- rectangle.setMap(null);
52
37
  });
53
- function setupRectangleEventListeners(rectangle2) {
54
- eventsWithoutPayload.forEach((event) => {
55
- rectangle2.addListener(event, () => emit(event));
56
- });
57
- eventsWithMapMouseEventPayload.forEach((event) => {
58
- rectangle2.addListener(event, (payload) => emit(event, payload));
59
- });
60
- }
38
+ watch(() => props.options, (options) => {
39
+ if (rectangle.value && options) {
40
+ rectangle.value.setOptions(options);
41
+ }
42
+ }, { deep: true });
61
43
  </script>
44
+
45
+ <template>
46
+
47
+ </template>
@@ -1,9 +1,13 @@
1
1
  type __VLS_Props = {
2
+ /**
3
+ * Configuration options for the rectangle overlay.
4
+ * @see https://developers.google.com/maps/documentation/javascript/reference/polygon#RectangleOptions
5
+ */
2
6
  options?: Omit<google.maps.RectangleOptions, 'map'>;
3
7
  };
4
- declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
5
- click: (payload: google.maps.MapMouseEvent) => any;
8
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
6
9
  contextmenu: (payload: google.maps.MapMouseEvent) => any;
10
+ click: (payload: google.maps.MapMouseEvent) => any;
7
11
  dblclick: (payload: google.maps.MapMouseEvent) => any;
8
12
  drag: (payload: google.maps.MapMouseEvent) => any;
9
13
  dragend: (payload: google.maps.MapMouseEvent) => any;
@@ -15,8 +19,8 @@ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {
15
19
  mouseup: (payload: google.maps.MapMouseEvent) => any;
16
20
  bounds_changed: () => any;
17
21
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
18
- onClick?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
19
22
  onContextmenu?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
23
+ onClick?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
20
24
  onDblclick?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
21
25
  onDrag?: ((payload: google.maps.MapMouseEvent) => any) | undefined;
22
26
  onDragend?: ((payload: google.maps.MapMouseEvent) => any) | undefined;