2013-02-22 11:44:21 +00:00
|
|
|
from openerp.osv import osv
|
|
|
|
|
2013-03-11 11:04:23 +00:00
|
|
|
|
2013-02-22 11:44:21 +00:00
|
|
|
class res_users_gamification_group(osv.Model):
|
|
|
|
""" Update of res.users class
|
2013-03-21 11:01:52 +00:00
|
|
|
- if adding groups to an user, check gamification.goal.plan linked to
|
2013-02-22 11:44:21 +00:00
|
|
|
this group, and the user. This is done by overriding the write method.
|
|
|
|
"""
|
|
|
|
_name = 'res.users'
|
|
|
|
_inherit = ['res.users']
|
|
|
|
|
|
|
|
def write(self, cr, uid, ids, vals, context=None):
|
|
|
|
write_res = super(res_users_gamification_group, self).write(cr, uid, ids, vals, context=context)
|
|
|
|
if vals.get('groups_id'):
|
|
|
|
# form: {'group_ids': [(3, 10), (3, 3), (4, 10), (4, 3)]} or {'group_ids': [(6, 0, [ids]}
|
|
|
|
user_group_ids = [command[1] for command in vals['groups_id'] if command[0] == 4]
|
|
|
|
user_group_ids += [id for command in vals['groups_id'] if command[0] == 6 for id in command[2]]
|
|
|
|
|
|
|
|
goal_plan_obj = self.pool.get('gamification.goal.plan')
|
|
|
|
plan_ids = goal_plan_obj.search(cr, uid, [('autojoin_group_id', 'in', user_group_ids)], context=context)
|
2013-04-23 10:15:12 +00:00
|
|
|
if plan_ids:
|
|
|
|
goal_plan_obj.write(cr, uid, plan_ids, {'user_ids': [(4, user_id) for user_id in ids]}, context=context)
|
2013-03-29 15:45:35 +00:00
|
|
|
|
|
|
|
if vals.get('image'):
|
|
|
|
self.pool.get('gamification.goal').changed_users_avatar(cr, uid, ids, context)
|
2013-02-22 11:44:21 +00:00
|
|
|
return write_res
|
|
|
|
|
2013-03-21 11:01:52 +00:00
|
|
|
def get_goals_todo_info(self, cr, uid, context=None):
|
|
|
|
"""Return the list of goals assigned to the user, grouped by plan"""
|
2013-03-25 15:39:53 +00:00
|
|
|
all_goals_info = []
|
2013-03-21 11:01:52 +00:00
|
|
|
plan_obj = self.pool.get('gamification.goal.plan')
|
2013-03-25 15:39:53 +00:00
|
|
|
|
2013-04-18 10:32:29 +00:00
|
|
|
plan_ids = plan_obj.search(cr, uid, [('user_ids', 'in', uid), ('state', '=', 'inprogress')], context=context)
|
2013-03-21 11:01:52 +00:00
|
|
|
for plan in plan_obj.browse(cr, uid, plan_ids, context=context):
|
2013-03-25 15:39:53 +00:00
|
|
|
# serialize goals info to be able to use it in javascript
|
|
|
|
serialized_goals_info = {
|
2013-03-27 11:16:36 +00:00
|
|
|
'id': plan.id,
|
2013-03-25 15:39:53 +00:00
|
|
|
'name': plan.name,
|
2013-03-26 15:45:53 +00:00
|
|
|
'visibility_mode': plan.visibility_mode,
|
2013-03-25 15:39:53 +00:00
|
|
|
}
|
2013-03-26 15:45:53 +00:00
|
|
|
user = self.browse(cr, uid, uid, context=context)
|
|
|
|
serialized_goals_info['currency'] = user.company_id.currency_id.id
|
2013-03-25 15:39:53 +00:00
|
|
|
|
|
|
|
if plan.visibility_mode == 'board':
|
|
|
|
# board report should be grouped by planline for all users
|
|
|
|
goals_info = plan_obj.get_board_goal_info(cr, uid, plan, subset_goal_ids=False, context=context)
|
2013-03-21 11:01:52 +00:00
|
|
|
|
2013-04-08 14:11:32 +00:00
|
|
|
if len(goals_info) == 0:
|
|
|
|
# plan with no valid planlines
|
2013-03-22 08:51:51 +00:00
|
|
|
continue
|
|
|
|
|
2013-03-25 15:39:53 +00:00
|
|
|
serialized_goals_info['planlines'] = []
|
|
|
|
for planline_board in goals_info:
|
|
|
|
vals = {'type_name': planline_board['goal_type'].name,
|
|
|
|
'type_description': planline_board['goal_type'].description,
|
|
|
|
'type_condition': planline_board['goal_type'].condition,
|
2013-03-26 15:45:53 +00:00
|
|
|
'type_computation_mode': planline_board['goal_type'].computation_mode,
|
|
|
|
'type_monetary': planline_board['goal_type'].monetary,
|
2013-06-03 20:30:53 +00:00
|
|
|
'type_suffix': planline_board['goal_type'].suffix,
|
2013-04-08 13:17:29 +00:00
|
|
|
'type_action': True if planline_board['goal_type'].action_id else False,
|
2013-04-16 10:27:24 +00:00
|
|
|
'type_display': planline_board['goal_type'].display_mode,
|
2013-04-12 15:21:50 +00:00
|
|
|
'target_goal': planline_board['target_goal'],
|
2013-03-25 15:39:53 +00:00
|
|
|
'goals': []}
|
|
|
|
for goal in planline_board['board_goals']:
|
2013-04-18 16:05:12 +00:00
|
|
|
# Keep only the Top 3 and the current user
|
|
|
|
if goal[0] > 2 and goal[1].user_id.id != uid:
|
|
|
|
continue
|
|
|
|
|
2013-03-25 15:39:53 +00:00
|
|
|
vals['goals'].append({
|
|
|
|
'rank': goal[0]+1,
|
|
|
|
'id': goal[1].id,
|
2013-04-18 16:05:12 +00:00
|
|
|
'user_id': goal[1].user_id.id,
|
2013-03-25 15:39:53 +00:00
|
|
|
'user_name': goal[1].user_id.name,
|
|
|
|
'state': goal[1].state,
|
|
|
|
'completeness': goal[1].completeness,
|
|
|
|
'current': goal[1].current,
|
|
|
|
'target_goal': goal[1].target_goal,
|
|
|
|
})
|
2013-03-27 11:16:36 +00:00
|
|
|
if uid == goal[1].user_id.id:
|
|
|
|
vals['own_goal_id'] = goal[1].id
|
2013-03-25 15:39:53 +00:00
|
|
|
serialized_goals_info['planlines'].append(vals)
|
|
|
|
|
|
|
|
else:
|
|
|
|
# individual report are simply a list of goal
|
|
|
|
goals_info = plan_obj.get_indivual_goal_info(cr, uid, uid, plan, subset_goal_ids=False, context=context)
|
|
|
|
|
|
|
|
if not goals_info:
|
|
|
|
continue
|
|
|
|
|
|
|
|
serialized_goals_info['goals'] = []
|
|
|
|
for goal in goals_info['goals']:
|
|
|
|
serialized_goals_info['goals'].append({
|
|
|
|
'id': goal.id,
|
|
|
|
'type_name': goal.type_id.name,
|
|
|
|
'type_description': goal.type_description,
|
2013-03-26 15:45:53 +00:00
|
|
|
'type_condition': goal.type_id.condition,
|
|
|
|
'type_monetary': goal.type_id.monetary,
|
2013-06-03 20:30:53 +00:00
|
|
|
'type_suffix': goal.type_id.suffix,
|
2013-04-08 13:17:29 +00:00
|
|
|
'type_action': True if goal.type_id.action_id else False,
|
2013-04-16 10:27:24 +00:00
|
|
|
'type_display': goal.type_id.display_mode,
|
2013-03-25 15:39:53 +00:00
|
|
|
'state': goal.state,
|
|
|
|
'completeness': goal.completeness,
|
|
|
|
'computation_mode': goal.computation_mode,
|
|
|
|
'current': goal.current,
|
|
|
|
'target_goal': goal.target_goal,
|
|
|
|
})
|
|
|
|
|
|
|
|
all_goals_info.append(serialized_goals_info)
|
|
|
|
return all_goals_info
|
2013-03-21 11:01:52 +00:00
|
|
|
|
2013-04-18 10:32:29 +00:00
|
|
|
def get_challenge_suggestions(self, cr, uid, context=None):
|
|
|
|
"""Return the list of goal plans suggested to the user"""
|
|
|
|
if context is None: context = {}
|
|
|
|
plan_info = []
|
|
|
|
plan_ids = self.pool.get('gamification.goal.plan').search(cr, uid, [('proposed_user_ids', 'in', uid), ('state', '=', 'inprogress')], context=context)
|
|
|
|
for plan in self.pool.get('gamification.goal.plan').browse(cr, uid, plan_ids, context=context):
|
|
|
|
values = {
|
|
|
|
'id': plan.id,
|
|
|
|
'name': plan.name,
|
|
|
|
'description': plan.description,
|
|
|
|
}
|
|
|
|
plan_info.append(values)
|
|
|
|
return plan_info
|
|
|
|
|
2013-03-21 11:01:52 +00:00
|
|
|
|
2013-02-22 11:44:21 +00:00
|
|
|
class res_groups_gamification_group(osv.Model):
|
|
|
|
""" Update of res.groups class
|
2013-03-21 11:01:52 +00:00
|
|
|
- if adding users from a group, check gamification.goal.plan linked to
|
2013-02-22 11:44:21 +00:00
|
|
|
this group, and the user. This is done by overriding the write method.
|
|
|
|
"""
|
|
|
|
_name = 'res.groups'
|
|
|
|
_inherit = 'res.groups'
|
|
|
|
|
|
|
|
def write(self, cr, uid, ids, vals, context=None):
|
|
|
|
write_res = super(res_groups_gamification_group, self).write(cr, uid, ids, vals, context=context)
|
|
|
|
if vals.get('users'):
|
|
|
|
# form: {'group_ids': [(3, 10), (3, 3), (4, 10), (4, 3)]} or {'group_ids': [(6, 0, [ids]}
|
|
|
|
user_ids = [command[1] for command in vals['users'] if command[0] == 4]
|
|
|
|
user_ids += [id for command in vals['users'] if command[0] == 6 for id in command[2]]
|
|
|
|
|
|
|
|
goal_plan_obj = self.pool.get('gamification.goal.plan')
|
|
|
|
plan_ids = goal_plan_obj.search(cr, uid, [('autojoin_group_id', 'in', ids)], context=context)
|
2013-04-23 10:15:12 +00:00
|
|
|
if plan_ids:
|
|
|
|
goal_plan_obj.write(cr, uid, plan_ids, {'user_ids': [(4, user_id) for user_id in user_ids]}, context=context)
|
2013-02-22 11:44:21 +00:00
|
|
|
return write_res
|