@nuxt/scripts 1.0.0-beta.3 → 1.0.0-beta.30

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 (217) hide show
  1. package/README.md +3 -3
  2. package/dist/client/200.html +1 -1
  3. package/dist/client/404.html +1 -1
  4. package/dist/client/_nuxt/{Ds2G8aQM.js → AwAKM0sG.js} +1 -1
  5. package/dist/client/_nuxt/Bl23o3st.js +162 -0
  6. package/dist/client/_nuxt/{DdVDSbUA.js → CYlYSSNW.js} +1 -1
  7. package/dist/client/_nuxt/{CD5B-xvT.js → D5FIkDae.js} +1 -1
  8. package/dist/client/_nuxt/builds/latest.json +1 -1
  9. package/dist/client/_nuxt/builds/meta/f0b4dd20-8496-4003-b7a3-05cbae515923.json +1 -0
  10. package/dist/client/_nuxt/entry.C5SUNdim.css +1 -0
  11. package/dist/client/_nuxt/error-404.1K8v8Su2.css +1 -0
  12. package/dist/client/_nuxt/error-500.B9qvKpQm.css +1 -0
  13. package/dist/client/index.html +1 -1
  14. package/dist/module.d.mts +7 -19
  15. package/dist/module.d.ts +164 -0
  16. package/dist/module.json +1 -1
  17. package/dist/module.mjs +935 -645
  18. package/dist/registry.d.ts +6 -0
  19. package/dist/registry.mjs +235 -69
  20. package/dist/runtime/components/GoogleMaps/ScriptGoogleMaps.d.vue.ts +16 -9
  21. package/dist/runtime/components/GoogleMaps/ScriptGoogleMaps.vue +57 -30
  22. package/dist/runtime/components/GoogleMaps/ScriptGoogleMaps.vue.d.ts +16 -9
  23. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsAdvancedMarkerElement.d.vue.ts +22 -39
  24. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsAdvancedMarkerElement.vue +69 -72
  25. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsAdvancedMarkerElement.vue.d.ts +22 -39
  26. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsCircle.d.vue.ts +5 -1
  27. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsCircle.vue +25 -38
  28. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsCircle.vue.d.ts +5 -1
  29. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsGeoJson.d.vue.ts +43 -0
  30. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsGeoJson.vue +61 -0
  31. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsGeoJson.vue.d.ts +43 -0
  32. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsHeatmapLayer.d.vue.ts +4 -0
  33. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsHeatmapLayer.vue +22 -26
  34. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsHeatmapLayer.vue.d.ts +4 -0
  35. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsInfoWindow.d.vue.ts +9 -5
  36. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsInfoWindow.vue +62 -53
  37. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsInfoWindow.vue.d.ts +9 -5
  38. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarker.d.vue.ts +26 -11
  39. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarker.vue +48 -45
  40. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarker.vue.d.ts +26 -11
  41. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarkerClusterer.d.vue.ts +10 -2
  42. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarkerClusterer.vue +38 -37
  43. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsMarkerClusterer.vue.d.ts +10 -2
  44. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsOverlayView.d.vue.ts +63 -0
  45. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsOverlayView.vue +160 -0
  46. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsOverlayView.vue.d.ts +63 -0
  47. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPinElement.d.vue.ts +4 -0
  48. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPinElement.vue +23 -32
  49. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPinElement.vue.d.ts +4 -0
  50. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolygon.d.vue.ts +7 -3
  51. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolygon.vue +24 -38
  52. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolygon.vue.d.ts +7 -3
  53. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolyline.d.vue.ts +7 -3
  54. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolyline.vue +24 -38
  55. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsPolyline.vue.d.ts +7 -3
  56. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsRectangle.d.vue.ts +7 -3
  57. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsRectangle.vue +25 -38
  58. package/dist/runtime/components/GoogleMaps/ScriptGoogleMapsRectangle.vue.d.ts +7 -3
  59. package/dist/runtime/components/GoogleMaps/bindGoogleMapsEvents.d.ts +13 -0
  60. package/dist/runtime/components/GoogleMaps/bindGoogleMapsEvents.js +8 -0
  61. package/dist/runtime/components/GoogleMaps/injectionKeys.d.ts +13 -0
  62. package/dist/runtime/components/GoogleMaps/injectionKeys.js +3 -0
  63. package/dist/runtime/components/GoogleMaps/useGoogleMapsResource.d.ts +26 -0
  64. package/dist/runtime/components/GoogleMaps/useGoogleMapsResource.js +42 -0
  65. package/dist/runtime/components/ScriptBlueskyEmbed.d.vue.ts +87 -0
  66. package/dist/runtime/components/ScriptBlueskyEmbed.vue +85 -0
  67. package/dist/runtime/components/ScriptBlueskyEmbed.vue.d.ts +87 -0
  68. package/dist/runtime/components/ScriptCrisp.vue +1 -1
  69. package/dist/runtime/components/ScriptGoogleAdsense.vue +1 -1
  70. package/dist/runtime/components/ScriptGravatar.d.vue.ts +22 -0
  71. package/dist/runtime/components/ScriptGravatar.vue +46 -0
  72. package/dist/runtime/components/ScriptGravatar.vue.d.ts +22 -0
  73. package/dist/runtime/components/ScriptInstagramEmbed.d.vue.ts +2 -2
  74. package/dist/runtime/components/ScriptInstagramEmbed.vue +5 -2
  75. package/dist/runtime/components/ScriptInstagramEmbed.vue.d.ts +2 -2
  76. package/dist/runtime/components/ScriptIntercom.vue +4 -3
  77. package/dist/runtime/components/ScriptPayPalButtons.d.vue.ts +43 -32
  78. package/dist/runtime/components/ScriptPayPalButtons.vue +48 -79
  79. package/dist/runtime/components/ScriptPayPalButtons.vue.d.ts +43 -32
  80. package/dist/runtime/components/ScriptPayPalMessages.d.vue.ts +37 -23
  81. package/dist/runtime/components/ScriptPayPalMessages.vue +46 -50
  82. package/dist/runtime/components/ScriptPayPalMessages.vue.d.ts +37 -23
  83. package/dist/runtime/components/ScriptStripePricingTable.vue +2 -2
  84. package/dist/runtime/components/ScriptVimeoPlayer.d.vue.ts +9 -0
  85. package/dist/runtime/components/ScriptVimeoPlayer.vue +13 -10
  86. package/dist/runtime/components/ScriptVimeoPlayer.vue.d.ts +9 -0
  87. package/dist/runtime/components/ScriptXEmbed.d.vue.ts +2 -2
  88. package/dist/runtime/components/ScriptXEmbed.vue +6 -3
  89. package/dist/runtime/components/ScriptXEmbed.vue.d.ts +2 -2
  90. package/dist/runtime/components/ScriptYouTubePlayer.d.vue.ts +2 -2
  91. package/dist/runtime/components/ScriptYouTubePlayer.vue +11 -5
  92. package/dist/runtime/components/ScriptYouTubePlayer.vue.d.ts +2 -2
  93. package/dist/runtime/composables/useScript.js +13 -6
  94. package/dist/runtime/composables/useScriptEventPage.js +2 -2
  95. package/dist/runtime/composables/useScriptTriggerConsent.d.ts +10 -0
  96. package/dist/runtime/composables/useScriptTriggerConsent.js +33 -20
  97. package/dist/runtime/composables/useScriptTriggerElement.js +1 -1
  98. package/dist/runtime/composables/useScriptTriggerIdleTimeout.js +1 -1
  99. package/dist/runtime/registry/bing-uet.d.ts +20 -0
  100. package/dist/runtime/registry/bing-uet.js +29 -0
  101. package/dist/runtime/registry/bluesky-embed.d.ts +116 -0
  102. package/dist/runtime/registry/bluesky-embed.js +72 -0
  103. package/dist/runtime/registry/clarity.d.ts +10 -15
  104. package/dist/runtime/registry/clarity.js +22 -31
  105. package/dist/runtime/registry/cloudflare-web-analytics.d.ts +2 -13
  106. package/dist/runtime/registry/cloudflare-web-analytics.js +2 -14
  107. package/dist/runtime/registry/crisp.d.ts +10 -40
  108. package/dist/runtime/registry/crisp.js +2 -33
  109. package/dist/runtime/registry/databuddy-analytics.d.ts +2 -35
  110. package/dist/runtime/registry/databuddy-analytics.js +20 -45
  111. package/dist/runtime/registry/fathom-analytics.d.ts +7 -26
  112. package/dist/runtime/registry/fathom-analytics.js +2 -24
  113. package/dist/runtime/registry/google-adsense.d.ts +3 -11
  114. package/dist/runtime/registry/google-adsense.js +2 -11
  115. package/dist/runtime/registry/google-analytics.d.ts +3 -5
  116. package/dist/runtime/registry/google-analytics.js +3 -8
  117. package/dist/runtime/registry/google-maps.d.ts +3 -9
  118. package/dist/runtime/registry/google-maps.js +2 -8
  119. package/dist/runtime/registry/google-recaptcha.d.ts +2 -6
  120. package/dist/runtime/registry/google-recaptcha.js +4 -12
  121. package/dist/runtime/registry/google-sign-in.d.ts +2 -13
  122. package/dist/runtime/registry/google-sign-in.js +2 -22
  123. package/dist/runtime/registry/google-tag-manager.d.ts +3 -28
  124. package/dist/runtime/registry/google-tag-manager.js +4 -27
  125. package/dist/runtime/registry/gravatar.d.ts +26 -0
  126. package/dist/runtime/registry/gravatar.js +33 -0
  127. package/dist/runtime/registry/hotjar.d.ts +4 -6
  128. package/dist/runtime/registry/hotjar.js +2 -5
  129. package/dist/runtime/registry/instagram-embed.d.ts +3 -18
  130. package/dist/runtime/registry/instagram-embed.js +4 -19
  131. package/dist/runtime/registry/intercom.d.ts +4 -12
  132. package/dist/runtime/registry/intercom.js +2 -12
  133. package/dist/runtime/registry/matomo-analytics.d.ts +3 -12
  134. package/dist/runtime/registry/matomo-analytics.js +3 -12
  135. package/dist/runtime/registry/meta-pixel.d.ts +4 -6
  136. package/dist/runtime/registry/meta-pixel.js +2 -4
  137. package/dist/runtime/registry/mixpanel-analytics.d.ts +22 -0
  138. package/dist/runtime/registry/mixpanel-analytics.js +46 -0
  139. package/dist/runtime/registry/npm.d.ts +3 -7
  140. package/dist/runtime/registry/npm.js +2 -9
  141. package/dist/runtime/registry/paypal.d.ts +4 -25
  142. package/dist/runtime/registry/paypal.js +3 -66
  143. package/dist/runtime/registry/plausible-analytics.js +18 -13
  144. package/dist/runtime/registry/posthog.d.ts +10 -12
  145. package/dist/runtime/registry/posthog.js +7 -14
  146. package/dist/runtime/registry/reddit-pixel.d.ts +5 -6
  147. package/dist/runtime/registry/reddit-pixel.js +2 -4
  148. package/dist/runtime/registry/rybbit-analytics.d.ts +2 -14
  149. package/dist/runtime/registry/rybbit-analytics.js +10 -20
  150. package/dist/runtime/registry/schemas.d.ts +982 -0
  151. package/dist/runtime/registry/schemas.js +937 -0
  152. package/dist/runtime/registry/segment.d.ts +2 -5
  153. package/dist/runtime/registry/segment.js +2 -5
  154. package/dist/runtime/registry/snapchat-pixel.d.ts +4 -33
  155. package/dist/runtime/registry/snapchat-pixel.js +2 -20
  156. package/dist/runtime/registry/stripe.d.ts +3 -4
  157. package/dist/runtime/registry/stripe.js +2 -4
  158. package/dist/runtime/registry/tiktok-pixel.d.ts +4 -7
  159. package/dist/runtime/registry/tiktok-pixel.js +2 -6
  160. package/dist/runtime/registry/umami-analytics.d.ts +2 -31
  161. package/dist/runtime/registry/umami-analytics.js +2 -36
  162. package/dist/runtime/registry/vercel-analytics.d.ts +29 -0
  163. package/dist/runtime/registry/vercel-analytics.js +84 -0
  164. package/dist/runtime/registry/vimeo-player.d.ts +2 -2
  165. package/dist/runtime/registry/vimeo-player.js +1 -1
  166. package/dist/runtime/registry/x-embed.d.ts +3 -17
  167. package/dist/runtime/registry/x-embed.js +3 -18
  168. package/dist/runtime/registry/x-pixel.d.ts +4 -7
  169. package/dist/runtime/registry/x-pixel.js +2 -5
  170. package/dist/runtime/registry/youtube-player.d.ts +7 -7
  171. package/dist/runtime/registry/youtube-player.js +1 -1
  172. package/dist/runtime/server/{sw-handler.d.ts → bluesky-embed-image.d.ts} +1 -1
  173. package/dist/runtime/server/bluesky-embed-image.js +7 -0
  174. package/dist/runtime/server/bluesky-embed.d.ts +16 -0
  175. package/dist/runtime/server/bluesky-embed.js +59 -0
  176. package/dist/runtime/server/google-maps-geocode-proxy.d.ts +2 -0
  177. package/dist/runtime/server/google-maps-geocode-proxy.js +34 -0
  178. package/dist/runtime/server/google-static-maps-proxy.js +2 -13
  179. package/dist/runtime/server/gravatar-proxy.d.ts +2 -0
  180. package/dist/runtime/server/gravatar-proxy.js +46 -0
  181. package/dist/runtime/server/instagram-embed-asset.js +8 -41
  182. package/dist/runtime/server/instagram-embed-image.js +6 -53
  183. package/dist/runtime/server/instagram-embed.d.ts +16 -0
  184. package/dist/runtime/server/instagram-embed.js +173 -35
  185. package/dist/runtime/server/proxy-handler.js +134 -93
  186. package/dist/runtime/server/utils/image-proxy.d.ts +12 -0
  187. package/dist/runtime/server/utils/image-proxy.js +70 -0
  188. package/dist/runtime/server/utils/privacy.d.ts +1 -2
  189. package/dist/runtime/server/utils/privacy.js +54 -34
  190. package/dist/runtime/server/x-embed-image.js +5 -49
  191. package/dist/runtime/server/x-embed.js +3 -2
  192. package/dist/runtime/types.d.ts +74 -40
  193. package/dist/runtime/utils/pure.d.ts +1 -5
  194. package/dist/runtime/utils/pure.js +0 -67
  195. package/dist/runtime/utils.d.ts +4 -3
  196. package/dist/runtime/utils.js +24 -10
  197. package/dist/shared/scripts.ViOoYQXH.mjs +381 -0
  198. package/dist/stats.d.mts +202 -0
  199. package/dist/stats.d.ts +202 -0
  200. package/dist/stats.mjs +3868 -0
  201. package/dist/types-source.d.mts +17 -0
  202. package/dist/types-source.d.ts +17 -0
  203. package/dist/types-source.mjs +3600 -0
  204. package/package.json +52 -38
  205. package/dist/client/_nuxt/D-kOnTuH.js +0 -162
  206. package/dist/client/_nuxt/builds/meta/f1474569-6922-450d-bc3f-4fd5f3e1391a.json +0 -1
  207. package/dist/client/_nuxt/entry.D45OuV0w.css +0 -1
  208. package/dist/client/_nuxt/error-404.B57D-jUQ.css +0 -1
  209. package/dist/client/_nuxt/error-500.DTHUW7BI.css +0 -1
  210. package/dist/runtime/components/ScriptPayPalMarks.d.vue.ts +0 -52
  211. package/dist/runtime/components/ScriptPayPalMarks.vue +0 -69
  212. package/dist/runtime/components/ScriptPayPalMarks.vue.d.ts +0 -52
  213. package/dist/runtime/plugins/sw-register.client.d.ts +0 -2
  214. package/dist/runtime/plugins/sw-register.client.js +0 -12
  215. package/dist/runtime/server/sw-handler.js +0 -25
  216. package/dist/runtime/sw/proxy-sw.template.d.ts +0 -1
  217. package/dist/runtime/sw/proxy-sw.template.js +0 -54
