product account setting
parent
664ba814c5
commit
7b1a349319
|
@ -28,19 +28,6 @@
|
||||||
</field>
|
</field>
|
||||||
</group>
|
</group>
|
||||||
</tab>
|
</tab>
|
||||||
<!--
|
|
||||||
<tab string="RD Shop">
|
|
||||||
<group span="6" columns="1">
|
|
||||||
<separator string="Filter Product By Category Below"/>
|
|
||||||
<field name="shop_categs" noadd="1" nolabel="1">
|
|
||||||
<list>
|
|
||||||
<field name="code"/>
|
|
||||||
<field name="name"/>
|
|
||||||
</list>
|
|
||||||
</field>
|
|
||||||
</group>
|
|
||||||
</tab>
|
|
||||||
-->
|
|
||||||
<tab string="Development">
|
<tab string="Development">
|
||||||
<button string="Click Me" type="default" method="run_script" perm="clinic_setting_test"/>
|
<button string="Click Me" type="default" method="run_script" perm="clinic_setting_test"/>
|
||||||
</tab>
|
</tab>
|
||||||
|
|
|
@ -391,20 +391,17 @@ class HDCase(Model):
|
||||||
if line.amount < 1:
|
if line.amount < 1:
|
||||||
continue #XXX
|
continue #XXX
|
||||||
prod=line.product_id
|
prod=line.product_id
|
||||||
# 1.find in line
|
print("#1.find in line")
|
||||||
account_id=line.account_id.id
|
account_id=line.account_id.id
|
||||||
if not account_id:
|
if not account_id:
|
||||||
# 2.find in clinic setting
|
print("#2.find in ratchawat setting")
|
||||||
for sline in cst.products:
|
prod_acc=cst.get_product_account
|
||||||
stype=sline.patient_type_id
|
acc=prod_acc(prod.id,obj.patient_type_id.id)
|
||||||
if stype.id==obj.patient_type_id.id and prod.id==sline.product_id.id:
|
account_id=acc.get("ar_credit_id",None)
|
||||||
#account_id=sline.account_id.id
|
print("#3.find account in account setting -> income account")
|
||||||
account_id=sline.ar_credit_id.id
|
|
||||||
break
|
|
||||||
# 3.find account in account setting -> income account
|
|
||||||
if not account_id and not prod:
|
if not account_id and not prod:
|
||||||
account_id=setting.income_account_id.id
|
account_id=setting.income_account_id.id
|
||||||
# 4.find in product(tab accounting)
|
print("#4.find in product(tab accounting)")
|
||||||
if not account_id:
|
if not account_id:
|
||||||
account_id=prod.sale_account_id.id
|
account_id=prod.sale_account_id.id
|
||||||
if not account_id:
|
if not account_id:
|
||||||
|
@ -982,12 +979,15 @@ class HDCase(Model):
|
||||||
if not vals.get('lines'):
|
if not vals.get('lines'):
|
||||||
vals['lines']=[]
|
vals['lines']=[]
|
||||||
for st_prod in st.products:
|
for st_prod in st.products:
|
||||||
if patient.type_id.id==st_prod.patient_type_id.id:
|
ptype=st_prod.patient_type_id
|
||||||
|
prod=st_prod.product_id
|
||||||
|
prod_acc=st.get_product_account(prod.id,ptype.id) # get product account
|
||||||
|
if patient.type_id.id==ptype.id:
|
||||||
price=st_prod.price or 0
|
price=st_prod.price or 0
|
||||||
qty=st_prod.qty or 0
|
qty=st_prod.qty or 0
|
||||||
amt=st_prod.amount
|
amt=st_prod.amount
|
||||||
categ=st_prod.product_categ_id
|
categ=st_prod.product_categ_id
|
||||||
account_id=st_prod.ar_credit_id.id
|
account_id=prod_acc.get("ar_credit_id",None)
|
||||||
if not amt:
|
if not amt:
|
||||||
amt=qty*price
|
amt=qty*price
|
||||||
line_vals={
|
line_vals={
|
||||||
|
@ -1000,7 +1000,6 @@ class HDCase(Model):
|
||||||
'amount': amt,
|
'amount': amt,
|
||||||
'account_id': account_id,
|
'account_id': account_id,
|
||||||
}
|
}
|
||||||
prod=st_prod.product_id
|
|
||||||
if prod:
|
if prod:
|
||||||
line_vals.update({
|
line_vals.update({
|
||||||
'product_id': prod.id,
|
'product_id': prod.id,
|
||||||
|
@ -1008,7 +1007,7 @@ class HDCase(Model):
|
||||||
if not line_vals['account_id']:
|
if not line_vals['account_id']:
|
||||||
line_vals['account_id']=prod.sale_account_id.id
|
line_vals['account_id']=prod.sale_account_id.id
|
||||||
if not line_vals['account_id']:
|
if not line_vals['account_id']:
|
||||||
raise Exception("Please define sale account for product [%s] %s"%(prod.code, prod.name))
|
raise Exception("Please contact accountant: product [%s] %s"%(prod.code, prod.name))
|
||||||
vals['lines'].append(('create',line_vals))
|
vals['lines'].append(('create',line_vals))
|
||||||
# XXX need to get default
|
# XXX need to get default
|
||||||
partner=patient.type_id.contact_id
|
partner=patient.type_id.contact_id
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from netforce.model import Model, fields, get_model
|
from netforce.model import Model, fields, get_model
|
||||||
from netforce.utils import get_file_path, get_data_path
|
from netforce.utils import get_file_path, get_data_path
|
||||||
from netforce.access import get_active_company
|
from netforce.access import get_active_company, get_active_user
|
||||||
from netforce.database import get_connection
|
from netforce.database import get_connection
|
||||||
|
|
||||||
class ClinicSetting(Model):
|
class ClinicSetting(Model):
|
||||||
|
@ -102,6 +102,10 @@ class ClinicSetting(Model):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def run_script(self,ids,context={}):
|
def run_script(self,ids,context={}):
|
||||||
|
user_id=get_active_user
|
||||||
|
if user_id !=1:
|
||||||
|
print("Only admin!!")
|
||||||
|
return
|
||||||
count=1
|
count=1
|
||||||
for hd_case in get_model("clinic.hd.case").search_browse([]):
|
for hd_case in get_model("clinic.hd.case").search_browse([]):
|
||||||
hd_case.write({
|
hd_case.write({
|
||||||
|
@ -132,12 +136,12 @@ class ClinicSetting(Model):
|
||||||
print("to draft payment ", payment.id)
|
print("to draft payment ", payment.id)
|
||||||
print("Done")
|
print("Done")
|
||||||
|
|
||||||
def get_account_prod(self,ptype_id=None,prod_id=None,context={}):
|
def get_product_account(self,prod_id=None,patient_type_id=None,context={}):
|
||||||
res={}
|
res={}
|
||||||
for ac_prod in get_model("clinic.setting.account.product").browse([]):
|
for ac_prod in get_model("clinic.setting.account.product").browse([]):
|
||||||
prod=ac_prod.product_id
|
prod=ac_prod.product_id
|
||||||
ptype=ac_prod.patient_type_id
|
ptype=ac_prod.patient_type_id
|
||||||
if ptype_id==ptype.id and prod_id==prod.id:
|
if patient_type_id==ptype.id and prod_id==prod.id:
|
||||||
res.update({
|
res.update({
|
||||||
'ar_credit_id': ac_prod.ar_credit_id.id,
|
'ar_credit_id': ac_prod.ar_credit_id.id,
|
||||||
'ar_debit_id': ac_prod.ar_debit_id.id,
|
'ar_debit_id': ac_prod.ar_debit_id.id,
|
||||||
|
|
|
@ -11,7 +11,7 @@ class SettingAccountProduct(Model):
|
||||||
"patient_type_id": fields.Many2One("clinic.patient.type","Patient Type"),
|
"patient_type_id": fields.Many2One("clinic.patient.type","Patient Type"),
|
||||||
'categ_id': fields.Many2One("product.categ","Category"),
|
'categ_id': fields.Many2One("product.categ","Category"),
|
||||||
"product_id": fields.Many2One("product","Product"),
|
"product_id": fields.Many2One("product","Product"),
|
||||||
"ar_credit_id": fields.Many2One("account.account","AR Credit",multi_company=True),
|
"ar_credit_id": fields.Many2One("account.account","Income Credit",multi_company=True),
|
||||||
"ar_debit_id": fields.Many2One("account.account","AR Debit",multi_company=True),
|
"ar_debit_id": fields.Many2One("account.account","AR Debit",multi_company=True),
|
||||||
'company_id': fields.Many2One("company","Company"),
|
'company_id': fields.Many2One("company","Company"),
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue