Customer normalizer
The normalizeCustomer
function is used to map a Commercetools Customer
into the unified SfCustomer
data model.
Parameters
Name | Type | Default value | Description |
---|---|---|---|
context | NormalizerContext | context needed for the normalizer | |
customer | Customer | Commercetools Customer |
Extending
The SfCustomer
model is returned from Unified Methods such as RegisterCustomer
, LoginCustomer
and GetCustomer
. If the SfCustomer
structure doesn't contain the information you need for your Storefront, you can extend its logic using the addCustomFields
API. The following example demonstrates how to extend SfCustomer
with a company
field.
export const unifiedApiExtension = createUnifiedExtension({
normalizers: {
addCustomFields: [
{
normalizeCustomer: (context, customer) => ({
company: customer.companyName,
}),
},
],
},
config: {
...
},
});
Source
customer.ts
import { defineNormalizer } from "../defineNormalizer";
export const normalizeCustomer = defineNormalizer.normalizeCustomer((_context, customer) => {
return {
id: customer.id,
firstName: customer.firstName ?? "",
lastName: customer.lastName ?? "",
email: customer.email,
};
});