[MERGE] merge with trunk addons

bzr revid: mra@mra-laptop-20100701045050-3cyxsrvfy34k8upg
bzr revid: mra@mra-laptop-20100701061711-shkuh22890mi1md7
This commit is contained in:
Mustufa Rangwala 2010-07-01 11:47:11 +05:30
commit 2419ded972
14 changed files with 103 additions and 87 deletions

View File

@ -13,7 +13,7 @@ msgstr ""
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"X-Launchpad-Export-Date: 2010-06-30 03:34+0000\n"
"X-Launchpad-Export-Date: 2010-07-01 03:45+0000\n"
"X-Generator: Launchpad (build Unknown)\n"
#. module: account

View File

@ -576,7 +576,7 @@ property or property parameter."),
if not vals.get("email") and vals.get("cn"):
cnval = vals.get("cn").split(':')
email = filter(lambda x:x.__contains__('@'), cnval)
vals['email'] = email[0]
vals['email'] = email and email[0] or ''
vals['cn'] = vals.get("cn")
res = super(calendar_attendee, self).create(cr, uid, vals, context)
return res
@ -629,6 +629,7 @@ true, it will allow you to hide the event alarm information without removing it.
if not context:
context = {}
alarm_obj = self.pool.get('calendar.alarm')
res_alarm_obj = self.pool.get('res.alarm')
ir_obj = self.pool.get('ir.model')
model_id = ir_obj.search(cr, uid, [('model', '=', model)])[0]
@ -636,6 +637,30 @@ true, it will allow you to hide the event alarm information without removing it.
for data in model_obj.browse(cr, uid, ids, context):
basic_alarm = data.alarm_id
cal_alarm = data.base_calendar_alarm_id
if (not basic_alarm and cal_alarm) or (basic_alarm and cal_alarm):
new_res_alarm = None
# Find for existing res.alarm
duration = cal_alarm.trigger_duration
interval = cal_alarm.trigger_interval
occurs = cal_alarm.trigger_occurs
related = cal_alarm.trigger_related
domain = [('trigger_duration', '=', duration), ('trigger_interval', '=', interval), ('trigger_occurs', '=', occurs), ('trigger_related', '=', related)]
alarm_ids = res_alarm_obj.search(cr, uid, domain, context=context)
if not alarm_ids:
val = {
'trigger_duration': duration,
'trigger_interval': interval,
'trigger_occurs': occurs,
'trigger_related': related,
'name': str(duration) + ' ' + str(interval) + ' ' + str(occurs)
}
new_res_alarm = res_alarm_obj.create(cr, uid, val, context=context)
else:
new_res_alarm = alarm_ids[0]
cr.execute('Update %s set base_calendar_alarm_id=%s, alarm_id=%s \
where id=%s' % (model_obj._table, \
cal_alarm.id, new_res_alarm, data.id))
if not context.get('alarm_id', False):
self.do_alarm_unlink(cr, uid, [data.id], model)
return True
@ -1463,7 +1488,7 @@ true, it will allow you to hide the event alarm information without removing it.
context = {}
res = super(calendar_event, self).copy(cr, uid, base_calendar_id2real_id(id), default, context)
alarm_obj = self.pool.get('res.alarm')
alarm_obj.do_alarm_create(cr, uid, [res], self._name, 'date')
alarm_obj.do_alarm_create(cr, uid, [res], self._name, 'date', context=context)
return res
@ -1514,7 +1539,7 @@ true, it will allow you to hide the event alarm information without removing it.
context = {}
res = super(calendar_event, self).create(cr, uid, vals, context)
alarm_obj = self.pool.get('res.alarm')
alarm_obj.do_alarm_create(cr, uid, [res], self._name, 'date')
alarm_obj.do_alarm_create(cr, uid, [res], self._name, 'date', context=context)
return res
calendar_event()

View File

