vsf-payment-klarna
vsf-payment-klarna copied to clipboard
Klarna Checkout for Vue Storefront
vsf-payment-klarna
data:image/s3,"s3://crabby-images/5bd80/5bd8041deacb796bd7be443bd313fa30feeb496c" alt=""
-
Frontend
- Installation
- Config
- Checkout
- Confirmation page
- Plugins
-
API
- Installation
- Config
- Magento 2
-
Development
- Requirements
- Get started
- e2e
- Tunnel
Frontend
Installation
- Copy
packages/payment-klarna
tosrc/modules/payment-klarna
- Update
modules/client.ts
with the following:import { KlarnaCheckout } from './payment-klarna' ... export const registerModules: VueStorefrontModule[] = [ ..., KlarnaCheckout ]
Config
See config.json for example config
klarna.create
Endpoint for creating order (vsf-api)
klarna.confirmation
Endpoint for retrieving Klana confirmation snippet (vsf-api)
klarna.validate_order
Endpoint called when order total changes (vsf-api)
klarna.showShippingOptions
If set to true available shipping methods will be sent to Klarna and enable Klarnas shipping method form
klarna.options
https://developers.klarna.com/api/#checkout-api__create-a-new-order__options
Some plugins might use other keys
Checkout
In theme/pages/Checkout.vue
import KCO from 'src/modules/payment-klarna/components/KlarnaCheckout'
export {
...,
components: {
klarna-checkout: KCO
}
}
And then just <klarna-checkout />
where you want to render it
Confirmation page
Will be found at www.example.com/confirmation
and www.example.com/STORECODE/confirmation
See beforeRegistration.ts for more info
Plugins
If you need to extend this library you most likely don't need to fork it, just create a plugin!
There's a few default plugins already made. See the plugins folder for README and inspiration.
API
Installation
- Copy
packages/payment-klarna-bridge
tosrc/api/extensions/payment-klarna-bridge
- Add
payment-klarna-bridge
toregisteredExtensions
inlocal.json
Config
See config.json for example config
klarna.merchant_urls
Klarna docs: https://developers.klarna.com/api/#checkout-api__create-a-new-order__merchant_urls
Alongside Klarnas variables ({checkout.order.id}
, {checkout.order.url}
and/or {checkout.order.uri}
) you can also use {{sourceCode}}
which will be replaced currentStoreView().storeCode
and {{dataSourceCode}}
which will be replaced currentStoreView().dataSourceCode
(useful if you need a different field for the url).
klarna.auth
Your Klarna auth credentials
"auth": {
"user": "PK0123_something",
"pass": "password"
},
klarna.endpoints
"endpoints": {
"order": "https://api.something.klarna.com", // pick from https://developers.klarna.com/api/#api-urls
// TODO: Integrate to magento2-vsf-kco module
"validate_order": "" // will be called when total amount changes
},
https://developers.klarna.com/api/#api-urls
Magento 2
Please use this module: https://github.com/kodbruket/magento2-vsf-kco
Development
Requirements
- Node 10+ (https://nodejs.org/en/download/)
- Yarn (https://yarnpkg.com/en/docs/install)
- Docker (https://docs.docker.com/v17.09/engine/installation/)
-
docker-compose
(https://docs.docker.com/compose/install/)
Protip: On Mac run, install Docker and Brew then run
brew install node && brew install yarn && brew install docker-compose
Get started
git clone --recurse-submodules https://github.com/kodbruket/vsf-payment-klarna
cd vsf-payment-klarna
yarn # set up git hooks
docker-compose up
# new tab
make es-restore # seed Magento catalog data
Visit http://localhost:3000
e2e
yarn cypress
Tunnel
ssh -R vsf-payment-klarna:80:localhost:8080 serveo.net