UNPKG

@chargebee/chargebee-js-angular-wrapper

Version:
168 lines 20.3 kB
import { Input, Directive, Output, EventEmitter, ContentChild, } from "@angular/core"; import { NumberFieldDirective } from "./number-field.directive"; import { ExpiryFieldDirective } from "./expiry-field.directive"; import { CvvFieldDirective } from "./cvv-field.directive"; import { getPropChanges } from "../../utils"; import * as i0 from "@angular/core"; export class CardFieldDirective { id = ""; cbInstance = null; cbComponent = null; icon; classes; fonts; styles; locale; showTestCards; currency; placeholder; numberComponent; expiryComponent; cvvComponent; // Below events only for combined-field ready = new EventEmitter(); focus = new EventEmitter(); blur = new EventEmitter(); change = new EventEmitter(); load; initialization; constructor(el) { if (el.nativeElement) { this.id = el.nativeElement.id; } } onReady = (cardComponent, field) => { let data; if (field) { // Emit allows only one argument (Spec deviation) data = { cardComponent, field }; } else { data = cardComponent; } this.ready.emit(data); }; // Below events only for Combined field onFocus = (status) => { this.focus.emit(status); }; onBlur = (status) => { this.blur.emit(status); }; onChange = (status) => { this.change.emit(status); }; ngOnInit() { if (typeof window !== "undefined" && typeof window["Chargebee"] !== "undefined") { const options = { icon: typeof this.icon === "boolean" ? this.icon : true, fonts: this.fonts || [], style: this.styles || {}, locale: this.locale || "en", showTestCards: this.showTestCards ?? false, classes: this.classes || {}, currency: this.currency || "USD", placeholder: this.placeholder || {}, }; this.cbInstance = window["Chargebee"].getInstance(); this.cbInstance.load("components").then(() => { this.cbComponent = this.cbInstance.createComponent("card", options); // Attaching listeners if any (only applicable for combined field) this.cbComponent.on("ready", this.onReady); this.cbComponent.on("focus", this.onFocus); this.cbComponent.on("blur", this.onBlur); this.cbComponent.on("change", this.onChange); // Initialize inidividual fields (if present) this.initializeField(this.cbComponent, this.numberComponent); this.initializeField(this.cbComponent, this.expiryComponent); this.initializeField(this.cbComponent, this.cvvComponent); this.cbComponent.mount(`#${this.id}`); }); } } initializeField(cbComponent, fieldElement) { if (cbComponent && fieldElement) { const fieldInstance = cbComponent .createField(fieldElement.type, { style: fieldElement.styles || {}, placeholder: fieldElement.placeholder || "", }) .at(`#${fieldElement.id}`); fieldElement.field = fieldInstance; // attach listeners fieldInstance.on("ready", fieldElement.onReady); fieldInstance.on("focus", fieldElement.onFocus); fieldInstance.on("blur", fieldElement.onBlur); fieldInstance.on("change", fieldElement.onChange); return fieldInstance; } return null; } tokenize(additionalData) { return this.cbComponent.tokenize(additionalData); } authorizeWith3ds(paymentIntent, additionalData, callbacks) { return this.cbComponent.authorizeWith3ds(paymentIntent, additionalData, callbacks); } ngOnChanges(changes) { if (this.cbComponent) { const props = [ "icon", "classes", "fonts", "locale", "showTestCards", "styles", "placeholder", ]; const { currentOptions, hasChanged } = getPropChanges(changes, props); if (hasChanged) { this.cbComponent.update(currentOptions); } } } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CardFieldDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); /** @nocollapse */ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CardFieldDirective, isStandalone: true, selector: "[cbCardField]", inputs: { icon: "icon", classes: "classes", fonts: "fonts", styles: "styles", locale: "locale", showTestCards: "showTestCards", currency: "currency", placeholder: "placeholder" }, outputs: { ready: "ready", focus: "focus", blur: "blur", change: "change" }, queries: [{ propertyName: "numberComponent", first: true, predicate: NumberFieldDirective, descendants: true, static: true }, { propertyName: "expiryComponent", first: true, predicate: ExpiryFieldDirective, descendants: true, static: true }, { propertyName: "cvvComponent", first: true, predicate: CvvFieldDirective, descendants: true, static: true }], usesOnChanges: true, ngImport: i0 }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CardFieldDirective, decorators: [{ type: Directive, args: [{ selector: "[cbCardField]", standalone: true, }] }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { icon: [{ type: Input }], classes: [{ type: Input }], fonts: [{ type: Input }], styles: [{ type: Input }], locale: [{ type: Input }], showTestCards: [{ type: Input }], currency: [{ type: Input }], placeholder: [{ type: Input }], numberComponent: [{ type: ContentChild, args: [NumberFieldDirective, { static: true }] }], expiryComponent: [{ type: ContentChild, args: [ExpiryFieldDirective, { static: true }] }], cvvComponent: [{ type: ContentChild, args: [CvvFieldDirective, { static: true }] }], ready: [{ type: Output }], focus: [{ type: Output }], blur: [{ type: Output }], change: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card-field.directive.js","sourceRoot":"","sources":["../../../../../projects/chargebee-js-angular-wrapper/src/lib/directives/card-field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  Directive,\n  Output,\n  EventEmitter,\n  ContentChild,\n  ElementRef,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n} from \"@angular/core\";\nimport { NumberFieldDirective } from \"./number-field.directive\";\nimport { ExpiryFieldDirective } from \"./expiry-field.directive\";\nimport { CvvFieldDirective } from \"./cvv-field.directive\";\nimport { getPropChanges } from \"../../utils\";\nimport { PaymentIntent, AdditionalData, Callbacks } from \"../types\";\n\ndeclare var Chargebee: any;\n\n@Directive({\n  selector: \"[cbCardField]\",\n  standalone: true,\n})\nexport class CardFieldDirective implements OnInit, OnChanges {\n  id = \"\";\n  cbInstance = null;\n  cbComponent = null;\n\n  @Input() icon?: boolean;\n  @Input() classes?: object;\n  @Input() fonts?: object;\n  @Input() styles?: object;\n  @Input() locale?: string;\n  @Input() showTestCards?: boolean;\n  @Input() currency?: string;\n  @Input() placeholder?: {\n    number?: string;\n    expiry?: string;\n    cvv?: string;\n  };\n\n  @ContentChild(NumberFieldDirective, { static: true }) numberComponent;\n  @ContentChild(ExpiryFieldDirective, { static: true }) expiryComponent;\n  @ContentChild(CvvFieldDirective, { static: true }) cvvComponent;\n\n  // Below events only for combined-field\n  @Output() ready: EventEmitter<any> = new EventEmitter();\n  @Output() focus: EventEmitter<any> = new EventEmitter();\n  @Output() blur: EventEmitter<any> = new EventEmitter();\n  @Output() change: EventEmitter<any> = new EventEmitter();\n\n  load: Promise<boolean>;\n  initialization: Promise<any>;\n\n  constructor(el: ElementRef) {\n    if (el.nativeElement) {\n      this.id = el.nativeElement.id;\n    }\n  }\n\n  onReady = (cardComponent: any, field: any) => {\n    let data: any;\n    if (field) {\n      // Emit allows only one argument (Spec deviation)\n      data = { cardComponent, field };\n    } else {\n      data = cardComponent;\n    }\n    this.ready.emit(data);\n  };\n\n  // Below events only for Combined field\n  onFocus = (status: any) => {\n    this.focus.emit(status);\n  };\n  onBlur = (status: any) => {\n    this.blur.emit(status);\n  };\n  onChange = (status: any) => {\n    this.change.emit(status);\n  };\n\n  ngOnInit() {\n    if (\n      typeof window !== \"undefined\" &&\n      typeof window[\"Chargebee\"] !== \"undefined\"\n    ) {\n      const options = {\n        icon: typeof this.icon === \"boolean\" ? this.icon : true,\n        fonts: this.fonts || [],\n        style: this.styles || {},\n        locale: this.locale || \"en\",\n        showTestCards: this.showTestCards ?? false,\n        classes: this.classes || {},\n        currency: this.currency || \"USD\",\n        placeholder: this.placeholder || {},\n      };\n\n      this.cbInstance = window[\"Chargebee\"].getInstance();\n\n      this.cbInstance.load(\"components\").then(() => {\n        this.cbComponent = this.cbInstance.createComponent(\"card\", options);\n\n        // Attaching listeners if any (only applicable for combined field)\n        this.cbComponent.on(\"ready\", this.onReady);\n        this.cbComponent.on(\"focus\", this.onFocus);\n        this.cbComponent.on(\"blur\", this.onBlur);\n        this.cbComponent.on(\"change\", this.onChange);\n\n        // Initialize inidividual fields (if present)\n        this.initializeField(this.cbComponent, this.numberComponent);\n        this.initializeField(this.cbComponent, this.expiryComponent);\n        this.initializeField(this.cbComponent, this.cvvComponent);\n\n        this.cbComponent.mount(`#${this.id}`);\n      });\n    }\n  }\n\n  initializeField(cbComponent, fieldElement) {\n    if (cbComponent && fieldElement) {\n      const fieldInstance = cbComponent\n        .createField(fieldElement.type, {\n          style: fieldElement.styles || {},\n          placeholder: fieldElement.placeholder || \"\",\n        })\n        .at(`#${fieldElement.id}`);\n\n      fieldElement.field = fieldInstance;\n\n      // attach listeners\n      fieldInstance.on(\"ready\", fieldElement.onReady);\n      fieldInstance.on(\"focus\", fieldElement.onFocus);\n      fieldInstance.on(\"blur\", fieldElement.onBlur);\n      fieldInstance.on(\"change\", fieldElement.onChange);\n      return fieldInstance;\n    }\n    return null;\n  }\n\n  public tokenize(additionalData: any) {\n    return this.cbComponent.tokenize(additionalData);\n  }\n\n  public authorizeWith3ds(\n    paymentIntent: PaymentIntent,\n    additionalData: AdditionalData,\n    callbacks: Callbacks\n  ) {\n    return this.cbComponent.authorizeWith3ds(\n      paymentIntent,\n      additionalData,\n      callbacks\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.cbComponent) {\n      const props = [\n        \"icon\",\n        \"classes\",\n        \"fonts\",\n        \"locale\",\n        \"showTestCards\",\n        \"styles\",\n        \"placeholder\",\n      ];\n      const { currentOptions, hasChanged } = getPropChanges(changes, props);\n\n      if (hasChanged) {\n        this.cbComponent.update(currentOptions);\n      }\n    }\n  }\n}\n"]}