2010-01-06 15:24:08 +00:00
# -*- coding: utf-8 -*-
##############################################################################
#
# OpenERP, Open Source Management Solution
# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
##############################################################################
2010-08-13 04:12:51 +00:00
2010-04-30 06:13:14 +00:00
import time
import datetime
from dateutil . relativedelta import relativedelta
2010-06-18 07:23:59 +00:00
from os . path import join as opj
2010-04-30 06:13:14 +00:00
from operator import itemgetter
2010-08-13 04:12:51 +00:00
2010-06-18 07:23:59 +00:00
from tools . translate import _
2010-01-06 15:24:08 +00:00
from osv import fields , osv
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
import netsvc
2010-05-11 09:40:59 +00:00
import tools
2010-01-06 15:24:08 +00:00
class account_installer ( osv . osv_memory ) :
_name = ' account.installer '
_inherit = ' res.config.installer '
2010-05-12 14:07:19 +00:00
def _get_default_accounts ( self , cr , uid , context = None ) :
2010-10-21 09:19:25 +00:00
accounts = [ { ' acc_name ' : ' Current ' , ' account_type ' : ' bank ' } ,
{ ' acc_name ' : ' Deposit ' , ' account_type ' : ' bank ' } ,
{ ' acc_name ' : ' Cash ' , ' account_type ' : ' cash ' } ]
2010-05-12 14:07:19 +00:00
return accounts
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
def _get_charts ( self , cr , uid , context = None ) :
modules = self . pool . get ( ' ir.module.module ' )
2010-10-20 05:13:53 +00:00
ids = modules . search ( cr , uid , [ ( ' category_id ' , ' = ' , ' Account Charts ' ) ] , context = context )
2010-04-30 06:13:14 +00:00
charts = list (
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
sorted ( ( ( m . name , m . shortdesc )
2010-12-13 06:43:09 +00:00
for m in modules . browse ( cr , uid , ids , context = context ) ) ,
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
key = itemgetter ( 1 ) ) )
2010-10-21 09:19:25 +00:00
charts . insert ( 0 , ( ' configurable ' , ' Generic Chart Of Account ' ) )
2010-04-30 06:13:14 +00:00
return charts
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
2010-01-06 15:24:08 +00:00
_columns = {
# Accounting
2010-10-15 09:00:41 +00:00
' charts ' : fields . selection ( _get_charts , ' Chart of Accounts ' ,
2010-09-01 12:26:56 +00:00
required = True ,
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
help = " Installs localized accounting charts to match as closely as "
" possible the accounting needs of your company based on your "
" country. " ) ,
2010-04-30 06:13:14 +00:00
' date_start ' : fields . date ( ' Start Date ' , required = True ) ,
' date_stop ' : fields . date ( ' End Date ' , required = True ) ,
2010-10-20 05:13:53 +00:00
' period ' : fields . selection ( [ ( ' month ' , ' Monthly ' ) , ( ' 3months ' , ' 3 Monthly ' ) ] , ' Periods ' , required = True ) ,
2010-10-18 15:13:12 +00:00
' bank_accounts_id ' : fields . one2many ( ' account.bank.accounts.wizard ' , ' bank_account_id ' , ' Your Bank and Cash Accounts ' ) ,
2010-10-15 09:00:41 +00:00
' sale_tax ' : fields . float ( ' Sale Tax( % ) ' ) ,
' purchase_tax ' : fields . float ( ' Purchase Tax( % ) ' ) ,
2010-12-23 15:16:39 +00:00
' company_id ' : fields . many2one ( ' res.company ' , ' Company ' , required = True ) ,
2010-07-30 13:17:47 +00:00
}
2010-08-20 06:58:03 +00:00
2010-09-23 05:47:31 +00:00
def _default_company ( self , cr , uid , context = None ) :
2010-08-20 06:58:03 +00:00
user = self . pool . get ( ' res.users ' ) . browse ( cr , uid , uid , context = context )
2010-10-21 12:24:24 +00:00
return user . company_id and user . company_id . id or False
2010-08-20 06:58:03 +00:00
2010-09-23 05:47:31 +00:00
def _get_default_charts ( self , cr , uid , context = None ) :
2010-09-14 05:57:48 +00:00
module_name = False
company_id = self . _default_company ( cr , uid , context = context )
2010-10-20 05:13:53 +00:00
company = self . pool . get ( ' res.company ' ) . browse ( cr , uid , company_id , context = context )
2010-09-14 05:57:48 +00:00
address_id = self . pool . get ( ' res.partner ' ) . address_get ( cr , uid , [ company . partner_id . id ] )
if address_id [ ' default ' ] :
2010-10-20 05:13:53 +00:00
address = self . pool . get ( ' res.partner.address ' ) . browse ( cr , uid , address_id [ ' default ' ] , context = context )
2010-09-14 05:57:48 +00:00
code = address . country_id . code
module_name = ( code and ' l10n_ ' + code . lower ( ) ) or False
if module_name :
2010-10-20 05:13:53 +00:00
module_id = self . pool . get ( ' ir.module.module ' ) . search ( cr , uid , [ ( ' name ' , ' = ' , module_name ) ] , context = context )
2010-09-14 05:57:48 +00:00
if module_id :
return module_name
return ' configurable '
2010-01-06 15:24:08 +00:00
_defaults = {
2010-11-04 12:42:42 +00:00
' date_start ' : lambda * a : time . strftime ( ' % Y-01-01 ' ) ,
' date_stop ' : lambda * a : time . strftime ( ' % Y-12-31 ' ) ,
2010-10-18 15:13:12 +00:00
' period ' : ' month ' ,
' sale_tax ' : 0.0 ,
' purchase_tax ' : 0.0 ,
2010-08-20 06:58:03 +00:00
' company_id ' : _default_company ,
2010-09-23 05:47:31 +00:00
' bank_accounts_id ' : _get_default_accounts ,
2010-09-14 05:57:48 +00:00
' charts ' : _get_default_charts
2010-07-30 13:17:47 +00:00
}
2010-12-10 09:40:23 +00:00
def fields_view_get ( self , cr , uid , view_id = None , view_type = ' form ' , context = None , toolbar = False , submenu = False ) :
res = super ( account_installer , self ) . fields_view_get ( cr , uid , view_id = view_id , view_type = view_type , context = context , toolbar = toolbar , submenu = False )
configured_cmp = [ ]
unconfigured_cmp = [ ]
cmp_select = [ ]
company_ids = self . pool . get ( ' res.company ' ) . search ( cr , uid , [ ] , context = context )
2010-12-23 15:16:39 +00:00
#display in the widget selection of companies, only the companies that haven't been configured yet (but don't care about the demo chart of accounts)
cr . execute ( " SELECT company_id FROM account_account WHERE active = ' t ' AND account_account.parent_id IS NULL AND name != %s " , ( " Chart For Automated Tests " , ) )
configured_cmp = [ r [ 0 ] for r in cr . fetchall ( ) ]
2010-12-10 09:40:23 +00:00
unconfigured_cmp = list ( set ( company_ids ) - set ( configured_cmp ) )
if unconfigured_cmp :
2010-12-23 15:16:39 +00:00
cmp_select = [ ( line . id , line . name ) for line in self . pool . get ( ' res.company ' ) . browse ( cr , uid , unconfigured_cmp ) ]
2010-12-10 09:40:23 +00:00
for field in res [ ' fields ' ] :
if field == ' company_id ' :
res [ ' fields ' ] [ field ] [ ' domain ' ] = unconfigured_cmp
res [ ' fields ' ] [ field ] [ ' selection ' ] = cmp_select
return res
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
2010-05-13 11:50:52 +00:00
def on_change_tax ( self , cr , uid , id , tax ) :
2010-10-15 09:00:41 +00:00
return { ' value ' : { ' purchase_tax ' : tax } }
2010-05-13 11:50:52 +00:00
2010-09-23 05:47:31 +00:00
def on_change_start_date ( self , cr , uid , id , start_date = False ) :
2010-04-30 06:13:14 +00:00
if start_date :
start_date = datetime . datetime . strptime ( start_date , " % Y- % m- %d " )
end_date = ( start_date + relativedelta ( months = 12 ) ) - relativedelta ( days = 1 )
2010-10-20 05:13:53 +00:00
return { ' value ' : { ' date_stop ' : end_date . strftime ( ' % Y- % m- %d ' ) } }
2010-04-30 06:13:14 +00:00
return { }
2010-05-11 09:40:59 +00:00
def generate_configurable_chart ( self , cr , uid , ids , context = None ) :
obj_acc = self . pool . get ( ' account.account ' )
obj_acc_tax = self . pool . get ( ' account.tax ' )
obj_journal = self . pool . get ( ' account.journal ' )
2010-10-21 09:19:25 +00:00
obj_acc_tax_code = self . pool . get ( ' account.tax.code ' )
2010-05-11 09:40:59 +00:00
obj_acc_template = self . pool . get ( ' account.account.template ' )
2010-10-20 05:13:53 +00:00
obj_acc_tax_template = self . pool . get ( ' account.tax.code.template ' )
2010-05-11 09:40:59 +00:00
obj_fiscal_position_template = self . pool . get ( ' account.fiscal.position.template ' )
obj_fiscal_position = self . pool . get ( ' account.fiscal.position ' )
2010-09-24 11:03:20 +00:00
analytic_journal_obj = self . pool . get ( ' account.analytic.journal ' )
2010-10-20 05:13:53 +00:00
obj_acc_chart_template = self . pool . get ( ' account.chart.template ' )
2010-10-21 09:19:25 +00:00
obj_acc_journal_view = self . pool . get ( ' account.journal.view ' )
2010-10-20 05:13:53 +00:00
mod_obj = self . pool . get ( ' ir.model.data ' )
obj_sequence = self . pool . get ( ' ir.sequence ' )
2010-10-21 09:19:25 +00:00
property_obj = self . pool . get ( ' ir.property ' )
fields_obj = self . pool . get ( ' ir.model.fields ' )
obj_tax_fp = self . pool . get ( ' account.fiscal.position.tax ' )
obj_ac_fp = self . pool . get ( ' account.fiscal.position.account ' )
2010-10-20 05:13:53 +00:00
2010-10-28 08:35:00 +00:00
result = mod_obj . get_object_reference ( cr , uid , ' account ' , ' configurable_chart_template ' )
id = result and result [ 1 ] or False
2010-10-20 05:13:53 +00:00
obj_multi = obj_acc_chart_template . browse ( cr , uid , id , context = context )
2010-08-13 04:12:51 +00:00
2010-10-08 12:49:22 +00:00
record = self . browse ( cr , uid , ids , context = context ) [ 0 ]
2010-08-13 04:12:51 +00:00
if context is None :
context = { }
2010-10-21 09:19:25 +00:00
company_id = self . browse ( cr , uid , ids , context = context ) [ 0 ] . company_id
2010-05-11 09:40:59 +00:00
seq_journal = True
# Creating Account
obj_acc_root = obj_multi . account_root_id
tax_code_root_id = obj_multi . tax_code_root_id . id
#new code
acc_template_ref = { }
tax_template_ref = { }
tax_code_template_ref = { }
todo_dict = { }
#create all the tax code
2010-10-20 05:13:53 +00:00
children_tax_code_template = obj_acc_tax_template . search ( cr , uid , [ ( ' parent_id ' , ' child_of ' , [ tax_code_root_id ] ) ] , order = ' id ' )
2010-05-11 09:40:59 +00:00
children_tax_code_template . sort ( )
2010-10-21 09:19:25 +00:00
for tax_code_template in obj_acc_tax_template . browse ( cr , uid , children_tax_code_template , context = context ) :
vals = {
2010-05-11 09:40:59 +00:00
' name ' : ( tax_code_root_id == tax_code_template . id ) and company_id . name or tax_code_template . name ,
' code ' : tax_code_template . code ,
' info ' : tax_code_template . info ,
' parent_id ' : tax_code_template . parent_id and ( ( tax_code_template . parent_id . id in tax_code_template_ref ) and tax_code_template_ref [ tax_code_template . parent_id . id ] ) or False ,
' company_id ' : company_id . id ,
' sign ' : tax_code_template . sign ,
}
2010-10-21 09:19:25 +00:00
new_tax_code = obj_acc_tax_code . create ( cr , uid , vals , context = context )
2010-05-11 09:40:59 +00:00
#recording the new tax code to do the mapping
tax_code_template_ref [ tax_code_template . id ] = new_tax_code
#create all the tax
for tax in obj_multi . tax_template_ids :
#create it
vals_tax = {
2010-10-21 09:19:25 +00:00
' name ' : tax . name ,
2010-05-11 09:40:59 +00:00
' sequence ' : tax . sequence ,
2010-10-15 09:00:41 +00:00
' amount ' : tax . amount ,
' type ' : tax . type ,
2010-05-11 09:40:59 +00:00
' applicable_type ' : tax . applicable_type ,
2010-10-15 09:00:41 +00:00
' domain ' : tax . domain ,
2010-05-11 09:40:59 +00:00
' parent_id ' : tax . parent_id and ( ( tax . parent_id . id in tax_template_ref ) and tax_template_ref [ tax . parent_id . id ] ) or False ,
' child_depend ' : tax . child_depend ,
' python_compute ' : tax . python_compute ,
' python_compute_inv ' : tax . python_compute_inv ,
' python_applicable ' : tax . python_applicable ,
' base_code_id ' : tax . base_code_id and ( ( tax . base_code_id . id in tax_code_template_ref ) and tax_code_template_ref [ tax . base_code_id . id ] ) or False ,
' tax_code_id ' : tax . tax_code_id and ( ( tax . tax_code_id . id in tax_code_template_ref ) and tax_code_template_ref [ tax . tax_code_id . id ] ) or False ,
' base_sign ' : tax . base_sign ,
' tax_sign ' : tax . tax_sign ,
' ref_base_code_id ' : tax . ref_base_code_id and ( ( tax . ref_base_code_id . id in tax_code_template_ref ) and tax_code_template_ref [ tax . ref_base_code_id . id ] ) or False ,
' ref_tax_code_id ' : tax . ref_tax_code_id and ( ( tax . ref_tax_code_id . id in tax_code_template_ref ) and tax_code_template_ref [ tax . ref_tax_code_id . id ] ) or False ,
' ref_base_sign ' : tax . ref_base_sign ,
' ref_tax_sign ' : tax . ref_tax_sign ,
' include_base_amount ' : tax . include_base_amount ,
2010-10-21 09:19:25 +00:00
' description ' : tax . description ,
2010-05-11 09:40:59 +00:00
' company_id ' : company_id . id ,
2010-11-16 08:00:18 +00:00
' type_tax_use ' : tax . type_tax_use ,
' price_include ' : tax . price_include
2010-05-11 09:40:59 +00:00
}
2010-10-21 09:19:25 +00:00
new_tax = obj_acc_tax . create ( cr , uid , vals_tax , context = context )
2010-05-11 09:40:59 +00:00
#as the accounts have not been created yet, we have to wait before filling these fields
todo_dict [ new_tax ] = {
' account_collected_id ' : tax . account_collected_id and tax . account_collected_id . id or False ,
' account_paid_id ' : tax . account_paid_id and tax . account_paid_id . id or False ,
}
tax_template_ref [ tax . id ] = new_tax
#deactivate the parent_store functionnality on account_account for rapidity purpose
2010-12-06 15:37:09 +00:00
ctx = context and context . copy ( ) or { }
ctx [ ' defer_parent_store_computation ' ] = True
2010-05-11 09:40:59 +00:00
2010-10-21 09:19:25 +00:00
children_acc_template = obj_acc_template . search ( cr , uid , [ ( ' parent_id ' , ' child_of ' , [ obj_acc_root . id ] ) , ( ' nocreate ' , ' != ' , True ) ] , context = context )
2010-05-11 09:40:59 +00:00
children_acc_template . sort ( )
2010-10-21 09:19:25 +00:00
for account_template in obj_acc_template . browse ( cr , uid , children_acc_template , context = context ) :
2010-05-11 09:40:59 +00:00
tax_ids = [ ]
for tax in account_template . tax_ids :
tax_ids . append ( tax_template_ref [ tax . id ] )
#create the account_account
dig = 6
code_main = account_template . code and len ( account_template . code ) or 0
code_acc = account_template . code or ' '
2010-10-21 09:19:25 +00:00
if code_main > 0 and code_main < = dig and account_template . type != ' view ' :
code_acc = str ( code_acc ) + ( str ( ' 0 ' * ( dig - code_main ) ) )
vals = {
2010-05-11 09:40:59 +00:00
' name ' : ( obj_acc_root . id == account_template . id ) and company_id . name or account_template . name ,
#'sign': account_template.sign,
2010-09-23 06:17:36 +00:00
' currency_id ' : account_template . currency_id and account_template . currency_id . id or False ,
2010-05-11 09:40:59 +00:00
' code ' : code_acc ,
' type ' : account_template . type ,
' user_type ' : account_template . user_type and account_template . user_type . id or False ,
' reconcile ' : account_template . reconcile ,
' shortcut ' : account_template . shortcut ,
' note ' : account_template . note ,
' parent_id ' : account_template . parent_id and ( ( account_template . parent_id . id in acc_template_ref ) and acc_template_ref [ account_template . parent_id . id ] ) or False ,
2010-10-15 09:00:41 +00:00
' tax_ids ' : [ ( 6 , 0 , tax_ids ) ] ,
2010-05-11 09:40:59 +00:00
' company_id ' : company_id . id ,
}
2010-12-06 15:37:09 +00:00
new_account = obj_acc . create ( cr , uid , vals , context = ctx )
2010-05-11 09:40:59 +00:00
acc_template_ref [ account_template . id ] = new_account
if account_template . name == ' Bank Current Account ' :
2010-10-21 09:19:25 +00:00
b_vals = {
2010-09-17 05:46:52 +00:00
' name ' : ' Bank Accounts ' ,
' code ' : ' 110500 ' ,
' type ' : ' view ' ,
' user_type ' : account_template . parent_id . user_type and account_template . user_type . id or False ,
' shortcut ' : account_template . shortcut ,
' note ' : account_template . note ,
' parent_id ' : account_template . parent_id and ( ( account_template . parent_id . id in acc_template_ref ) and acc_template_ref [ account_template . parent_id . id ] ) or False ,
' tax_ids ' : [ ( 6 , 0 , tax_ids ) ] ,
' company_id ' : company_id . id ,
}
2010-12-06 15:37:09 +00:00
bank_account = obj_acc . create ( cr , uid , b_vals , context = ctx )
2010-10-28 08:35:00 +00:00
2010-10-21 09:19:25 +00:00
view_id_cash = obj_acc_journal_view . search ( cr , uid , [ ( ' name ' , ' = ' , ' Bank/Cash Journal View ' ) ] , context = context ) [ 0 ] #why fixed name here?
view_id_cur = obj_acc_journal_view . search ( cr , uid , [ ( ' name ' , ' = ' , ' Bank/Cash Journal (Multi-Currency) View ' ) ] , context = context ) [ 0 ] #Why Fixed name here?
2010-05-11 12:19:50 +00:00
2010-10-28 08:35:00 +00:00
cash_result = mod_obj . get_object_reference ( cr , uid , ' account ' , ' conf_account_type_cash ' )
cash_type_id = cash_result and cash_result [ 1 ] or False
2010-05-11 09:40:59 +00:00
2010-10-28 08:35:00 +00:00
bank_result = mod_obj . get_object_reference ( cr , uid , ' account ' , ' conf_account_type_bnk ' )
bank_type_id = bank_result and bank_result [ 1 ] or False
2010-05-11 09:40:59 +00:00
2010-10-28 08:35:00 +00:00
check_result = mod_obj . get_object_reference ( cr , uid , ' account ' , ' conf_account_type_chk ' )
check_type_id = check_result and check_result [ 1 ] or False
2010-05-11 09:40:59 +00:00
2010-10-08 12:49:22 +00:00
# record = self.browse(cr, uid, ids, context=context)[0]
2010-05-11 09:40:59 +00:00
code_cnt = 1
2010-05-11 12:19:50 +00:00
vals_seq = {
2010-10-21 09:19:25 +00:00
' name ' : _ ( ' Bank Journal ' ) ,
' code ' : ' account.journal ' ,
' prefix ' : ' BNK/ %(year)s / ' ,
2010-11-02 07:31:48 +00:00
' company_id ' : company_id . id ,
2010-10-21 09:19:25 +00:00
' padding ' : 5
}
seq_id = obj_sequence . create ( cr , uid , vals_seq , context = context )
2010-05-11 12:19:50 +00:00
2010-08-16 11:18:33 +00:00
#create the bank journals
2010-10-21 09:19:25 +00:00
analitical_bank_ids = analytic_journal_obj . search ( cr , uid , [ ( ' type ' , ' = ' , ' situation ' ) ] , context = context )
2010-09-24 11:03:20 +00:00
analitical_journal_bank = analitical_bank_ids and analitical_bank_ids [ 0 ] or False
2010-10-21 09:19:25 +00:00
vals_journal = {
' name ' : _ ( ' Bank Journal ' ) ,
' code ' : _ ( ' BNK ' ) ,
' sequence_id ' : seq_id ,
' type ' : ' bank ' ,
2010-11-02 07:31:48 +00:00
' company_id ' : company_id . id ,
2010-10-21 09:19:25 +00:00
' analytic_journal_id ' : analitical_journal_bank
}
2010-05-11 12:19:50 +00:00
if vals . get ( ' currency_id ' , False ) :
2010-10-21 09:19:25 +00:00
vals_journal . update ( {
' view_id ' : view_id_cur ,
' currency ' : vals . get ( ' currency_id ' , False )
} )
2010-05-11 12:19:50 +00:00
else :
2010-10-21 09:19:25 +00:00
vals_journal . update ( { ' view_id ' : view_id_cash } )
vals_journal . update ( {
' default_credit_account_id ' : new_account ,
' default_debit_account_id ' : new_account ,
} )
obj_journal . create ( cr , uid , vals_journal , context = context )
2010-05-11 12:19:50 +00:00
2010-05-11 09:40:59 +00:00
for val in record . bank_accounts_id :
2010-08-16 11:18:33 +00:00
seq_padding = 5
if val . account_type == ' cash ' :
type = cash_type_id
elif val . account_type == ' bank ' :
type = bank_type_id
elif val . account_type == ' check ' :
type = check_type_id
2010-08-20 06:58:03 +00:00
else :
2010-08-16 11:18:33 +00:00
type = check_type_id
seq_padding = None
2010-08-20 06:58:03 +00:00
2010-10-21 09:19:25 +00:00
vals_bnk = {
' name ' : val . acc_name or ' ' ,
2010-05-11 09:40:59 +00:00
' currency_id ' : val . currency_id . id or False ,
2010-09-17 05:46:52 +00:00
' code ' : str ( 110500 + code_cnt ) ,
2010-09-15 05:23:35 +00:00
' type ' : ' liquidity ' ,
2010-05-11 09:40:59 +00:00
' user_type ' : type ,
2010-10-21 09:19:25 +00:00
' parent_id ' : bank_account ,
' company_id ' : company_id . id
}
2010-12-06 15:37:09 +00:00
child_bnk_acc = obj_acc . create ( cr , uid , vals_bnk , context = ctx )
2010-05-11 12:19:50 +00:00
vals_seq_child = {
2010-10-12 13:25:29 +00:00
' name ' : _ ( vals_bnk [ ' name ' ] + ' ' + ' Journal ' ) ,
2010-05-11 12:19:50 +00:00
' code ' : ' account.journal ' ,
2010-10-12 13:25:29 +00:00
' prefix ' : _ ( ( vals_bnk [ ' name ' ] [ : 3 ] . upper ( ) ) + ' / %(year)s / ' ) ,
2010-08-16 11:18:33 +00:00
' padding ' : seq_padding
2010-10-21 09:19:25 +00:00
}
seq_id = obj_sequence . create ( cr , uid , vals_seq_child , context = context )
2010-05-11 12:19:50 +00:00
#create the bank journal
vals_journal = { }
2010-10-21 09:19:25 +00:00
vals_journal = {
2010-10-25 15:23:33 +00:00
' name ' : vals_bnk [ ' name ' ] + _ ( ' Journal ' ) ,
2010-10-21 09:19:25 +00:00
' code ' : _ ( vals_bnk [ ' name ' ] [ : 3 ] ) . upper ( ) ,
' sequence_id ' : seq_id ,
' type ' : ' cash ' ,
2010-11-02 07:31:48 +00:00
' company_id ' : company_id . id
2010-10-21 09:19:25 +00:00
}
2010-05-11 12:19:50 +00:00
if vals . get ( ' currency_id ' , False ) :
2010-10-21 09:19:25 +00:00
vals_journal . update ( {
' view_id ' : view_id_cur ,
' currency ' : vals_bnk . get ( ' currency_id ' , False ) ,
} )
2010-05-11 12:19:50 +00:00
else :
2010-10-21 09:19:25 +00:00
vals_journal . update ( { ' view_id ' : view_id_cash } )
vals_journal . update ( {
' default_credit_account_id ' : child_bnk_acc ,
' default_debit_account_id ' : child_bnk_acc ,
' analytic_journal_id ' : analitical_journal_bank
} )
obj_journal . create ( cr , uid , vals_journal , context = context )
2010-05-11 09:40:59 +00:00
code_cnt + = 1
2010-08-16 11:18:33 +00:00
#reactivate the parent_store functionality on account_account
2010-10-21 09:19:25 +00:00
obj_acc . _parent_store_compute ( cr )
2010-05-11 09:40:59 +00:00
2010-10-21 09:19:25 +00:00
for key , value in todo_dict . items ( ) :
2010-05-11 09:40:59 +00:00
if value [ ' account_collected_id ' ] or value [ ' account_paid_id ' ] :
obj_acc_tax . write ( cr , uid , [ key ] , {
' account_collected_id ' : acc_template_ref [ value [ ' account_collected_id ' ] ] ,
' account_paid_id ' : acc_template_ref [ value [ ' account_paid_id ' ] ] ,
} )
2010-07-23 14:07:26 +00:00
# Creating Journals Sales and Purchase
2010-10-21 09:19:25 +00:00
vals_journal = { }
data_id = mod_obj . search ( cr , uid , [ ( ' model ' , ' = ' , ' account.journal.view ' ) , ( ' name ' , ' = ' , ' account_sp_journal_view ' ) ] , context = context )
data = mod_obj . browse ( cr , uid , data_id [ 0 ] , context = context )
2010-07-23 14:07:26 +00:00
view_id = data . res_id
2010-10-21 09:19:25 +00:00
seq_id = obj_sequence . search ( cr , uid , [ ( ' name ' , ' = ' , ' Account Journal ' ) ] , context = context ) [ 0 ]
2010-05-11 09:40:59 +00:00
if seq_journal :
2010-08-16 11:18:33 +00:00
seq_sale = {
2010-10-21 09:19:25 +00:00
' name ' : ' Sale Journal ' ,
' code ' : ' account.journal ' ,
' prefix ' : ' SAJ/ %(year)s / ' ,
2010-11-02 07:31:48 +00:00
' padding ' : 3 ,
' company_id ' : company_id . id
2010-10-21 09:19:25 +00:00
}
seq_id_sale = obj_sequence . create ( cr , uid , seq_sale , context = context )
2010-08-16 11:18:33 +00:00
seq_purchase = {
2010-10-21 09:19:25 +00:00
' name ' : ' Purchase Journal ' ,
' code ' : ' account.journal ' ,
' prefix ' : ' EXJ/ %(year)s / ' ,
2010-11-02 07:31:48 +00:00
' padding ' : 3 ,
' company_id ' : company_id . id
2010-10-21 09:19:25 +00:00
}
seq_id_purchase = obj_sequence . create ( cr , uid , seq_purchase , context = context )
2010-10-12 13:25:29 +00:00
seq_refund_sale = {
2010-10-21 09:19:25 +00:00
' name ' : ' Sales Refund Journal ' ,
' code ' : ' account.journal ' ,
' prefix ' : ' SCNJ/ %(year)s / ' ,
2010-11-02 07:31:48 +00:00
' padding ' : 3 ,
' company_id ' : company_id . id
2010-10-21 09:19:25 +00:00
}
seq_id_sale_refund = obj_sequence . create ( cr , uid , seq_refund_sale , context = context )
2010-10-12 13:25:29 +00:00
seq_refund_purchase = {
2010-10-21 09:19:25 +00:00
' name ' : ' Purchase Refund Journal ' ,
' code ' : ' account.journal ' ,
' prefix ' : ' ECNJ/ %(year)s / ' ,
2010-11-02 07:31:48 +00:00
' padding ' : 3 ,
' company_id ' : company_id . id
2010-10-21 09:19:25 +00:00
}
seq_id_purchase_refund = obj_sequence . create ( cr , uid , seq_refund_purchase , context = context )
2010-05-11 09:40:59 +00:00
else :
seq_id_sale = seq_id
seq_id_purchase = seq_id
2010-10-12 13:25:29 +00:00
seq_id_sale_refund = seq_id
seq_id_purchase_refund = seq_id
2010-10-13 05:11:12 +00:00
2010-05-11 09:40:59 +00:00
vals_journal [ ' view_id ' ] = view_id
#Sales Journal
2010-10-21 09:19:25 +00:00
analitical_sale_ids = analytic_journal_obj . search ( cr , uid , [ ( ' type ' , ' = ' , ' sale ' ) ] , context = context )
2010-09-24 11:03:20 +00:00
analitical_journal_sale = analitical_sale_ids and analitical_sale_ids [ 0 ] or False
2010-09-23 05:42:09 +00:00
2010-10-22 09:31:57 +00:00
vals_journal . update ( {
2010-10-21 09:19:25 +00:00
' name ' : _ ( ' Sales Journal ' ) ,
' type ' : ' sale ' ,
' code ' : _ ( ' SAJ ' ) ,
' sequence_id ' : seq_id_sale ,
2010-11-02 07:31:48 +00:00
' analytic_journal_id ' : analitical_journal_sale ,
' company_id ' : company_id . id
2010-10-22 09:31:57 +00:00
} )
2010-05-11 09:40:59 +00:00
if obj_multi . property_account_receivable :
2010-10-21 09:19:25 +00:00
vals_journal . update ( {
' default_credit_account_id ' : acc_template_ref [ obj_multi . property_account_income_categ . id ] ,
' default_debit_account_id ' : acc_template_ref [ obj_multi . property_account_income_categ . id ] ,
} )
obj_journal . create ( cr , uid , vals_journal , context = context )
2010-05-11 09:40:59 +00:00
# Purchase Journal
2010-10-21 09:19:25 +00:00
analitical_purchase_ids = analytic_journal_obj . search ( cr , uid , [ ( ' type ' , ' = ' , ' purchase ' ) ] , context = context )
2010-09-24 11:03:20 +00:00
analitical_journal_purchase = analitical_purchase_ids and analitical_purchase_ids [ 0 ] or False
2010-09-23 05:42:09 +00:00
2010-10-22 09:31:57 +00:00
vals_journal . update ( {
2010-10-21 09:19:25 +00:00
' name ' : _ ( ' Purchase Journal ' ) ,
' type ' : ' purchase ' ,
' code ' : _ ( ' EXJ ' ) ,
' sequence_id ' : seq_id_purchase ,
2010-11-02 07:31:48 +00:00
' analytic_journal_id ' : analitical_journal_purchase ,
' company_id ' : company_id . id
2010-10-22 09:31:57 +00:00
} )
2010-05-11 09:40:59 +00:00
if obj_multi . property_account_payable :
2010-10-21 09:19:25 +00:00
vals_journal . update ( {
' default_credit_account_id ' : acc_template_ref [ obj_multi . property_account_expense_categ . id ] ,
' default_debit_account_id ' : acc_template_ref [ obj_multi . property_account_expense_categ . id ]
} )
2010-08-20 06:58:03 +00:00
2010-10-21 09:19:25 +00:00
obj_journal . create ( cr , uid , vals_journal , context = context )
2010-08-16 11:18:33 +00:00
# Creating Journals Sales Refund and Purchase Refund
2010-10-21 09:19:25 +00:00
vals_journal = { }
data_id = mod_obj . search ( cr , uid , [ ( ' model ' , ' = ' , ' account.journal.view ' ) , ( ' name ' , ' = ' , ' account_sp_refund_journal_view ' ) ] , context = context )
data = mod_obj . browse ( cr , uid , data_id [ 0 ] , context = context )
2010-08-16 11:18:33 +00:00
view_id = data . res_id
#Sales Refund Journal
2010-10-21 09:19:25 +00:00
vals_journal = {
' view_id ' : view_id ,
' name ' : _ ( ' Sales Refund Journal ' ) ,
' type ' : ' sale_refund ' ,
' refund_journal ' : True ,
' code ' : _ ( ' SCNJ ' ) ,
' sequence_id ' : seq_id_sale_refund ,
2010-11-02 07:31:48 +00:00
' analytic_journal_id ' : analitical_journal_sale ,
' company_id ' : company_id . id
2010-10-21 09:19:25 +00:00
}
2010-08-16 11:18:33 +00:00
if obj_multi . property_account_receivable :
2010-10-21 09:19:25 +00:00
vals_journal . update ( {
' default_credit_account_id ' : acc_template_ref [ obj_multi . property_account_income_categ . id ] ,
' default_debit_account_id ' : acc_template_ref [ obj_multi . property_account_income_categ . id ]
} )
2010-08-16 11:18:33 +00:00
2010-10-21 09:19:25 +00:00
obj_journal . create ( cr , uid , vals_journal , context = context )
2010-08-16 11:18:33 +00:00
# Purchase Refund Journal
2010-10-21 09:19:25 +00:00
vals_journal = {
2010-10-22 09:31:57 +00:00
' view_id ' : view_id ,
2010-10-21 09:19:25 +00:00
' name ' : _ ( ' Purchase Refund Journal ' ) ,
' type ' : ' purchase_refund ' ,
' refund_journal ' : True ,
' code ' : _ ( ' ECNJ ' ) ,
' sequence_id ' : seq_id_purchase_refund ,
2010-11-02 07:31:48 +00:00
' analytic_journal_id ' : analitical_journal_purchase ,
' company_id ' : company_id . id
2010-10-21 09:19:25 +00:00
}
2010-08-16 11:18:33 +00:00
if obj_multi . property_account_payable :
2010-10-21 09:19:25 +00:00
vals_journal . update ( {
' default_credit_account_id ' : acc_template_ref [ obj_multi . property_account_expense_categ . id ] ,
' default_debit_account_id ' : acc_template_ref [ obj_multi . property_account_expense_categ . id ]
} )
obj_journal . create ( cr , uid , vals_journal , context = context )
2010-08-20 06:58:03 +00:00
2010-05-11 09:40:59 +00:00
# Bank Journals
2010-10-21 09:19:25 +00:00
view_id_cash = obj_acc_journal_view . search ( cr , uid , [ ( ' name ' , ' = ' , ' Bank/Cash Journal View ' ) ] , context = context ) [ 0 ] #TOFIX: Why put fixed name ?
view_id_cur = obj_acc_journal_view . search ( cr , uid , [ ( ' name ' , ' = ' , ' Bank/Cash Journal (Multi-Currency) View ' ) ] , context = context ) [ 0 ] #TOFIX: why put fixed name?
2010-05-11 09:40:59 +00:00
#create the properties
todo_list = [
2010-10-15 09:00:41 +00:00
( ' property_account_receivable ' , ' res.partner ' , ' account.account ' ) ,
( ' property_account_payable ' , ' res.partner ' , ' account.account ' ) ,
( ' property_account_expense_categ ' , ' product.category ' , ' account.account ' ) ,
( ' property_account_income_categ ' , ' product.category ' , ' account.account ' ) ,
( ' property_account_expense ' , ' product.template ' , ' account.account ' ) ,
( ' property_account_income ' , ' product.template ' , ' account.account ' ) ,
( ' property_reserve_and_surplus_account ' , ' res.company ' , ' account.account ' ) ,
2010-05-11 09:40:59 +00:00
]
2010-08-13 14:14:06 +00:00
2010-05-11 09:40:59 +00:00
for record in todo_list :
r = [ ]
2010-10-21 09:19:25 +00:00
r = property_obj . search ( cr , uid , [ ( ' name ' , ' = ' , record [ 0 ] ) , ( ' company_id ' , ' = ' , company_id . id ) ] , context = context )
2010-05-11 09:40:59 +00:00
account = getattr ( obj_multi , record [ 0 ] )
2010-10-21 09:19:25 +00:00
field = fields_obj . search ( cr , uid , [ ( ' name ' , ' = ' , record [ 0 ] ) , ( ' model ' , ' = ' , record [ 1 ] ) , ( ' relation ' , ' = ' , record [ 2 ] ) ] , context = context )
2010-05-11 09:40:59 +00:00
vals = {
' name ' : record [ 0 ] ,
' company_id ' : company_id . id ,
' fields_id ' : field [ 0 ] ,
2010-10-21 09:19:25 +00:00
' value ' : account and ' account.account, ' + str ( acc_template_ref [ account . id ] ) or False ,
2010-05-11 09:40:59 +00:00
}
if r :
#the property exist: modify it
2010-10-21 09:19:25 +00:00
property_obj . write ( cr , uid , r , vals , context = context )
2010-05-11 09:40:59 +00:00
else :
#create the property
2010-10-21 09:19:25 +00:00
property_obj . create ( cr , uid , vals , context = context )
2010-05-11 09:40:59 +00:00
2010-10-21 09:19:25 +00:00
fp_ids = obj_fiscal_position_template . search ( cr , uid , [ ( ' chart_template_id ' , ' = ' , obj_multi . id ) ] , context = context )
2010-05-11 09:40:59 +00:00
if fp_ids :
2010-10-21 09:19:25 +00:00
for position in obj_fiscal_position_template . browse ( cr , uid , fp_ids , context = context ) :
2010-05-11 09:40:59 +00:00
vals_fp = {
2010-10-21 09:19:25 +00:00
' company_id ' : company_id . id ,
' name ' : position . name ,
}
new_fp = obj_fiscal_position . create ( cr , uid , vals_fp , context = context )
2010-05-11 09:40:59 +00:00
for tax in position . tax_ids :
vals_tax = {
2010-10-21 09:19:25 +00:00
' tax_src_id ' : tax_template_ref [ tax . tax_src_id . id ] ,
' tax_dest_id ' : tax . tax_dest_id and tax_template_ref [ tax . tax_dest_id . id ] or False ,
' position_id ' : new_fp ,
}
obj_tax_fp . create ( cr , uid , vals_tax , context = context )
2010-05-11 09:40:59 +00:00
for acc in position . account_ids :
vals_acc = {
2010-10-21 09:19:25 +00:00
' account_src_id ' : acc_template_ref [ acc . account_src_id . id ] ,
' account_dest_id ' : acc_template_ref [ acc . account_dest_id . id ] ,
' position_id ' : new_fp ,
}
obj_ac_fp . create ( cr , uid , vals_acc , context = context )
2010-05-11 09:40:59 +00:00
2010-04-30 06:13:14 +00:00
def execute ( self , cr , uid , ids , context = None ) :
2010-08-13 04:12:51 +00:00
if context is None :
context = { }
2010-09-08 08:03:49 +00:00
fy_obj = self . pool . get ( ' account.fiscalyear ' )
2010-09-22 12:46:46 +00:00
mod_obj = self . pool . get ( ' ir.model.data ' )
2010-08-14 07:30:47 +00:00
obj_acc = self . pool . get ( ' account.account ' )
2010-09-22 12:46:46 +00:00
obj_tax_code = self . pool . get ( ' account.tax.code ' )
obj_temp_tax_code = self . pool . get ( ' account.tax.code.template ' )
2010-10-21 09:19:25 +00:00
obj_tax = self . pool . get ( ' account.tax ' )
obj_product = self . pool . get ( ' product.product ' )
ir_values = self . pool . get ( ' ir.values ' )
2010-04-30 06:13:14 +00:00
super ( account_installer , self ) . execute ( cr , uid , ids , context = context )
2010-05-05 04:53:49 +00:00
record = self . browse ( cr , uid , ids , context = context ) [ 0 ]
2010-09-23 16:20:14 +00:00
company_id = record . company_id
2010-10-21 09:19:25 +00:00
for res in self . read ( cr , uid , ids , context = context ) :
2010-05-11 09:40:59 +00:00
if record . charts == ' configurable ' :
2010-10-21 09:19:25 +00:00
fp = tools . file_open ( opj ( ' account ' , ' configurable_account_chart.xml ' ) )
tools . convert_xml_import ( cr , ' account ' , fp , { } , ' init ' , True , None )
2010-05-11 09:40:59 +00:00
fp . close ( )
self . generate_configurable_chart ( cr , uid , ids , context = context )
2010-10-15 09:00:41 +00:00
s_tax = ( res . get ( ' sale_tax ' , 0.0 ) ) / 100
p_tax = ( res . get ( ' purchase_tax ' , 0.0 ) ) / 100
2010-05-11 11:13:46 +00:00
tax_val = { }
default_tax = [ ]
2010-09-23 05:42:09 +00:00
2010-10-28 08:35:00 +00:00
pur_temp_tax = mod_obj . get_object_reference ( cr , uid , ' account ' , ' tax_code_base_purchases ' )
pur_temp_tax_id = pur_temp_tax and pur_temp_tax [ 1 ] or False
2010-10-21 09:19:25 +00:00
pur_temp_tax_names = obj_temp_tax_code . read ( cr , uid , [ pur_temp_tax_id ] , [ ' name ' ] , context = context )
2010-09-22 12:46:46 +00:00
pur_tax_parent_name = pur_temp_tax_names and pur_temp_tax_names [ 0 ] [ ' name ' ] or False
2010-10-21 09:19:25 +00:00
pur_taxcode_parent_id = obj_tax_code . search ( cr , uid , [ ( ' name ' , ' ilike ' , pur_tax_parent_name ) ] , context = context )
2010-09-22 12:46:46 +00:00
if pur_taxcode_parent_id :
pur_taxcode_parent_id = pur_taxcode_parent_id [ 0 ]
else :
pur_taxcode_parent_id = False
2010-10-28 08:35:00 +00:00
pur_temp_tax_paid = mod_obj . get_object_reference ( cr , uid , ' account ' , ' tax_code_input ' )
pur_temp_tax_paid_id = pur_temp_tax_paid and pur_temp_tax_paid [ 1 ] or False
2010-10-21 09:19:25 +00:00
pur_temp_tax_paid_names = obj_temp_tax_code . read ( cr , uid , [ pur_temp_tax_paid_id ] , [ ' name ' ] , context = context )
2010-09-22 12:46:46 +00:00
pur_tax_paid_parent_name = pur_temp_tax_names and pur_temp_tax_paid_names [ 0 ] [ ' name ' ] or False
2010-10-21 09:19:25 +00:00
pur_taxcode_paid_parent_id = obj_tax_code . search ( cr , uid , [ ( ' name ' , ' ilike ' , pur_tax_paid_parent_name ) ] , context = context )
2010-09-22 12:46:46 +00:00
if pur_taxcode_paid_parent_id :
pur_taxcode_paid_parent_id = pur_taxcode_paid_parent_id [ 0 ]
else :
pur_taxcode_paid_parent_id = False
2010-09-23 05:42:09 +00:00
2010-10-28 08:35:00 +00:00
sale_temp_tax = mod_obj . get_object_reference ( cr , uid , ' account ' , ' tax_code_base_sales ' )
sale_temp_tax_id = sale_temp_tax and sale_temp_tax [ 1 ] or False
2010-10-21 09:19:25 +00:00
sale_temp_tax_names = obj_temp_tax_code . read ( cr , uid , [ sale_temp_tax_id ] , [ ' name ' ] , context = context )
2010-09-22 12:46:46 +00:00
sale_tax_parent_name = sale_temp_tax_names and sale_temp_tax_names [ 0 ] [ ' name ' ] or False
2010-10-21 09:19:25 +00:00
sale_taxcode_parent_id = obj_tax_code . search ( cr , uid , [ ( ' name ' , ' ilike ' , sale_tax_parent_name ) ] , context = context )
2010-09-22 12:46:46 +00:00
if sale_taxcode_parent_id :
sale_taxcode_parent_id = sale_taxcode_parent_id [ 0 ]
else :
sale_taxcode_parent_id = False
2010-09-23 05:42:09 +00:00
2010-10-28 08:35:00 +00:00
sale_temp_tax_paid = mod_obj . get_object_reference ( cr , uid , ' account ' , ' tax_code_output ' )
sale_temp_tax_paid_id = sale_temp_tax_paid and sale_temp_tax_paid [ 1 ] or False
2010-10-21 09:19:25 +00:00
sale_temp_tax_paid_names = obj_temp_tax_code . read ( cr , uid , [ sale_temp_tax_paid_id ] , [ ' name ' ] , context = context )
2010-09-22 12:46:46 +00:00
sale_tax_paid_parent_name = sale_temp_tax_paid_names and sale_temp_tax_paid_names [ 0 ] [ ' name ' ] or False
2010-10-21 09:19:25 +00:00
sale_taxcode_paid_parent_id = obj_tax_code . search ( cr , uid , [ ( ' name ' , ' ilike ' , sale_tax_paid_parent_name ) ] , context = context )
2010-09-22 12:46:46 +00:00
if sale_taxcode_paid_parent_id :
sale_taxcode_paid_parent_id = sale_taxcode_paid_parent_id [ 0 ]
else :
sale_taxcode_paid_parent_id = False
2010-05-13 07:03:39 +00:00
2010-05-11 11:13:46 +00:00
if s_tax * 100 > 0.0 :
2010-10-15 09:00:41 +00:00
tax_account_ids = obj_acc . search ( cr , uid , [ ( ' name ' , ' = ' , ' Tax Received ' ) ] , context = context )
2010-08-31 09:04:01 +00:00
sales_tax_account_id = tax_account_ids and tax_account_ids [ 0 ] or False
2010-05-11 12:19:50 +00:00
vals_tax_code = {
2010-08-14 07:30:47 +00:00
' name ' : ' TAX %s %% ' % ( s_tax * 100 ) ,
' code ' : ' TAX %s %% ' % ( s_tax * 100 ) ,
2010-05-11 12:19:50 +00:00
' company_id ' : company_id . id ,
' sign ' : 1 ,
2010-09-22 12:46:46 +00:00
' parent_id ' : sale_taxcode_parent_id
2010-10-21 09:19:25 +00:00
}
new_tax_code = obj_tax_code . create ( cr , uid , vals_tax_code , context = context )
2010-09-23 05:42:09 +00:00
2010-09-22 12:46:46 +00:00
vals_paid_tax_code = {
2010-09-23 16:01:36 +00:00
' name ' : ' TAX Received %s %% ' % ( s_tax * 100 ) ,
' code ' : ' TAX Received %s %% ' % ( s_tax * 100 ) ,
2010-09-22 12:46:46 +00:00
' company_id ' : company_id . id ,
' sign ' : 1 ,
' parent_id ' : sale_taxcode_paid_parent_id
}
2010-10-21 09:19:25 +00:00
new_paid_tax_code = obj_tax_code . create ( cr , uid , vals_paid_tax_code , context = context )
2010-09-23 05:42:09 +00:00
2010-05-11 11:13:46 +00:00
sales_tax = obj_tax . create ( cr , uid ,
2010-10-21 09:19:25 +00:00
{ ' name ' : ' TAX %s %% ' % ( s_tax * 100 ) ,
' amount ' : s_tax ,
' base_code_id ' : new_tax_code ,
' tax_code_id ' : new_paid_tax_code ,
' type_tax_use ' : ' sale ' ,
' account_collected_id ' : sales_tax_account_id ,
' account_paid_id ' : sales_tax_account_id
} , context = context )
default_account_ids = obj_acc . search ( cr , uid , [ ( ' name ' , ' = ' , ' Product Sales ' ) ] , context = context )
2010-08-31 09:04:01 +00:00
if default_account_ids :
2010-10-21 09:19:25 +00:00
obj_acc . write ( cr , uid , default_account_ids , { ' tax_ids ' : [ ( 6 , 0 , [ sales_tax ] ) ] } , context = context )
2010-10-15 09:00:41 +00:00
tax_val . update ( { ' taxes_id ' : [ ( 6 , 0 , [ sales_tax ] ) ] } )
default_tax . append ( ( ' taxes_id ' , sales_tax ) )
2010-05-11 11:13:46 +00:00
if p_tax * 100 > 0.0 :
2010-10-15 09:00:41 +00:00
tax_account_ids = obj_acc . search ( cr , uid , [ ( ' name ' , ' = ' , ' Tax Paid ' ) ] , context = context )
2010-08-31 09:04:01 +00:00
purchase_tax_account_id = tax_account_ids and tax_account_ids [ 0 ] or False
2010-05-11 12:19:50 +00:00
vals_tax_code = {
2010-08-14 07:30:47 +00:00
' name ' : ' TAX %s %% ' % ( p_tax * 100 ) ,
2010-09-23 05:42:09 +00:00
' code ' : ' TAX %s %% ' % ( p_tax * 100 ) ,
2010-05-11 12:19:50 +00:00
' company_id ' : company_id . id ,
' sign ' : 1 ,
2010-09-22 12:46:46 +00:00
' parent_id ' : pur_taxcode_parent_id
2010-09-08 08:03:49 +00:00
}
2010-10-21 09:19:25 +00:00
new_tax_code = obj_tax_code . create ( cr , uid , vals_tax_code , context = context )
2010-09-22 12:46:46 +00:00
vals_paid_tax_code = {
' name ' : ' TAX Paid %s %% ' % ( p_tax * 100 ) ,
2010-09-22 15:58:40 +00:00
' code ' : ' TAX Paid %s %% ' % ( p_tax * 100 ) ,
2010-09-22 12:46:46 +00:00
' company_id ' : company_id . id ,
' sign ' : 1 ,
' parent_id ' : pur_taxcode_paid_parent_id
}
2010-10-21 09:19:25 +00:00
new_paid_tax_code = obj_tax_code . create ( cr , uid , vals_paid_tax_code , context = context )
2010-09-23 05:42:09 +00:00
2010-05-11 11:13:46 +00:00
purchase_tax = obj_tax . create ( cr , uid ,
2010-10-15 09:00:41 +00:00
{ ' name ' : ' TAX %s %% ' % ( p_tax * 100 ) ,
' description ' : ' TAX %s %% ' % ( p_tax * 100 ) ,
' amount ' : p_tax ,
' base_code_id ' : new_tax_code ,
' tax_code_id ' : new_paid_tax_code ,
' type_tax_use ' : ' purchase ' ,
' account_collected_id ' : purchase_tax_account_id ,
' account_paid_id ' : purchase_tax_account_id
2010-10-21 09:19:25 +00:00
} , context = context )
2010-10-15 09:00:41 +00:00
default_account_ids = obj_acc . search ( cr , uid , [ ( ' name ' , ' = ' , ' Expenses ' ) ] , context = context )
2010-08-31 09:04:01 +00:00
if default_account_ids :
2010-10-21 09:19:25 +00:00
obj_acc . write ( cr , uid , default_account_ids , { ' tax_ids ' : [ ( 6 , 0 , [ purchase_tax ] ) ] } , context = context )
2010-10-15 09:00:41 +00:00
tax_val . update ( { ' supplier_taxes_id ' : [ ( 6 , 0 , [ purchase_tax ] ) ] } )
default_tax . append ( ( ' supplier_taxes_id ' , purchase_tax ) )
2010-10-08 12:49:22 +00:00
if tax_val :
2010-10-21 09:19:25 +00:00
product_ids = obj_product . search ( cr , uid , [ ] , context = context )
for product in obj_product . browse ( cr , uid , product_ids , context = context ) :
obj_product . write ( cr , uid , product . id , tax_val , context = context )
2010-05-11 11:13:46 +00:00
for name , value in default_tax :
2010-10-21 09:19:25 +00:00
ir_values . set ( cr , uid , key = ' default ' , key2 = False , name = name , models = [ ( ' product.product ' , False ) ] , value = [ value ] )
2010-05-05 04:53:49 +00:00
2010-05-03 10:28:01 +00:00
if ' date_start ' in res and ' date_stop ' in res :
2010-10-21 09:19:25 +00:00
f_ids = fy_obj . search ( cr , uid , [ ( ' date_start ' , ' <= ' , res [ ' date_start ' ] ) , ( ' date_stop ' , ' >= ' , res [ ' date_stop ' ] ) , ( ' company_id ' , ' = ' , res [ ' company_id ' ] ) ] , context = context )
2010-09-08 09:32:25 +00:00
if not f_ids :
name = code = res [ ' date_start ' ] [ : 4 ]
if int ( name ) != int ( res [ ' date_stop ' ] [ : 4 ] ) :
name = res [ ' date_start ' ] [ : 4 ] + ' - ' + res [ ' date_stop ' ] [ : 4 ]
code = res [ ' date_start ' ] [ 2 : 4 ] + ' - ' + res [ ' date_stop ' ] [ 2 : 4 ]
2010-10-21 09:19:25 +00:00
vals = {
' name ' : name ,
' code ' : code ,
' date_start ' : res [ ' date_start ' ] ,
' date_stop ' : res [ ' date_stop ' ] ,
' company_id ' : res [ ' company_id ' ]
}
2010-09-08 10:43:18 +00:00
fiscal_id = fy_obj . create ( cr , uid , vals , context = context )
2010-09-08 09:32:25 +00:00
if res [ ' period ' ] == ' month ' :
2010-09-08 10:43:18 +00:00
fy_obj . create_period ( cr , uid , [ fiscal_id ] )
2010-09-08 09:32:25 +00:00
elif res [ ' period ' ] == ' 3months ' :
2010-09-08 10:43:18 +00:00
fy_obj . create_period3 ( cr , uid , [ fiscal_id ] )
2010-08-20 06:58:03 +00:00
2010-04-30 06:13:14 +00:00
[imp] account, base_setup: move chart of accounts selection from base_setup installer to account's
Also remove it from account's config item as it's redundant
Rationale: account can be installed due to dependency chains, not just
direct installation from base_setup: project, stock, purchase and
profile_auction all depend on account, mrp depends on stock which
depends on account, so from base_setup's installer alone there are 5
different ways to end up with account installed and need to configure
charts of accounts.
Therefore having chart of accounts config in base_setup's installer is
dumb (as we need a second one anyway), and since it's (in a way) a
problem of module installation, the most coherent way is to move it to
account/installer.py, and remove it from the config screen where it
was (which becomes redundant).
Made it required, because it was required in the config item, not sure
it's actually mandatory to install a chart of accounts but whatever.
bzr revid: xmo@tinyerp.com-20100126140830-h4c7hlvmzzos69ls
2010-01-26 14:08:30 +00:00
def modules_to_install ( self , cr , uid , ids , context = None ) :
modules = super ( account_installer , self ) . modules_to_install (
cr , uid , ids , context = context )
chart = self . read ( cr , uid , ids , [ ' charts ' ] ,
context = context ) [ 0 ] [ ' charts ' ]
self . logger . notifyChannel (
' installer ' , netsvc . LOG_DEBUG ,
' Installing chart of accounts %s ' % chart )
return modules | set ( [ chart ] )
2010-01-06 15:24:08 +00:00
account_installer ( )
2010-05-05 04:53:49 +00:00
class account_bank_accounts_wizard ( osv . osv_memory ) :
_name = ' account.bank.accounts.wizard '
_columns = {
2010-08-13 04:12:51 +00:00
' acc_name ' : fields . char ( ' Account Name. ' , size = 64 , required = True ) ,
2010-10-18 15:13:12 +00:00
' bank_account_id ' : fields . many2one ( ' account.installer ' , ' Bank Account ' , required = True ) ,
2010-08-27 07:24:46 +00:00
' currency_id ' : fields . many2one ( ' res.currency ' , ' Secondary Currency ' , help = " Forces all moves for this account to have this secondary currency. " ) ,
2010-10-21 09:19:25 +00:00
' account_type ' : fields . selection ( [ ( ' cash ' , ' Cash ' ) , ( ' check ' , ' Check ' ) , ( ' bank ' , ' Bank ' ) ] , ' Account Type ' , size = 32 ) ,
2010-05-05 04:53:49 +00:00
}
account_bank_accounts_wizard ( )
2010-08-13 03:55:27 +00:00
class account_installer_modules ( osv . osv_memory ) :
_name = ' account.installer.modules '
_inherit = ' res.config.installer '
_columns = {
2010-10-15 09:00:41 +00:00
' account_analytic_plans ' : fields . boolean ( ' Multiple Analytic Plans ' ,
2010-08-13 03:55:27 +00:00
help = " Allows invoice lines to impact multiple analytic accounts "
" simultaneously. " ) ,
2010-10-15 09:00:41 +00:00
' account_payment ' : fields . boolean ( ' Suppliers Payment Management ' ,
2010-08-13 03:55:27 +00:00
help = " Streamlines invoice payment and creates hooks to plug "
" automated payment systems in. " ) ,
2010-10-15 09:00:41 +00:00
' account_followup ' : fields . boolean ( ' Followups Management ' ,
2010-08-13 03:55:27 +00:00
help = " Helps you generate reminder letters for unpaid invoices, "
" including multiple levels of reminding and customized "
" per-partner policies. " ) ,
2010-10-15 09:00:41 +00:00
' account_voucher ' : fields . boolean ( ' Voucher Management ' ,
2010-08-13 03:55:27 +00:00
help = " Account Voucher module includes all the basic requirements of "
2010-09-01 12:26:56 +00:00
" Voucher Entries for Bank, Cash, Sales, Purchase, Expenses, Contra, etc... " ) ,
' account_anglo_saxon ' : fields . boolean ( ' Anglo-Saxon Accounting ' ,
help = " This module will support the Anglo-Saxons accounting methodology by "
" changing the accounting logic with stock transactions. " ) ,
2010-09-23 05:47:31 +00:00
}
2010-08-13 03:55:27 +00:00
2010-09-06 05:54:26 +00:00
_defaults = {
' account_voucher ' : True ,
2010-09-23 05:47:31 +00:00
}
2010-08-13 03:55:27 +00:00
account_installer_modules ( )
2010-11-04 12:08:52 +00:00
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: