flutterwave-angular-v3
Version:
Flutterwave official Angular library to accept payment via card , USSD, QrCode etc.
146 lines • 18.9 kB
JavaScript
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { FlutterwaveService } from '../flutterwave.service';
import { ApiTrackingService } from '../api-tracking.service';
import { CommonModule } from '@angular/common';
import * as i0 from "@angular/core";
import * as i1 from "../flutterwave.service";
import * as i2 from "@angular/common";
export class MakePaymentComponent {
constructor(flutterwaveService) {
this.flutterwaveService = flutterwaveService;
this.callback = new EventEmitter();
this.close = new EventEmitter();
this.customer_defaults = {
email: '',
phone_number: '',
name: ''
};
this.meta_defaults = {
consumer_id: '',
consumer_mac: ''
};
this.customizations_defaults = {
title: '',
description: '',
logo: ''
};
const inlineSdk = 'https://checkout.flutterwave.com/v3.js';
const script = document.createElement('script');
script.src = inlineSdk;
if (!document.querySelector(`[src="${inlineSdk}"]`)) {
document.body.appendChild(script);
}
}
ngOnInit() {
}
makePayment() {
this.prepareForPayment();
if (window.FlutterwaveCheckout) {
window.FlutterwaveCheckout(this.inlinePaymentOptions);
}
else {
console.error('FlutterwaveCheckout is not defined');
}
}
prepareForPayment() {
this.customer = this.customer || {};
this.meta = this.meta || {};
this.customizations = this.customizations || {};
if (this.data) {
this.inlinePaymentOptions = {
...this.data,
callback: response => {
this.flutterwaveService.submitToTracker(this.data, response, 10000);
if (this.data?.callbackContext && this.data.callback) {
this.data.callbackContext[this.data.callback.name](response);
}
},
onclose: () => {
try {
if (this.data?.callbackContext && this.data.onclose) {
this.data.callbackContext[this.data.onclose.name]();
}
}
catch (e) {
}
},
};
}
else {
this.inlinePaymentOptions = {
callbackContext: null,
public_key: this.public_key,
tx_ref: this.tx_ref,
amount: this.amount,
currency: this.currency || 'NGN',
payment_options: this.payment_options || 'card, mobilemoney, ussd',
redirect_url: this.redirect_url || '',
meta: { ...this.meta_defaults, ...this.meta },
customer: { ...this.customer_defaults, ...this.customer },
callback: (response) => {
this.flutterwaveService.submitToTracker(this.inlinePaymentOptions, response, 10000);
this.callback.emit(response);
},
onclose: () => this.close.emit(),
customizations: {
...this.customizations_defaults,
...this.customizations
}
};
if (this.payment_plan) {
this.inlinePaymentOptions.payment_plan = this.payment_plan;
}
if (this.subaccounts) {
this.inlinePaymentOptions.subaccounts = this.subaccounts;
}
if (this.integrity_hash) {
this.inlinePaymentOptions.integrity_hash = this.integrity_hash;
}
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: MakePaymentComponent, deps: [{ token: i1.FlutterwaveService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.6", type: MakePaymentComponent, isStandalone: true, selector: "flutterwave-make-payment", inputs: { public_key: "public_key", tx_ref: "tx_ref", amount: "amount", currency: "currency", payment_options: "payment_options", payment_plan: "payment_plan", subaccounts: "subaccounts", integrity_hash: "integrity_hash", redirect_url: "redirect_url", meta: "meta", customer: "customer", customizations: "customizations", text: "text", style: "style", className: "className", data: "data" }, outputs: { callback: "callback", close: "close" }, providers: [FlutterwaveService, ApiTrackingService], ngImport: i0, template: "<button\n [ngStyle]=\"style\"\n [ngClass]=\"className ? className : 'flutterwave-pay-button'\"\n (click)=\"makePayment()\">\n {{text || 'Pay'}}\n</button>\n", styles: [".flutterwave-pay-button{background-color:#f5a623;border-radius:4px;border-color:#f5a623;box-shadow:0 2px 3px #ccc;color:#fff;display:block;font-size:12px;font-weight:700;padding:14px 22px;text-align:center;text-decoration:none;-webkit-transition:all .3s ease-in-out;transition:all .3s ease-in-out}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: MakePaymentComponent, decorators: [{
type: Component,
args: [{ selector: 'flutterwave-make-payment', standalone: true, providers: [FlutterwaveService, ApiTrackingService], imports: [
CommonModule
], template: "<button\n [ngStyle]=\"style\"\n [ngClass]=\"className ? className : 'flutterwave-pay-button'\"\n (click)=\"makePayment()\">\n {{text || 'Pay'}}\n</button>\n", styles: [".flutterwave-pay-button{background-color:#f5a623;border-radius:4px;border-color:#f5a623;box-shadow:0 2px 3px #ccc;color:#fff;display:block;font-size:12px;font-weight:700;padding:14px 22px;text-align:center;text-decoration:none;-webkit-transition:all .3s ease-in-out;transition:all .3s ease-in-out}\n"] }]
}], ctorParameters: () => [{ type: i1.FlutterwaveService }], propDecorators: { public_key: [{
type: Input
}], tx_ref: [{
type: Input
}], amount: [{
type: Input
}], currency: [{
type: Input
}], payment_options: [{
type: Input
}], payment_plan: [{
type: Input
}], subaccounts: [{
type: Input
}], integrity_hash: [{
type: Input
}], redirect_url: [{
type: Input
}], meta: [{
type: Input
}], customer: [{
type: Input
}], callback: [{
type: Output
}], close: [{
type: Output
}], customizations: [{
type: Input
}], text: [{
type: Input
}], style: [{
type: Input
}], className: [{
type: Input
}], data: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"make-payment.component.js","sourceRoot":"","sources":["../../../../../projects/flutterwave-angular-v3/src/lib/make-payment/make-payment.component.ts","../../../../../projects/flutterwave-angular-v3/src/lib/make-payment/make-payment.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;AAY/C,MAAM,OAAO,oBAAoB;IAqC/B,YAAoB,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;QAzBhD,aAAQ,GAAyC,IAAI,YAAY,EAA0B,CAAC;QAC5F,UAAK,GAAsB,IAAI,YAAY,EAAE,CAAC;QASxD,sBAAiB,GAAG;YAClB,KAAK,EAAE,EAAE;YACT,YAAY,EAAE,EAAE;YAChB,IAAI,EAAE,EAAE;SACT,CAAC;QACF,kBAAa,GAAG;YACd,WAAW,EAAE,EAAE;YACf,YAAY,EAAE,EAAE;SACjB,CAAC;QACF,4BAAuB,GAAG;YACxB,KAAK,EAAE,EAAE;YACT,WAAW,EAAE,EAAE;YACf,IAAI,EAAE,EAAE;SACT,CAAC;QAGA,MAAM,SAAS,GAAG,wCAAwC,CAAC;QAC3D,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,CAAC,GAAG,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,SAAS,IAAI,CAAC,EAAE,CAAC;YACpD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IAED,QAAQ;IACR,CAAC;IAED,WAAW;QACT,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,MAAM,CAAC,mBAAmB,EAAE,CAAC;YAC/B,MAAM,CAAC,mBAAmB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACxD,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;QACpC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC;QAEhD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,CAAC,oBAAoB,GAAG;gBAC1B,GAAG,IAAI,CAAC,IAAI;gBACZ,QAAQ,EAAE,QAAQ,CAAC,EAAE;oBACnB,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,EAAG,QAAQ,EAAG,KAAK,CAAC,CAAC;oBACtE,IAAI,IAAI,CAAC,IAAI,EAAE,eAAe,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACpD,IAAI,CAAC,IAAI,CAAC,eAA+C,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;oBAChG,CAAC;gBACH,CAAC;gBACD,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,CAAC;wBACH,IAAI,IAAI,CAAC,IAAI,EAAE,eAAe,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;4BACnD,IAAI,CAAC,IAAI,CAAC,eAA+C,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;wBACvF,CAAC;oBACH,CAAC;oBAAC,OAAO,CAAC,EAAE,CAAC;oBACb,CAAC;gBACH,CAAC;aACF,CAAA;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,oBAAoB,GAAG;gBAC1B,eAAe,EAAE,IAAI;gBACrB,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;gBAChC,eAAe,EAAE,IAAI,CAAC,eAAe,IAAI,yBAAyB;gBAClE,YAAY,EAAE,IAAI,CAAC,YAAY,IAAI,EAAE;gBACrC,IAAI,EAAE,EAAC,GAAG,IAAI,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,IAAI,EAAC;gBAC3C,QAAQ,EAAE,EAAC,GAAG,IAAI,CAAC,iBAAiB,EAAE,GAAG,IAAI,CAAC,QAAQ,EAAC;gBACvD,QAAQ,EAAE,CAAC,QAAgC,EAAE,EAAE;oBAC7C,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,oBAAoB,EAAG,QAAQ,EAAG,KAAK,CAAC,CAAC;oBACtF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC/B,CAAC;gBACD,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;gBAChC,cAAc,EAAE;oBACd,GAAG,IAAI,CAAC,uBAAuB;oBAC/B,GAAG,IAAI,CAAC,cAAc;iBACvB;aACF,CAAA;YACD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtB,IAAI,CAAC,oBAAoB,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;YAC7D,CAAC;YACD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACrB,IAAI,CAAC,oBAAoB,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;YAC3D,CAAC;YACD,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,IAAI,CAAC,oBAAoB,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;YACjE,CAAC;QACH,CAAC;IACH,CAAC;8GAhHU,oBAAoB;kGAApB,oBAAoB,kgBAPpB,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,0BCTrD,kKAMA,oWDKI,YAAY;;2FAKH,oBAAoB;kBAVhC,SAAS;+BACE,0BAA0B,cACxB,IAAI,aACL,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,WAC1C;wBACP,YAAY;qBACb;uFAKQ,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,QAAQ;sBAAjB,MAAM;gBACG,KAAK;sBAAd,MAAM;gBACE,cAAc;sBAAtB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FlutterwaveService } from '../flutterwave.service';\nimport { ApiTrackingService } from '../api-tracking.service';\nimport { InlinePaymentOptions, PaymentSuccessResponse } from '../models';\nimport { CommonModule } from '@angular/common';\n\n@Component({\n  selector: 'flutterwave-make-payment',\n  standalone: true,\n  providers: [FlutterwaveService, ApiTrackingService],\n  imports: [\n    CommonModule\n  ],\n  templateUrl: './make-payment.component.html',\n  styleUrl: './make-payment.component.css'\n})\nexport class MakePaymentComponent {\n  @Input() public_key!: string;\n  @Input() tx_ref!: string;\n  @Input() amount!: number;\n  @Input() currency?: string;\n  @Input() payment_options?: string;\n  @Input() payment_plan?: string | number;\n  @Input() subaccounts: any;\n  @Input() integrity_hash: any;\n  @Input() redirect_url?: string;\n  @Input() meta?: object; // { counsumer_id, consumer_mac }\n  @Input() customer?: object; // { email, phone_number,name }\n  @Output() callback: EventEmitter<PaymentSuccessResponse> = new EventEmitter<PaymentSuccessResponse>();\n  @Output() close: EventEmitter<any> = new EventEmitter();\n  @Input() customizations?: object; // { title, description, logo }\n  @Input() text?: string;\n  @Input() style: any;\n  @Input() className?: string;\n  @Input() data?: InlinePaymentOptions;\n\n  private inlinePaymentOptions!: InlinePaymentOptions;\n\n  customer_defaults = {\n    email: '',\n    phone_number: '',\n    name: ''\n  };\n  meta_defaults = {\n    consumer_id: '',\n    consumer_mac: ''\n  };\n  customizations_defaults = {\n    title: '',\n    description: '',\n    logo: ''\n  };\n\n  constructor(private flutterwaveService: FlutterwaveService) {\n    const inlineSdk = 'https://checkout.flutterwave.com/v3.js';\n    const script = document.createElement('script');\n    script.src = inlineSdk;\n    if (!document.querySelector(`[src=\"${inlineSdk}\"]`)) {\n      document.body.appendChild(script);\n    }\n  }\n\n  ngOnInit(): void {\n  }\n\n  makePayment() {\n    this.prepareForPayment();\n    if (window.FlutterwaveCheckout) {\n      window.FlutterwaveCheckout(this.inlinePaymentOptions);\n    } else {\n      console.error('FlutterwaveCheckout is not defined');\n    }\n  }\n\n  prepareForPayment(): void {\n    this.customer = this.customer || {};\n    this.meta = this.meta || {};\n    this.customizations = this.customizations || {};\n\n    if (this.data) {\n      this.inlinePaymentOptions = {\n        ...this.data,\n        callback: response => {\n          this.flutterwaveService.submitToTracker(this.data , response,  10000);\n          if (this.data?.callbackContext && this.data.callback) {\n            (this.data.callbackContext as { [key: string]: Function })[this.data.callback.name](response);\n          }\n        },\n        onclose: () => {\n          try {\n            if (this.data?.callbackContext && this.data.onclose) {\n              (this.data.callbackContext as { [key: string]: Function })[this.data.onclose.name]();\n            }\n          } catch (e) {\n          }\n        },\n      }\n    } else {\n      this.inlinePaymentOptions = {\n        callbackContext: null,\n        public_key: this.public_key,\n        tx_ref: this.tx_ref,\n        amount: this.amount,\n        currency: this.currency || 'NGN',\n        payment_options: this.payment_options || 'card, mobilemoney, ussd',\n        redirect_url: this.redirect_url || '',\n        meta: {...this.meta_defaults, ...this.meta},\n        customer: {...this.customer_defaults, ...this.customer},\n        callback: (response: PaymentSuccessResponse) => {\n          this.flutterwaveService.submitToTracker(this.inlinePaymentOptions , response,  10000);\n          this.callback.emit(response);\n        },\n        onclose: () => this.close.emit(),\n        customizations: {\n          ...this.customizations_defaults,\n          ...this.customizations\n        }\n      }\n      if (this.payment_plan) {\n        this.inlinePaymentOptions.payment_plan = this.payment_plan;\n      }\n      if (this.subaccounts) {\n        this.inlinePaymentOptions.subaccounts = this.subaccounts;\n      }\n      if (this.integrity_hash) {\n        this.inlinePaymentOptions.integrity_hash = this.integrity_hash;\n      }\n    }\n  }\n}\n","<button\n  [ngStyle]=\"style\"\n  [ngClass]=\"className ? className : 'flutterwave-pay-button'\"\n  (click)=\"makePayment()\">\n  {{text || 'Pay'}}\n</button>\n"]}