Skip to Content
Menu
v 18.0 Third Party 2
Download for v 18.0 Deploy on Odoo.sh
Availability
Odoo Online
Odoo.sh
On Premise
Odoo Apps Dependencies Invoicing (account)
Discuss (mail)
Community Apps Dependencies
Lines of code 5403
Technical Name contract_refund_on_stop
LicenseAGPL-3
Websitehttps://github.com/OCA/contract
You bought this module and need support? Click here!
Odoo Community Association

Contract Refund On Stop

Beta License: AGPL-3 OCA/contract Translate me on Weblate Try me on Runboat

This module allows stopping a contract line even after it has been invoiced.

When the stop date is earlier than the last invoiced date, the system will:

  • Automatically create a refund invoice for the period between the stop date and the last invoiced date.
  • Adjust the last_date_invoiced of the contract line to match the stop date.
  • Proceed with the normal stop process.

To accurately compute the refund amount, the module depends on ``contract_variable_qty_prorated``, which provides the prorating logic used to determine how much of the previously invoiced quantity should be refunded based on the actual number of days covered by the refund period.

Without this dependency, it would not be possible to proportionally calculate the part of the invoiced quantity corresponding to unused service time when a contract is stopped mid-period.

This ensures that users can gracefully handle early contract terminations without manual refund management, while maintaining accurate prorated invoicing and accounting consistency.

Table of contents

Use Cases / Context

In the standard behavior of the Contract module, it is not possible to stop a contract line if its stop date is earlier than the last invoiced date. This restriction prevents users from adjusting contracts that were invoiced too far in advance.

In some business cases, however, a contract may need to be stopped retroactively (e.g., customer cancellation, early termination, or service interruption). In such cases, it is necessary to automatically create a refund for the invoiced period that should no longer be billed.

Configuration

To enable the refund behavior when stopping invoiced contract lines:

  1. Go to Invoicing / Configuration / Settings.

  2. In the Contracts section, enable the checkbox:

    Enable Contract Line Refund on Stop

Usage

  1. Ensure the Enable Contract Line Refund on Stop option is enabled for your company.
  2. Open any active contract line that has been invoiced.
  3. Click Stop and choose a stop date earlier than the last invoiced period.
  4. The system will:
    • Create a refund invoice covering the over-invoiced period.
    • Update the contract line to end on the chosen stop date.

Bug Tracker

Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us to smash it by providing a detailed and welcomed feedback.

Do not contact contributors directly about support or help with technical issues.

Credits

Authors

  • ACSONE SA/NV

Maintainers

This module is maintained by the OCA.

Odoo Community Association

OCA, or the Odoo Community Association, is a nonprofit organization whose mission is to support the collaborative development of Odoo features and promote its widespread use.

Current maintainer:

sbejaoui

This module is part of the OCA/contract project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

Please log in to comment on this module

  • The author can leave a single reply to each comment.
  • This section is meant to ask simple questions or leave a rating. Every report of a problem experienced while using the module should be addressed to the author directly (refer to the following point).
  • If you want to start a discussion with the author, please use the developer contact information. They can usually be found in the description.
Please choose a rating from 1 to 5 for this module.