The Worldpay Connector for SAP Spartacus Storefront is an Angular Library that provides the components to integrate WorldPay payment solutions with the SAP Commerce Cloud Spartacus storefront.
Worldpay from FIS is one of the world's leading global eCommerce and payment technology companies. FIS is a leading provider of technology solutions for merchants, banks and capital markets firms globally.
Starting with version 2211.19, composable storefront has aligned its versioning with SAP Commerce Cloud. The previous release of composable storefront was version 6.8. For more information, see Changes to Release Numbering and Update Policies for Composable Storefront Starting in February 2024.
Composable storefront is based off the Spartacus open source code, and is included in the SAP Commerce Cloud license at no extra cost. Composable storefront has a roll-forward update policy. Spartacus documentation: https://sap.github.io/spartacus-docs/. Release information: https://sap.github.io/spartacus-docs/release-information/.
- If you are working with Spartacus 2211, see the 2211 Angular development environment requirements on the SAP Help Portal.
- Angular CLI: Version 17.0.0 is the minimum required. The most recent 17.x version is strongly recommended.
- npm: Version 10.2.4 or newer.
- Node.js: Version 20.9.0 is the minimum required. The most recent 20.x version is strongly recommended.
Note: Some Spartacus features require API endpoints that are only available in newer versions of SAP Commerce Cloud. For more information, see Feature Compatibility.
The Connector is compatible with the Spartacus Release 2211.28.0
Run the command ./install.sh
to do a clean install and run the example-storefront
- Install
@worldpay2020/sap-composable
to your Spartacus project - final name pending
npm install @worldpay2020/sap-composable
or
npm install @worldpay2020/sap-composable@2211.28.0
- Include Worldpay Module the following in your Spartacus storefront's
app.module.ts
file.
import { WorldpayModule } from '@worldpay2020/sap-composable';
@NgModule({
imports: [
...
WorldpayModule,
],
})
Note: WorldpayModule will include the following modules:
@NgModule({
imports: [
...
OccWorldpayModule,
WorldpayFraudsightRiskModule,
WorldpayCheckoutPaymentMethodModule,
WorldpayCheckoutDeliveryAddressModule,
WorldpayDdcIframeModule,
WorldpayDdcIframeRoutingModule,
Worldpay3dsChallengeIframeModule,
WorldpayCheckoutPlaceOrderModule,
WorldpayCheckoutReviewPaymentModule,
WorldpayCartSharedModule,
WorldpayOrderConfirmationModule,
WorldpayOrderDetailsModule,
],
...
})
- Add additional translations
@NgModule({
providers: [
provideConfig({
i18n: {
resources: worldpayTranslations
},
} as I18nConfig),
{
provide: APP_BASE_HREF,
useFactory: getBaseHref,
deps: [PlatformLocation]
},
...worldpayFacadeProviders,
],
})
export class WorldpayModule {
}
- Include Worldpay script before closing the body tag inside the index.html file
<html>
...
<app-root></app-root>
...
<script src="https://secure.worldpay.com/resources/cse/js/worldpay-cse-1.latest.min.js"></script>
</body>
</html>
To enable Guaranteed Payments, you must:
- add the
WorldpayGuaranteedPaymentsModule
to yourapp.module.ts
file:
@NgModule({
imports: [
...
WorldpayModule,
WorldpayGuaranteedPaymentsModule
],
})
- Then update your
app.component.html
file using the<worldpay-guaranteed-payments></worldpay-guaranteed-payments>
tag
<cx-storefront></cx-storefront>
<worldpay-guaranteed-payments></worldpay-guaranteed-payments>
- To enable Guaranteed Payments, you must add the WorldpayFraudsightRiskModule to your
app.module.ts
file:
@NgModule({
imports: [
...
WorldpayModule,
WorldpayFraudsightRiskModule
],
})
- Update your environment.ts file with the following configuration:
export const environment = {
fraudSight: {
organisationId: 'YOUR_ORGANISATION_ID',
profilingDomain: 'PROFILING_DOMAIN',
pageId: 'PAGE_ID',
},
};
- Then update your
app.component.html
file using the tag
<cx-storefront></cx-storefront>
<worldpay-fraudsight-risk
threatMetrix="wprofile"
[randomIdLength]="128"
[organisationId]="fraudsightConfig.organisationId"
[pageId]="fraudsightConfig.pageId"
[profilingDomain]="fraudsightConfig.profilingDomain"
></worldpay-fraudsight-risk>
Copyright (c) 2022 Worldpay Ltd.
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- Compatible with SAP Commerce Cloud 2211.2X
- Supported APM’s:
Payment | Enabled Country | Currency | Requires User Data | Additional User Data |
---|---|---|---|---|
ACH Direct Debit | US | USD | Yes | Account type, Account Number, Routing Number, Check Number, Company Name, Custom Identifier |
AliPay | CN | USD, EUR | ||
ApplePay | All | All | Yes | |
Bancontact MisterCash | BE | EUR | ||
China Union Pay | CN | GBP,EUR,USD,SGD | ||
GiroPay | GE | EUR | ||
GooglePay | All | All | Yes | |
iDeal | NL | EUR | Yes | Bank Code |
Klarna | AT,FI,DE,NL,NO,SE,GB | EUR,GBP | ||
Klarna Pay Later | SE,NO,FI,DE,NL,AT,CH,GB,DK,US | EUR,GBP | ||
Klarna Pay Now | SE,DE,NL,AT | EUR,GBP | ||
Klarna Slice It | SE,NO,FI,DE,AT,GB,DK,US | EUR,GBP | ||
PayPal SSL | All | All | ||
POLi | NZ | NZ | ||
Postepay | IT | EUR | ||
Sepa | AT,BE,FR,DE,IE,IT,NL,ES | EUR | ||
Sofort | AT,BE,FR,DE,CH | EUR,CHF |
- Included ACH payment method for United States
- Supported APM’s:
Payment | Enabled Country | Currency | Requires User Data | Additional User Data |
---|---|---|---|---|
ACH Direct Debit | US | USD | Yes | Account type, Account Number, Routing Number, Check Number, Company Name, Custom Identifier |
AliPay | CN | USD, EUR | ||
ApplePay | All | All | Yes | |
Bancontact MisterCash | BE | EUR | ||
China Union Pay | CN | GBP,EUR,USD,SGD | ||
GiroPay | GE | EUR | ||
GooglePay | All | All | Yes | |
iDeal | NL | EUR | Yes | Bank Code |
Klarna | AT,FI,DE,NL,NO,SE,GB | EUR,GBP | ||
Klarna Pay Later | SE,NO,FI,DE,NL,AT,CH,GB,DK,US | EUR,GBP | ||
Klarna Pay Now | SE,DE,NL,AT | EUR,GBP | ||
Klarna Slice It | SE,NO,FI,DE,AT,GB,DK,US | EUR,GBP | ||
PayPal SSL | All | All | ||
POLi | NZ | NZ | ||
Postepay | IT | EUR | ||
Sepa | AT,BE,FR,DE,IE,IT,NL,ES | EUR | ||
Sofort | AT,BE,FR,DE,CH | EUR,CHF |
- Updated iDeal 2.0
- Implemented PayPal SSL
- Credit card form
- Supports Guest checkout
- 3d Secure
- Fraud Sight
- Supported APM’s:
Payment | Enabled Country | Currency | Requires User Data | Additional User Data |
---|---|---|---|---|
AliPay | CN | USD | ||
ApplePay | All | All | Yes | |
Bancontact MisterCash | BE | EUR | ||
China Union Pay | CN | GBP,EUR,USD,SGD | ||
GiroPay | DE | EUR | ||
GooglePay | All | All | Yes | |
iDeal | NL | EUR | Yes | Bank Code |
Klarna | AT,FI,DE,NL,NO,SE,GB | EUR,GBP | ||
Klarna Pay Later | SE,NO,FI,DE,NL,AT,CH,GB,DK,US | EUR,GBP | ||
Klarna Pay Now | SE,DE,NL,AT | EUR,GBP | ||
Klarna Slice It | SE,NO,FI,DE,AT,GB,DK,US | EUR,GBP | ||
PayPal | All | All | ||
POLi | NZ | NZ | ||
Postepay | IT | EUR | ||
Sepa | AT,BE,FR,DE,IE,IT,NL,ES | EUR | ||
Sofort | AT,BE,FR,DE,CH | EUR,CHF |