1 # -*- coding: utf-8 -*-
2 ##############################################################################
4 # OpenERP, Open Source Management Solution
5 # Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
7 # This program is free software: you can redistribute it and/or modify
8 # it under the terms of the GNU Affero General Public License as
9 # published by the Free Software Foundation, either version 3 of the
10 # License, or (at your option) any later version.
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU Affero General Public License for more details.
17 # You should have received a copy of the GNU Affero General Public License
18 # along with this program. If not, see <http://www.gnu.org/licenses/>.
20 ##############################################################################
21 from osv import fields, osv
25 class base_setup_installer(osv.osv_memory):
26 _name = 'base.setup.installer'
27 _inherit = 'res.config.installer'
30 ('sale','crm'): ['sale_crm'],
31 ('sale','project'): ['project_mrp'],
35 'crm':fields.boolean('Customer Relationship Management',
36 help="Helps you track and manage relations with customers such as"
37 " leads, requests or issues. Can automatically send "
38 "reminders, escalate requests or trigger business-specific "
39 "actions based on standard events."),
40 'sale':fields.boolean('Sales Management',
41 help="Helps you handle your quotations, sale orders and invoicing"
43 'project':fields.boolean('Project Management',
44 help="Helps you manage your projects and tasks by tracking them, "
45 "generating plannings, etc..."),
46 'knowledge':fields.boolean('Knowledge Management',
47 help="Lets you install addons geared towards sharing knowledge "
48 "with and between your employees."),
49 'stock':fields.boolean('Warehouse Management',
50 help="Helps you manage your inventory and main stock operations: delivery orders, receptions, etc."),
51 'mrp':fields.boolean('Manufacturing',
52 help="Helps you manage your manufacturing processes and generate "
53 "reports on those processes."),
54 'account_voucher':fields.boolean('Invoicing',
55 help="Allows you to create your invoices and track the payments. It is an easier version of the accounting module for managers who are not accountants."),
56 'account_accountant':fields.boolean('Accounting & Finance',
57 help="Helps you handle your accounting needs, if you are not an accountant, we suggest you to install only the Invoicing "),
58 'purchase':fields.boolean('Purchase Management',
59 help="Helps you manage your purchase-related processes such as "
60 "requests for quotations, supplier invoices, etc..."),
61 'hr':fields.boolean('Human Resources',
62 help="Helps you manage your human resources by encoding your employees structure, generating work sheets, tracking attendance and more."),
63 'point_of_sale':fields.boolean('Point of Sales',
64 help="Helps you get the most out of your points of sales with "
65 "fast sale encoding, simplified payment mode encoding, "
66 "automatic picking lists generation and more."),
67 'marketing':fields.boolean('Marketing',
68 help="Helps you manage your marketing campaigns step by step."),
69 'profile_tools':fields.boolean('Extra Tools',
70 help="Lets you install various interesting but non-essential tools "
71 "like Survey, Lunch and Ideas box."),
72 'report_designer':fields.boolean('Advanced Reporting',
73 help="Lets you install various tools to simplify and enhance "
74 "OpenERP's report creation."),
76 'product_expiry':fields.boolean('Food Industry',
77 help="Installs a preselected set of OpenERP applications "
78 "which will help you manage your industry."),
79 'association':fields.boolean('Associations',
80 help="Installs a preselected set of OpenERP "
81 "applications which will help you manage your association "
83 'auction':fields.boolean('Auction Houses',
84 help="Installs a preselected set of OpenERP "
85 "applications selected to help you manage your auctions "
86 "as well as the business processes around them."),
89 def _if_knowledge(self, cr, uid, ids, context=None):
90 if self.pool.get('res.users').browse(cr, uid, uid, context=context)\
92 return ['document_ftp']
95 def _if_misc_tools(self, cr, uid, ids, context=None):
96 return ['profile_tools']
98 def onchange_moduleselection(self, cr, uid, ids, *args, **kargs):
101 closed, total = self.get_current_progress(cr, uid)
102 progress = round(100. * closed / (total + len(filter(None, args))))
103 value.update({'progress':progress})
107 return {'value':value}
110 def execute(self, cr, uid, ids, context=None):
113 module_pool = self.pool.get('ir.module.module')
114 modules_selected = []
115 datas = self.read(cr, uid, ids, context=context)[0]
116 for mod in datas.keys():
117 if mod in ('id', 'progress'):
120 modules_selected.append(mod)
122 module_ids = module_pool.search(cr, uid, [('name', 'in', modules_selected)], context=context)
123 for module in module_pool.browse(cr, uid, module_ids, context=context):
124 if module.state == 'uninstalled':
125 module_pool.state_update(cr, uid, [module.id], 'to install', ['uninstalled'], context)
127 new_db, self.pool = pooler.restart_pool(cr.dbname, update_module=True)
128 elif module.state == 'installed':
129 cr.execute("update ir_actions_todo set state='open' \
130 from ir_model_data as data where data.res_id = ir_actions_todo.id \
131 and ir_actions_todo.type='special'\
132 and data.model = 'ir.actions.todo' and data.module=%s", (module.name, ))
135 base_setup_installer()
137 #Migrate data from another application Conf wiz
139 class migrade_application_installer_modules(osv.osv_memory):
140 _name = 'migrade.application.installer.modules'
141 _inherit = 'res.config.installer'
143 'import_saleforce': fields.boolean('Import Saleforce',
144 help="For Import Saleforce"),
145 'import_sugarcrm': fields.boolean('Import Sugarcrm',
146 help="For Import Sugarcrm"),
147 'sync_google_contact': fields.boolean('Sync Google Contact',
148 help="For Sync Google Contact"),
149 'quickbooks_ippids': fields.boolean('Quickbooks Ippids',
150 help="For Quickbooks Ippids"),
153 migrade_application_installer_modules()
155 class product_installer(osv.osv_memory):
156 _name = 'product.installer'
157 _inherit = 'res.config'
159 'customers': fields.selection([('create','Create'), ('import','Import')], 'Customers', size=32, required=True, help="Import or create customers"),
163 'customers': 'create',
166 def execute(self, cr, uid, ids, context=None):
169 data_obj = self.pool.get('ir.model.data')
170 val = self.browse(cr, uid, ids, context=context)[0]
171 if val.customers == 'create':
172 id2 = data_obj._get_id(cr, uid, 'base', 'view_partner_form')
174 id2 = data_obj.browse(cr, uid, id2, context=context).res_id
178 'res_model': 'res.partner',
179 'views': [(id2, 'form')],
180 'type': 'ir.actions.act_window',
184 if val.customers == 'import':
185 return {'type': 'ir.actions.act_window'}
190 # Define default users preferences config wiz
192 def _lang_get(self, cr, uid, context=None):
193 obj = self.pool.get('res.lang')
194 ids = obj.search(cr, uid, [('translatable','=',True)])
195 res = obj.read(cr, uid, ids, ['code', 'name'], context=context)
196 res = [(r['code'], r['name']) for r in res]
199 def _tz_get(self,cr,uid, context=None):
200 return [(x, x) for x in pytz.all_timezones]
202 class user_preferences_config(osv.osv_memory):
203 _name = 'user.preferences.config'
204 _inherit = 'res.config'
206 'context_tz': fields.selection(_tz_get, 'Timezone', size=64,
207 help="Set default for new user's timezone, used to perform timezone conversions "
208 "between the server and the client."),
209 'context_lang': fields.selection(_lang_get, 'Language', required=True,
210 help="Sets default language for the all user interface, when UI "
211 "translations are available. If you want to Add new Language, you can add it from 'Load an Official Translation' wizard from 'Administration' menu."),
212 'view': fields.selection([('simple','Simplified'),
213 ('extended','Extended')],
214 'Interface', required=True, help= "If you use OpenERP for the first time we strongly advise you to select the simplified interface, which has less features but is easier. You can always switch later from the user preferences." ),
215 'menu_tips': fields.boolean('Display Tips', help="Check out this box if you want to always display tips on each menu action"),
219 'view' : lambda self,cr,uid,*args: self.pool.get('res.users').browse(cr, uid, uid).view or 'simple',
220 'context_lang' : 'en_US',
224 def default_get(self, cr, uid, fields, context=None):
227 res = super(user_preferences_config, self).default_get(cr, uid, fields, context=context)
228 res_default = self.pool.get('ir.values').get(cr, uid, 'default', False, ['res.users'])
229 for id, field, value in res_default:
230 res.update({field: value})
233 def execute(self, cr, uid, ids, context=None):
234 user_obj = self.pool.get('res.users')
235 user_ids = user_obj.search(cr, uid, [], context=context)
236 for o in self.browse(cr, uid, ids, context=context):
237 user_obj.write(cr , uid, user_ids ,{'context_tz' : o.context_tz, 'context_lang' : o.context_lang, 'view' : o.view, 'menu_tips' : o.menu_tips}, context=context)
238 ir_values_obj = self.pool.get('ir.values')
239 ir_values_obj.set(cr, uid, 'default', False, 'context_tz', ['res.users'], o.context_tz)
240 ir_values_obj.set(cr, uid, 'default', False, 'context_lang', ['res.users'], o.context_lang)
241 ir_values_obj.set(cr, uid, 'default', False, 'view', ['res.users'], o.view)
242 ir_values_obj.set(cr, uid, 'default', False, 'menu_tips', ['res.users'], o.menu_tips)
245 user_preferences_config()
247 # Specify Your Terminology
249 class specify_partner_terminology(osv.osv_memory):
250 _name = 'specify.partner.terminology'
251 _inherit = 'res.config'
253 'partner': fields.selection([('Customer','Customer'),
256 ('Patient','Patient'),
257 ('Partner','Partner'),
262 'Choose how to call a customer', required=True ),
265 'partner' :'Partner',
268 def make_translations(self, cr, uid, ids, name, type, src, value, res_id=0, context=None):
269 trans_obj = self.pool.get('ir.translation')
270 user_obj = self.pool.get('res.users')
271 context_lang = user_obj.browse(cr, uid, uid, context=context).context_lang
272 existing_trans_ids = trans_obj.search(cr, uid, [('name','=',name), ('lang','=',context_lang), ('type','=',type), ('src','=',src)])
273 if existing_trans_ids:
274 trans_obj.write(cr, uid, existing_trans_ids, {'value': value}, context=context)
276 create_id = trans_obj.create(cr, uid, {'name': name,'lang': context_lang, 'type': type, 'src': src, 'value': value , 'res_id': res_id}, context=context)
279 def execute(self, cr, uid, ids, context=None):
280 def _case_insensitive_replace(ref_string, src, value):
282 pattern = re.compile(src, re.IGNORECASE)
283 return pattern.sub(value, ref_string)
284 trans_obj = self.pool.get('ir.translation')
285 fields_obj = self.pool.get('ir.model.fields')
286 menu_obj = self.pool.get('ir.ui.menu')
287 act_window_obj = self.pool.get('ir.actions.act_window')
288 for o in self.browse(cr, uid, ids, context=context):
289 #translate label of field
290 field_ids = fields_obj.search(cr, uid, [('field_description','ilike','Customer')])
291 for f_id in fields_obj.browse(cr ,uid, field_ids, context=context):
292 field_ref = f_id.model_id.model + ',' + f_id.name
293 self.make_translations(cr, uid, ids, field_ref, 'field', f_id.field_description, _case_insensitive_replace(f_id.field_description,'Customer',o.partner), context=context)
294 #translate help tooltip of field
295 for obj in self.pool.obj_pool.values():
296 for field_name, field_rec in obj._columns.items():
297 if field_rec.help.lower().count('customer'):
298 field_ref = obj._name + ',' + field_name
299 self.make_translations(cr, uid, ids, field_ref, 'help', field_rec.help, _case_insensitive_replace(field_rec.help,'Customer',o.partner), context=context)
301 menu_ids = menu_obj.search(cr,uid, [('name','ilike','Customer')])
302 for m_id in menu_obj.browse(cr, uid, menu_ids, context=context):
303 menu_name = m_id.name
304 menu_ref = 'ir.ui.menu' + ',' + 'name'
305 self.make_translations(cr, uid, ids, menu_ref, 'model', menu_name, _case_insensitive_replace(menu_name,'Customer',o.partner), res_id=m_id.id, context=context)
306 #translate act window name
307 act_window_ids = act_window_obj.search(cr, uid, [('name','ilike','Customer')])
308 for act_id in act_window_obj.browse(cr ,uid, act_window_ids, context=context):
309 act_ref = 'ir.actions.act_window' + ',' + 'name'
310 self.make_translations(cr, uid, ids, act_ref, 'model', act_id.name, _case_insensitive_replace(act_id.name,'Customer',o.partner), res_id=act_id.id, context=context)
311 #translate act window tooltips
312 act_window_ids = act_window_obj.search(cr, uid, [('help','ilike','Customer')])
313 for act_id in act_window_obj.browse(cr ,uid, act_window_ids, context=context):
314 act_ref = 'ir.actions.act_window' + ',' + 'help'
315 self.make_translations(cr, uid, ids, act_ref, 'model', act_id.help, _case_insensitive_replace(act_id.help,'Customer',o.partner), res_id=act_id.id, context=context)
318 specify_partner_terminology()
320 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: