[IMP]base_setup: Label Name Improved in terminology
[odoo/odoo.git] / addons / base_setup / __init__.py
index 405742d..2dab90b 100644 (file)
@@ -1,6 +1,6 @@
 # -*- coding: utf-8 -*-
 ##############################################################################
-#    
+#
 #    OpenERP, Open Source Management Solution
 #    Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>).
 #
 #    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/>.     
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 #
 ##############################################################################
 
 import installer
-import todo
 import wizard
-
-from osv import osv
+import os
+import base64
+import random
+import tools
+from osv import fields, osv
 import netsvc
+from tools.translate import _
 
 class base_setup_config_choice(osv.osv_memory):
     """
@@ -32,33 +35,44 @@ class base_setup_config_choice(osv.osv_memory):
     _name = 'base.setup.config'
     logger = netsvc.Logger()
 
-    def set_default_menu(self, cr, uid, menu, context=None):
-        users = self.pool.get('res_users')
-        users.write(cr, uid,
-                    users.search(cr, uid,
-                                 [('action_id','=','Setup')],
-                                 context=context),
-                    {'action_id': menu.id},
-                    context=context)
-        users.write(cr, uid,
-                    users.search(cr, uid,
-                                 [('menu_id','=','Setup')],
-                                 context=context),
-                    {'menu_id': menu.id},
-                    context=context)
+    def _get_image(self, cr, uid, context=None):
+        file_no = str(random.randint(1,3))
+        path = os.path.join('base','res','config_pixmaps/%s.png'%file_no)
+        file_data = tools.file_open(path,'rb').read()
+        return base64.encodestring(file_data)
+
+    def get_users(self, cr, uid, context=None):
+        user_obj = self.pool.get('res.users')
+        user_ids = user_obj.search(cr, uid, [])
+        user_list = []
+        user_tmpl_nopass = _('    - %s :\n\t\tLogin : %s')
+        user_tmpl_pass =   _('    - %s :\n\t\tLogin : %s \n\t\tPassword : %s')
+        for user in user_obj.browse(cr, uid, user_ids, context=context):
+            if user.password and not user.password.startswith('$'):
+                user_list.append(user_tmpl_pass % (user.name, user.login, user.password))
+            else:
+                user_list.append(user_tmpl_nopass % (user.name, user.login))
+        return _('The following users have been installed : \n')+ '\n'.join(user_list)
+
+    _columns = {
+        'installed_users':fields.text('Installed Users', readonly=True),
+        'config_logo' : fields.binary('Image', readonly=True),
+        }
 
-    def get_default_menu(self, cr, uid, context=None):
-        actions = self.pool.get('ir.actions.act_window')
+    _defaults = {
+        'installed_users':get_users,
+         'config_logo' : _get_image
+        }
 
-        current_menu_id = actions.search(cr, uid, [('name','=','Menu')],
-                                         context=context)
-        assert len(current_menu_id) == 1,\
-               'A given user should only have menu item'
-        return actions.browse(cr, uid, current_menu_id[0], context=context)
+    def reset_menu(self, cr, uid, context=None):
+        user = self.pool.get('res.users').browse(cr, uid, uid, context=context)
+        menu_id = user._get_menu()
+        user.write({'action_id': False,
+                    'menu_id': menu_id})
+        return self.pool.get('ir.actions.act_window').browse(cr, uid, menu_id, context=context)
 
     def menu(self, cr, uid, ids, context=None):
-        menu = self.get_default_menu(cr, uid, context=context)
-        self.set_default_menu(cr, uid, menu, context=context)
+        menu = self.reset_menu(cr, uid, context=context)
 
         if menu.view_id.id:
             view_id = (menu.view_id.id, menu.view_id.name)
@@ -70,16 +84,15 @@ class base_setup_config_choice(osv.osv_memory):
             'type': menu.type,
             'view_id': view_id,
             'domain': menu.domain,
-            'res_users': menu.res_model,
+            'res_model': menu.res_model,
             'src_model': menu.src_model,
             'view_type': menu.view_type,
             'view_mode': menu.view_mode,
             'views': menu.views,
         }
-    def config(self, cr, uid, ids, context=None):
-        menu = self.get_default_menu(cr, uid, context=context)
-        self.set_default_menu(cr, uid, menu, context=context)
 
+    def config(self, cr, uid, ids, context=None):
+        self.reset_menu(cr, uid, context=context)
         return self.pool.get('res.config').next(cr, uid, [], context=context)
 
 base_setup_config_choice()