UNPKG

@spartacus/checkout

Version:

Checkout feature library for Spartacus

168 lines 27.9 kB
import { HttpHeaders, HttpParams } from '@angular/common/http'; import { Injectable } from '@angular/core'; import { CARD_TYPE_NORMALIZER, PAYMENT_DETAILS_SERIALIZER, } from '@spartacus/checkout/core'; import { HttpParamsURIEncoder, PAYMENT_DETAILS_NORMALIZER, } from '@spartacus/core'; import { map, mergeMap } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common/http"; import * as i2 from "@spartacus/core"; export class OccCheckoutPaymentAdapter { constructor(http, occEndpoints, converter) { this.http = http; this.occEndpoints = occEndpoints; this.converter = converter; if (typeof DOMParser !== 'undefined') { this.domparser = new DOMParser(); } } getSetPaymentDetailsEndpoint(userId, cartId, paymentDetailsId) { return this.occEndpoints.buildUrl('setCartPaymentDetails', { urlParams: { userId, cartId }, queryParams: { paymentDetailsId }, }); } getPaymentProviderSubInfoEndpoint(userId, cartId) { return this.occEndpoints.buildUrl('paymentProviderSubInfo', { urlParams: { userId, cartId, }, }); } getCreatePaymentDetailsEndpoint(userId, cartId) { return this.occEndpoints.buildUrl('createPaymentDetails', { urlParams: { userId, cartId, }, }); } getCardTypesEndpoint() { return this.occEndpoints.buildUrl('cardTypes'); } create(userId, cartId, paymentDetails) { paymentDetails = this.converter.convert(paymentDetails, PAYMENT_DETAILS_SERIALIZER); return this.getProviderSubInfo(userId, cartId).pipe(map((data) => { const labelsMap = this.convertToMap(data.mappingLabels.entry); return { url: data.postUrl, parameters: this.getParamsForPaymentProvider(paymentDetails, data.parameters.entry, labelsMap), mappingLabels: labelsMap, }; }), mergeMap((sub) => { // create a subscription directly with payment provider return this.createSubWithProvider(sub.url, sub.parameters).pipe(map((response) => this.extractPaymentDetailsFromHtml(response)), mergeMap((fromPaymentProvider) => { var _a; fromPaymentProvider['defaultPayment'] = (_a = paymentDetails.defaultPayment) !== null && _a !== void 0 ? _a : false; fromPaymentProvider['savePaymentInfo'] = true; return this.createDetailsWithParameters(userId, cartId, fromPaymentProvider).pipe(this.converter.pipeable(PAYMENT_DETAILS_NORMALIZER)); })); })); } set(userId, cartId, paymentDetailsId) { return this.http.put(this.getSetPaymentDetailsEndpoint(userId, cartId, paymentDetailsId), {}); } loadCardTypes() { return this.http.get(this.getCardTypesEndpoint()).pipe(map((cardTypeList) => { var _a; return (_a = cardTypeList.cardTypes) !== null && _a !== void 0 ? _a : []; }), this.converter.pipeableMany(CARD_TYPE_NORMALIZER)); } getProviderSubInfo(userId, cartId) { return this.http.get(this.getPaymentProviderSubInfoEndpoint(userId, cartId)); } createSubWithProvider(postUrl, parameters) { const headers = new HttpHeaders({ 'Content-Type': 'application/x-www-form-urlencoded', Accept: 'text/html', }); let httpParams = new HttpParams({ encoder: new HttpParamsURIEncoder() }); Object.keys(parameters).forEach((key) => { httpParams = httpParams.append(key, parameters[key]); }); return this.http.post(postUrl, httpParams, { headers, responseType: 'text', }); } createDetailsWithParameters(userId, cartId, parameters) { let httpParams = new HttpParams({ encoder: new HttpParamsURIEncoder() }); Object.keys(parameters).forEach((key) => { httpParams = httpParams.append(key, parameters[key]); }); const headers = new HttpHeaders({ 'Content-Type': 'application/x-www-form-urlencoded', }); return this.http.post(this.getCreatePaymentDetailsEndpoint(userId, cartId), httpParams, { headers }); } getParamsForPaymentProvider(paymentDetails, parameters, mappingLabels) { var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k; const params = this.convertToMap(parameters); params[mappingLabels['hybris_account_holder_name']] = paymentDetails.accountHolderName; params[mappingLabels['hybris_card_type']] = (_a = paymentDetails.cardType) === null || _a === void 0 ? void 0 : _a.code; params[mappingLabels['hybris_card_number']] = paymentDetails.cardNumber; if (mappingLabels['hybris_combined_expiry_date'] === 'true') { params[mappingLabels['hybris_card_expiry_date']] = paymentDetails.expiryMonth + mappingLabels['hybris_separator_expiry_date'] + paymentDetails.expiryYear; } else { params[mappingLabels['hybris_card_expiration_month']] = paymentDetails.expiryMonth; params[mappingLabels['hybris_card_expiration_year']] = paymentDetails.expiryYear; } params[mappingLabels['hybris_card_cvn']] = paymentDetails.cvn; // billing address params[mappingLabels['hybris_billTo_country']] = (_c = (_b = paymentDetails.billingAddress) === null || _b === void 0 ? void 0 : _b.country) === null || _c === void 0 ? void 0 : _c.isocode; params[mappingLabels['hybris_billTo_firstname']] = (_d = paymentDetails.billingAddress) === null || _d === void 0 ? void 0 : _d.firstName; params[mappingLabels['hybris_billTo_lastname']] = (_e = paymentDetails.billingAddress) === null || _e === void 0 ? void 0 : _e.lastName; params[mappingLabels['hybris_billTo_street1']] = ((_f = paymentDetails.billingAddress) === null || _f === void 0 ? void 0 : _f.line1) + ' ' + ((_g = paymentDetails.billingAddress) === null || _g === void 0 ? void 0 : _g.line2); params[mappingLabels['hybris_billTo_city']] = (_h = paymentDetails.billingAddress) === null || _h === void 0 ? void 0 : _h.town; if ((_j = paymentDetails.billingAddress) === null || _j === void 0 ? void 0 : _j.region) { params[mappingLabels['hybris_billTo_region']] = paymentDetails.billingAddress.region.isocodeShort; } else { params[mappingLabels['hybris_billTo_region']] = ''; } params[mappingLabels['hybris_billTo_postalcode']] = (_k = paymentDetails.billingAddress) === null || _k === void 0 ? void 0 : _k.postalCode; return params; } extractPaymentDetailsFromHtml(html) { const domdoc = this.domparser.parseFromString(html, 'text/xml'); const responseForm = domdoc.getElementsByTagName('form')[0]; const inputs = responseForm.getElementsByTagName('input'); const values = {}; for (let i = 0; inputs[i]; i++) { const input = inputs[i]; const name = input.getAttribute('name'); const value = input.getAttribute('value'); if (name && name !== '{}' && value && value !== '') { values[name] = value; } } return values; } convertToMap(paramList) { return paramList.reduce(function (result, item) { const key = item.key; result[key] = item.value; return result; }, {}); } } OccCheckoutPaymentAdapter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OccCheckoutPaymentAdapter, deps: [{ token: i1.HttpClient }, { token: i2.OccEndpointsService }, { token: i2.ConverterService }], target: i0.ɵɵFactoryTarget.Injectable }); OccCheckoutPaymentAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OccCheckoutPaymentAdapter }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OccCheckoutPaymentAdapter, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.OccEndpointsService }, { type: i2.ConverterService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"occ-checkout-payment.adapter.js","sourceRoot":"","sources":["../../../../../feature-libs/checkout/occ/adapters/occ-checkout-payment.adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport {\n  CARD_TYPE_NORMALIZER,\n  CheckoutPaymentAdapter,\n  PAYMENT_DETAILS_SERIALIZER,\n} from '@spartacus/checkout/core';\nimport {\n  CardType,\n  ConverterService,\n  HttpParamsURIEncoder,\n  Occ,\n  OccEndpointsService,\n  PaymentDetails,\n  PAYMENT_DETAILS_NORMALIZER,\n} from '@spartacus/core';\nimport { Observable } from 'rxjs';\nimport { map, mergeMap } from 'rxjs/operators';\n\n@Injectable()\nexport class OccCheckoutPaymentAdapter implements CheckoutPaymentAdapter {\n  constructor(\n    protected http: HttpClient,\n    protected occEndpoints: OccEndpointsService,\n    protected converter: ConverterService\n  ) {\n    if (typeof DOMParser !== 'undefined') {\n      this.domparser = new DOMParser();\n    }\n  }\n\n  private domparser: DOMParser;\n\n  protected getSetPaymentDetailsEndpoint(\n    userId: string,\n    cartId: string,\n    paymentDetailsId: string\n  ): string {\n    return this.occEndpoints.buildUrl('setCartPaymentDetails', {\n      urlParams: { userId, cartId },\n      queryParams: { paymentDetailsId },\n    });\n  }\n\n  protected getPaymentProviderSubInfoEndpoint(\n    userId: string,\n    cartId: string\n  ): string {\n    return this.occEndpoints.buildUrl('paymentProviderSubInfo', {\n      urlParams: {\n        userId,\n        cartId,\n      },\n    });\n  }\n\n  protected getCreatePaymentDetailsEndpoint(\n    userId: string,\n    cartId: string\n  ): string {\n    return this.occEndpoints.buildUrl('createPaymentDetails', {\n      urlParams: {\n        userId,\n        cartId,\n      },\n    });\n  }\n\n  protected getCardTypesEndpoint(): string {\n    return this.occEndpoints.buildUrl('cardTypes');\n  }\n\n  public create(\n    userId: string,\n    cartId: string,\n    paymentDetails: PaymentDetails\n  ): Observable<PaymentDetails> {\n    paymentDetails = this.converter.convert(\n      paymentDetails,\n      PAYMENT_DETAILS_SERIALIZER\n    );\n    return this.getProviderSubInfo(userId, cartId).pipe(\n      map((data) => {\n        const labelsMap = this.convertToMap(data.mappingLabels.entry) as {\n          [key: string]: string;\n        };\n        return {\n          url: data.postUrl,\n          parameters: this.getParamsForPaymentProvider(\n            paymentDetails,\n            data.parameters.entry,\n            labelsMap\n          ),\n          mappingLabels: labelsMap,\n        };\n      }),\n      mergeMap((sub) => {\n        // create a subscription directly with payment provider\n        return this.createSubWithProvider(sub.url, sub.parameters).pipe(\n          map((response) => this.extractPaymentDetailsFromHtml(response)),\n          mergeMap((fromPaymentProvider) => {\n            fromPaymentProvider['defaultPayment'] =\n              paymentDetails.defaultPayment ?? false;\n            fromPaymentProvider['savePaymentInfo'] = true;\n            return this.createDetailsWithParameters(\n              userId,\n              cartId,\n              fromPaymentProvider\n            ).pipe(this.converter.pipeable(PAYMENT_DETAILS_NORMALIZER));\n          })\n        );\n      })\n    );\n  }\n\n  public set(\n    userId: string,\n    cartId: string,\n    paymentDetailsId: string\n  ): Observable<any> {\n    return this.http.put(\n      this.getSetPaymentDetailsEndpoint(userId, cartId, paymentDetailsId),\n      {}\n    );\n  }\n\n  loadCardTypes(): Observable<CardType[]> {\n    return this.http.get<Occ.CardTypeList>(this.getCardTypesEndpoint()).pipe(\n      map((cardTypeList) => cardTypeList.cardTypes ?? []),\n      this.converter.pipeableMany(CARD_TYPE_NORMALIZER)\n    );\n  }\n\n  protected getProviderSubInfo(\n    userId: string,\n    cartId: string\n  ): Observable<any> {\n    return this.http.get(\n      this.getPaymentProviderSubInfoEndpoint(userId, cartId)\n    );\n  }\n\n  protected createSubWithProvider(\n    postUrl: string,\n    parameters: any\n  ): Observable<any> {\n    const headers = new HttpHeaders({\n      'Content-Type': 'application/x-www-form-urlencoded',\n      Accept: 'text/html',\n    });\n    let httpParams = new HttpParams({ encoder: new HttpParamsURIEncoder() });\n    Object.keys(parameters).forEach((key) => {\n      httpParams = httpParams.append(key, parameters[key]);\n    });\n\n    return this.http.post(postUrl, httpParams, {\n      headers,\n      responseType: 'text',\n    });\n  }\n\n  protected createDetailsWithParameters(\n    userId: string,\n    cartId: string,\n    parameters: any\n  ): Observable<PaymentDetails> {\n    let httpParams = new HttpParams({ encoder: new HttpParamsURIEncoder() });\n    Object.keys(parameters).forEach((key) => {\n      httpParams = httpParams.append(key, parameters[key]);\n    });\n\n    const headers = new HttpHeaders({\n      'Content-Type': 'application/x-www-form-urlencoded',\n    });\n\n    return this.http.post<PaymentDetails>(\n      this.getCreatePaymentDetailsEndpoint(userId, cartId),\n      httpParams,\n      { headers }\n    );\n  }\n\n  private getParamsForPaymentProvider(\n    paymentDetails: PaymentDetails,\n    parameters: { key: string; value: string }[],\n    mappingLabels: { [key: string]: string }\n  ) {\n    const params = this.convertToMap(parameters);\n    params[mappingLabels['hybris_account_holder_name']] =\n      paymentDetails.accountHolderName;\n    params[mappingLabels['hybris_card_type']] = paymentDetails.cardType?.code;\n    params[mappingLabels['hybris_card_number']] = paymentDetails.cardNumber;\n    if (mappingLabels['hybris_combined_expiry_date'] === 'true') {\n      params[mappingLabels['hybris_card_expiry_date']] =\n        paymentDetails.expiryMonth +\n        mappingLabels['hybris_separator_expiry_date'] +\n        paymentDetails.expiryYear;\n    } else {\n      params[mappingLabels['hybris_card_expiration_month']] =\n        paymentDetails.expiryMonth;\n      params[mappingLabels['hybris_card_expiration_year']] =\n        paymentDetails.expiryYear;\n    }\n    params[mappingLabels['hybris_card_cvn']] = paymentDetails.cvn;\n\n    // billing address\n    params[mappingLabels['hybris_billTo_country']] =\n      paymentDetails.billingAddress?.country?.isocode;\n    params[mappingLabels['hybris_billTo_firstname']] =\n      paymentDetails.billingAddress?.firstName;\n    params[mappingLabels['hybris_billTo_lastname']] =\n      paymentDetails.billingAddress?.lastName;\n    params[mappingLabels['hybris_billTo_street1']] =\n      paymentDetails.billingAddress?.line1 +\n      ' ' +\n      paymentDetails.billingAddress?.line2;\n    params[mappingLabels['hybris_billTo_city']] =\n      paymentDetails.billingAddress?.town;\n    if (paymentDetails.billingAddress?.region) {\n      params[mappingLabels['hybris_billTo_region']] =\n        paymentDetails.billingAddress.region.isocodeShort;\n    } else {\n      params[mappingLabels['hybris_billTo_region']] = '';\n    }\n    params[mappingLabels['hybris_billTo_postalcode']] =\n      paymentDetails.billingAddress?.postalCode;\n    return params;\n  }\n\n  private extractPaymentDetailsFromHtml(html: string): {\n    [key: string]: string | boolean;\n  } {\n    const domdoc = this.domparser.parseFromString(html, 'text/xml');\n    const responseForm = domdoc.getElementsByTagName('form')[0];\n    const inputs = responseForm.getElementsByTagName('input');\n\n    const values: { [key: string]: string | boolean } = {};\n    for (let i = 0; inputs[i]; i++) {\n      const input = inputs[i];\n      const name = input.getAttribute('name');\n      const value = input.getAttribute('value');\n      if (name && name !== '{}' && value && value !== '') {\n        values[name] = value;\n      }\n    }\n\n    return values;\n  }\n\n  private convertToMap(paramList: { key: string; value: string }[]): {\n    [key: string]: string | undefined;\n  } {\n    return paramList.reduce(function (\n      result: { [key: string]: string | undefined },\n      item\n    ) {\n      const key = item.key;\n      result[key] = item.value;\n      return result;\n    },\n    {});\n  }\n}\n"]}