@spartacus/checkout
Version:
Checkout feature library for Spartacus
168 lines • 27.9 kB
JavaScript
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"]}