@@ -1,98 +1,66 @@
1
1
  <script setup>
2
- import { computed, onMounted, ref, shallowRef, watch } from "vue";
3
2
  import { defu } from "defu";
4
- import { useScriptPayPal } from "../registry/paypal";
3
+ import { computed, onBeforeUnmount, onMounted, ref, resolveComponent, shallowRef } from "vue";
5
4
  import { useScriptTriggerElement } from "../composables/useScriptTriggerElement";
6
- import { onBeforeUnmount, resolveComponent } from "vue";
7
- const el = ref(null);
8
- const rootEl = ref(null);
5
+ import { useScriptPayPal } from "../registry/paypal";
9
6
  const props = defineProps({
10
7
  rootAttrs: { type: Object, required: false },
11
8
  trigger: { type: [String, Array, Boolean], required: false, default: "visible" },
12
9
  clientId: { type: String, required: false, default: "test" },
13
- buttonOptions: { type: Object, required: false, default: () => ({}) },
14
- paypalScriptOptions: { type: Object, required: false, default: () => ({}) },
15
- disabled: { type: Boolean, required: false, default: false }
10
+ clientToken: { type: String, required: false },
11
+ components: { type: Array, required: false, default: () => ["paypal-payments"] },
12
+ pageType: { type: String, required: false },
13
+ locale: { type: String, required: false },
14
+ merchantId: { type: [String, Array], required: false },
15
+ partnerAttributionId: { type: String, required: false },
16
+ paypalScriptOptions: { type: Object, required: false, default: () => ({}) }
16
17
  });
