Mihir Kandoi
39aaefc202
fix: trigger release
2026-03-31 19:58:36 +05:30
mergify[bot]
75344e9e82
revert: botched backport (backport #53967 ) ( #53968 )
...
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
fix(manufacturing): apply work order status filter in job card (#53776 )"
fix(manufacturing): apply work order status filter in job card (backport #53766 ) (#53767 )"
2026-03-31 19:24:30 +05:30
Frappe PR Bot
d39072a689
chore(release): Bumped to Version 15.103.0
...
# [15.103.0](https://github.com/frappe/erpnext/compare/v15.102.0...v15.103.0 ) (2026-03-30)
### Bug Fixes
* **bank_account:** added validation to fetch bank account details using `get_bank_account_details` (backport [#53926 ](https://github.com/frappe/erpnext/issues/53926 )) ([#53929 ](https://github.com/frappe/erpnext/issues/53929 )) ([d16061f ](d16061f1bc ))
* change shipment parcel dimension fields from Int to Float (backport [#53867 ](https://github.com/frappe/erpnext/issues/53867 )) ([#53872 ](https://github.com/frappe/erpnext/issues/53872 )) ([a21b82b ](a21b82b238 ))
* **contract_template:** restrict `create`, `write` and `delete` access only to `System Manager` (backport [#53787 ](https://github.com/frappe/erpnext/issues/53787 )) ([#53788 ](https://github.com/frappe/erpnext/issues/53788 )) ([d50c727 ](d50c727f89 ))
* correct item valuation when "Deduct" is used in Purchase Invoice and Receipt. ([2585287 ](25852879f6 ))
* **email_campaign:** prevent unsubscribing entire campaign when email group member unsubscribes ([6151a49 ](6151a496e7 ))
* flaky currency exchange test (backport [#53813 ](https://github.com/frappe/erpnext/issues/53813 )) ([#53816 ](https://github.com/frappe/erpnext/issues/53816 )) ([d9cd09b ](d9cd09b24a ))
* invalid dynamic link filter for address doctype (backport [#53849 ](https://github.com/frappe/erpnext/issues/53849 )) ([#53851 ](https://github.com/frappe/erpnext/issues/53851 )) ([f7536f6 ](f7536f645b ))
* **item_dashboard:** escaping `warehouse`, `item_code`, `stock_uom` and `item_name` on `get_data` (backport [#53904 ](https://github.com/frappe/erpnext/issues/53904 )) ([#53912 ](https://github.com/frappe/erpnext/issues/53912 )) ([db70d2e ](db70d2e4df ))
* **manufacturing:** apply work order status filter in job card ([#53776 ](https://github.com/frappe/erpnext/issues/53776 )) ([78635eb ](78635ebe99 ))
* **manufacturing:** apply work order status filter in job card (backport [#53766 ](https://github.com/frappe/erpnext/issues/53766 )) ([#53767 ](https://github.com/frappe/erpnext/issues/53767 )) ([d6afb9b ](d6afb9b10a ))
* **manufacturing:** close work order status when stock reservation is… (backport [#53714 ](https://github.com/frappe/erpnext/issues/53714 )) ([#53720 ](https://github.com/frappe/erpnext/issues/53720 )) ([468ca2b ](468ca2bde1 ))
* **manufacturing:** update condition for base hour rate calculation ([#53777 ](https://github.com/frappe/erpnext/issues/53777 )) ([64956ab ](64956ab59c ))
* **manufacturing:** update the qty precision (backport [#53874 ](https://github.com/frappe/erpnext/issues/53874 )) ([#53884 ](https://github.com/frappe/erpnext/issues/53884 )) ([46f751e ](46f751e403 ))
* **opening_invoice_creation_tool:** sanitize summary content for dashboard (backport [#53917 ](https://github.com/frappe/erpnext/issues/53917 )) ([#53923 ](https://github.com/frappe/erpnext/issues/53923 )) ([b35a6c2 ](b35a6c2e73 ))
* purchase invoice for internal transfers should not require PO (backport [#53791 ](https://github.com/frappe/erpnext/issues/53791 )) ([#53792 ](https://github.com/frappe/erpnext/issues/53792 )) ([0a28fb3 ](0a28fb3ae1 ))
* purchase invoice missing item ([bcd56ab](bcd56abb62 ))
* **stock:** add warehouse filter to pick work order raw materials (backport [#53748 ](https://github.com/frappe/erpnext/issues/53748 )) ([#53897 ](https://github.com/frappe/erpnext/issues/53897 )) ([fffd3a7 ](fffd3a785c ))
* **stock:** handle legacy single sle recon entries ([d09207a ](d09207ab82 ))
* **stock:** update company validation for expense account in lcv ([40c2b3c ](40c2b3c0f6 ))
* **templates:** escape attachment `file_url` and `file_name` in `order.html` and `projects.html` ([7b9f262 ](7b9f2626f8 ))
* **templates:** using correct syntax of `include` in `projects.html` ([979c594 ](979c594e98 ))
* **test:** enable perpetual inventory ([88c16c8 ](88c16c8378 ))
* validate if quantity greater than 0 in item dashboard (backport [#53846 ](https://github.com/frappe/erpnext/issues/53846 )) ([#53847 ](https://github.com/frappe/erpnext/issues/53847 )) ([ddf6eab ](ddf6eab013 ))
* **warehouse_capacity_dashboard:** escaping `warehouse`, `item_code` and `company` on `get_data` (backport [#53894 ](https://github.com/frappe/erpnext/issues/53894 )) ([#53899 ](https://github.com/frappe/erpnext/issues/53899 )) ([1eda22c ](1eda22c2bd ))
### Features
* **report:** add service start/end date and amount with roll-ups in deferred revenue/expense report ([14088ee ](14088ee7ac ))
v15.103.0
2026-03-30 18:03:28 +00:00
diptanilsaha
f4a1f04566
Merge pull request #53916 from frappe/version-15-hotfix
2026-03-30 23:31:54 +05:30
Lakshit Jain
01b8ae3e11
Merge pull request #53931 from frappe/mergify/bp/version-15-hotfix/pr-53406
...
fix: correct item valuation when "Deduct" is used in Purchase Invoice and Receipt. (backport #53406 )
2026-03-30 20:39:14 +05:30
ljain112
b80e10e15e
chore: resolve conflicts
2026-03-30 20:22:30 +05:30
ljain112
25852879f6
fix: correct item valuation when "Deduct" is used in Purchase Invoice and Receipt.
...
(cherry picked from commit e68f149d3a )
# Conflicts:
# erpnext/controllers/buying_controller.py
2026-03-30 14:24:21 +00:00
mergify[bot]
d16061f1bc
fix(bank_account): added validation to fetch bank account details using get_bank_account_details (backport #53926 ) ( #53929 )
...
Co-authored-by: diptanilsaha <diptanil@frappe.io >
fix(bank_account): added validation to fetch bank account details using `get_bank_account_details` (#53926 )
2026-03-30 13:42:19 +00:00
mergify[bot]
b35a6c2e73
fix(opening_invoice_creation_tool): sanitize summary content for dashboard (backport #53917 ) ( #53923 )
...
Co-authored-by: diptanilsaha <diptanil@frappe.io >
fix(opening_invoice_creation_tool): sanitize summary content for dashboard (#53917 )
2026-03-30 13:40:32 +00:00
rohitwaghchaure
5884b71b0a
Merge pull request #53910 from frappe/mergify/bp/version-15-hotfix/pr-53906
...
fix: purchase invoice missing item (backport #53906 )
2026-03-30 18:39:08 +05:30
Rohit Waghchaure
bcd56abb62
fix: purchase invoice missing item
...
(cherry picked from commit af994c1a22 )
2026-03-30 18:24:24 +05:30
mergify[bot]
db70d2e4df
fix(item_dashboard): escaping warehouse, item_code, stock_uom and item_name on get_data (backport #53904 ) ( #53912 )
...
* fix(item_dashboard): escaping `warehouse`, `item_code`, `stock_uom` and `item_name` on `get_data` (#53904 )
(cherry picked from commit fa5238ba12 )
# Conflicts:
# erpnext/stock/dashboard/item_dashboard.py
* chore: resolve conflict
---------
Co-authored-by: diptanilsaha <diptanil@frappe.io >
2026-03-30 09:55:57 +00:00
rohitwaghchaure
098cbcde10
Merge pull request #53895 from frappe/mergify/bp/version-15-hotfix/pr-53799
...
fix(stock): update company validation for expense account in lcv (backport #53799 )
2026-03-30 14:45:20 +05:30
mergify[bot]
1eda22c2bd
fix(warehouse_capacity_dashboard): escaping warehouse, item_code and company on get_data (backport #53894 ) ( #53899 )
...
* fix(warehouse_capacity_dashboard): escaping `warehouse`, `item_code` and `company` on `get_data` (#53894 )
(cherry picked from commit ddeb9775ed )
# Conflicts:
# erpnext/stock/dashboard/warehouse_capacity_dashboard.py
* chore: resolve conflicts
---------
Co-authored-by: diptanilsaha <diptanil@frappe.io >
2026-03-30 08:34:37 +00:00
mergify[bot]
fffd3a785c
fix(stock): add warehouse filter to pick work order raw materials (backport #53748 ) ( #53897 )
...
Co-authored-by: Sudharsanan Ashok <135326972+Sudharsanan11@users.noreply.github.com >
fix(stock): add warehouse filter to pick work order raw materials (#53748 )
2026-03-30 08:02:27 +00:00
Sudharsanan11
88c16c8378
fix(test): enable perpetual inventory
...
(cherry picked from commit 875a2e4947 )
2026-03-30 07:34:27 +00:00
Sudharsanan11
40c2b3c0f6
fix(stock): update company validation for expense account in lcv
...
(cherry picked from commit 913168e8b6 )
2026-03-30 07:34:27 +00:00
mergify[bot]
46f751e403
fix(manufacturing): update the qty precision (backport #53874 ) ( #53884 )
...
* fix(manufacturing): update the qty precision (#53874 )
(cherry picked from commit f3a794384a )
# Conflicts:
# erpnext/manufacturing/doctype/production_plan/production_plan.py
* chore: resolve conflicts
---------
Co-authored-by: Sudharsanan Ashok <135326972+Sudharsanan11@users.noreply.github.com >
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
2026-03-29 16:38:51 +00:00
mergify[bot]
a21b82b238
fix: change shipment parcel dimension fields from Int to Float (backport #53867 ) ( #53872 )
...
* fix: change shipment parcel dimension fields from Int to Float (#53867 )
(cherry picked from commit 6badf00313 )
# Conflicts:
# erpnext/stock/doctype/shipment_parcel/shipment_parcel.json
# erpnext/stock/doctype/shipment_parcel_template/shipment_parcel_template.json
* chore: resolve conflicts
* chore: resole conflicts
---------
Co-authored-by: Kaushal Shriwas <64089478+kaulith@users.noreply.github.com >
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
2026-03-29 07:06:55 +00:00
mergify[bot]
f7536f645b
fix: invalid dynamic link filter for address doctype (backport #53849 ) ( #53851 )
2026-03-27 12:38:29 +00:00
mergify[bot]
ddf6eab013
fix: validate if quantity greater than 0 in item dashboard (backport #53846 ) ( #53847 )
...
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
fix: validate if quantity greater than 0 in item dashboard (#53846 )
2026-03-27 16:03:48 +05:30
ruthra kumar
3e4c331962
Merge pull request #53829 from frappe/mergify/bp/version-15-hotfix/pr-53429
...
feat(report): add service start/end date and amount with roll-ups in deferred revenue/expense report (backport #53429 )
2026-03-27 10:53:35 +05:30
ruthra kumar
4b1c1d33b0
Merge pull request #53827 from frappe/mergify/bp/version-15-hotfix/pr-53343
...
fix(email_campaign): prevent unsubscribing entire campaign when email group member unsubscribes (backport #53343 )
2026-03-27 10:43:29 +05:30
Shllokkk
14088ee7ac
feat(report): add service start/end date and amount with roll-ups in deferred revenue/expense report
...
(cherry picked from commit 8e5692d8a3 )
2026-03-27 05:00:35 +00:00
Shllokkk
6151a496e7
fix(email_campaign): prevent unsubscribing entire campaign when email group member unsubscribes
...
(cherry picked from commit 56f597f5ad )
2026-03-27 04:57:30 +00:00
rohitwaghchaure
237915dc03
Merge pull request #53809 from frappe/mergify/bp/version-15-hotfix/pr-53216
...
fix(stock): handle legacy single sle recon entries (backport #53216 )
2026-03-26 18:27:19 +05:30
kavin-114
d09207ab82
fix(stock): handle legacy single sle recon entries
...
(cherry picked from commit 7e6bbcc3fb )
2026-03-26 18:12:09 +05:30
mergify[bot]
d9cd09b24a
fix: flaky currency exchange test (backport #53813 ) ( #53816 )
2026-03-26 12:38:36 +00:00
mergify[bot]
0a28fb3ae1
fix: purchase invoice for internal transfers should not require PO (backport #53791 ) ( #53792 )
...
* fix: purchase invoice for internal transfers should not require PO (#53791 )
(cherry picked from commit 3f74733942 )
# Conflicts:
# erpnext/accounts/doctype/purchase_invoice/purchase_invoice.py
* chore: resolve conflicts
---------
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
2026-03-26 03:45:18 +00:00
mergify[bot]
d50c727f89
fix(contract_template): restrict create, write and delete access only to System Manager (backport #53787 ) ( #53788 )
...
* fix(contract_template): restrict `create`, `write` and `delete` access only to `System Manager` (#53787 )
(cherry picked from commit e136bfbb61 )
# Conflicts:
# erpnext/crm/doctype/contract_template/contract_template.json
* chore: resolve conflicts
---------
Co-authored-by: diptanilsaha <diptanil@frappe.io >
2026-03-25 15:05:12 +00:00
diptanilsaha
40c8201302
Merge pull request #53780 from frappe/mergify/bp/version-15-hotfix/pr-53779
...
fix(template): escape attachment `file_url` and `file_name` and jinja syntax (backport #53779 )
2026-03-25 15:20:01 +05:30
diptanilsaha
979c594e98
fix(templates): using correct syntax of include in projects.html
...
(cherry picked from commit bc6561cdd0 )
2026-03-25 09:28:18 +00:00
diptanilsaha
7b9f2626f8
fix(templates): escape attachment file_url and file_name in order.html and projects.html
...
(cherry picked from commit d9760bbf4f )
2026-03-25 09:28:18 +00:00
Pandiyan P
64956ab59c
fix(manufacturing): update condition for base hour rate calculation ( #53777 )
2026-03-25 13:49:31 +05:30
Pandiyan P
78635ebe99
fix(manufacturing): apply work order status filter in job card ( #53776 )
2026-03-25 13:24:07 +05:30
mergify[bot]
d6afb9b10a
fix(manufacturing): apply work order status filter in job card (backport #53766 ) ( #53767 )
...
Co-authored-by: Pandiyan P <pandiyanpalani37@gmail.com >
fix(manufacturing): apply work order status filter in job card (#53766 )
2026-03-25 11:21:31 +05:30
mergify[bot]
468ca2bde1
fix(manufacturing): close work order status when stock reservation is… (backport #53714 ) ( #53720 )
...
Co-authored-by: Pandiyan P <pandiyanpalani37@gmail.com >
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
fix(manufacturing): close work order status when stock reservation is… (#53714 )
2026-03-23 16:28:01 +00:00
Frappe PR Bot
1d14ba1639
chore(release): Bumped to Version 15.102.0
...
# [15.102.0](https://github.com/frappe/erpnext/compare/v15.101.3...v15.102.0 ) (2026-03-23)
### Bug Fixes
* Adding validation for operation time in BOM ([7707a79 ](7707a79d44 ))
* batch validation for subcontracting receipt ([32c0532 ](32c0532dec ))
* **budget-variance-report:** validate 'budget_against' filter (backport [#53079 ](https://github.com/frappe/erpnext/issues/53079 )) ([#53663 ](https://github.com/frappe/erpnext/issues/53663 )) ([d96590c ](d96590c4d9 ))
* check for `submit` permissions instead of `write` permissions when updating status (backport [#53697 ](https://github.com/frappe/erpnext/issues/53697 )) ([#53702 ](https://github.com/frappe/erpnext/issues/53702 )) ([46e784d ](46e784d094 ))
* check posting_date in args (backport [#53303 ](https://github.com/frappe/erpnext/issues/53303 )) ([#53611 ](https://github.com/frappe/erpnext/issues/53611 )) ([e0f1e75 ](e0f1e757f3 ))
* consider returned qty in subcontracting report (backport [#53616 ](https://github.com/frappe/erpnext/issues/53616 )) ([#53620 ](https://github.com/frappe/erpnext/issues/53620 )) ([af86fd3 ](af86fd3cb4 ))
* deadlock issue for SLE ([540a854 ](540a8540d6 ))
* do not overwrite expense account in stock entry (backport [#53658 ](https://github.com/frappe/erpnext/issues/53658 )) ([#53660 ](https://github.com/frappe/erpnext/issues/53660 )) ([90e4f90 ](90e4f9026d ))
* ignore cost center (backport [#53063 ](https://github.com/frappe/erpnext/issues/53063 )) ([#53613 ](https://github.com/frappe/erpnext/issues/53613 )) ([562f93e ](562f93e75c ))
* incorrect sle calculation when doc has project ([#53599 ](https://github.com/frappe/erpnext/issues/53599 )) ([7acd435 ](7acd435835 ))
* initialize all tax columns to resolve Key error in `item_wise_sales_register` and `item_wise_purchase_register` reports (backport [#53323 ](https://github.com/frappe/erpnext/issues/53323 )) ([#53583 ](https://github.com/frappe/erpnext/issues/53583 )) ([119195c ](119195c6fa ))
* **manufacturing:** update non-stock item dict (backport [#53689 ](https://github.com/frappe/erpnext/issues/53689 )) ([#53698 ](https://github.com/frappe/erpnext/issues/53698 )) ([c0ce34e ](c0ce34e12c ))
* merge conflicts ([b3f0e2a ](b3f0e2a00d ))
* PO should not be required for internal transfers (backport [#53681 ](https://github.com/frappe/erpnext/issues/53681 )) ([#53683 ](https://github.com/frappe/erpnext/issues/53683 )) ([04d74ad ](04d74ad6eb ))
* python error in manufacture entry if transfer against is job card (backport [#53615 ](https://github.com/frappe/erpnext/issues/53615 )) ([#53617 ](https://github.com/frappe/erpnext/issues/53617 )) ([5a3bc27 ](5a3bc27e2c ))
* **sales_invoice:** using `msgprint` and removed condition checking for `is_created_using_pos` to refetch payment methods ([#53636 ](https://github.com/frappe/erpnext/issues/53636 )) ([f8ab56e ](f8ab56ecc9 ))
* set customer details on customer creation at login ([#53509 ](https://github.com/frappe/erpnext/issues/53509 )) ([4f39dfd ](4f39dfd642 ))
* shipping rule applied twice on non stock items (backport [#53655 ](https://github.com/frappe/erpnext/issues/53655 )) ([#53686 ](https://github.com/frappe/erpnext/issues/53686 )) ([5e767ea ](5e767ea595 ))
* stock queue for SABB ([461bc17 ](461bc1733f ))
* **stock:** add company filter while fetching batches (backport [#53369 ](https://github.com/frappe/erpnext/issues/53369 )) ([#53580 ](https://github.com/frappe/erpnext/issues/53580 )) ([c09c599 ](c09c5999dc ))
* **stock:** fix email error message (backport [#53606 ](https://github.com/frappe/erpnext/issues/53606 )) ([#53632 ](https://github.com/frappe/erpnext/issues/53632 )) ([6ea3d56 ](6ea3d56972 ))
* **trends:** added validation for `period_based_on` filter (backport [#53690 ](https://github.com/frappe/erpnext/issues/53690 )) ([#53691 ](https://github.com/frappe/erpnext/issues/53691 )) ([974755b ](974755b224 ))
* validate permission before updating status (backport [#53651 ](https://github.com/frappe/erpnext/issues/53651 )) ([#53652 ](https://github.com/frappe/erpnext/issues/53652 )) ([defa1d4 ](defa1d4a76 ))
### Features
* add cost center field to the stock entry accounting dimension tab ([e17b5df ](e17b5dfe61 ))
v15.102.0
2026-03-23 14:59:14 +00:00
diptanilsaha
a270c02bb4
Merge pull request #53700 from frappe/version-15-hotfix
2026-03-23 20:27:38 +05:30
rohitwaghchaure
28aa21bf83
Merge pull request #53706 from frappe/mergify/bp/version-15-hotfix/pr-53705
...
fix: batch validation for subcontracting receipt (backport #53705 )
2026-03-23 18:52:47 +05:30
mergify[bot]
119195c6fa
fix: initialize all tax columns to resolve Key error in item_wise_sales_register and item_wise_purchase_register reports (backport #53323 ) ( #53583 )
...
Co-authored-by: Lakshit Jain <ljain112@gmail.com >
fix: initialize all tax columns to resolve Key error in `item_wise_sales_register` and `item_wise_purchase_register` reports (#53323 )
2026-03-23 18:05:54 +05:30
Rohit Waghchaure
32c0532dec
fix: batch validation for subcontracting receipt
...
(cherry picked from commit b8d201658a )
2026-03-23 11:32:42 +00:00
diptanilsaha
46e784d094
fix: check for submit permissions instead of write permissions when updating status (backport #53697 ) ( #53702 )
2026-03-23 16:03:50 +05:30
mergify[bot]
c0ce34e12c
fix(manufacturing): update non-stock item dict (backport #53689 ) ( #53698 )
...
Co-authored-by: Sudharsanan Ashok <135326972+Sudharsanan11@users.noreply.github.com >
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
fix(manufacturing): update non-stock item dict (#53689 )
2026-03-23 10:26:29 +00:00
Mihir Kandoi
eaf5494502
chore: linter ( #53696 )
2026-03-23 10:19:41 +00:00
mergify[bot]
04d74ad6eb
fix: PO should not be required for internal transfers (backport #53681 ) ( #53683 )
...
* fix: PO should not be required for internal transfers (#53681 )
(cherry picked from commit 5154102468 )
# Conflicts:
# erpnext/stock/doctype/purchase_receipt/purchase_receipt.py
* chore: resolve conflicts
* chore: resolve conflicts
* chore: resolve conflicts
---------
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
2026-03-23 09:30:20 +00:00
Nishka Gosalia
2de04b8a46
Merge pull request #53693 from frappe/mergify/bp/version-15-hotfix/pr-53649
2026-03-23 14:46:49 +05:30
mergify[bot]
974755b224
fix(trends): added validation for period_based_on filter (backport #53690 ) ( #53691 )
...
Co-authored-by: diptanilsaha <diptanil@frappe.io >
fix(trends): added validation for `period_based_on` filter (#53690 )
2026-03-23 14:42:03 +05:30
mergify[bot]
5e767ea595
fix: shipping rule applied twice on non stock items (backport #53655 ) ( #53686 )
...
Co-authored-by: Mihir Kandoi <kandoimihir@gmail.com >
fix: shipping rule applied twice on non stock items (#53655 )
2026-03-23 14:38:32 +05:30
nishkagosalia
f5bd85b4dc
chore: Adding new argument in status updater to skip qty validation
...
(cherry picked from commit dcd0509089 )
2026-03-23 08:57:35 +00:00