| Availability |
Odoo Online
Odoo.sh
On Premise
|
| Odoo Apps Dependencies |
•
Inventory (stock)
• Discuss (mail) |
| Lines of code | 288 |
| Technical Name |
no_stock_aging |
| License | LGPL-3 |
| Website | https://www.oudayet.com |
| Availability |
Odoo Online
Odoo.sh
On Premise
|
| Odoo Apps Dependencies |
•
Inventory (stock)
• Discuss (mail) |
| Lines of code | 288 |
| Technical Name |
no_stock_aging |
| License | LGPL-3 |
| Website | https://www.oudayet.com |
Stock Aging Report
Bucket on-hand stock by how long it's been sitting — with buckets you define.
SQL view over stock.quant · Configurable buckets · Pivot · Graph · List
Odoo 19 $34.99 · LGPL-3 For Inventory Managers 9 LanguagesHow much of your warehouse hasn't moved in 90 days?
Native Odoo 19 ships an inventory-at-date wizard, a forecasted-quantity view, and a per-product reordering screen — but no aging report. So nobody can answer the dead-stock question without exporting CSVs and pivoting them by hand. This module fills the gap with a single landing page under Inventory → Reporting → Stock Aging.
Without this module
Export quants → load into Excel → subtract dates → bucket manually → pivot. Repeat next month. No one is sure if the dead-stock pile is shrinking or growing.
With this module
Open Stock Aging, see your age buckets, click the oldest one, see the products. The pivot stays current automatically — no cron, no recompute step.
What it does
Define any number of named age bands with your own day ranges. Ships with 0-30, 31-60, 61-90 and 90+ out of the box.
Default pivot is bucket-by-product. Bar graph for the boardroom. List view for drill-down.
Bucket, product, category, location, warehouse — all in the search panel.
Type any bucket name in the search box to focus it, or group by age bucket to see every band at once.
Transit, customer, supplier and inventory adjustment locations are excluded automatically.
Pure SQL view — no stored fields, no cron, no triggers. The buckets shift forward as time passes.
See It In Action
A single landing page under Inventory → Reporting — pivot, graph and list, all bucketed by age. Define the bands under Inventory → Configuration → Aging Buckets.
Pivot. On-hand quantity by age bucket and product — drill into any cell to see exactly what's aging.
Graph. See at a glance how much stock sits in each age bucket.
Grouped list. Every quant bucketed by your bands — with on-hand quantity and age in days. Type a bucket name in the search box to focus any single band.
How it works
A read-only model stock.aging.report is mapped to a Postgres CREATE VIEW over stock_quant.
The view filters on location.usage = 'internal' and quantity > 0, computes age_days from quant.in_date, then maps each quant to one of your buckets via a CASE generated from your bucket definitions.
Pivot, graph and list views read from the SQL view directly. Every page load gives the buckets as of now() — no recompute, no staleness.
Technical Details
| Odoo Version | 19.0 Community + Enterprise |
| License | LGPL-3 |
| Dependencies | stock |
| Backend code | ~240 LOC, two models + a generated CREATE VIEW |
| Frontend code | none (standard pivot / graph / list) |
| Override point | models/stock_aging_report.py |
Available in 9 Languages
Field labels, search filters and age buckets speak your team's language. Each user sees them in their own Odoo language setting — no extra setup.
Installation
1. Download from the Odoo App Store.
2. Drop no_stock_aging/ into your Odoo addons directory.
3. Apps → Update Apps List → Install Stock Aging Report.
4. Inventory → Reporting → Stock Aging.
Found a bug?
Reach out via the Odoo App Store contact form.
Stock Aging Report — $34.99 — Odoo 19
© Naim OUDAYET — LGPL-3
Please log in to comment on this module