PHPackages                             thelia/chronopost-pickup-point-module - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [HTTP &amp; Networking](/categories/http)
4. /
5. thelia/chronopost-pickup-point-module

ActiveThelia-module[HTTP &amp; Networking](/categories/http)

thelia/chronopost-pickup-point-module
=====================================

Chronopost delivery module for pickup point deliveries.

2.1.0(7mo ago)184410[3 PRs](https://github.com/thelia-modules/ChronopostPickupPoint/pulls)LGPL-3.0+PHPCI passing

Since Aug 20Pushed 5mo ago5 watchersCompare

[ Source](https://github.com/thelia-modules/ChronopostPickupPoint)[ Packagist](https://packagist.org/packages/thelia/chronopost-pickup-point-module)[ RSS](/packages/thelia-chronopost-pickup-point-module/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (10)Dependencies (1)Versions (17)Used By (0)

Chronopost
==========

[](#chronopost)

Allows you to choose between differents pickup point delivery modes offered by Chronopost. Activating one or more of them will let your customers choose which one they want.

Delivery types currently availables :

- Chrono13 BAL (pickup points/relay delivery in France)
- Others will be added in future versions

NB1 : You need IDs provided by Chronopost to use this module.

Installation
------------

[](#installation)

### Manually

[](#manually)

- Copy the module into `/local/modules/` directory and be sure that the name of the module is ChronopostPickupPoint.
- Activate it in your thelia administration panel

### Composer

[](#composer)

Add it in your main thelia composer.json file

```
composer require thelia/chronopost-pickup-point-module:~2.0.0

```

Usage
-----

[](#usage)

First, go to your back office, tab Modules, and activate the module Chronopost. Then go to Chronopost configuration page, tab "Advanced Configuration" and fill the required fields.

After activating the delivery types you wih to use, new tabs will appear. With these, you can change the shipping prices according to the delivery type and the area, and/or activate free shipping for a given price and/or given area, or just activate it no matter the are and cart amount.

If you also have the ChronopostLabel module, you can then generate and download labels from the Chronopost Label page accessible from the toolbar on the left of the BackOffice, or directly from the order page.
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

[](#if-you-also-have-the-chronopostlabel-module-you-can-then-generate-and-download-labels-from-the-chronopost-label-page-accessible-from-the-toolbar-on-the-left-of-the-backoffice-or-directly-from-the-order-page)

For relay / pickup points, you need to integrate a template to choose one relay in the list provided by the loop 'chronopost.pickup.point.get.relay'. Ideally from a map, like google maps, yandex, or similar.

Then, you can either create an entry in the address table and use it immediately, or overload the thelia.order.delivery form to accept entire addresses as input instead of only an address id from which to get the entire address.

Loop
----

[](#loop)

\###\[chronopost.pickup.point\]

### Input arguments

[](#input-arguments)

ArgumentDescription**area\_id****Mandatory** ID of the area from which you want to know the prices.**delivery\_mode\_id****Mandatory** ID of the delivery mode of which you want to know the prices.### Output arguments

[](#output-arguments)

VariableDescription$SLICE\_IDID of the price slice$MAX\_WEIGHTMax weight for this slice price$MAX\_PRICEMax untaxed price of a cart for this price$PRICEPrice for this slice$FRANCOPrice of the Franco for this slice\###\[chronopost.pickup.point.delivery.mode\]

### Input arguments

[](#input-arguments-1)

None

### Output arguments

[](#output-arguments-1)

VariableDescription$IDThe delivery mode ID in the table$TITLEThe delivery mode title (ex : Fresh13)$CODEThe delivery mode code (ex : 2R)$FREESHIPPING\_ACTIVE0 or 1 depending on whether the total freeshipping is active or not$FREESHIPPING\_FROMCart price needed for freeshipping\###\[chronopost.pickup.point.area.freeshipping\]

### Input arguments

[](#input-arguments-2)

ArgumentDescription**area\_id**ID of the area from which you want to know the free shipping minimum amount needed.**delivery\_mode\_id**ID of the delivery mode of which you want to know the free shipping minimum amount needed.### Output arguments

[](#output-arguments-2)

VariableDescription$AREA\_IDID of the area$DELIVERY\_MODE\_IDID of the delivery mode$CART\_AMOUNTCart amount needed for free shipping in this area and for this delivery mode\###\[chronopost.pickup.point.get.relay\]

Search for pickup points (relays)

### Input arguments

[](#input-arguments-3)

ArgumentDescription**orderweight**REQUIRED : The order weight**countryid**The country ID in the database**zipcode**Zipcode where to search for pickup points (needs to be paired with city)**city**City in which to search for the pickup points (needs to be paired with a zipcode)**address**An address to search pickup points close by### Output arguments

[](#output-arguments-3)

The outputs are the same given in return by the Chronopost API response from the recherchePointChronopostInterParService method, in uppercase. Here will be displayed the most important ones

VariableDescription$IDENTIFIANTThe pickup point ID$NOMThe pickup point name$ADRESSE1Pickup point address line 1$ADRESSE2Pickup point address line 2$ADRESSE3Pickup point address line 3$CODEPOSTALPickup point Zipcode$LOCALITEPickup point City$CODEPAYSPickup point country code ISO ALPHA2$COORDGEOLOCALISATIONLATITUDEPickup point latitude coordinate$COORDGEOLOCALISATIONLONGITUDEPickup point longitude coordinate$URLGOOGLEMAPSURL for the position of the pickup point on google mazps$LISTEPERIODEFERMETURE(Array) List of closed periods for the pickup point$LISTEPERIODEOUVERTURE(Array) List of opened periods for the pickup point$TYPEDEPOINTType of pickup point$POIDSMAXIMax package weight accepted for this relay$DISTANCEENMETREDistance in meters between the given address and the relay\##Integration

There is no map integration example as of the 1.0.0. As such, you will have to make one yourself (you may use the ColissimoPickupPoint one as an example as they work similarily).

###  Health Score

45

—

FairBetter than 93% of packages

Maintenance67

Regular maintenance activity

Popularity22

Limited adoption so far

Community19

Small or concentrated contributor base

Maturity63

Established project with proven stability

 Bus Factor1

Top contributor holds 55.6% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~144 days

Recently: every ~166 days

Total

14

Last Release

223d ago

Major Versions

1.0.5 → 2.0.22022-11-28

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/2196919?v=4)[thelia](/maintainers/thelia)[@thelia](https://github.com/thelia)

---

Top Contributors

[![Lurivar](https://avatars.githubusercontent.com/u/33634597?v=4)](https://github.com/Lurivar "Lurivar (15 commits)")[![NicolasBarbey](https://avatars.githubusercontent.com/u/26166378?v=4)](https://github.com/NicolasBarbey "NicolasBarbey (5 commits)")[![julescournut](https://avatars.githubusercontent.com/u/26310511?v=4)](https://github.com/julescournut "julescournut (2 commits)")[![thomas-dsm](https://avatars.githubusercontent.com/u/84772220?v=4)](https://github.com/thomas-dsm "thomas-dsm (2 commits)")[![zawaze](https://avatars.githubusercontent.com/u/37273643?v=4)](https://github.com/zawaze "zawaze (2 commits)")[![leanormandon](https://avatars.githubusercontent.com/u/30038624?v=4)](https://github.com/leanormandon "leanormandon (1 commits)")

### Embed Badge

![Health badge](/badges/thelia-chronopost-pickup-point-module/health.svg)

```
[![Health](https://phpackages.com/badges/thelia-chronopost-pickup-point-module/health.svg)](https://phpackages.com/packages/thelia-chronopost-pickup-point-module)
```

###  Alternatives

[friendsofsymfony/rest-bundle

This Bundle provides various tools to rapidly develop RESTful API's with Symfony

2.8k73.3M319](/packages/friendsofsymfony-rest-bundle)[php-http/discovery

Finds and installs PSR-7, PSR-17, PSR-18 and HTTPlug implementations

1.3k309.5M1.2k](/packages/php-http-discovery)[pusher/pusher-php-server

Library for interacting with the Pusher REST API

1.5k94.8M293](/packages/pusher-pusher-php-server)[react/http

Event-driven, streaming HTTP client and server implementation for ReactPHP

78026.4M414](/packages/react-http)[php-http/curl-client

PSR-18 and HTTPlug Async client with cURL

48347.0M384](/packages/php-http-curl-client)[smi2/phpclickhouse

PHP ClickHouse Client

84310.1M71](/packages/smi2-phpclickhouse)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
