| Availability |
Odoo Online
Odoo.sh
On Premise
|
| Odoo Apps Dependencies |
•
Discuss (mail)
• Invoicing (account) • Point of Sale (point_of_sale) • Inventory (stock) |
| Lines of code | 1869 |
| Technical Name |
has_pos_customer_payment |
| License | OPL-1 |
| Website | https://www.has-top.com |
| Availability |
Odoo Online
Odoo.sh
On Premise
|
| Odoo Apps Dependencies |
•
Discuss (mail)
• Invoicing (account) • Point of Sale (point_of_sale) • Inventory (stock) |
| Lines of code | 1869 |
| Technical Name |
has_pos_customer_payment |
| License | OPL-1 |
| Website | https://www.has-top.com |
💳 POS Customer Payment Collection
Collect outstanding customer invoices directly from the Point of Sale
in seconds — automatic accounting reconciliation, instant credit application,
thermal receipt printing and email delivery, all without leaving the POS screen.
Designed for cashiers. Built for accountants.
🔍 Smart Customer Search
Find any customer by name or tax ID in real time. Results are paginated so the interface stays fast even with tens of thousands of contacts. A toggle switches to advance payment mode to show all customers.
📋 Flexible Invoice Selection
Open invoices are shown oldest to newest with their individual balance. Select any combination for full or partial payment. Typing a custom amount auto-distributes it across invoices oldest-first.
✅ Automatic Reconciliation & Clearing
On confirmation, a proper account.payment is created and posted.
A clearing entry immediately moves the collected amount from the
payment method's transit account to the actual cash or bank account — no bank
statement reconciliation step required. Then the payment is reconciled with
the selected invoices, and any existing credit notes or overpayments are applied first.
📈 Session Closing Integration
Customer collection amounts appear in the POS session closing control totals per payment method. Cash, card and other methods are all correctly reflected so end-of-day counts stay accurate.
🖨 Thermal Receipt
Generates a professional narrow-format (60 mm) PDF receipt with your company logo, cashier, payment method and full invoice detail. Print it directly or send it by email with one click.
💳 Advance Payments
Need to collect a prepayment before an invoice exists? Enable Advance mode to collect any free amount. The credit is registered in accounting and reconciled automatically when future invoices are confirmed.
⚖ Payment Difference Write-off
When the collected amount differs from the selected invoices total, the system always shows the exact difference with a clear warning. If a write-off account and journal are configured for the POS, the cashier can cancel the difference with a single checkbox — generating an automatic journal entry. Supports both underpayments (remaining debt) and overpayments (customer credit), each with distinct alerts.
🚫 Safe Payment Void
Need to cancel a confirmed payment? Use the built-in Void Payment button.
It reverses all three accounting entries automatically: the
account.payment, the clearing entry (transit → cash/bank), and the
write-off entry (if one was created). The record moves to Cancelled and
session closing totals stay accurate.
Reversing from Accounting alone would leave the record in an inconsistent state
and cause discrepancies at end-of-day.
📄 Session History
View the last 100 payments across all sessions directly from the POS. Each row shows reference, customer, session, method, amount and date (in the user's configured timezone). From history you can reprint the receipt, resend it by email, or void any confirmed payment — all without leaving the POS interface.
📷 Screenshots
📚 Step-by-Step User Guide
- Open the popup — tap the Collect button on the POS product screen. The popup opens without interrupting the current sale order.
- Find the customer — type the customer name or tax/ID number in the search box. Results update as you type (300 ms debounce). By default only customers with an outstanding balance appear; toggle Advance (all customers) to search all contacts. Tip: partial names work — e.g. "Pet" will match "Petrov", "Peter's Shop", etc.
- Review open invoices — all unpaid or partially paid invoices are listed oldest-to-newest with their original total, current balance and amount to pay. All are pre-selected by default. You can deselect individual invoices by tapping the row, or use Select all / Deselect all for bulk operations.
- Adjust the amount (optional) — type a custom amount in the Amount to Collect field. The invoice selection updates automatically: the oldest invoices are fully covered first; if the amount only covers part of an invoice it is marked partial. If the customer already has a credit (overpayment or credit note), the system shows it and deducts it automatically from the net amount owed.
- Choose the payment method — select from the payment methods configured for this POS. If cash is selected, an Amount Received field appears and the change is calculated in real time.
-
Handle payment difference (optional) — if the amount entered does not
exactly match the selected invoices total, a warning appears showing the exact difference.
- Underpayment: difference remains as outstanding debt — or tick Cancel difference against [account] to post an automatic write-off entry.
- Overpayment: excess is recorded as customer credit — or tick the checkbox to cancel it via write-off.
-
Confirm the payment — tap Confirm Payment. The system:
- Creates and posts an
account.paymentin accounting - Posts a clearing entry to move the amount from the transit account to the actual cash or bank account (e.g. Efectivo, Afiliados VISA)
- Reconciles the payment with the selected invoices
- Applies any pre-existing customer credit automatically
- Posts the write-off journal entry if requested
- Records the amount in the POS session closing control
- Logs a full audit trail in the record chatter
- Creates and posts an
- Print or email the receipt — after confirmation you can print a narrow-format thermal receipt (60 mm, ideal for receipt printers) or send it directly to the customer's email address with one tap. The receipt includes company header, customer name, tax ID, payment reference, method, a full list of paid invoices, previous balance, total collected and the real remaining balance (read from accounting after reconciliation, reflecting any applied credit).
-
Void a confirmed payment (if needed) — Open the payment record from
Point of Sale → Customer Payments and click Void Payment.
The system reverses all three accounting entries: the
account.payment, the clearing entry (transit → cash/bank), and the write-off entry (if one was created). The record moves to Cancelled state and the amount is removed from the session closing totals. ⚠ Never reverse theaccount.paymentdirectly from Accounting — doing so leaves the POS record in posted state, the clearing entry unreconciled, and causes an incorrect discrepancy in the end-of-day session control. - View history & reprint — tap Session History on the search screen to browse the last 100 payments across all sessions. From any row you can reprint the receipt, resend it by email, or void a confirmed payment — all without leaving the POS.
✅ Full Feature List
- POS Native control button — no extra menus, always one tap away
- Search Real-time customer search by name or tax ID, paginated (10 per page)
- Invoices Displays all unpaid/partial invoices oldest-first with individual balances
- Selection Per-invoice checkbox + select all/deselect all + custom amount auto-distribution
- Partial Partial payment on a single invoice — clearly labeled in the UI
- Accounting Creates and posts
account.paymentwith correct journal - Clearing Automatic clearing entry moves amount from transit account to the actual cash/bank account immediately on confirm
- Reconcile Automatically reconciles payment with selected invoices on confirm
- Credit Detects and applies existing unreconciled credit notes / overpayments first
- Overpay Overpayments recorded as customer credit in accounting for future use
- Cash Cash method: amount received + change calculation in real time
- Session Updates POS session closing control per payment method (cash & non-cash)
- Advance Advance payment mode for customers without open invoices
- Receipt 60 mm thermal PDF receipt with full company header and invoice detail
- Email One-tap email delivery of the PDF receipt to the customer
- Audit Full chatter trail on every payment record for complete traceability
- Lock Row-level database lock on session prevents concurrent update conflicts
- Write-off Configurable write-off account & journal per POS for automatic difference cancellation
- Underpay Underpayment write-off: posts credit to receivable, debit to write-off account — clears outstanding debt
- Overpay Overpayment write-off: eliminates customer credit balance via write-off account
- Void Safe void via Void Payment button — reverses
account.payment, clearing entry and write-off entry, syncs session closing totals - Balance Receipt shows real remaining balance after reconciliation (reads live
partner.credit, not a simple subtraction) - History Session History screen — last 100 payments, all sessions, with reference, customer, method, amount and status
- Reprint Reprint receipt for any past payment directly from the history screen
- History Email Resend receipt by email for any past payment directly from the history screen
- Format Amounts displayed with thousand separators and currency decimals
- Timezone Dates in history shown in the user's configured timezone
- i18n Fully translated into Spanish (es / es_CR)
- Safe Does not interfere with electronic invoicing workflows (FE/TE/NC)
account.payment directly
from the Accounting module. Doing so will not update the POS payment state, leaving it
as Confirmed and causing the reversed amount to incorrectly appear in the POS
session closing control totals. The clearing entry (transit → cash/bank) and the
write-off entry (if applicable) will also not be reversed — leaving
orphaned accounting entries that must be corrected manually.
📧 Support & Contact
For questions, installation help, or custom development, contact us directly:
📧 support@has-top.com
Odoo Proprietary License v1.0 This software and associated files (the "Software") may only be used (executed, modified, executed after modifications) if you have purchased a valid license from the authors, typically via Odoo Apps, or if you have received a written agreement from the authors of the Software (see the COPYRIGHT file). You may develop Odoo modules that use the Software as a library (typically by depending on it, importing it and using its resources), but without copying any source code or material from the Software. You may distribute those modules under the license of your choice, provided that this license is compatible with the terms of the Odoo Proprietary License (For example: LGPL, MIT, or proprietary licenses similar to this one). It is forbidden to publish, distribute, sublicense, or sell copies of the Software or modified copies of the Software. The above copyright notice and this permission notice must be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Please log in to comment on this module