Introduction
VueJS component wrapper for Khalti SDK
Demo
https://codesandbox.io/s/k574mxpl17
Installation
Install dependency
npm install khalti-web --save
Install component
npm install vue-khalti --save
Usage
Browser
<script src="dist/vue-khalti-min.js"></script>
<script src="path/to/vue.js"></script>
<script>
Vue.use(VueKhalti)
</script>
Build
<script>
import VueKhalti from 'vue-khalti'
export default {
components: { VueKhalti }
}
</script>
<template>
<div>
<vue-khalti />
</div>
</template>
Overwrite default config with your config
data () {
return {
khaltiConfig: {
"publicKey": "YOUR_PUBLIC_KEY",
"productIdentity": "YOUR_PRODUCT_ID",
"productName": "YOUR_PRODUCT_NAME",
"productUrl": "YOUR_PRODUCT_URL",
"amount": 1000,
"eventHandler": {
onSuccess (payload) {
console.log(payload);
},
onError (error) {
console.log(error);
},
onClose () {
console.log('widget is closing');
}
}
}
}
}
<vue-khalti v-bind="khaltiConfig" />
Change apperance of the component
<vue-khalti>
.
Wrap your code inside <vue-khalti ref="khaltiCheckout">
<img
src="https://d7vw40z4bofef.cloudfront.net/static/www/images/khaltilogo.png"
@click="onKhaltiClick" />
</vue-khalti>
$refs
. The default event handler is onClick
.
Access the component via methods: {
onKhaltiClick () {
const khaltiCheckout = this.$refs.khaltiCheckout
khaltiCheckout.onClick()
}
}