PHPackages                             orderreminder/orderreminder - 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. [Mail &amp; Notifications](/categories/mail)
4. /
5. orderreminder/orderreminder

ActiveThelia-module[Mail &amp; Notifications](/categories/mail)

orderreminder/orderreminder
===========================

Send reminder emails to customers who placed an order X months ago

00PHP

Since Feb 27Pushed 2mo agoCompare

[ Source](https://github.com/delimard/OrderReminder)[ Packagist](https://packagist.org/packages/orderreminder/orderreminder)[ RSS](/packages/orderreminder-orderreminder/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (1)DependenciesVersions (1)Used By (0)

Order Reminder Module for Thelia
================================

[](#order-reminder-module-for-thelia)

Description
-----------

[](#description)

Ce module permet d'envoyer automatiquement des emails de rappel aux clients ayant passé une commande il y a X mois. Il permet de proposer aux clients de renouveler leur achat.

Fonctionnalités
---------------

[](#fonctionnalités)

- ✅ Configuration du nombre de mois avant l'envoi du rappel
- ✅ Envoi d'emails de test pour vérifier le fonctionnement
- ✅ Liste des emails envoyés dans le back-office
- ✅ Commande CLI pour automatiser l'envoi via cron
- ✅ Flag sur les commandes pour éviter les doublons
- ✅ Templates d'email personnalisables (HTML et texte)
- ✅ Support multilingue (FR/EN)

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

[](#installation)

1. Copier le module dans le dossier `local/modules/OrderReminder`
2. Activer le module depuis le back-office Thelia
3. Le module créera automatiquement la table de base de données nécessaire

Configuration
-------------

[](#configuration)

### Back-office

[](#back-office)

1. Aller dans **Modules** &gt; **Order Reminder**
2. Configurer le nombre de mois avant l'envoi du rappel (défaut : 6 mois)
3. Configurer le nombre maximum d'emails par exécution (défaut : 100)
4. Tester l'envoi avec un email de test

### Limite d'envoi

[](#limite-denvoi)

Le paramètre "Nombre maximum d'emails par exécution" permet de :

- **Limiter la charge serveur** : Évite d'envoyer trop d'emails d'un coup
- **Respecter les quotas** : Évite les blocages liés aux limites d'envoi SMTP
- **Répartir les envois** : Permet d'exécuter le cron plusieurs fois par jour

**Exemple** : Avec une limite de 50 emails et un cron toutes les 2 heures, vous pouvez envoyer jusqu'à 600 emails par jour (12 exécutions × 50 emails).

### Ligne de commande

[](#ligne-de-commande)

Pour envoyer les emails de rappel :

```
php Thelia OrderReminder:send
```

#### Options disponibles

[](#options-disponibles)

- `--months=X` : Remplacer le nombre de mois configuré
- `--dry-run` : Mode test (affiche les commandes éligibles sans envoyer d'emails)

#### Exemples

[](#exemples)

```
# Utiliser la configuration par défaut
php Thelia OrderReminder:send

# Envoyer pour les commandes de 3 mois
php Thelia OrderReminder:send --months=3

# Mode test
php Thelia OrderReminder:send --dry-run
```

Automatisation avec Cron
------------------------

[](#automatisation-avec-cron)

Pour automatiser l'envoi quotidien à 9h du matin :

```
0 9 * * * cd /path/to/thelia && php Thelia OrderReminder:send
```

Personnalisation des templates
------------------------------

[](#personnalisation-des-templates)

Les templates d'email se trouvent dans :

- `templates/email/default/order-reminder.html` (version HTML)
- `templates/email/default/order-reminder.txt` (version texte)

Vous pouvez les personnaliser selon vos besoins.

Base de données
---------------

[](#base-de-données)

Le module crée une table `order_reminder_log` qui enregistre :

- L'ID de la commande
- L'ID du client
- L'email du destinataire
- La date d'envoi
- Si c'est un email de test ou non

Cette table permet d'éviter d'envoyer plusieurs fois le même email pour une commande.

Critères d'éligibilité
----------------------

[](#critères-déligibilité)

Une commande est éligible pour un rappel si :

1. Elle a été passée il y a **X mois ou plus** (configuré dans le back-office)
2. Son statut est "payé", "expédié" ou "livré" (statuts 2, 3 ou 4)
3. Aucun email de rappel n'a déjà été envoyé pour cette commande

**Note importante** : Le système envoie des rappels pour toutes les commandes de X mois ou plus qui n'ont pas encore reçu de rappel. Cela permet de rattraper les commandes manquées si le module n'est pas exécuté quotidiennement.

Support
-------

[](#support)

Pour toute question ou problème, consultez la documentation Thelia ou contactez le support.

Licence
-------

[](#licence)

Ce module est fourni tel quel, sans garantie. Vous êtes libre de l'utiliser et de le modifier selon vos besoins.

###  Health Score

19

—

LowBetter than 10% of packages

Maintenance56

Moderate activity, may be stable

Popularity0

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity12

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% 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.

### Community

Maintainers

![](https://www.gravatar.com/avatar/1e19b640d1bdfe4b4489b9d208f7fee7ebe14ba47cc1f4cd2335890c21b134ed?d=identicon)[delimard](/maintainers/delimard)

---

Top Contributors

[![delimard](https://avatars.githubusercontent.com/u/6093730?v=4)](https://github.com/delimard "delimard (8 commits)")

---

Tags

theliathelia-module

### Embed Badge

![Health badge](/badges/orderreminder-orderreminder/health.svg)

```
[![Health](https://phpackages.com/badges/orderreminder-orderreminder/health.svg)](https://phpackages.com/packages/orderreminder-orderreminder)
```

###  Alternatives

[tijsverkoyen/css-to-inline-styles

CssToInlineStyles is a class that enables you to convert HTML-pages/files into HTML-pages/files with inline styles. This is very useful when you're sending emails.

5.8k505.3M227](/packages/tijsverkoyen-css-to-inline-styles)[minishlink/web-push

Web Push library for PHP

1.9k12.0M53](/packages/minishlink-web-push)[laravel-notification-channels/twilio

Provides Twilio notification channel for Laravel

2587.7M12](/packages/laravel-notification-channels-twilio)[spatie/url-signer

Generate a url with an expiration date and signature to prevent unauthorized access

4422.3M16](/packages/spatie-url-signer)[mattketmo/email-checker

Throwaway email detection library

2742.0M5](/packages/mattketmo-email-checker)[laravel-notification-channels/discord

Laravel notification driver for Discord.

2371.3M11](/packages/laravel-notification-channels-discord)

PHPackages © 2026

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