[MOD] lunch : Usability Improvements
[odoo/odoo.git] / addons / base_setup / installer.py
1 # -*- coding: utf-8 -*-
2 ##############################################################################
3 #
4 #    OpenERP, Open Source Management Solution
5 #    Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
6 #
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.
11 #
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.
16 #
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/>.
19 #
20 ##############################################################################
21 from osv import fields, osv
22 import netsvc
23
24 class base_setup_installer(osv.osv_memory):
25     _name = 'base.setup.installer'
26     _inherit = 'res.config.installer'
27
28     _install_if = {
29         ('sale','crm'): ['sale_crm'],
30         ('sale','project'): ['project_mrp'],
31         ('sale',):['account_accountant']
32         }
33     _columns = {
34         # Generic modules
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"
42                  "."),
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 stocks and stocks locations, as well "
51                  "as the flow of stock between warehouses."),
52         'mrp':fields.boolean('Manufacturing',
53             help="Helps you manage your manufacturing processes and generate "
54                  "reports on those processes."),
55         'account':fields.boolean('Financial & Accounting',
56             help="Helps you handle your accounting needs, as well as create "
57                  "and track your budgets."),
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 "
63                  "employee structure, generating work sheets, tracking "
64                  "attendance and more."),
65         'point_of_sale':fields.boolean('Point of Sales',
66             help="Helps you get the most out of your points of sales with "
67                  "fast sale encoding, simplified payment mode encoding, "
68                  "automatic picking lists generation and more."),
69         'marketing':fields.boolean('Marketing',
70             help="Helps you manage your marketing campaigns step by step."),
71         'misc_tools':fields.boolean('Miscellaneous Tools',
72             help="Lets you install various interesting but non-essential "
73                  "tools like Survey, Lunch,..."),
74         'report_designer':fields.boolean('Advanced Reporting',
75             help="Lets you install various tools to simplify and enhance "
76                  "OpenERP's report creation."),
77         'thunderbird' :fields.boolean('Thunderbird'),
78         # Vertical modules
79         'product_expiry':fields.boolean('Food Industry',
80             help="Installs a preselected set of OpenERP "
81                  "applications which will help you manage foods."),
82         'association':fields.boolean('Associations',
83             help="Installs a preselected set of OpenERP "
84                  "applications which will help you manage your association "
85                  "more efficiently."),
86         'auction':fields.boolean('Auction Houses',
87             help="Installs a preselected set of OpenERP "
88                  "applications selected to help you manage your auctions "
89                  "as well as the business processes around them."),
90         }
91     _defaults = {
92         'crm': True,
93         }
94
95     def _if_mrp(self, cr, uid, ids, context=None):
96         if self.pool.get('res.users').browse(cr, uid, uid, context=context)\
97                .view == 'simple':
98             return ['mrp_jit']
99         return None
100
101     def _if_knowledge(self, cr, uid, ids, context=None):
102         if self.pool.get('res.users').browse(cr, uid, uid, context=context)\
103                .view == 'simple':
104             return ['document_ftp']
105         return None
106
107     def _if_misc_tools(self, cr, uid, ids, context=None):
108         interface = self.pool.get('res.users').browse(cr, uid, uid, context=context).view
109         if interface == 'simple' or interface =='extended' :
110             return ['profile_tools']
111         return None
112
113     def _if_account(self, cr, uid, ids, context=None):
114         if self.pool.get('res.users').browse(cr, uid, uid, context=context)\
115                .view == 'simple':
116             return ['account_voucher']
117         return None
118
119     def onchange_moduleselection(self, cr, uid, ids, *args):
120         closed, total = self.get_current_progress(cr, uid)
121
122         progress = round(100. * closed / (total + len(filter(None, args))))
123         if progress < 10.:
124             progress = 10.
125         return {'value':{'progress':progress}}
126 base_setup_installer()