18
+ const emit = defineEmits(["ready", "error"]);
19
+ const el = ref(null);
20
+ const rootEl = ref(null);
17
21
  const ready = ref(false);
22
+ const failed = ref(false);
23
+ const sdkInstance = shallowRef();
18
24
  const { onLoaded, status } = useScriptPayPal({
19
- clientId: props.clientId,
25
+ ...props.clientToken ? { clientToken: props.clientToken } : { clientId: props.clientId },
20
26
  ...props.paypalScriptOptions
21
27
  });
22
- const emit = defineEmits(["approve", "error", "cancel", "clickButtons", "shippingOptionsChange", "shippingAddressChange", "init"]);
23
- const initActions = shallowRef(null);
24
- const handleDisabled = () => {
25
- if (!initActions.value) return;
26
- if (props.disabled) {
27
- initActions.value.disable();
28
- } else {
29
- initActions.value.enable();
30
- }
31
- };
32
- const options = computed(() => {
33
- const _options = {
34
- onApprove: async (data, actions) => {
35
- emit("approve", data, actions);
36
- return props.buttonOptions?.onApprove?.(data, actions);
37
- },
38
- onError: (err) => {
39
- emit("error", err);
40
- return props.buttonOptions?.onError?.(err);
41
- },
42
- onCancel: (data, actions) => {
43
- emit("cancel", data, actions);
44
- return props.buttonOptions?.onCancel?.(data, actions);
45
- },
46
- onClick: (data, actions) => {
47
- emit("clickButtons", data, actions);
48
- return props.buttonOptions?.onClick?.(data, actions);
49
- },
50
- onShippingOptionsChange: async (data, actions) => {
51
- emit("shippingOptionsChange", data, actions);
52
- return props.buttonOptions?.onShippingOptionsChange?.(data, actions);
53
- },
54
- onShippingAddressChange: async (data, actions) => {
55
- emit("shippingAddressChange", data, actions);
56
- return props.buttonOptions?.onShippingAddressChange?.(data, actions);
57
- },
58
- onInit: (data, actions) => {
59
- initActions.value = actions;
60
- actions.disable();
61
- handleDisabled();
62
- emit("init", data, actions);
63
- return props.buttonOptions?.onInit?.(data, actions);
64
- }
65
- };
66
- return defu(_options, props.buttonOptions);
67
- });
68
- watch(() => props.disabled, handleDisabled);
69
- const buttonInst = shallowRef();
70
28
  onMounted(() => {
71
29
  onLoaded(async ({ paypal }) => {
72
- if (!el.value) return;
73
- buttonInst.value = paypal?.Buttons?.(options.value);
74
- await buttonInst.value?.render(el.value);
75
- ready.value = true;
76
- watch(() => options.value, async (_options) => {
77
- if (!el.value) return;
78
- await buttonInst.value?.updateProps(_options);
79
- });
30
+ if (!el.value)
31
+ return;
32
+ const instanceOptions = {
33
+ ...props.clientToken ? { clientToken: props.clientToken } : { clientId: props.clientId },
34
+ components: props.components,
35
+ ...props.pageType && { pageType: props.pageType },
36
+ ...props.locale && { locale: props.locale },
37
+ ...props.merchantId && { merchantId: props.merchantId },
38
+ ...props.partnerAttributionId && { partnerAttributionId: props.partnerAttributionId }
39
+ };
40
+ try {
41
+ sdkInstance.value = await paypal.createInstance(instanceOptions);
42
+ ready.value = true;
43
+ emit("ready", sdkInstance.value);
44
+ } catch (err) {
45
+ sdkInstance.value = void 0;
46
+ failed.value = true;
47
+ emit("error", err);
48
+ }
80
49
  });
81
50
  });
82
- async function destroy() {
83
- if (buttonInst.value) {
84
- await buttonInst.value?.close();
85
- }
86
- }
87
- onBeforeUnmount(async () => {
88
- await destroy();
51
+ onBeforeUnmount(() => {
52
+ sdkInstance.value = void 0;
53
+ });
54
+ defineExpose({
55
+ /** The PayPal SDK v6 instance for creating payment sessions, checking eligibility, etc. */
56
+ sdkInstance
89
57
  });
90
58
  const ScriptLoadingIndicator = resolveComponent("ScriptLoadingIndicator");
91
59
  const trigger = useScriptTriggerElement({ trigger: props.trigger, el: rootEl });
92
60
  const rootAttrs = computed(() => {
93
61
  return defu(props.rootAttrs, {
94
62
  "aria-busy": status.value === "loading",
95
- "aria-label": status.value === "awaitingLoad" ? "PayPal Script Placeholder" : status.value === "loading" ? "PayPal Buttons Loading" : "PayPal Buttons",
63
+ "aria-label": status.value === "awaitingLoad" ? "PayPal Script Placeholder" : status.value === "loading" ? "PayPal Loading" : "PayPal",
96
64
  "aria-live": "polite",
97
65
  "role": "application",
98
66
  ...trigger instanceof Promise ? trigger.ssrAttrs || {} : {}
@@ -101,16 +69,17 @@ const rootAttrs = computed(() => {
101
69
  </script>
102
70
 
103
71
  <template>
104
- <div v-bind="rootAttrs" id="test">
105
- <div v-show="ready" ref="el" />
106
- <slot v-if="!ready" name="placeholder">
72
+ <div ref="rootEl" v-bind="rootAttrs">
73
+ <div ref="el">
74
+ <slot v-if="ready" name="default" :sdk-instance="sdkInstance" />
75
+ </div>
76
+ <slot v-if="status !== 'error' && !ready && !failed" name="placeholder">
107
77
  placeholder
108
78
  </slot>
109
- <slot v-if="status !== 'awaitingLoad' && !ready" name="loading">
79
+ <slot v-if="status !== 'awaitingLoad' && status !== 'error' && !ready && !failed" name="loading">
110
80
  <ScriptLoadingIndicator color="black" />
111
81
  </slot>
112
82
  <slot v-if="status === 'awaitingLoad'" name="awaitingLoad" />
113
- <slot v-else-if="status === 'error'" name="error" />
114
- <slot />
83
+ <slot v-else-if="status === 'error' || failed" name="error" />
115
84
  </div>
116
85
  </template>
@@ -1,6 +1,6 @@
1
- import { type HTMLAttributes, type ReservedProps } from 'vue';
2
- import type { OnApproveActions, OnApproveData, OnCancelledActions, OnClickActions, OnShippingAddressChangeActions, OnShippingAddressChangeData, OnShippingOptionsChangeActions, OnShippingOptionsChangeData, PayPalButtonsComponentOptions, OnInitActions } from '@paypal/paypal-js';
3
1
  import type { ElementScriptTrigger } from '#nuxt-scripts/types';
2
+ import type { Components, PageTypes, SdkInstance } from '@paypal/paypal-js/sdk-v6';
3
+ import type { HTMLAttributes, ReservedProps } from 'vue';
4
4
  import type { PayPalInput } from '../registry/paypal.js';
5
5
  type __VLS_Props = {
6
6
  /**
@@ -12,55 +12,66 @@ type __VLS_Props = {
12
12
  */
13
13
  trigger?: ElementScriptTrigger;
14
14
  /**
15
- * The client id for the paypal script.
15
+ * Client ID or client token for PayPal SDK v6 authentication.
16
16
  */
17
17
  clientId?: string;
18
18
  /**
19
- * The options for the paypal buttons.
19
+ * Server-generated client token for SDK v6.
20
20
  */
21
- buttonOptions?: PayPalButtonsComponentOptions;
21
+ clientToken?: string;
22
22
  /**
23
- * The paypal script options.
23
+ * The v6 SDK components to load.
24
+ * @default ['paypal-payments']
24
25
  */
25
- paypalScriptOptions?: Partial<PayPalInput>;
26
+ components?: Components[];
27
+ /**
28
+ * The page type context hint.
29
+ */
30
+ pageType?: PageTypes;
31
+ /**
32
+ * The locale for the SDK (BCP-47 code).
33
+ */
34
+ locale?: string;
26
35
  /**
27
- * Disables the paypal buttons.
36
+ * The merchant ID(s).
28
37
  */
29
- disabled?: boolean;
38
+ merchantId?: string | string[];
39
+ /**
40
+ * Partner attribution ID for revenue sharing.
41
+ */
42
+ partnerAttributionId?: string;
43
+ /**
44
+ * The paypal script options.
45
+ */
46
+ paypalScriptOptions?: Partial<PayPalInput>;
30
47
  };
31
- declare var __VLS_1: {}, __VLS_3: {}, __VLS_10: {}, __VLS_12: {}, __VLS_14: {};
48
+ declare var __VLS_1: {
49
+ sdkInstance: SdkInstance<Components[]> | undefined;
50
+ }, __VLS_3: {}, __VLS_5: {}, __VLS_12: {}, __VLS_14: {};
32
51
  type __VLS_Slots = {} & {
33
- placeholder?: (props: typeof __VLS_1) => any;
52
+ default?: (props: typeof __VLS_1) => any;
34
53
  } & {
35
- loading?: (props: typeof __VLS_3) => any;
54
+ placeholder?: (props: typeof __VLS_3) => any;
36
55
  } & {
37
- awaitingLoad?: (props: typeof __VLS_10) => any;
56
+ loading?: (props: typeof __VLS_5) => any;
38
57
  } & {
39
- error?: (props: typeof __VLS_12) => any;
58
+ awaitingLoad?: (props: typeof __VLS_12) => any;
40
59
  } & {
41
- default?: (props: typeof __VLS_14) => any;
60
+ error?: (props: typeof __VLS_14) => any;
42
61
  };
43
- declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
44
- error: (error: Record<string, unknown>) => any;
45
- init: (data: Record<string, unknown>, actions: OnInitActions) => any;
46
- cancel: (data: Record<string, unknown>, actions: OnCancelledActions) => any;
47
- approve: (data: OnApproveData, actions: OnApproveActions) => any;
48
- clickButtons: (data: Record<string, unknown>, actions: OnClickActions) => any;
49
- shippingOptionsChange: (data: OnShippingOptionsChangeData, actions: OnShippingOptionsChangeActions) => any;
50
- shippingAddressChange: (data: OnShippingAddressChangeData, actions: OnShippingAddressChangeActions) => any;
62
+ declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {
63
+ /** The PayPal SDK v6 instance for creating payment sessions, checking eligibility, etc. */
64
+ sdkInstance: import("vue").ShallowRef<SdkInstance<Components[]> | undefined, SdkInstance<Components[]> | undefined>;
65
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
66
+ error: (error: unknown) => any;
67
+ ready: (instance: SdkInstance<Components[]>) => any;
51
68
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
52
- onError?: ((error: Record<string, unknown>) => any) | undefined;
53
- onInit?: ((data: Record<string, unknown>, actions: OnInitActions) => any) | undefined;
54
- onCancel?: ((data: Record<string, unknown>, actions: OnCancelledActions) => any) | undefined;
55
- onApprove?: ((data: OnApproveData, actions: OnApproveActions) => any) | undefined;
56
- onClickButtons?: ((data: Record<string, unknown>, actions: OnClickActions) => any) | undefined;
57
- onShippingOptionsChange?: ((data: OnShippingOptionsChangeData, actions: OnShippingOptionsChangeActions) => any) | undefined;
58
- onShippingAddressChange?: ((data: OnShippingAddressChangeData, actions: OnShippingAddressChangeActions) => any) | undefined;
69
+ onError?: ((error: unknown) => any) | undefined;
70
+ onReady?: ((instance: SdkInstance<Components[]>) => any) | undefined;
59
71
  }>, {
60
72
  trigger: ElementScriptTrigger;
61
- disabled: boolean;
62
73
  clientId: string;
63
- buttonOptions: PayPalButtonsComponentOptions;
74
+ components: Components[];
64
75
  paypalScriptOptions: Partial<PayPalInput>;
65
76
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
66
77
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
@@ -1,6 +1,6 @@
1
- import { type HTMLAttributes, type ReservedProps } from 'vue';
2
- import type { PayPalMessagesComponentOptions } from '@paypal/paypal-js';
3
1
  import type { ElementScriptTrigger } from '#nuxt-scripts/types';
2
+ import type { PageTypes, PayPalMessagesOptions, PayPalMessagesSession } from '@paypal/paypal-js/sdk-v6';
3
+ import type { HTMLAttributes, ReservedProps } from 'vue';
4
4
  import type { PayPalInput } from '../registry/paypal.js';
5
5
  type __VLS_Props = {
6
6
  /**
@@ -12,51 +12,65 @@ type __VLS_Props = {
12
12
  */
13
13
  trigger?: ElementScriptTrigger;
14
14
  /**
15
- * The client id for the paypal script.
15
+ * Client ID or client token for PayPal SDK v6 authentication.
16
16
  */
17
17
  clientId?: string;
18
18
  /**
19
- * The options for the paypal buttons.
19
+ * Server-generated client token for SDK v6.
20
20
  */
21
- messagesOptions?: PayPalMessagesComponentOptions;
21
+ clientToken?: string;
22
22
  /**
23
- * The merchant id for the paypal script.
23
+ * The merchant ID for the paypal script.
24
24
  */
25
- merchantId?: string;
25
+ merchantId?: string | string[];
26
26
  /**
27
- * The partner attribution id for the paypal script.
27
+ * The partner attribution ID.
28
28
  */
29
29
  partnerAttributionId?: string;
30
30
  /**
31
- * The options for the paypal scipt.
31
+ * The page type context hint.
32
+ */
33
+ pageType?: PageTypes;
34
+ /**
35
+ * The locale for the SDK (BCP-47 code).
36
+ */
37
+ locale?: string;
38
+ /**
39
+ * Options for the PayPal Messages session.
40
+ */
41
+ messagesOptions?: PayPalMessagesOptions;
42
+ /**
43
+ * The paypal script options.
32
44
  */
33
45
  paypalScriptOptions?: Partial<PayPalInput>;
34
46
  };
35
- declare var __VLS_1: {}, __VLS_3: {}, __VLS_10: {}, __VLS_12: {}, __VLS_14: {};
47
+ declare var __VLS_1: {
48
+ messagesSession: PayPalMessagesSession | undefined;
49
+ }, __VLS_3: {}, __VLS_5: {}, __VLS_12: {}, __VLS_14: {};
36
50
  type __VLS_Slots = {} & {
37
- placeholder?: (props: typeof __VLS_1) => any;
51
+ default?: (props: typeof __VLS_1) => any;
38
52
  } & {
39
- loading?: (props: typeof __VLS_3) => any;
53
+ placeholder?: (props: typeof __VLS_3) => any;
40
54
  } & {
41
- awaitingLoad?: (props: typeof __VLS_10) => any;
55
+ loading?: (props: typeof __VLS_5) => any;
42
56
  } & {
43
- error?: (props: typeof __VLS_12) => any;
57
+ awaitingLoad?: (props: typeof __VLS_12) => any;
44
58
  } & {
45
- default?: (props: typeof __VLS_14) => any;
59
+ error?: (props: typeof __VLS_14) => any;
46
60
  };
47
- declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
48
- render: (data: Record<string, unknown>) => any;
49
- apply: (data: Record<string, unknown>) => any;
50
- clickMessages: (data: Record<string, unknown>) => any;
61
+ declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {
62
+ messagesSession: import("vue").ShallowRef<PayPalMessagesSession | undefined, PayPalMessagesSession | undefined>;
63
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
64
+ error: (error: unknown) => any;
65
+ ready: (session: PayPalMessagesSession) => any;
51
66
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
52
- onRender?: ((data: Record<string, unknown>) => any) | undefined;
53
- onApply?: ((data: Record<string, unknown>) => any) | undefined;
54
- onClickMessages?: ((data: Record<string, unknown>) => any) | undefined;
67
+ onError?: ((error: unknown) => any) | undefined;
68
+ onReady?: ((session: PayPalMessagesSession) => any) | undefined;
55
69
  }>, {
56
70
  trigger: ElementScriptTrigger;
57
71
  clientId: string;
58
72
  paypalScriptOptions: Partial<PayPalInput>;
59
- messagesOptions: PayPalMessagesComponentOptions;
73
+ messagesOptions: PayPalMessagesOptions;
60
74
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
61
75
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
62
76
  declare const _default: typeof __VLS_export;
@@ -1,72 +1,67 @@
1
1
  <script setup>
2
- import { computed, onMounted, ref, shallowRef, watch } from "vue";
3
2
  import { defu } from "defu";
4
- import { useScriptPayPal } from "../registry/paypal";
3
+ import { computed, onBeforeUnmount, onMounted, ref, resolveComponent, shallowRef } from "vue";
5
4
  import { useScriptTriggerElement } from "../composables/useScriptTriggerElement";
6
- import { onBeforeUnmount, resolveComponent } from "vue";
7
- const el = ref(null);
8
- const rootEl = ref(null);
5
+ import { useScriptPayPal } from "../registry/paypal";
9
6
  const props = defineProps({
10
7
  rootAttrs: { type: Object, required: false },
11
8
  trigger: { type: [String, Array, Boolean], required: false, default: "visible" },
12
9
  clientId: { type: String, required: false, default: "test" },
13
- messagesOptions: { type: Object, required: false, default: () => ({}) },
14
- merchantId: { type: String, required: false },
10
+ clientToken: { type: String, required: false },
11
+ merchantId: { type: [String, Array], required: false },
15
12
  partnerAttributionId: { type: String, required: false },
13
+ pageType: { type: String, required: false },
14
+ locale: { type: String, required: false },
15
+ messagesOptions: { type: Object, required: false, default: () => ({}) },
16
16
  paypalScriptOptions: { type: Object, required: false, default: () => ({}) }
17
17
  });
18
+ const emit = defineEmits(["ready", "error"]);
19
+ const el = ref(null);
20
+ const rootEl = ref(null);
18
21
  const ready = ref(false);
22
+ const failed = ref(false);
23
+ const messagesSession = shallowRef();
19
24
  const { onLoaded, status } = useScriptPayPal({
20
- clientId: props.clientId,
21
- merchantId: props.merchantId,
22
- partnerAttributionId: props.partnerAttributionId,
25
+ ...props.clientToken ? { clientToken: props.clientToken } : { clientId: props.clientId },
23
26
  ...props.paypalScriptOptions
24
27
  });
25
- const emit = defineEmits(["apply", "clickMessages", "render"]);
26
- const options = computed(() => {
27
- const _options = {
28
- onApply: (data) => {
29
- emit("apply", data);
30
- return props.messagesOptions?.onApply?.(data);
31
- },
32
- onClick: (data) => {
33
- emit("clickMessages", data);
34
- return props.messagesOptions?.onClick?.(data);
35
- },
36
- onRender: (data) => {
37
- emit("render", data);
38
- return props.messagesOptions?.onRender?.(data);
39
- }
40
- };
41
- return defu(_options, props.messagesOptions);
42
- });
43
- const messageInst = shallowRef();
44
28
  onMounted(() => {
45
29
  onLoaded(async ({ paypal }) => {
46
- if (!el.value) return;
47
- messageInst.value = paypal?.Messages?.(options.value);
48
- await messageInst.value?.render(el.value);
49
- ready.value = true;
50
- watch(() => options.value, async (_options) => {
51
- if (!el.value) return;
52
- messageInst.value = paypal?.Messages?.(_options);
53
- await messageInst.value?.render(el.value);
54
- });
30
+ if (!el.value)
31
+ return;
32
+ const components = ["paypal-messages"];
33
+ const instanceOptions = {
34
+ ...props.clientToken ? { clientToken: props.clientToken } : { clientId: props.clientId },
35
+ components,
36
+ ...props.pageType && { pageType: props.pageType },
37
+ ...props.locale && { locale: props.locale },
38
+ ...props.merchantId && { merchantId: props.merchantId },
39
+ ...props.partnerAttributionId && { partnerAttributionId: props.partnerAttributionId }
40
+ };
41
+ try {
42
+ const instance = await paypal.createInstance(instanceOptions);
43
+ messagesSession.value = instance.createPayPalMessages(props.messagesOptions);
44
+ ready.value = true;
45
+ emit("ready", messagesSession.value);
46
+ } catch (err) {
47
+ messagesSession.value = void 0;
48
+ failed.value = true;
49
+ emit("error", err);
50
+ }
55
51
  });
56
52
  });
57
- function destroy() {
58
- if (!el.value) return;
59
- el.value?.replaceChildren();
60
- }
61
53
  onBeforeUnmount(() => {
62
- destroy();
54
+ messagesSession.value = void 0;
55
+ });
56
+ defineExpose({
57
+ messagesSession
63
58
  });
64
59
  const ScriptLoadingIndicator = resolveComponent("ScriptLoadingIndicator");
65
60
  const trigger = useScriptTriggerElement({ trigger: props.trigger, el: rootEl });
66
61
  const rootAttrs = computed(() => {
67
62
  return defu(props.rootAttrs, {
68
63
  "aria-busy": status.value === "loading",
69
- "aria-label": status.value === "awaitingLoad" ? "PayPal Script Placeholder" : status.value === "loading" ? "PayPal Buttons Loading" : "PayPal Buttons",
64
+ "aria-label": status.value === "awaitingLoad" ? "PayPal Script Placeholder" : status.value === "loading" ? "PayPal Messages Loading" : "PayPal Messages",
70
65
  "aria-live": "polite",
71
66
  "role": "application",
72
67
  ...trigger instanceof Promise ? trigger.ssrAttrs || {} : {}
@@ -75,16 +70,17 @@ const rootAttrs = computed(() => {
75
70
  </script>
76
71
 
77
72
  <template>
78
- <div v-bind="rootAttrs" id="test">
79
- <div v-show="ready" ref="el" />
80
- <slot v-if="!ready" name="placeholder">
73
+ <div ref="rootEl" v-bind="rootAttrs">
74
+ <div ref="el">
75
+ <slot v-if="ready" name="default" :messages-session="messagesSession" />
76
+ </div>
77
+ <slot v-if="status !== 'error' && !ready && !failed" name="placeholder">
81
78
  placeholder
82
79
  </slot>
83
- <slot v-if="status !== 'awaitingLoad' && !ready" name="loading">
80
+ <slot v-if="status !== 'awaitingLoad' && status !== 'error' && !ready && !failed" name="loading">
84
81
  <ScriptLoadingIndicator color="black" />
85
82
  </slot>
86
83
  <slot v-if="status === 'awaitingLoad'" name="awaitingLoad" />
87
- <slot v-else-if="status === 'error'" name="error" />
88
- <slot />
84
+ <slot v-else-if="status === 'error' || failed" name="error" />
89
85
  </div>
90
86
  </template>
@@ -1,6 +1,6 @@
1
- import { type HTMLAttributes, type ReservedProps } from 'vue';
2
- import type { PayPalMessagesComponentOptions } from '@paypal/paypal-js';
3
1
  import type { ElementScriptTrigger } from '#nuxt-scripts/types';
2
+ import type { PageTypes, PayPalMessagesOptions, PayPalMessagesSession } from '@paypal/paypal-js/sdk-v6';
3
+ import type { HTMLAttributes, ReservedProps } from 'vue';
4
4
  import type { PayPalInput } from '../registry/paypal.js';
5
5
  type __VLS_Props = {
6
6
  /**
@@ -12,51 +12,65 @@ type __VLS_Props = {
12
12
  */
13
13
  trigger?: ElementScriptTrigger;
14
14
  /**
15
- * The client id for the paypal script.
15
+ * Client ID or client token for PayPal SDK v6 authentication.
16
16
  */
17
17
  clientId?: string;
18
18
  /**
19
- * The options for the paypal buttons.
19
+ * Server-generated client token for SDK v6.
20
20
  */
21
- messagesOptions?: PayPalMessagesComponentOptions;
21
+ clientToken?: string;
22
22
  /**
23
- * The merchant id for the paypal script.
23
+ * The merchant ID for the paypal script.
24
24
  */
25
- merchantId?: string;
25
+ merchantId?: string | string[];
26
26
  /**
27
- * The partner attribution id for the paypal script.
27
+ * The partner attribution ID.
28
28
  */
29
29
  partnerAttributionId?: string;
30
30
  /**
31
- * The options for the paypal scipt.
31
+ * The page type context hint.
32
+ */
33
+ pageType?: PageTypes;
34
+ /**
35
+ * The locale for the SDK (BCP-47 code).
36
+ */
37
+ locale?: string;
38
+ /**
39
+ * Options for the PayPal Messages session.
40
+ */
41
+ messagesOptions?: PayPalMessagesOptions;
42
+ /**
43
+ * The paypal script options.
32
44
  */
33
45
  paypalScriptOptions?: Partial<PayPalInput>;
34
46
  };
35
- declare var __VLS_1: {}, __VLS_3: {}, __VLS_10: {}, __VLS_12: {}, __VLS_14: {};
47
+ declare var __VLS_1: {
48
+ messagesSession: PayPalMessagesSession | undefined;
49
+ }, __VLS_3: {}, __VLS_5: {}, __VLS_12: {}, __VLS_14: {};
36
50
  type __VLS_Slots = {} & {
37
- placeholder?: (props: typeof __VLS_1) => any;
51
+ default?: (props: typeof __VLS_1) => any;
38
52
  } & {
39
- loading?: (props: typeof __VLS_3) => any;
53
+ placeholder?: (props: typeof __VLS_3) => any;
40
54
  } & {
41
- awaitingLoad?: (props: typeof __VLS_10) => any;
55
+ loading?: (props: typeof __VLS_5) => any;
42
56
  } & {
43
- error?: (props: typeof __VLS_12) => any;
57
+ awaitingLoad?: (props: typeof __VLS_12) => any;
44
58
  } & {
45
- default?: (props: typeof __VLS_14) => any;
59
+ error?: (props: typeof __VLS_14) => any;
46
60
  };
47
- declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
48
- render: (data: Record<string, unknown>) => any;
49
- apply: (data: Record<string, unknown>) => any;
50
- clickMessages: (data: Record<string, unknown>) => any;
61
+ declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {
62
+ messagesSession: import("vue").ShallowRef<PayPalMessagesSession | undefined, PayPalMessagesSession | undefined>;
63
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
64
+ error: (error: unknown) => any;
65
+ ready: (session: PayPalMessagesSession) => any;
51
66
  }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
52
- onRender?: ((data: Record<string, unknown>) => any) | undefined;
53
- onApply?: ((data: Record<string, unknown>) => any) | undefined;
54
- onClickMessages?: ((data: Record<string, unknown>) => any) | undefined;
67
+ onError?: ((error: unknown) => any) | undefined;
68
+ onReady?: ((session: PayPalMessagesSession) => any) | undefined;
55
69
  }>, {
56
70
  trigger: ElementScriptTrigger;
57
71
  clientId: string;
58
72
  paypalScriptOptions: Partial<PayPalInput>;
59
- messagesOptions: PayPalMessagesComponentOptions;
73
+ messagesOptions: PayPalMessagesOptions;
60
74
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
61
75
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
62
76
  declare const _default: typeof __VLS_export;
@@ -1,7 +1,7 @@
1
1
  <script setup>
2
- import { ref, computed, onBeforeUnmount, onMounted, watch } from "vue";
3
- import { useScriptTriggerElement } from "../composables/useScriptTriggerElement";
2
+ import { computed, onBeforeUnmount, onMounted, ref, watch } from "vue";
4
3
  import { useScript } from "../composables/useScript";
4
+ import { useScriptTriggerElement } from "../composables/useScriptTriggerElement";
5
5
  const props = defineProps({
6
6
  trigger: { type: [String, Array, Boolean], required: false, default: "visible" },
7
7
  publishableKey: { type: String, required: true },
@@ -36,6 +36,13 @@ type __VLS_Props = {
36
36
  vimeoOptions?: VimeoOptions;
37
37
  id?: number | undefined;
38
38
  url?: string | undefined;
39
+ ratio?: string;
40
+ /**
41
+ * Object-fit for the placeholder image.
42
+ *
43
+ * @default 'contain'
44
+ */
45
+ placeholderObjectFit?: 'cover' | 'contain' | 'fill' | 'none' | 'scale-down';
39
46
  };
40
47
  declare var __VLS_1: any, __VLS_3: {}, __VLS_10: {}, __VLS_12: {}, __VLS_14: {};
41
48
  type __VLS_Slots = {} & {
@@ -117,6 +124,8 @@ declare const __VLS_base: import("vue").DefineComponent<__VLS_Props, {
117
124
  onLeavepictureinpicture?: ((event: never, player: Vimeo.Player) => any) | undefined;
118
125
  }>, {
119
126
  trigger: ElementScriptTrigger;
127
+ ratio: string;
128
+ placeholderObjectFit: "cover" | "contain" | "fill" | "none" | "scale-down";
120
129
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
121
130
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
122
131
  declare const _default: typeof __VLS_export;