Yireo_LokiCheckoutPostcodeNl

Latest Release 0.0.9
other

This is an add-on package for adding support for the Postcode NL address validation and autocompletion to the LokiCheckout.

Overview of this module

This module changes the layout of an address form, so that a streetname and city can be determined by entering a postcode and housenumber (plus housenumber addition). Because the Magento core stores the street as multiple streetlines, the fields are renamed by this module: The field street0 is renamed to Streetname, the field street1 is renamed to House Number, the field street2 is renamed to House Number Addition. The field street3 is not handled by this module.

The fields Streetname and City are disabled when autocompletion is enabled.

An additional checkbox Use autocompletion is added to allow customers to disable the Postcode NL lookup. When autocompletion is disabled (HTML attribute disabled), the fields Streetname and City are enabled again.

Thanks Trinos

Portions of this module are shamelessly copied from the Trinos_PostcodeNL module. Thank you, Trinos, for kickstarting this module. Note that this module is not depending on the Trinos module though.

Installation

Install this package via composer (assuming you have setup the composer.yireo.com repository correctly already):

composer require yireo/magento2-loki-checkout-postcode-nl

Next, enable this module:

bin/magento module:enable Yireo_LokiCheckoutPostcodeNl

Basic configuration

Configure the Postcode NL settings via the backend (Store > Configuration > Yireo > Yireo Loki Checkout > Postcode NL) or via the CLI:

magerun2 config:set yireo_loki_checkout/postcode_nl/enable 1
magerun2 config:set yireo_loki_checkout/postcode_nl/api_key YOUR_API_KEY
magerun2 config:set yireo_loki_checkout/postcode_nl/api_secret YOUR_API_SECRET

In the backend, you can also validate the credentials right away via the button Validate API credentials.

Dealing with streetlines

We recommend you to set the configuration value customer/address/street_lines to be 3.

If the configuration value customer/address/street_lines is 3, both the field House Number and House Number Addition are taken into account when dealing with the Postcode NL autocompletion. When there are multiple options for the housenumber addition, the House Number Addition changes from an input field to a select field. When there are no options to choose from, you can also disable the field itself by setting the configuration option Disable Empty House Number Addition to Yes. Likewise, the configuration option Require Housenumber to be Numeric can be enabled to force the value of the field House Number to be numeric.

If the configuration value customer/address/street_lines is 2, the field House Number Addition is never shown. Instead, the value of House Number allows for adding the addition as well (like: 10A). Here, it is assumed that the numerical prefix is the value for the house number (10) and the remainder is the addition (A). The configuration option Require Housenumber to be Numeric has no effect at this moment.

Optimize address templates

Because this module assumes that the streetname, housenumber and housenumber addition are stored as separate street lines, the address template (so, the configuration option with path customer/address_templates/html) is best changed. The following is identical to the default value, but with HTML <br/> elements removed:

{{depend prefix}}{{var prefix}} {{/depend}}{{var firstname}} {{depend middlename}}{{var middlename}} {{/depend}}{{var lastname}}{{depend suffix}} {{var suffix}}{{/depend}}{{depend firstname}}<br />{{/depend}}
{{depend company}}{{var company}}<br />{{/depend}}
{{depend street1}}{{var street1}}{{/depend}}
{{depend street2}}{{var street2}}{{/depend}}
{{depend street3}}{{var street3}}{{/depend}}
{{depend street4}}{{var street4}}{{/depend}}<br/>
{{if city}}{{var city}},  {{/if}}{{if region}}{{var region}}, {{/if}}{{if postcode}}{{var postcode}}{{/if}}<br />
{{var country}}<br />
{{depend telephone}}T: <a href="tel:{{var telephone}}">{{var telephone}}</a>{{/depend}}
{{depend fax}}<br />F: {{var fax}}{{/depend}}
{{depend vat_id}}<br />VAT: {{var vat_id}}{{/depend}}

Debugging

When the configuration option Debug is enabled, a new block is shown in the checkout (with yellow background). The autocompletion state (saved to the checkout session) is shown.

Possible errors are shown as well. For instance Housenumber addition is not available: A [street1, street2] would tell you that a specific local error is shown for the components street1 and street2.

The raw API data show the response from the Postcode NL API.

CLI usage