@ -117,7 +117,7 @@ def get_attribute_mapping(cr, uid, calname, context={}):
res['uid']['type'] = "integer"
return res
def map_data(cr, uid, obj):
def map_data(cr, uid, obj, context=None):
""" Map Data
@param self: The object pointer
@param cr: the current row, from the database cursor,"""
@ -144,7 +144,7 @@ def map_data(cr, uid, obj):
model = obj.__attribute__[map_dict].get('object', False)
modobj = obj.pool.get(model)
for map_vall in map_val:
id = modobj.create(cr, uid, map_vall)
id = modobj.create(cr, uid, map_vall, context=context)
ids.append(id)
vals[field] = [(6, 0, ids)]
continue
@ -155,7 +155,15 @@ def map_data(cr, uid, obj):
continue
model = obj.__attribute__[map_dict].get('object', False)
modobj = obj.pool.get(model)
id = modobj.create(cr, uid, map_val)
# check if the record exists or not
key1 = map_val.keys()
value1 = map_val.values()
domain = [(key1[i], '=', value1[i]) for i in range(len(key1)) if value1[i]]
exist_id = modobj.search(cr, uid, domain, context=context)
if exist_id:
id = exist_id[0]
else:
id = modobj.create(cr, uid, map_val, context=context)
vals[field] = id
continue
if field_type == 'timedelta':
@ -245,7 +253,7 @@ class CalDAV(object):
if cal_data.params.get('X-VOBJ-ORIGINAL-TZID'):
self.ical_set('vtimezone', cal_data.params.get('X-VOBJ-ORIGINAL-TZID'), 'value')
self.ical_set(cal_data.name.lower(), cal_data.value, 'value')
vals = map_data(cr, uid, self)
vals = map_data(cr, uid, self, context=context)
return vals
def create_ics(self, cr, uid, datas, name, ical, context=None):
@ -874,7 +882,7 @@ class Timezone(CalDAV, osv.osv_memory):
if child.name.lower() == 'tzid':
tzname = child.value
self.ical_set(child.name.lower(), tzname, 'value')
vals = map_data(cr, uid, self)
vals = map_data(cr, uid, self, context=context)
return vals
Timezone()
@ -969,7 +977,7 @@ class Alarm(CalDAV, osv.osv_memory):
self.ical_set('trigger_related', child.params.get('related')[0].lower(), 'value')
else:
self.ical_set(child.name.lower(), child.value.lower(), 'value')
vals = map_data(cr, uid, self)
vals = map_data(cr, uid, self, context=context)
return vals
Alarm()
@ -1013,7 +1021,7 @@ class Attendee(CalDAV, osv.osv_memory):
self.ical_set(para.lower(), ical_data.params[para][0].lower(), 'value')
if not ical_data.params.get('CN'):
self.ical_set('cn', ical_data.value, 'value')
vals = map_data(cr, uid, self)
vals = map_data(cr, uid, self, context=context)
return vals
def export_cal(self, cr, uid, model, attendee_ids, vevent, context={}):

View File

@ -170,17 +170,17 @@ class crm_send_new_email(osv.osv_memory):
for case in mod_obj.browse(cr, uid, res_id):
if 'email_to' in fields:
res.update({'email_to': case.email_from})
res.update({'email_to': tools.ustr(case.email_from)})
if 'email_from' in fields:
res.update({'email_from': user_mail_from})
res.update({'email_from': tools.ustr(user_mail_from)})
if 'subject' in fields:
res.update({'subject': tools.ustr(context.get('subject', case.name) or '')})
if 'email_cc' in fields:
res.update({'email_cc': case.email_cc or ''})
res.update({'email_cc': tools.ustr(case.email_cc or '')})
if 'text' in fields:
res.update({'text': '\n\n'+(case.user_id.signature or '')})
res.update({'text': u'\n\n'+(tools.ustr(case.user_id.signature or ''))})
if 'state' in fields:
res.update({'state': 'pending'})
res.update({'state': u'pending'})
return res
@ -207,28 +207,28 @@ class crm_send_new_email(osv.osv_memory):
res_id = hist.res_id
case = model_pool.browse(cr, uid, res_id)
if 'email_to' in fields:
res.update({'email_to': hist.email_from or False})
res.update({'email_to': case.email_from and tools.ustr(case.email_from) or False})
if 'email_from' in fields:
res.update({'email_from': user_mail_from})
res.update({'email_from': user_mail_from and tools.ustr(user_mail_from) or False})
signature = '\n' + (case.user_id.signature or '')
signature = u'\n' + (tools.ustr(case.user_id.signature or ''))
original = [signature]
if include_original == True and 'text' in fields:
header = '-------- Original Message --------'
sender = 'From: %s' %(hist.email_from or '')
to = 'To: %s' % (hist.email_to or '')
sentdate = 'Date: %s' % (hist.date)
desc = '\n%s'%(hist.description)
header = u'-------- Original Message --------'
sender = u'From: %s' %(tools.ustr(hist.email_from or ''))
to = u'To: %s' % (tools.ustr(hist.email_to or ''))
sentdate = u'Date: %s' % (tools.ustr(hist.date))
desc = u'\n%s'%(tools.ustr(hist.description))
original = [header, sender, to, sentdate, desc, signature]
res['text']= '\n\n\n' + '\n'.join(original)
res['text']= u'\n\n\n' + u'\n'.join(original)
if 'subject' in fields:
res.update({'subject': 'Re: %s' %(hist.name or '')})
res.update({u'subject': u'Re: %s' %(tools.ustr(hist.name or ''))})
if 'state' in fields:
res['state']='pending'
res['state'] = u'pending'
return res
def view_init(self, cr, uid, fields_list, context=None):

View File

