LogoLogo
Connectors
Salesforce B2B Commerce App 2.1.0
Salesforce B2B Commerce App 2.1.0
  • Salesforce B2B Commerce App 2.1.0
  • Introduction
    • How it works
    • What's new in version 2.1.0
    • Requirements
  • Integrating the Digital River Salesforce B2B Commerce App
    • Step 1: Install the Digital River App for Salesforce B2B
    • Step 2: Create page labels
    • Step 3: Configure the Salesforce B2B Commerce App
    • Step 4: Add custom Salesforce B2B Commerce App fields to page layouts
    • Step 5: Enable email deliverability
    • Step 6: Import ECCN codes, tax groups, and tax types
    • Step 7. Update the Product Sync settings
    • Step 8: Set up Digital River fulfillments
    • Step 9: Set up webhooks
    • Step 10: Configure CC Admin settings
    • Step 11: Configure landed cost
    • Step 12: Schedule backend jobs
    • Step 13: Manage permission sets
    • Step 14: Configure the Salesforce B2B Commerce app logs
    • Step 15: Test the Digital River Salesforce B2B Commerce app integration
    • Step 16: Override the default App implementation
  • Support
  • Version number
  • Appendix
    • Fulfillment and cancellation flow
    • Issuing refunds
    • Managing regulatory fees
    • Managing subscriptions
    • Salesforce B2B Commerce App logs
    • Uploading tax certificates (US TEMS)
    • VAT invoices
Powered by GitBook
On this page
  • Inputs:
  • Output:
  • Example 1
  • Example 2
  1. Integrating the Digital River Salesforce B2B Commerce App

Step 16: Override the default App implementation

Learn how to override the default App implementation.

PreviousStep 15: Test the Digital River Salesforce B2B Commerce app integrationNextSupport

Last updated 4 years ago

Each Salesforce B2B Commerce implementation comes with its own business requirements and unique challenges. While OOTB (Out of the Box) App for Salesforce B2B Commerce can solve some of these challenges with specific configurations, sometimes the business requirements cannot be fulfilled in a configurable manner. That is, the solution requires code. To address these challenges, we provide extension points within the App. These extension points are called by the core app code and allow you to meet specific business requirements for each implementation.

The current version of the App provides an extension point for setting the Ship From Address (Warehouse location) based on the client’s business requirement.

Extension for Ship from Address: digitalriverv2.DRB2B_ShipFromAddressInterface. The digitalriverv2.DRB2B_ShipFromAddressInterface extension is used to extend the App's ShipFromAddress functionality.

global Map getShipFromAddressMap(). This method is called when posting the user and cart information to Digital River to get the tax value. Out of the box, the App uses the Ship From Address values configured in the General Config tab of the Salesforce B2B Commerce App.

Inputs:

None

Output:

Map<String, String>: This contains addressLine1, addressLine2, city, stateCode, countryCode, and postalCode.

Implementing an extension is a two-step process. To override the default App implementation:

  1. Extend the Salesforce B2B Commerce App extension point. That is, implement the interface digitalriverv2.DRB2B_ShipFromAddressInterface and provide the implementation for the method getShipFromAddressMap(). shows the constructor that should be used to create this extension. shows an example of how the extension point can be used to populate the shipFrom address. Utilize this extension point to implement code to meet your business requirements.

  2. Configure the App to use this extension class as follows:

    • Go to the digitalriverv2__DR_Connector_Extension_Configuration__mdt metadata type.

    • Click Manage DR Connector Extension Configurations.

    • Open the Ship From Address metadata record.

    • Update the Extension Class field with the previously created Custom Class name.

Example 1

global class drb2b_myproj_shipFromAddress implements digitalriverv2.DRB2B_ShipFromAddressInterface
{
     global Map<String, String> getShipFromAddressMap() {
          //implementation specific code here
     }
}

Example 2

global with sharing class DRB2B_ExtensionShipFromAddress implements digitalriverv2.DRB2B_ShipFromAddressInterface {
        global Map<String, String> getShipFromAddressMap() {
        Map<String, String> shipFromAddressMap = new Map<String, String>();
        // Populate Shipping Address
        shipFromAddressMap.put('addressLine1', '123 Main St');
        shipFromAddressMap.put('addressLine2', '');
        shipFromAddressMap.put('city', 'Plainsboro');
        shipFromAddressMap.put('stateCode', 'NJ');
        shipFromAddressMap.put('countryCode', 'US');
        shipFromAddressMap.put('postalCode', '08536');
        return shipFromAddressMap;
    }
}
Example 1
Example 2