[IMP] crm, base_calendar: move the core of crm.meeting into base_calendar
bzr revid: rco@openerp.com-20120704141042-fiy0o7pdhc8hboht
This commit is contained in:
parent
3bf79cdb78
commit
bd1d436f9d
|
@ -0,0 +1,26 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
##############################################################################
|
||||||
|
#
|
||||||
|
# OpenERP, Open Source Management Solution
|
||||||
|
# Copyright (C) 2004-2010 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/>.
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
import base_calendar
|
||||||
|
import crm_meeting
|
||||||
|
import wizard
|
||||||
|
|
||||||
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
|
@ -22,7 +22,7 @@
|
||||||
{
|
{
|
||||||
"name": "Calendar Layer",
|
"name": "Calendar Layer",
|
||||||
"version": "1.0",
|
"version": "1.0",
|
||||||
"depends": ["base", "mail"],
|
"depends": ["base", "base_status", "mail"],
|
||||||
'description': """
|
'description': """
|
||||||
This is a full-featured calendar system.
|
This is a full-featured calendar system.
|
||||||
========================================
|
========================================
|
||||||
|
|
|
@ -0,0 +1,112 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
##############################################################################
|
||||||
|
#
|
||||||
|
# OpenERP, Open Source Management Solution
|
||||||
|
# Copyright (C) 2004-today OpenERP SA (<http://www.openerp.com>)
|
||||||
|
#
|
||||||
|
# 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/>.
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
from osv import osv, fields
|
||||||
|
import tools
|
||||||
|
from tools.translate import _
|
||||||
|
|
||||||
|
import base_calendar
|
||||||
|
from base_status.base_state import base_state
|
||||||
|
|
||||||
|
#
|
||||||
|
# crm.meeting is defined here so that it may be used by modules other than crm,
|
||||||
|
# without forcing the installation of crm.
|
||||||
|
#
|
||||||
|
|
||||||
|
class crm_meeting_type(osv.Model):
|
||||||
|
_name = 'crm.meeting.type'
|
||||||
|
_description = 'Meeting Type'
|
||||||
|
_columns = {
|
||||||
|
'name': fields.char('Name', size=64, required=True, translate=True),
|
||||||
|
}
|
||||||
|
|
||||||
|
class crm_meeting(base_state, osv.Model):
|
||||||
|
""" Model for CRM meetings """
|
||||||
|
_name = 'crm.meeting'
|
||||||
|
_description = "Meeting"
|
||||||
|
_order = "id desc"
|
||||||
|
_inherit = ["calendar.event", 'ir.needaction_mixin', "mail.thread"]
|
||||||
|
_columns = {
|
||||||
|
# base_state required fields
|
||||||
|
'create_date': fields.datetime('Creation Date', readonly=True),
|
||||||
|
'write_date': fields.datetime('Write Date', readonly=True),
|
||||||
|
'date_open': fields.datetime('Confirmed', readonly=True),
|
||||||
|
'date_closed': fields.datetime('Closed', readonly=True),
|
||||||
|
'partner_id': fields.many2one('res.partner', 'Partner', states={'done': [('readonly', True)]}),
|
||||||
|
'email_from': fields.char('Email', size=128, states={'done': [('readonly', True)]},
|
||||||
|
help="These people will receive email."),
|
||||||
|
'state': fields.selection(
|
||||||
|
[('draft', 'Unconfirmed'), ('open', 'Confirmed'), ('cancel', 'Cancelled'), ('done', 'Done')],
|
||||||
|
string='Status', size=16, readonly=True),
|
||||||
|
# Meeting fields
|
||||||
|
'name': fields.char('Summary', size=128, required=True, states={'done': [('readonly', True)]}),
|
||||||
|
'categ_id': fields.many2one('crm.meeting.type', 'Meeting Type'),
|
||||||
|
'attendee_ids': fields.many2many('calendar.attendee', 'meeting_attendee_rel',\
|
||||||
|
'event_id', 'attendee_id', 'Attendees', states={'done': [('readonly', True)]}),
|
||||||
|
}
|
||||||
|
_defaults = {
|
||||||
|
'state': 'draft',
|
||||||
|
}
|
||||||
|
|
||||||
|
def create(self, cr, uid, vals, context=None):
|
||||||
|
obj_id = super(crm_meeting, self).create(cr, uid, vals, context=context)
|
||||||
|
self.create_send_note(cr, uid, [obj_id], context=context)
|
||||||
|
return obj_id
|
||||||
|
|
||||||
|
# ----------------------------------------
|
||||||
|
# OpenChatter
|
||||||
|
# ----------------------------------------
|
||||||
|
|
||||||
|
def case_get_note_msg_prefix(self, cr, uid, id, context=None):
|
||||||
|
return 'Meeting'
|
||||||
|
|
||||||
|
def create_send_note(self, cr, uid, ids, context=None):
|
||||||
|
if context is None:
|
||||||
|
context = {}
|
||||||
|
# update context: if come from phonecall, default state values can make the message_append_note crash
|
||||||
|
context.pop('default_state', False)
|
||||||
|
for meeting in self.browse(cr, uid, ids, context=context):
|
||||||
|
# convert datetime field to a datetime, using server format, then
|
||||||
|
# convert it to the user TZ and re-render it with %Z to add the timezone
|
||||||
|
meeting_datetime = fields.DT.datetime.strptime(meeting.date, tools.DEFAULT_SERVER_DATETIME_FORMAT)
|
||||||
|
meeting_date_str = fields.datetime.context_timestamp(cr, uid, meeting_datetime, context=context).strftime(tools.DATETIME_FORMATS_MAP['%+'] + " (%Z)")
|
||||||
|
message = _("A meeting has been <b>scheduled</b> on <em>%s</em>.") % (meeting_date_str)
|
||||||
|
if meeting.opportunity_id: # meeting can be create from phonecalls or opportunities, therefore checking for the parent
|
||||||
|
lead = meeting.opportunity_id
|
||||||
|
parent_message = _("Meeting linked to the opportunity <em>%s</em> has been <b>created</b> and <b>cscheduled</b> on <em>%s</em>.") % (lead.name, meeting.date)
|
||||||
|
lead.message_append_note(_('System Notification'), message)
|
||||||
|
elif meeting.phonecall_id:
|
||||||
|
phonecall = meeting.phonecall_id
|
||||||
|
parent_message = _("Meeting linked to the phonecall <em>%s</em> has been <b>created</b> and <b>cscheduled</b> on <em>%s</em>.") % (phonecall.name, meeting.date)
|
||||||
|
phonecall.message_append_note(body=message)
|
||||||
|
else:
|
||||||
|
parent_message = message
|
||||||
|
if parent_message:
|
||||||
|
meeting.message_append_note(body=parent_message)
|
||||||
|
return True
|
||||||
|
|
||||||
|
def case_open_send_note(self, cr, uid, ids, context=None):
|
||||||
|
return self.message_append_note(cr, uid, ids, body=_("Meeting has been <b>confirmed</b>."), context=context)
|
||||||
|
|
||||||
|
def case_close_send_note(self, cr, uid, ids, context=None):
|
||||||
|
return self.message_append_note(cr, uid, ids, body=_("Meeting has been <b>done</b>."), context=context)
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,7 @@ class base_state(object):
|
||||||
- ``date_closed`` (datetime field)
|
- ``date_closed`` (datetime field)
|
||||||
- ``user_id`` (many2one to res.users)
|
- ``user_id`` (many2one to res.users)
|
||||||
- ``partner_id`` (many2one to res.partner)
|
- ``partner_id`` (many2one to res.partner)
|
||||||
|
- ``email_from`` (char field)
|
||||||
- ``state`` (selection field)
|
- ``state`` (selection field)
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
|
@ -19,104 +19,24 @@
|
||||||
#
|
#
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
from base_calendar import base_calendar
|
|
||||||
from base_status.base_state import base_state
|
|
||||||
from base_status.base_stage import base_stage
|
|
||||||
import logging
|
|
||||||
from osv import fields, osv
|
from osv import fields, osv
|
||||||
import tools
|
import tools
|
||||||
from tools.translate import _
|
from tools.translate import _
|
||||||
|
import logging
|
||||||
_logger = logging.getLogger(__name__)
|
_logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
class crm_meeting(base_state, osv.Model):
|
#
|
||||||
|
# crm.meeting is defined in module base_calendar
|
||||||
|
#
|
||||||
|
class crm_meeting(osv.Model):
|
||||||
""" Model for CRM meetings """
|
""" Model for CRM meetings """
|
||||||
_name = 'crm.meeting'
|
_inherit = 'crm.meeting'
|
||||||
_description = "Meeting"
|
|
||||||
_order = "id desc"
|
|
||||||
_inherit = ["calendar.event", 'ir.needaction_mixin', "mail.thread"]
|
|
||||||
_columns = {
|
_columns = {
|
||||||
# base_state required fields
|
|
||||||
'partner_id': fields.many2one('res.partner', 'Partner', states={'done': [('readonly', True)]}),
|
|
||||||
'section_id': fields.many2one('crm.case.section', 'Sales Team', states={'done': [('readonly', True)]},
|
'section_id': fields.many2one('crm.case.section', 'Sales Team', states={'done': [('readonly', True)]},
|
||||||
select=True, groups='base.group_sale_salesman', help='Sales team to which Case belongs to.'),
|
select=True, groups='base.group_sale_salesman', help='Sales team to which Case belongs to.'),
|
||||||
'email_from': fields.char('Email', size=128, states={'done': [('readonly', True)]}, help="These people will receive email."),
|
|
||||||
'create_date': fields.datetime('Creation Date' , readonly=True),
|
|
||||||
'write_date': fields.datetime('Write Date' , readonly=True),
|
|
||||||
'date_action_last': fields.datetime('Last Action', readonly=1),
|
|
||||||
'date_action_next': fields.datetime('Next Action', readonly=1),
|
|
||||||
# Meeting fields
|
|
||||||
'name': fields.char('Summary', size=124, required=True, states={'done': [('readonly', True)]}),
|
|
||||||
'categ_id': fields.many2one('crm.case.categ', 'Meeting Type', \
|
|
||||||
domain="[('object_id.model', '=', 'crm.meeting')]", \
|
|
||||||
),
|
|
||||||
'phonecall_id': fields.many2one ('crm.phonecall', 'Phonecall'),
|
'phonecall_id': fields.many2one ('crm.phonecall', 'Phonecall'),
|
||||||
'opportunity_id': fields.many2one ('crm.lead', 'Opportunity', domain="[('type', '=', 'opportunity')]"),
|
'opportunity_id': fields.many2one ('crm.lead', 'Opportunity', domain="[('type', '=', 'opportunity')]"),
|
||||||
'attendee_ids': fields.many2many('calendar.attendee', 'meeting_attendee_rel',\
|
|
||||||
'event_id', 'attendee_id', 'Attendees', states={'done': [('readonly', True)]}),
|
|
||||||
'date_closed': fields.datetime('Closed', readonly=True),
|
|
||||||
'date_deadline': fields.datetime('Deadline', states={'done': [('readonly', True)]}),
|
|
||||||
'state': fields.selection([ ('draft', 'Unconfirmed'),
|
|
||||||
('open', 'Confirmed'),
|
|
||||||
('cancel', 'Cancelled'),
|
|
||||||
('done', 'Done')],
|
|
||||||
string='Status', size=16, readonly=True),
|
|
||||||
}
|
}
|
||||||
_defaults = {
|
|
||||||
'state': 'draft',
|
|
||||||
'active': 1,
|
|
||||||
'user_id': lambda self, cr, uid, ctx: uid,
|
|
||||||
}
|
|
||||||
|
|
||||||
def create(self, cr, uid, vals, context=None):
|
|
||||||
obj_id = super(crm_meeting, self).create(cr, uid, vals, context=context)
|
|
||||||
self.create_send_note(cr, uid, [obj_id], context=context)
|
|
||||||
return obj_id
|
|
||||||
|
|
||||||
def case_open(self, cr, uid, ids, context=None):
|
|
||||||
""" Confirms meeting """
|
|
||||||
res = super(crm_meeting, self).case_open(cr, uid, ids, context)
|
|
||||||
for (id, name) in self.name_get(cr, uid, ids):
|
|
||||||
id=base_calendar.base_calendar_id2real_id(id)
|
|
||||||
return res
|
|
||||||
|
|
||||||
# ----------------------------------------
|
|
||||||
# OpenChatter
|
|
||||||
# ----------------------------------------
|
|
||||||
|
|
||||||
def case_get_note_msg_prefix(self, cr, uid, id, context=None):
|
|
||||||
return 'Meeting'
|
|
||||||
|
|
||||||
def create_send_note(self, cr, uid, ids, context=None):
|
|
||||||
if context is None:
|
|
||||||
context = {}
|
|
||||||
# update context: if come from phonecall, default state values can make the message_append_note crash
|
|
||||||
context.pop('default_state', False)
|
|
||||||
for meeting in self.browse(cr, uid, ids, context=context):
|
|
||||||
# convert datetime field to a datetime, using server format, then
|
|
||||||
# convert it to the user TZ and re-render it with %Z to add the timezone
|
|
||||||
meeting_datetime = fields.DT.datetime.strptime(meeting.date, tools.DEFAULT_SERVER_DATETIME_FORMAT)
|
|
||||||
meeting_date_str = fields.datetime.context_timestamp(cr, uid, meeting_datetime, context=context).strftime(tools.DATETIME_FORMATS_MAP['%+'] + " (%Z)")
|
|
||||||
message = _("A meeting has been <b>scheduled</b> on <em>%s</em>.") % (meeting_date_str)
|
|
||||||
if meeting.opportunity_id: # meeting can be create from phonecalls or opportunities, therefore checking for the parent
|
|
||||||
lead = meeting.opportunity_id
|
|
||||||
parent_message = _("Meeting linked to the opportunity <em>%s</em> has been <b>created</b> and <b>cscheduled</b> on <em>%s</em>.") % (lead.name, meeting.date)
|
|
||||||
lead.message_append_note(_('System Notification'), message)
|
|
||||||
elif meeting.phonecall_id:
|
|
||||||
phonecall = meeting.phonecall_id
|
|
||||||
parent_message = _("Meeting linked to the phonecall <em>%s</em> has been <b>created</b> and <b>cscheduled</b> on <em>%s</em>.") % (phonecall.name, meeting.date)
|
|
||||||
phonecall.message_append_note(body=message)
|
|
||||||
else:
|
|
||||||
parent_message = message
|
|
||||||
if parent_message:
|
|
||||||
meeting.message_append_note(body=parent_message)
|
|
||||||
return True
|
|
||||||
|
|
||||||
def case_open_send_note(self, cr, uid, ids, context=None):
|
|
||||||
return self.message_append_note(cr, uid, ids, body=_("Meeting has been <b>confirmed</b>."), context=context)
|
|
||||||
|
|
||||||
def case_close_send_note(self, cr, uid, ids, context=None):
|
|
||||||
return self.message_append_note(cr, uid, ids, body=_("Meeting has been <b>done</b>."), context=context)
|
|
||||||
|
|
||||||
|
|
||||||
class calendar_attendee(osv.osv):
|
class calendar_attendee(osv.osv):
|
||||||
""" Calendar Attendee """
|
""" Calendar Attendee """
|
||||||
|
@ -151,8 +71,6 @@ class calendar_attendee(osv.osv):
|
||||||
relation="crm.case.categ", multi='categ_id'),
|
relation="crm.case.categ", multi='categ_id'),
|
||||||
}
|
}
|
||||||
|
|
||||||
calendar_attendee()
|
|
||||||
|
|
||||||
class res_users(osv.osv):
|
class res_users(osv.osv):
|
||||||
_name = 'res.users'
|
_name = 'res.users'
|
||||||
_inherit = 'res.users'
|
_inherit = 'res.users'
|
||||||
|
@ -173,7 +91,4 @@ class res_users(osv.osv):
|
||||||
_logger.debug('Skipped meetings shortcut for user "%s"', data.get('name','<new'))
|
_logger.debug('Skipped meetings shortcut for user "%s"', data.get('name','<new'))
|
||||||
return user_id
|
return user_id
|
||||||
|
|
||||||
res_users()
|
|
||||||
|
|
||||||
|
|
||||||
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
||||||
|
|
|
@ -4,22 +4,16 @@
|
||||||
|
|
||||||
<!-- CASE CATEGORY(categ_id) -->
|
<!-- CASE CATEGORY(categ_id) -->
|
||||||
|
|
||||||
<record model="crm.case.categ" id="categ_meet1">
|
<record model="crm.meeting.type" id="categ_meet1">
|
||||||
<field name="name">Customer Meeting</field>
|
<field name="name">Customer Meeting</field>
|
||||||
<field name="section_id" ref="section_sales_department"/>
|
|
||||||
<field name="object_id" search="[('model','=','crm.meeting')]" model="ir.model"/>
|
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record model="crm.case.categ" id="categ_meet2">
|
<record model="crm.meeting.type" id="categ_meet2">
|
||||||
<field name="name">Internal Meeting</field>
|
<field name="name">Internal Meeting</field>
|
||||||
<field name="section_id" ref="section_sales_department"/>
|
|
||||||
<field name="object_id" search="[('model','=','crm.meeting')]" model="ir.model"/>
|
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record model="crm.case.categ" id="categ_meet3">
|
<record model="crm.meeting.type" id="categ_meet3">
|
||||||
<field name="name">Phone Call</field>
|
<field name="name">Phone Call</field>
|
||||||
<field name="section_id" ref="section_sales_department"/>
|
|
||||||
<field name="object_id" search="[('model','=','crm.meeting')]" model="ir.model"/>
|
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record model="res.request.link" id="request_link_meeting">
|
<record model="res.request.link" id="request_link_meeting">
|
||||||
|
|
|
@ -39,21 +39,29 @@
|
||||||
<field name="key2">client_action_multi</field>
|
<field name="key2">client_action_multi</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<!-- CRM Meetings Categories Form View -->
|
<!-- CRM Meetings Types Form View -->
|
||||||
|
|
||||||
|
<record id="crm_meeting_type_tree" model="ir.ui.view">
|
||||||
|
<field name="name">Meeting Types Tree</field>
|
||||||
|
<field name="model">crm.meeting.type</field>
|
||||||
|
<field name="type">tree</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<tree string="Meeting Types" editable="bottom">
|
||||||
|
<field name="name"/>
|
||||||
|
</tree>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
<record id="crm_meeting_categ_action" model="ir.actions.act_window">
|
<record id="crm_meeting_categ_action" model="ir.actions.act_window">
|
||||||
<field name="name">Meeting Categories</field>
|
<field name="name">Meeting Types</field>
|
||||||
<field name="res_model">crm.case.categ</field>
|
<field name="res_model">crm.meeting.type</field>
|
||||||
<field name="view_type">form</field>
|
<field name="view_type">form</field>
|
||||||
<field name="view_id" ref="crm.crm_case_categ_tree-view"/>
|
<field name="view_id" ref="crm_meeting_type_tree"/>
|
||||||
<field name="domain">[('object_id.model', '=', 'crm.meeting')]</field>
|
|
||||||
<field name="context" eval="{'object_id': ref('model_crm_meeting')}"/>
|
|
||||||
<field name="help">Create different meeting categories to better organize and classify your meetings.</field>
|
<field name="help">Create different meeting categories to better organize and classify your meetings.</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<menuitem action="crm_meeting_categ_action"
|
<menuitem id="menu_crm_case_meeting-act" parent="base.menu_calendar_configuration" sequence="1"
|
||||||
groups="base.group_no_one"
|
action="crm_meeting_categ_action" groups="base.group_no_one"/>
|
||||||
id="menu_crm_case_meeting-act" parent="base.menu_calendar_configuration" sequence="1"/>
|
|
||||||
|
|
||||||
<!-- CRM Meetings Form View -->
|
<!-- CRM Meetings Form View -->
|
||||||
|
|
||||||
|
@ -122,9 +130,7 @@
|
||||||
<field name="email_from"/>
|
<field name="email_from"/>
|
||||||
</group>
|
</group>
|
||||||
<group colspan="2">
|
<group colspan="2">
|
||||||
<field name="categ_id" widget="selection"
|
<field name="categ_id" widget="selection"/>
|
||||||
string="Meeting Type"
|
|
||||||
domain="[('object_id.model', '=', 'crm.meeting')]" />
|
|
||||||
<field name="rrule" invisible="1" readonly="1"/>
|
<field name="rrule" invisible="1" readonly="1"/>
|
||||||
<field name="recurrent_id" invisible="1"/>
|
<field name="recurrent_id" invisible="1"/>
|
||||||
<field name="recurrent_uid" invisible="1"/>
|
<field name="recurrent_uid" invisible="1"/>
|
||||||
|
|
|
@ -5,11 +5,9 @@
|
||||||
-->
|
-->
|
||||||
<data>
|
<data>
|
||||||
|
|
||||||
<!-- Case category (for interview meetings) -->
|
<!-- Meeting Types (for interview meetings) -->
|
||||||
<record model="crm.case.categ" id="categ_meet_interview">
|
<record model="crm.meeting.type" id="categ_meet_interview">
|
||||||
<field name="name">Interview</field>
|
<field name="name">Interview</field>
|
||||||
<field name="section_id" ref="crm.section_sales_department"/>
|
|
||||||
<field name="object_id" search="[('model','=','crm.meeting')]" model="ir.model"/>
|
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<!-- HR Recruitment Source -->
|
<!-- HR Recruitment Source -->
|
||||||
|
|
Loading…
Reference in New Issue