@ -14,7 +14,7 @@ msgstr ""
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"X-Launchpad-Export-Date: 2010-06-30 03:34+0000\n"
"X-Launchpad-Export-Date: 2010-07-01 03:45+0000\n"
"X-Generator: Launchpad (build Unknown)\n"
#. module: hr_evaluation

View File

@ -371,16 +371,14 @@ class mailgate_tool(osv.osv_memory):
if part.get_content_subtype() == 'html':
body = tools.ustr(tools.html2plaintext(content))
elif part.get_content_subtype() == 'plain':
body = tools.ustr(content)
body = content
elif part.get_content_maintype() in ('application', 'image', 'text'):
filename = part.get_filename();
if filename :
attachments[filename] = part.get_payload(decode=True)
else:
res = part.get_payload(decode=True)
if encoding:
res = tools.ustr(res, encoding)
body += res
body += tools.ustr(res)
msg['body'] = body
msg['attachments'] = attachments

View File

@ -20,8 +20,7 @@
##############################################################################
from mx import DateTime
from osv import fields
from osv import osv
from osv import osv, fields
from tools.translate import _
import ir
import netsvc
@ -520,14 +519,17 @@ class mrp_production(osv.osv):
raise osv.except_osv(_('Invalid action !'), _('Cannot delete Production Order(s) which are in %s State!' % s['state']))
return osv.osv.unlink(self, cr, uid, unlink_ids, context=context)
def copy(self, cr, uid, id, default=None,context=None):
if not default:
def copy(self, cr, uid, id, default=None, context=None):
if default is None:
default = {}
default.update({
'name': self.pool.get('ir.sequence').get(cr, uid, 'mrp.production'),
'move_lines' : [],
'move_created_ids': [],
'state': 'draft'
'move_lines2' : [],
'move_created_ids' : [],
'move_created_ids2' : [],
'product_lines' : [],
'picking_id': False
})
return super(mrp_production, self).copy(cr, uid, id, default, context)

View File

@ -14,7 +14,7 @@ msgstr ""
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"X-Launchpad-Export-Date: 2010-06-30 03:34+0000\n"
"X-Launchpad-Export-Date: 2010-07-01 03:45+0000\n"
"X-Generator: Launchpad (build Unknown)\n"
#. module: survey

View File

@ -6,6 +6,8 @@
<field name="tags">help, quick start, wiki, formatting</field>
<field name="minor_edit">0</field>
<field name="section">1</field>
<field name="create_uid" eval="1"/>
<field name="write_uid" eval="1"/>
<field name="toc">0</field>
<field name="summary">Initial Page</field>
<field name="text_area">=The Open ERP wiki=

View File

@ -8,6 +8,8 @@
<record id="wiki_wiki_quickstart0" model="wiki.wiki">
<field name="name">Basic Wiki Editing</field>
<field name="tags">help, quick start, wiki, formatting</field>
<field name="create_uid" eval="1"/>
<field name="write_uid" eval="1"/>
<field name="minor_edit">0</field>
<field name="toc">1</field>
<field name="section">1.1</field>

View File

@ -32,7 +32,6 @@ import difflib
class Wiki(osv.osv):
""" wiki """
_name = "wiki.wiki"
Wiki()
@ -78,7 +77,7 @@ class GroupLink(osv.osv):
GroupLink()
class Wiki(osv.osv):
class Wiki2(osv.osv):
""" Wiki Page """
_inherit = "wiki.wiki"
@ -87,19 +86,22 @@ class Wiki(osv.osv):
_columns = {
'name': fields.char('Title', size=256, select=True, required=True),
'write_uid': fields.many2one('res.users', "Last Author"),
'write_uid': fields.many2one('res.users', "Last Contributor", select=True),
'text_area': fields.text("Content"),
'create_uid': fields.many2one('res.users', 'Author', select=True),
'create_date': fields.datetime("Created on", select=True),
'write_date': fields.datetime("Modification Date", select=True),
'tags': fields.char('Tags', size=1024),
'tags': fields.char('Tags', size=1024, select=True),
'history_id': fields.one2many('wiki.wiki.history', 'wiki_id', 'History Lines'),
'minor_edit': fields.boolean('Minor edit', select=True),
'summary': fields.char('Summary', size=256),
'section': fields.char('Sequence', size=32, help="Use page section code like 1.2.1"),
'group_id': fields.many2one('wiki.groups', 'Wiki Group', select=1, ondelete='set null'),
'toc': fields.boolean('Table of Contents'),
'review': fields.boolean('Need Review'),
'section': fields.char('Section', size=32, help="Use page section code like 1.2.1", select=True),
'group_id': fields.many2one('wiki.groups', 'Wiki Group', select=1, ondelete='set null',
help="Topic, also called Wiki Group"),
'toc': fields.boolean('Table of Contents',
help="Indicates that this pages is a table of contents (linking to other pages)"),
'review': fields.boolean('Needs Review', select=True,
help="Indicates that this page should be reviewed, raising the attention of other contributors"),
'parent_id': fields.many2one('wiki.wiki', 'Parent Page'),
'child_ids': fields.one2many('wiki.wiki', 'parent_id', 'Child Pages'),
}
@ -176,29 +178,7 @@ class Wiki(osv.osv):
history.create(cr, uid, res)
return result
def open_wiki_page(self, cr, uid, ids, context):
""" Opens Wiki Page for Editing
@param cr: the current row, from the database cursor,
@param uid: the current users ID for security checks,
@param ids: List of wiki pages IDs
"""
pages = self.pool.get('wiki.wiki').search(cr, uid, [('name', '=', 'Basic Wiki Editing')])
if not pages:
raise osv.except_osv(_('Warning !'), _("No Help page is defined"))
value = {
'view_type': 'form',
'view_mode': 'form,tree',
'res_model': 'wiki.wiki',
'view_id': False,
'res_id': pages[0],
'type': 'ir.actions.act_window',
'nodestroy': True,
}
return value
Wiki()
Wiki2()
class History(osv.osv):

