2015-03-03 14:55:30 +05:30
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
2013-08-05 14:59:54 +05:30
# License: GNU General Public License v3. See license.txt
2013-01-29 11:32:38 +05:30
from __future__ import unicode_literals
2014-02-14 15:47:51 +05:30
import frappe
from frappe . utils import nowdate , cstr , flt , now , getdate , add_months
2014-04-14 19:20:45 +05:30
from frappe import throw , _
2014-02-14 15:47:51 +05:30
from frappe . utils import formatdate
2014-09-09 16:15:35 +05:30
import frappe . desk . reportview
2013-01-29 11:32:38 +05:30
2014-02-14 15:47:51 +05:30
class FiscalYearError ( frappe . ValidationError ) : pass
class BudgetError ( frappe . ValidationError ) : pass
2013-08-22 18:25:43 +05:30
2014-10-03 17:43:02 +05:30
@frappe.whitelist ( )
def get_fiscal_year ( date = None , fiscal_year = None , label = " Date " , verbose = 1 , company = None ) :
return get_fiscal_years ( date , fiscal_year , label , verbose , company ) [ 0 ]
2013-01-29 11:32:38 +05:30
2015-01-12 16:41:46 +05:30
def get_fiscal_years ( transaction_date = None , fiscal_year = None , label = " Date " , verbose = 1 , company = None ) :
2013-01-29 11:32:38 +05:30
# if year start date is 2012-04-01, year end date should be 2013-03-31 (hence subdate)
2015-05-20 12:26:07 +05:30
cond = " ifnull(disabled, 0) = 0 "
2013-06-20 16:35:09 +05:30
if fiscal_year :
2015-05-20 12:53:04 +05:30
cond + = " and fy.name = %(fiscal_year)s "
2013-06-20 16:35:09 +05:30
else :
2015-05-20 12:53:04 +05:30
cond + = " and %(transaction_date)s >= fy.year_start_date and %(transaction_date)s <= fy.year_end_date "
2015-01-14 16:27:13 +05:30
2015-01-12 16:41:46 +05:30
if company :
cond + = """ and (not exists(select name from `tabFiscal Year Company` fyc where fyc.parent = fy.name)
or exists ( select company from ` tabFiscal Year Company ` fyc where fyc . parent = fy . name and fyc . company = % ( company ) s ) ) """
2015-01-14 16:27:13 +05:30
fy = frappe . db . sql ( """ select fy.name, fy.year_start_date, fy.year_end_date from `tabFiscal Year` fy
2015-05-20 12:26:07 +05:30
where % s order by fy . year_start_date desc """ % c ond, {
2015-01-12 16:41:46 +05:30
" fiscal_year " : fiscal_year ,
" transaction_date " : transaction_date ,
" company " : company
} )
2014-04-08 13:53:35 +05:30
2013-01-29 11:32:38 +05:30
if not fy :
2015-05-19 18:43:45 +05:30
error_msg = _ ( """ {0} {1} not in any active Fiscal Year. For more details check {2} . """ ) . format ( label , formatdate ( transaction_date ) , " https://erpnext.com/kb/accounts/fiscal-year-error " )
2014-10-03 17:43:02 +05:30
if verbose == 1 : frappe . msgprint ( error_msg )
2013-01-29 11:32:38 +05:30
raise FiscalYearError , error_msg
2013-02-05 23:25:37 +05:30
return fy
2014-04-08 13:53:35 +05:30
2015-02-19 14:51:58 +05:30
def validate_fiscal_year ( date , fiscal_year , label = _ ( " Date " ) , doc = None ) :
2013-07-11 17:49:18 +05:30
years = [ f [ 0 ] for f in get_fiscal_years ( date , label = label ) ]
2013-02-05 23:25:37 +05:30
if fiscal_year not in years :
2015-02-19 14:51:58 +05:30
if doc :
doc . fiscal_year = years [ 0 ]
else :
throw ( _ ( " {0} ' {1} ' not in Fiscal Year {2} " ) . format ( label , formatdate ( date ) , fiscal_year ) )
2013-01-29 11:32:38 +05:30
2014-02-14 15:47:51 +05:30
@frappe.whitelist ( )
2014-09-17 14:11:22 +05:30
def get_balance_on ( account = None , date = None , party_type = None , party = None ) :
2014-02-14 15:47:51 +05:30
if not account and frappe . form_dict . get ( " account " ) :
account = frappe . form_dict . get ( " account " )
2014-09-17 14:11:22 +05:30
if not date and frappe . form_dict . get ( " date " ) :
2014-02-14 15:47:51 +05:30
date = frappe . form_dict . get ( " date " )
2014-09-17 14:11:22 +05:30
if not party_type and frappe . form_dict . get ( " party_type " ) :
party_type = frappe . form_dict . get ( " party_type " )
if not party and frappe . form_dict . get ( " party " ) :
party = frappe . form_dict . get ( " party " )
2014-04-21 12:42:21 +05:30
2013-01-29 11:32:38 +05:30
cond = [ ]
if date :
cond . append ( " posting_date <= ' %s ' " % date )
else :
# get balance of all entries that exist
date = nowdate ( )
2014-04-08 13:53:35 +05:30
2013-01-29 11:32:38 +05:30
try :
year_start_date = get_fiscal_year ( date , verbose = 0 ) [ 1 ]
2014-04-14 19:20:45 +05:30
except FiscalYearError :
2013-01-29 11:32:38 +05:30
if getdate ( date ) > getdate ( nowdate ( ) ) :
# if fiscal year not found and the date is greater than today
# get fiscal year for today's date and its corresponding year start date
year_start_date = get_fiscal_year ( nowdate ( ) , verbose = 1 ) [ 1 ]
else :
# this indicates that it is a date older than any existing fiscal year.
# hence, assuming balance as 0.0
return 0.0
2014-04-08 13:53:35 +05:30
2014-09-17 14:11:22 +05:30
if account :
acc = frappe . get_doc ( " Account " , account )
acc . check_permission ( " read " )
# for pl accounts, get balance within a fiscal year
if acc . report_type == ' Profit and Loss ' :
cond . append ( " posting_date >= ' %s ' and voucher_type != ' Period Closing Voucher ' " \
% year_start_date )
# different filter for group and ledger - improved performance
2015-04-23 13:14:17 +05:30
if acc . is_group :
2014-09-17 14:11:22 +05:30
cond . append ( """ exists (
2015-06-14 17:49:29 +05:30
select name from ` tabAccount ` ac where ac . name = gle . account
2014-09-17 14:11:22 +05:30
and ac . lft > = % s and ac . rgt < = % s
) """ % (acc.lft, acc.rgt))
else :
cond . append ( """ gle.account = " %s " """ % ( account . replace ( ' " ' , ' \\ " ' ) , ) )
if party_type and party :
cond . append ( """ gle.party_type = " %s " and gle.party = " %s " """ %
( party_type . replace ( ' " ' , ' \\ " ' ) , party . replace ( ' " ' , ' \\ " ' ) ) )
2014-04-08 13:53:35 +05:30
2014-02-26 12:35:33 +05:30
bal = frappe . db . sql ( """
2014-04-08 13:53:35 +05:30
SELECT sum ( ifnull ( debit , 0 ) ) - sum ( ifnull ( credit , 0 ) )
2013-01-29 11:32:38 +05:30
FROM ` tabGL Entry ` gle
2013-08-21 17:47:11 +05:30
WHERE % s """ % " and " .join(cond))[0][0]
2013-01-29 11:32:38 +05:30
# if bal is None, return 0
2013-07-19 15:33:11 +05:30
return flt ( bal )
2013-01-30 19:16:13 +05:30
2014-02-14 15:47:51 +05:30
@frappe.whitelist ( )
2013-01-30 19:16:13 +05:30
def add_ac ( args = None ) :
if not args :
2014-02-14 15:47:51 +05:30
args = frappe . local . form_dict
2013-01-30 19:16:13 +05:30
args . pop ( " cmd " )
2014-04-08 13:53:35 +05:30
2014-04-22 18:54:54 +05:30
ac = frappe . new_doc ( " Account " )
ac . update ( args )
2014-03-28 13:55:00 +05:30
ac . old_parent = " "
ac . freeze_account = " No "
2013-01-30 19:16:13 +05:30
ac . insert ( )
2014-04-22 18:54:54 +05:30
2014-03-28 13:55:00 +05:30
return ac . name
2013-01-30 19:16:13 +05:30
2014-02-14 15:47:51 +05:30
@frappe.whitelist ( )
2013-01-30 19:16:13 +05:30
def add_cc ( args = None ) :
if not args :
2014-02-14 15:47:51 +05:30
args = frappe . local . form_dict
2013-01-30 19:16:13 +05:30
args . pop ( " cmd " )
2014-04-08 13:53:35 +05:30
2014-04-22 18:54:54 +05:30
cc = frappe . new_doc ( " Cost Center " )
cc . update ( args )
2014-03-28 13:55:00 +05:30
cc . old_parent = " "
2013-01-30 19:16:13 +05:30
cc . insert ( )
2014-03-28 13:55:00 +05:30
return cc . name
2013-01-30 19:16:13 +05:30
def reconcile_against_document ( args ) :
"""
Cancel JV , Update aginst document , split if required and resubmit jv
"""
for d in args :
check_if_jv_modified ( d )
2014-04-30 19:30:50 +05:30
validate_allocated_amount ( d )
2013-01-30 19:16:13 +05:30
against_fld = {
2014-12-25 17:14:18 +05:30
' Journal Entry ' : ' against_jv ' ,
2013-01-30 19:16:13 +05:30
' Sales Invoice ' : ' against_invoice ' ,
' Purchase Invoice ' : ' against_voucher '
}
2014-04-08 13:53:35 +05:30
2013-01-30 19:16:13 +05:30
d [ ' against_fld ' ] = against_fld [ d [ ' against_voucher_type ' ] ]
# cancel JV
2014-12-25 17:14:18 +05:30
jv_obj = frappe . get_doc ( ' Journal Entry ' , d [ ' voucher_no ' ] )
2014-04-08 13:53:35 +05:30
2013-01-30 19:16:13 +05:30
jv_obj . make_gl_entries ( cancel = 1 , adv_adj = 1 )
2014-04-08 13:53:35 +05:30
2013-01-30 19:16:13 +05:30
# update ref in JV Detail
update_against_doc ( d , jv_obj )
# re-submit JV
2014-12-25 17:14:18 +05:30
jv_obj = frappe . get_doc ( ' Journal Entry ' , d [ ' voucher_no ' ] )
2013-01-30 19:16:13 +05:30
jv_obj . make_gl_entries ( cancel = 0 , adv_adj = 1 )
def check_if_jv_modified ( args ) :
"""
check if there is already a voucher reference
check if amount is same
check if jv is submitted
"""
2014-02-26 12:35:33 +05:30
ret = frappe . db . sql ( """
2014-12-25 17:14:18 +05:30
select t2 . { dr_or_cr } from ` tabJournal Entry ` t1 , ` tabJournal Entry Account ` t2
2014-07-21 19:22:02 +05:30
where t1 . name = t2 . parent and t2 . account = % ( account ) s
2014-08-29 11:18:32 +05:30
and t2 . party_type = % ( party_type ) s and t2 . party = % ( party ) s
2014-04-08 13:53:35 +05:30
and ifnull ( t2 . against_voucher , ' ' ) = ' '
2013-01-30 19:16:13 +05:30
and ifnull ( t2 . against_invoice , ' ' ) = ' ' and ifnull ( t2 . against_jv , ' ' ) = ' '
2014-07-21 19:22:02 +05:30
and t1 . name = % ( voucher_no ) s and t2 . name = % ( voucher_detail_no ) s
and t1 . docstatus = 1 """ .format(dr_or_cr = args.get( " dr_or_cr " )), args)
2014-04-08 13:53:35 +05:30
2013-01-30 19:16:13 +05:30
if not ret :
2014-01-29 16:31:38 +05:30
throw ( _ ( """ Payment Entry has been modified after you pulled it. Please pull it again. """ ) )
2013-01-30 19:16:13 +05:30
2014-04-30 19:30:50 +05:30
def validate_allocated_amount ( args ) :
if args . get ( " allocated_amt " ) < 0 :
throw ( _ ( " Allocated amount can not be negative " ) )
elif args . get ( " allocated_amt " ) > args . get ( " unadjusted_amt " ) :
throw ( _ ( " Allocated amount can not greater than unadusted amount " ) )
2013-01-30 19:16:13 +05:30
def update_against_doc ( d , jv_obj ) :
"""
Updates against document , if partial amount splits into rows
"""
2014-12-25 18:19:39 +05:30
jv_detail = jv_obj . get ( " accounts " , { " name " : d [ " voucher_detail_no " ] } ) [ 0 ]
2014-04-08 13:53:35 +05:30
jv_detail . set ( d [ " dr_or_cr " ] , d [ " allocated_amt " ] )
jv_detail . set ( d [ " against_fld " ] , d [ " against_voucher " ] )
2013-01-30 19:16:13 +05:30
if d [ ' allocated_amt ' ] < d [ ' unadjusted_amt ' ] :
2014-04-08 13:53:35 +05:30
jvd = frappe . db . sql ( """ select cost_center, balance, against_account, is_advance
2014-12-25 16:01:55 +05:30
from ` tabJournal Entry Account ` where name = % s """ , d[ ' voucher_detail_no ' ])
2013-01-30 19:16:13 +05:30
# new entry with balance amount
2014-12-25 18:19:39 +05:30
ch = jv_obj . append ( " accounts " )
2013-01-30 19:16:13 +05:30
ch . account = d [ ' account ' ]
2014-08-29 11:18:32 +05:30
ch . party_type = d [ " party_type " ]
ch . party = d [ " party " ]
2013-01-30 19:16:13 +05:30
ch . cost_center = cstr ( jvd [ 0 ] [ 0 ] )
2014-07-07 15:54:11 +05:30
ch . balance = flt ( jvd [ 0 ] [ 1 ] )
2014-03-28 13:55:00 +05:30
ch . set ( d [ ' dr_or_cr ' ] , flt ( d [ ' unadjusted_amt ' ] ) - flt ( d [ ' allocated_amt ' ] ) )
ch . set ( d [ ' dr_or_cr ' ] == ' debit ' and ' credit ' or ' debit ' , 0 )
2013-01-30 19:16:13 +05:30
ch . against_account = cstr ( jvd [ 0 ] [ 2 ] )
ch . is_advance = cstr ( jvd [ 0 ] [ 3 ] )
ch . docstatus = 1
2014-04-08 13:53:35 +05:30
# will work as update after submit
2015-02-10 14:41:27 +05:30
jv_obj . flags . ignore_validate_update_after_submit = True
2014-04-08 13:53:35 +05:30
jv_obj . save ( )
2013-03-20 17:00:41 +05:30
def remove_against_link_from_jv ( ref_type , ref_no , against_field ) :
2014-12-25 16:01:55 +05:30
linked_jv = frappe . db . sql_list ( """ select parent from `tabJournal Entry Account`
2014-01-03 15:12:16 +05:30
where ` % s ` = % s and docstatus < 2 """ % (against_field, " %s " ), (ref_no))
2014-04-08 13:53:35 +05:30
if linked_jv :
2014-12-25 16:01:55 +05:30
frappe . db . sql ( """ update `tabJournal Entry Account` set ` %s `=null,
2014-01-03 15:12:16 +05:30
modified = % s , modified_by = % s
2014-04-08 13:53:35 +05:30
where ` % s ` = % s and docstatus < 2 """ % (against_field, " %s " , " %s " , against_field, " %s " ),
2014-02-14 15:47:51 +05:30
( now ( ) , frappe . session . user , ref_no ) )
2014-04-08 13:53:35 +05:30
2014-02-26 12:35:33 +05:30
frappe . db . sql ( """ update `tabGL Entry`
2014-01-03 15:12:16 +05:30
set against_voucher_type = null , against_voucher = null ,
modified = % s , modified_by = % s
where against_voucher_type = % s and against_voucher = % s
and voucher_no != ifnull ( against_voucher , ' ' ) """ ,
2014-02-14 15:47:51 +05:30
( now ( ) , frappe . session . user , ref_type , ref_no ) )
2014-04-08 13:53:35 +05:30
2014-12-25 17:14:18 +05:30
frappe . msgprint ( _ ( " Journal Entries {0} are un-linked " . format ( " \n " . join ( linked_jv ) ) ) )
2014-04-08 13:53:35 +05:30
2013-03-25 11:06:00 +05:30
2014-02-14 15:47:51 +05:30
@frappe.whitelist ( )
2013-03-25 11:06:00 +05:30
def get_company_default ( company , fieldname ) :
2014-02-26 12:35:33 +05:30
value = frappe . db . get_value ( " Company " , company , fieldname )
2014-04-08 13:53:35 +05:30
2013-03-25 11:06:00 +05:30
if not value :
2014-11-26 15:35:08 +05:30
throw ( _ ( " Please set default value {0} in Company {1} " ) . format ( frappe . get_meta ( " Company " ) . get_label ( fieldname ) , company ) )
2014-04-08 13:53:35 +05:30
2013-03-25 11:06:00 +05:30
return value
2013-05-28 16:52:30 +05:30
def fix_total_debit_credit ( ) :
2014-04-08 13:53:35 +05:30
vouchers = frappe . db . sql ( """ select voucher_type, voucher_no,
sum ( debit ) - sum ( credit ) as diff
from ` tabGL Entry `
2013-05-28 16:52:30 +05:30
group by voucher_type , voucher_no
having sum ( ifnull ( debit , 0 ) ) != sum ( ifnull ( credit , 0 ) ) """ , as_dict=1)
2014-04-08 13:53:35 +05:30
2013-05-28 16:52:30 +05:30
for d in vouchers :
if abs ( d . diff ) > 0 :
dr_or_cr = d . voucher_type == " Sales Invoice " and " credit " or " debit "
2014-04-08 13:53:35 +05:30
2014-02-26 12:35:33 +05:30
frappe . db . sql ( """ update `tabGL Entry` set %s = %s + %s
2013-05-28 16:52:30 +05:30
where voucher_type = % s and voucher_no = % s and % s > 0 limit 1 """ %
2014-04-08 13:53:35 +05:30
( dr_or_cr , dr_or_cr , ' %s ' , ' %s ' , ' %s ' , dr_or_cr ) ,
2013-08-02 11:44:29 +05:30
( d . diff , d . voucher_type , d . voucher_no ) )
2014-04-08 13:53:35 +05:30
2013-08-26 16:53:30 +05:30
def get_stock_and_account_difference ( account_list = None , posting_date = None ) :
2014-10-08 12:19:55 +05:30
from erpnext . stock . utils import get_stock_value_on
2014-04-08 13:53:35 +05:30
2013-08-26 16:53:30 +05:30
if not posting_date : posting_date = nowdate ( )
2014-04-08 13:53:35 +05:30
2013-08-02 11:44:29 +05:30
difference = { }
2014-04-08 13:53:35 +05:30
2014-08-27 12:05:48 +05:30
account_warehouse = dict ( frappe . db . sql ( """ select name, warehouse from tabAccount
where account_type = ' Warehouse ' and ifnull ( warehouse , ' ' ) != ' '
2013-09-25 10:32:51 +05:30
and name in ( % s ) """ % ' , ' .join([ ' %s ' ]*len(account_list)), account_list))
2014-04-08 13:53:35 +05:30
2013-09-25 10:32:51 +05:30
for account , warehouse in account_warehouse . items ( ) :
2013-08-26 16:53:30 +05:30
account_balance = get_balance_on ( account , posting_date )
2014-10-08 12:19:55 +05:30
stock_value = get_stock_value_on ( warehouse , posting_date )
2013-08-07 14:21:04 +05:30
if abs ( flt ( stock_value ) - flt ( account_balance ) ) > 0.005 :
2013-08-07 12:33:37 +05:30
difference . setdefault ( account , flt ( stock_value ) - flt ( account_balance ) )
2013-08-07 14:21:04 +05:30
2013-08-06 16:19:18 +05:30
return difference
2013-08-22 14:38:46 +05:30
def validate_expense_against_budget ( args ) :
2014-02-14 15:47:51 +05:30
args = frappe . _dict ( args )
2014-03-21 11:14:49 +05:30
if frappe . db . get_value ( " Account " , { " name " : args . account , " report_type " : " Profit and Loss " } ) :
2014-02-26 12:35:33 +05:30
budget = frappe . db . sql ( """
2014-04-08 13:53:35 +05:30
select bd . budget_allocated , cc . distribution_id
2013-08-22 14:38:46 +05:30
from ` tabCost Center ` cc , ` tabBudget Detail ` bd
where cc . name = bd . parent and cc . name = % s and account = % s and bd . fiscal_year = % s
""" , (args.cost_center, args.account, args.fiscal_year), as_dict=True)
2014-04-08 13:53:35 +05:30
2013-08-22 14:38:46 +05:30
if budget and budget [ 0 ] . budget_allocated :
2014-04-08 13:53:35 +05:30
yearly_action , monthly_action = frappe . db . get_value ( " Company " , args . company ,
2013-08-22 14:38:46 +05:30
[ " yearly_bgt_flag " , " monthly_bgt_flag " ] )
2013-08-22 18:25:43 +05:30
action_for = action = " "
if monthly_action in [ " Stop " , " Warn " ] :
2014-04-08 13:53:35 +05:30
budget_amount = get_allocated_budget ( budget [ 0 ] . distribution_id ,
2013-08-22 18:25:43 +05:30
args . posting_date , args . fiscal_year , budget [ 0 ] . budget_allocated )
2014-04-08 13:53:35 +05:30
args [ " month_end_date " ] = frappe . db . sql ( " select LAST_DAY( %s ) " ,
2013-08-23 10:46:41 +05:30
args . posting_date ) [ 0 ] [ 0 ]
2014-04-15 16:30:55 +05:30
action_for , action = _ ( " Monthly " ) , monthly_action
2014-04-08 13:53:35 +05:30
2013-08-22 18:25:43 +05:30
elif yearly_action in [ " Stop " , " Warn " ] :
budget_amount = budget [ 0 ] . budget_allocated
2014-04-15 16:30:55 +05:30
action_for , action = _ ( " Annual " ) , yearly_action
2013-08-23 10:46:41 +05:30
2013-08-22 18:25:43 +05:30
if action_for :
actual_expense = get_actual_expense ( args )
if actual_expense > budget_amount :
2014-04-15 16:30:55 +05:30
frappe . msgprint ( _ ( " {0} budget for Account {1} against Cost Center {2} will exceed by {3} " ) . format (
_ ( action_for ) , args . account , args . cost_center , cstr ( actual_expense - budget_amount ) ) )
if action == " Stop " :
raise BudgetError
2014-04-08 13:53:35 +05:30
2013-08-22 18:25:43 +05:30
def get_allocated_budget ( distribution_id , posting_date , fiscal_year , yearly_budget ) :
if distribution_id :
distribution = { }
2015-01-10 16:03:49 +05:30
for d in frappe . db . sql ( """ select mdp.month, mdp.percentage_allocation
from ` tabMonthly Distribution Percentage ` mdp , ` tabMonthly Distribution ` md
where mdp . parent = md . name and md . fiscal_year = % s """ , fiscal_year, as_dict=1):
2013-08-22 18:25:43 +05:30
distribution . setdefault ( d . month , d . percentage_allocation )
2013-08-23 10:46:41 +05:30
2014-02-26 12:35:33 +05:30
dt = frappe . db . get_value ( " Fiscal Year " , fiscal_year , " year_start_date " )
2013-08-22 18:25:43 +05:30
budget_percentage = 0.0
2014-04-08 13:53:35 +05:30
2013-08-22 18:25:43 +05:30
while ( dt < = getdate ( posting_date ) ) :
if distribution_id :
2013-08-23 10:46:41 +05:30
budget_percentage + = distribution . get ( getdate ( dt ) . strftime ( " % B " ) , 0 )
2013-08-22 18:25:43 +05:30
else :
budget_percentage + = 100.0 / 12
2014-04-08 13:53:35 +05:30
2013-08-22 18:25:43 +05:30
dt = add_months ( dt , 1 )
2014-04-08 13:53:35 +05:30
2013-08-22 18:25:43 +05:30
return yearly_budget * budget_percentage / 100
2014-04-08 13:53:35 +05:30
2013-08-22 14:38:46 +05:30
def get_actual_expense ( args ) :
2013-08-23 10:46:41 +05:30
args [ " condition " ] = " and posting_date<= ' %s ' " % args . month_end_date \
if args . get ( " month_end_date " ) else " "
2014-04-08 13:53:35 +05:30
2015-03-17 10:14:59 +05:30
return flt ( frappe . db . sql ( """
2013-08-22 14:38:46 +05:30
select sum ( ifnull ( debit , 0 ) ) - sum ( ifnull ( credit , 0 ) )
from ` tabGL Entry `
2014-04-08 13:53:35 +05:30
where account = ' %(account)s ' and cost_center = ' %(cost_center)s '
2013-08-23 10:46:41 +05:30
and fiscal_year = ' %(fiscal_year)s ' and company = ' %(company)s ' % ( condition ) s
2015-03-17 10:14:59 +05:30
""" % (args))[0][0])
2014-04-08 13:53:35 +05:30
2014-01-22 15:36:44 +05:30
def get_currency_precision ( currency = None ) :
if not currency :
2014-04-08 13:53:35 +05:30
currency = frappe . db . get_value ( " Company " ,
2015-04-27 13:13:38 +05:30
frappe . db . get_default ( " company " ) , " default_currency " , cache = True )
currency_format = frappe . db . get_value ( " Currency " , currency , " number_format " , cache = True )
2014-04-08 13:53:35 +05:30
2014-02-14 15:47:51 +05:30
from frappe . utils import get_number_format_info
2014-01-24 21:44:36 +05:30
return get_number_format_info ( currency_format ) [ 2 ]
2014-08-07 15:10:05 +05:30
def get_stock_rbnb_difference ( posting_date , company ) :
stock_items = frappe . db . sql_list ( """ select distinct item_code
2014-08-07 15:13:52 +05:30
from ` tabStock Ledger Entry ` where company = % s """ , company)
2014-08-07 15:10:05 +05:30
pr_valuation_amount = frappe . db . sql ( """
select sum ( ifnull ( pr_item . valuation_rate , 0 ) * ifnull ( pr_item . qty , 0 ) * ifnull ( pr_item . conversion_factor , 0 ) )
from ` tabPurchase Receipt Item ` pr_item , ` tabPurchase Receipt ` pr
where pr . name = pr_item . parent and pr . docstatus = 1 and pr . company = % s
and pr . posting_date < = % s and pr_item . item_code in ( % s ) """ %
( ' %s ' , ' %s ' , ' , ' . join ( [ ' %s ' ] * len ( stock_items ) ) ) , tuple ( [ company , posting_date ] + stock_items ) ) [ 0 ] [ 0 ]
pi_valuation_amount = frappe . db . sql ( """
select sum ( ifnull ( pi_item . valuation_rate , 0 ) * ifnull ( pi_item . qty , 0 ) * ifnull ( pi_item . conversion_factor , 0 ) )
from ` tabPurchase Invoice Item ` pi_item , ` tabPurchase Invoice ` pi
where pi . name = pi_item . parent and pi . docstatus = 1 and pi . company = % s
and pi . posting_date < = % s and pi_item . item_code in ( % s ) """ %
( ' %s ' , ' %s ' , ' , ' . join ( [ ' %s ' ] * len ( stock_items ) ) ) , tuple ( [ company , posting_date ] + stock_items ) ) [ 0 ] [ 0 ]
# Balance should be
stock_rbnb = flt ( pr_valuation_amount , 2 ) - flt ( pi_valuation_amount , 2 )
# Balance as per system
2014-08-07 15:13:52 +05:30
stock_rbnb_account = " Stock Received But Not Billed - " + frappe . db . get_value ( " Company " , company , " abbr " )
sys_bal = get_balance_on ( stock_rbnb_account , posting_date )
2014-08-07 15:10:05 +05:30
# Amount should be credited
return flt ( stock_rbnb ) + flt ( sys_bal )
2014-09-12 15:18:53 +05:30
2014-09-16 11:08:08 +05:30
def get_outstanding_invoices ( amount_query , account , party_type , party ) :
2014-09-12 15:18:53 +05:30
all_outstanding_vouchers = [ ]
outstanding_voucher_list = frappe . db . sql ( """
select
voucher_no , voucher_type , posting_date ,
ifnull ( sum ( { amount_query } ) , 0 ) as invoice_amount
from
` tabGL Entry `
where
2014-09-16 11:08:08 +05:30
account = % s and party_type = % s and party = % s and { amount_query } > 0
2014-09-12 15:18:53 +05:30
group by voucher_type , voucher_no
2014-09-16 11:08:08 +05:30
""" .format(amount_query = amount_query), (account, party_type, party), as_dict = True)
2014-09-12 15:18:53 +05:30
for d in outstanding_voucher_list :
payment_amount = frappe . db . sql ( """
2015-06-14 17:49:29 +05:30
select ifnull ( sum ( { amount_query } ) , 0 )
2014-09-12 15:18:53 +05:30
from
` tabGL Entry `
where
2014-09-16 11:08:08 +05:30
account = % s and party_type = % s and party = % s and { amount_query } < 0
2014-09-12 15:18:53 +05:30
and against_voucher_type = % s and ifnull ( against_voucher , ' ' ) = % s
""" .format(** {
" amount_query " : amount_query
2014-09-16 11:08:08 +05:30
} ) , ( account , party_type , party , d . voucher_type , d . voucher_no ) )
2014-09-12 15:18:53 +05:30
payment_amount = - 1 * payment_amount [ 0 ] [ 0 ] if payment_amount else 0
2015-04-15 12:03:21 +05:30
precision = frappe . get_precision ( " Sales Invoice " , " outstanding_amount " )
2014-09-12 15:18:53 +05:30
if d . invoice_amount > payment_amount :
all_outstanding_vouchers . append ( {
' voucher_no ' : d . voucher_no ,
' voucher_type ' : d . voucher_type ,
' posting_date ' : d . posting_date ,
2015-04-15 12:03:21 +05:30
' invoice_amount ' : flt ( d . invoice_amount , precision ) ,
' outstanding_amount ' : flt ( d . invoice_amount - payment_amount , precision )
} )
2014-09-12 15:18:53 +05:30
return all_outstanding_vouchers