This module also comes with a simple CLI command to check for specific addresses:

bin/magento loki-checkout:postcode-nl:check 1000AA 1 A

Support

For getting support, create an Issue under the following project URL:

https://gitlab.yireo.com/loki-checkout/Yireo_LokiCheckoutPostcodeNl

Configuration Options

The following options of this module can be configured via the Store Configuration:

yireo_loki_checkout/postcode_nl/enable
Enable
yireo_loki_checkout/postcode_nl/debug
Debug
yireo_loki_checkout/postcode_nl/api_key
API Key
yireo_loki_checkout/postcode_nl/api_secret
API Secret
yireo_loki_checkout/postcode_nl/api_check
API Check
yireo_loki_checkout/postcode_nl/api_client_timeout
API Client Timeout
yireo_loki_checkout/postcode_nl/housenumber_number_validator
Require Housenumber to be Numeric
yireo_loki_checkout/postcode_nl/disable_empty_housenumber_addition
Disable Empty House Number Addition
Loki Components

The following LokiComponents are created or references in this module:

loki-checkout.shipping.address.postcode_nl_toggle loki-checkout.billing.address.postcode_nl_toggle loki-checkout.shipping.address.postcode_nl_debug loki-checkout.billing.address.postcode_nl_debug loki-checkout.shipping.address.postcode loki-checkout.billing.address.postcode loki-checkout.shipping.address.street1 loki-checkout.billing.address.street1 loki-checkout.shipping.address.street2 loki-checkout.billing.address.street2 loki-checkout.shipping.address.country_id loki-checkout.billing.address.country_id
Module Dependencies

The following dependencies are declared in the module its `etc/module.xml` file:

Magento_Backend Magento_Checkout Magento_Config Magento_Customer Magento_Quote Magento_Store Yireo_LokiCheckout Yireo_LokiComponents Yireo_LokiFieldComponents
Composer details
Magento module name
Yireo_LokiCheckoutPostcodeNl
Composer name
yireo/magento2-loki-checkout-postcode-nl
Composer version
0.0.9
Default branch
main
Requirements
magento/framework: ^103.0
magento/module-backend: ^102.0
magento/module-checkout: ^100.4
magento/module-config: ^101.0
magento/module-customer: ^103.0
magento/module-quote: ^101.0
yireo/magento2-loki-checkout: ~0.0
yireo/magento2-loki-components: ~0.0
yireo/magento2-loki-field-components: ~0.0
composer/composer: ^2.8
psr/log: ^3.0
guzzlehttp/guzzle: ^6.0|^7.0
ext-json: *
Releases
dev-main 27 March 2025
0.0.9 11 March 2025
0.0.8 24 February 2025
0.0.7 24 February 2025
0.0.6 22 February 2025
0.0.5 22 February 2025
0.0.4 20 February 2025
0.0.3 18 February 2025
0.0.2 17 February 2025
0.0.1 21 January 2025
Changelog

[0.0.9] - 11 March 2025

Fixed

  • Move GridLayout from XML layout to config
  • Remove default grid class
  • Add module dependencies
  • Huge refactoring to move logic into new LokiFieldComponents

[0.0.8] - 24 February 2025

Fixed

  • Add Dutch translations

[0.0.7] - 24 February 2025

Fixed

  • Housenumber addition error when switching country

[0.0.6] - 22 February 2025

Fixed

  • Update loki_checkout.xml grid CSS for mobile

[0.0.5] - 22 February 2025

Fixed

  • Small responsive fixes
  • Change deps
  • Refactor to reusable RegionProvider

[0.0.4] - 20 February 2025

Fixed

  • Trigger Postcode API when changing country as well
  • Improve loading logic of streetlines
  • Fix possible issues in API client (like timeouts and outage)

[0.0.3] - 18 February 2025

Fixed

  • Better logic when validating faulty housenumber values
  • Fix local messages per field
  • Allow housenumber to be non-numeric via config option
  • Remove debug warnings (because they are in backend System Check)

[0.0.2] - 17 February 2025

Fixed

  • Dump housenumber addition properly
  • Add warning about streetlines in debug box
  • Properly skip API when country is not supported; Fix housenumber additions completion

[0.0.1] - 21 January 2025

Fixed

  • Add proper deps
  • Initial release

Last modified: April 1, 2025