View File

@ -123,18 +123,13 @@
<field name="arch" type="xml">
<form string="Wiki">
<group col="8" colspan="4">
<field name="name" select="1" colspan="6"/>
<button name="open_wiki_page" type="object"
string="Basic Wiki Editing" icon="gtk-ok" />
</group>
<group col="8" colspan="4">
<field name="name" select="1" colspan="8"/>
<field name="group_id" string="Topic" select="1" on_change="onchange_group_id(group_id, text_area)"/>
<field name="section" invisible="not context.get('section',False)"/>
<!-- <field name="parent_id"/>-->
</group>
<notebook colspan="4">
<page string="Content">
<separator colspan="4" string="Informations"/>
<separator colspan="4" string="Page Content"/>
<field name="text_area" nolabel="1" colspan="4" select="1" widget="text_wiki"/>
</page>
</notebook>
@ -144,7 +139,6 @@
<field name="review" select="1"/>
<field name="tags" select="1" groups="base.group_extended"/>
<field name="toc"/>
<!-- <field name="summary" colspan="4" groups="base.group_extended"/>-->
</group>
</form>
</field>
@ -165,12 +159,11 @@
<field name="group_id" select="1"/>
<field name="write_uid" select="1"/>
<field name="write_date" select="1"/>
<field name="review" select="1"/>
<newline/>
<group expand="0" string="Group By..." colspan="8" col="6">
<filter icon="terp-check" string="Wiki Group" domain="[]" context="{'group_by':'group_id'}"/>
<filter icon="terp-personal" string="Author" domain="[]" context="{'group_by':'create_uid'}"/>
<filter icon="terp-personal-" string="Last Author" domain="[]" context="{'group_by':'write_uid'}"/>
<filter icon="terp-personal-" string="Last Contributor" domain="[]" context="{'group_by':'write_uid'}"/>
</group>
</search>
</field>
@ -184,7 +177,6 @@
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="view_id" ref="view_wiki_tree"/>
<!-- <field name="context">{'section':'1','search_default_create_uid':uid}</field>-->
<field name="search_view_id" ref="view_wiki_filter"/>
</record>

View File

@ -9,14 +9,18 @@
== Answer ==
== External Links ==
</field>
</field>
</record>
<record id="wiki_wiki_bugs" model="wiki.wiki">
<field name="name">Bug Tracker ?</field>
<field name="tags">crm, bugs</field>
<field name="group_id" ref="wiki_groups_faq"/>
<field name="create_uid" eval="1"/>
<field name="write_uid" eval="1"/>
<field name="minor_edit">0</field>
<field name="toc">0</field>
<field name="review">1</field>
@ -48,13 +52,14 @@ Integration Benefits:
* The Open ERP Website: [http://openerp.com]
* The DMS Documentation: [http://openerp.com]
</field>
</field>
</record>
<record id="wiki_wiki_dms" model="wiki.wiki">
<field name="name">Document Management System ?</field>
<field name="tags">dms, document</field>
<field name="group_id" ref="wiki_groups_faq"/>
<field name="create_uid" eval="1"/>
<field name="write_uid" eval="1"/>
<field name="minor_edit">0</field>
<field name="toc">1</field>
<field name="section">1</field>
@ -88,8 +93,7 @@ Integration Benefits:
* The Open ERP Website : [http://openerp.com]
* The DMS Documentation : [http://openerp.com]
</field>
</field>
</record>
</data>
</openerp>

View File

@ -14,11 +14,14 @@
<field eval="2" name="section"/>
<field name="template">== Question ==
== Answer ==
== External Links ==
</field>
</field>
</record>