[IMP] Change aseet type view, Sale wizard calculation and screenshot

This commit is contained in:
Haresh Chavda 2018-07-28 12:56:48 +05:30
parent 9f0bc3ca6d
commit 57de0cd91d
5 changed files with 93 additions and 65 deletions

View File

@ -64,6 +64,7 @@
vals = { vals = {
'journal_id': journal_id, 'journal_id': journal_id,
'name': 'Electronics', 'name': 'Electronics',
'method_period': 12,
'method_number': 6, 'method_number': 6,
'account_asset_id': xfa_account_id, 'account_asset_id': xfa_account_id,
'account_depreciation_id': xfa_account_id, 'account_depreciation_id': xfa_account_id,

View File

@ -153,12 +153,11 @@ class AccountAssetAsset(models.Model):
date = datetime.strptime(date, DF).date() date = datetime.strptime(date, DF).date()
else: else:
date = datetime.now() date = datetime.now()
if date.month <= 3 and date.day < 31: year = date.year
year = date.year fiscal_date = date.replace(month=last_month, day=last_day, year=year)
else: if fiscal_date < date:
year = date.year + 1 fiscal_date = date.replace(month=last_month, day=last_day, year=year + 1)
date = date.replace(month=last_month, day=last_day, year=year) return datetime.strftime(fiscal_date, '%Y-%m-%d')
return datetime.strftime(date, '%Y-%m-%d')
@api.multi @api.multi
def count_invoice(self): def count_invoice(self):
@ -250,7 +249,6 @@ class AccountAssetAsset(models.Model):
fiscal_date = datetime.strptime(self.date or fields.Datetime.today(), '%Y-%m-%d') fiscal_date = datetime.strptime(self.date or fields.Datetime.today(), '%Y-%m-%d')
days = (self.company_id.compute_fiscalyear_dates(depreciation_date)['date_to'] - fiscal_date.date()).days days = (self.company_id.compute_fiscalyear_dates(depreciation_date)['date_to'] - fiscal_date.date()).days
amount = (amount_to_depr / self.method_number) / total_days * days amount = (amount_to_depr / self.method_number) / total_days * days
elif self.method == 'degressive': elif self.method == 'degressive':
amount = residual_amount * self.method_progress_factor amount = residual_amount * self.method_progress_factor
if self.prorata == 'purchase_date': if self.prorata == 'purchase_date':

Binary file not shown.

Before

Width:  |  Height:  |  Size: 101 KiB

After

Width:  |  Height:  |  Size: 106 KiB

View File

@ -10,57 +10,68 @@
<field name="model">account.asset.category</field> <field name="model">account.asset.category</field>
<field name="arch" type="xml"> <field name="arch" type="xml">
<form string="Asset category"> <form string="Asset category">
<group> <sheet>
<div class="oe_title">
<label for="name" string="Asset Type" class="oe_edit_only" attrs="{'invisible': [('type','!=','purchase')]}"/>
<label for="name" string="Deferred Revenue Type" class="oe_edit_only" attrs="{'invisible': [('type','==','purchase')]}"/>
<h1>
<field name="name" placeholder="e.g. Computers"/>
</h1>
</div>
<group> <group>
<field name="type" invisible="1"/> <div class="oe_title">
<field name="company_id" options="{'no_create': True}" groups="base.group_multi_company"/> <label for="name" string="Asset Type" class="oe_edit_only" attrs="{'invisible': [('type','!=','purchase')]}"/>
</group> <label for="name" string="Deferred Revenue Type" class="oe_edit_only" attrs="{'invisible': [('type','==','purchase')]}"/>
<group string="Journal Entries"> <h1>
<field name="journal_id"/> <field name="name" placeholder="e.g. Computers"/>
<div> </h1>
<label for="account_asset_id" attrs="{'invisible': [('type','!=','purchase')]}"/>
<label for="account_asset_id" string="Deferred Revenue Account" attrs="{'invisible': [('type','!=','sale')]}"/>
</div> </div>
<field name="account_asset_id" nolabel="1" attrs="{'invisible': [('type','=', False)]}"/> <group>
<div> <field name="type" invisible="1"/>
<label for="account_depreciation_id" attrs="{'invisible': [('type','!=','purchase')]}"/> <field name="company_id" options="{'no_create': True}" groups="base.group_multi_company"/>
<label for="account_depreciation_id" string="Recognition Income Account" attrs="{'invisible': [('type','!=','sale')]}"/> </group>
</div> <group string="Journal Entries">
<field name="account_depreciation_id" nolabel="1"/> <div>
<div> <label for="journal_id" style="font-weight: bold;" string="Journal"/>
<label for="account_depreciation_expense_id" attrs="{'invisible': [('type','!=','purchase')]}"/> </div>
<label for="account_depreciation_expense_id" string="Recognition Account" attrs="{'invisible': [('type','!=','sale')]}"/> <field name="journal_id" nolabel="1"/>
</div> <div>
<field name="account_depreciation_expense_id" nolabel="1"/> <label for="account_asset_id" style="font-weight: bold;" attrs="{'invisible': [('type','!=','purchase')]}"/>
<field name="account_analytic_id" groups="analytic.group_analytic_accounting"/> <label for="account_asset_id" style="font-weight: bold;" string="Deferred Revenue Account" attrs="{'invisible': [('type','!=','sale')]}"/>
</div>
<field name="account_asset_id" nolabel="1" attrs="{'invisible': [('type','=', False)]}"/>
<div>
<label for="account_depreciation_id" style="font-weight: bold;" attrs="{'invisible': [('type','!=','purchase')]}"/>
<label for="account_depreciation_id" style="font-weight: bold;" string="Recognition Income Account" attrs="{'invisible': [('type','!=','sale')]}"/>
</div>
<field name="account_depreciation_id" nolabel="1"/>
<div>
<label for="account_depreciation_expense_id" style="font-weight: bold;" attrs="{'invisible': [('type','!=','purchase')]}"/>
<label for="account_depreciation_expense_id" style="font-weight: bold;" string="Recognition Account" attrs="{'invisible': [('type','!=','sale')]}"/>
</div>
<field name="account_depreciation_expense_id" nolabel="1"/>
<field name="account_analytic_id" groups="analytic.group_analytic_accounting"/>
</group>
</group> </group>
<group string="Periodicity"> <notebook>
<field name="method_time" string="Time Method Based On" widget="radio" attrs="{'invisible': [('type','!=','purchase')]}"/> <page string="Other Information">
<field name="method_number" attrs="{'invisible':['|',('method_time','!=','number'),'&amp;',('type','=', False)], 'required':[('method_time','=','number')]}"/> <group>
<label for="method_period" string="One Entry Every" attrs="{'invisible': [('prorata','=','fiscal_year')]}"/> <group string="Periodicity">
<div attrs="{'invisible': [('prorata','=','fiscal_year')]}"> <field name="method_time" string="Time Method Based On" widget="radio" attrs="{'invisible': [('type','!=','purchase')]}"/>
<field name="method_period" nolabel="1" attrs="{'invisible': [('type','=', False)]}" class="oe_inline"/> <field name="method_number" attrs="{'invisible':['|',('method_time','!=','number'),'&amp;',('type','=', False)], 'required':[('method_time','=','number')]}"/>
months <label for="method_period" string="One Entry Every" attrs="{'invisible': [('prorata','=','fiscal_year')]}"/>
</div> <div attrs="{'invisible': [('prorata','=','fiscal_year')]}">
<field name="method_end" attrs="{'required': [('method_time','=','end')], 'invisible':[('method_time','!=','end')]}"/> <field name="method_period" nolabel="1" attrs="{'invisible': [('type','=', False)]}" class="oe_inline"/>
</group> months
<group string="Additional Options"> </div>
<field name="open_asset"/> <field name="method_end" attrs="{'required': [('method_time','=','end')], 'invisible':[('method_time','!=','end')]}"/>
<field name="group_entries"/> </group>
</group> <group attrs="{'invisible': [('type','=','sale')]}" string="Depreciation Method">
<group attrs="{'invisible': [('type','=','sale')]}" string="Depreciation Method"> <field name="method" widget="radio"/>
<field name="method" widget="radio"/> <field name="method_progress_factor" attrs="{'invisible':[('method','=','linear')], 'required':[('method','=','degressive')]}"/>
<field name="method_progress_factor" attrs="{'invisible':[('method','=','linear')], 'required':[('method','=','degressive')]}"/> <field name="prorata" attrs="{'invisible': [('method_time','=','end')]}"/>
<field name="prorata" attrs="{'invisible': [('method_time','=','end')]}"/> </group>
</group> <group string="Additional Options">
</group> <field name="open_asset"/>
<field name="group_entries"/>
</group>
</group>
</page>
</notebook>
</sheet>
</form> </form>
</field> </field>
</record> </record>

View File

@ -22,6 +22,16 @@ class SaleAssetWizard(models.TransientModel):
string="Date", default=lambda self: datetime.today(), string="Date", default=lambda self: datetime.today(),
required=True) required=True)
@api.onchange('product_id')
def onchange_product_id(self):
date = False
for line in self.asset_id.depreciation_line_ids:
if line.move_check:
date = line.depreciation_date
if not date:
date = self.asset_id.depreciation_line_ids and self.asset_id.depreciation_line_ids[0].depreciation_date or self.asset_id.date
self.sale_date = date
@api.onchange('sale_date') @api.onchange('sale_date')
def onchange_sale_date(self): def onchange_sale_date(self):
if self.sale_date: if self.sale_date:
@ -32,17 +42,16 @@ class SaleAssetWizard(models.TransientModel):
amount += line.amount amount += line.amount
last_date = line.depreciation_date last_date = line.depreciation_date
else: else:
if not last_date and line.sequence != 1: if not last_date:
last_date = line.depreciation_date last_date = line.depreciation_date
days, total_days = \ if line.sequence == 1:
self.get_days(last_date, self.sale_date) last_date = self.asset_id.date
else: days, total_days = \
days, total_days = \ self.get_days(last_date, self.sale_date)
self.get_days(self.asset_id.date, self.sale_date)
amount += (line.amount * days) / total_days amount += (line.amount * days) / total_days
break break
self.depreciated_amount = amount self.depreciated_amount = amount
self.sale_value = self.asset_id.value_residual - amount self.sale_value = self.asset_id.value - amount
@api.constrains('sale_date') @api.constrains('sale_date')
def _check_sale_date(self): def _check_sale_date(self):
@ -58,6 +67,9 @@ class SaleAssetWizard(models.TransientModel):
if self.sale_date < str(last_depreciation_date): if self.sale_date < str(last_depreciation_date):
raise ValueError(_("Sale date must be greater than last " raise ValueError(_("Sale date must be greater than last "
"Depreciated date!")) "Depreciated date!"))
if self.sale_date < self.asset_id.date:
raise ValueError(_("Sale date must be greater than "
"Date of Asset!"))
@api.multi @api.multi
def get_days(self, last_date, sale_date): def get_days(self, last_date, sale_date):
@ -66,6 +78,12 @@ class SaleAssetWizard(models.TransientModel):
delta = sale_date - last_depreciation_date delta = sale_date - last_depreciation_date
year = last_depreciation_date.year year = last_depreciation_date.year
total_days = (year % 4) and 365 or 366 total_days = (year % 4) and 365 or 366
if self.asset_id.depreciation_line_ids and self.asset_id.depreciation_line_ids[0].depreciation_date > str(sale_date):
depreciation_date = datetime.strptime(self.asset_id.depreciation_line_ids[0].depreciation_date, DF).date()
asset_date = datetime.strptime(self.asset_id.date, DF).date()
delta_day = depreciation_date - asset_date
total_days = delta_day.days
delta = sale_date - asset_date
return delta.days, total_days return delta.days, total_days
@api.multi @api.multi
@ -80,9 +98,9 @@ class SaleAssetWizard(models.TransientModel):
last_line = line last_line = line
else: else:
last_line = line last_line = line
if not last_date and line.sequence != 1: if not last_date:
last_date = line.depreciation_date last_date = line.depreciation_date
else: if line.sequence == 1:
last_date = self.asset_id.date last_date = self.asset_id.date
break break
days, total_days = self.get_days(last_date, sale_date) days, total_days = self.get_days(last_date, sale_date)
@ -96,7 +114,7 @@ class SaleAssetWizard(models.TransientModel):
'sale_date': self.sale_date, 'sale_date': self.sale_date,
}) })
last_line, amount = self.last_line_info() last_line, amount = self.last_line_info()
if last_line: if last_line and amount:
depreciated_value = \ depreciated_value = \
(last_line.depreciated_value - last_line.amount) + amount (last_line.depreciated_value - last_line.amount) + amount
last_line.update({ last_line.update({