NuxtJS module for Stripe.js
- Load Stripe.js only when required (once
$stripe()
is called) - Reuse the same instance across all components
- Retry mechanism to bypass temporary network issues
- TypeScript support
- Add
@chantouchsek/nuxt-stripe
dependency to your project:
npm install @chantouchsek/nuxt-stripe
- Add
@chantouchsek/nuxt-stripe
module and configuration tonuxt.config.js
:
export default {
modules: [
// simple usage
'@chantouchsek/nuxt-stripe',
// with options
["@chantouchsek/nuxt-stripe", {
publishableKey: 'YOUR_STRIPE_PUBLISHABLE_KEY',
version: '2020-08-27',
i18n: true,
}]
],
// .....option
stripe: {
publishableKey: 'YOUR_STRIPE_PUBLISHABLE_KEY',
version: '2020-08-27',
i18n: true,
},
// runtime config
publicRuntimeConfig: {
stripe: {
publishableKey: 'YOUR_STRIPE_PUBLISHABLE_KEY',
version: '2020-08-27',
i18n: true,
}
}
}
- (Optional) TypeScript support. Add
@chantouchsek/nuxt-stripe
to thetypes
section oftsconfig.json
:
{
"compilerOptions": {
"types": [
"@nuxt/types",
"@chantouchsek/nuxt-stripe"
]
}
}
- (Optional), If you need to support change stripe locale base i18n locale changed, just create a file
in
plugins/i18n.{js,ts}
import { Context, Inject } from '@nuxt/types/app'
import { getStripeInstance } from '@chantouchsek/nuxt-stripe'
import { CheckoutLocale, StripeElementLocale } from '@stripe/stripe-js'
export default function (ctx: Context, inject: Inject) {
const {app} = ctx
app.i18n.onLanguageSwitched = async (_, locale) => {
const stripeLocale = locale as StripeElementLocale | CheckoutLocale
const stripeInstance = await getStripeInstance(ctx, stripeLocale)
inject('stripe', stripeInstance)
ctx.app.stripe = stripeInstance
}
}
And call it in nuxt.config.{js,ts}
export default {
plugins: [
'~/plugins/i18n',
]
}
- Type:
String
Your Stripe's publishable key.
- Type:
String
Your Stripe's version.
- Type:
Boolean
- Default:
false
Enable i18n-module integration.
It can be used inside components like:
<template>
<div>
<div ref="stripeElements"/>
</div>
</template>
export default {
async mounted() {
const stripe = await this.$stripe()
const elements = stripe.elements()
const card = elements.create('card')
card.mount(this.$refs.stripeElements)
}
}
Stripe: JavaScript SDK documentation & reference
See the License file for license rights and limitations (MIT).