savoirfairelinux-openerp team mailing list archive
-
savoirfairelinux-openerp team
-
Mailing list archive
-
Message #01138
[Merge] lp:~savoirfairelinux-openerp/knowledge-addons/document_multiple_records into lp:knowledge-addons/7.0
El Hadji Dem (http://www.savoirfairelinux.com) has proposed merging lp:~savoirfairelinux-openerp/knowledge-addons/document_multiple_records into lp:knowledge-addons/7.0.
Requested reviews:
Sandy Carter (http://www.savoirfairelinux.com) (sandy-carter): code review, test
For more details, see:
https://code.launchpad.net/~savoirfairelinux-openerp/knowledge-addons/document_multiple_records/+merge/206960
Added document_multiple_records module: It allows to manage a document with a multiple records.
--
https://code.launchpad.net/~savoirfairelinux-openerp/knowledge-addons/document_multiple_records/+merge/206960
Your team Savoir-faire Linux' OpenERP is subscribed to branch lp:~savoirfairelinux-openerp/knowledge-addons/document_multiple_records.
=== added directory 'document_multiple_records'
=== added file 'document_multiple_records/__init__.py'
--- document_multiple_records/__init__.py 1970-01-01 00:00:00 +0000
+++ document_multiple_records/__init__.py 2014-03-19 15:30:33 +0000
@@ -0,0 +1,26 @@
+# -*- encoding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# This module copyright (C) 2014 Savoir-faire Linux
+# (<http://www.savoirfairelinux.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 . import document
+from . import wizard
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added file 'document_multiple_records/__openerp__.py'
--- document_multiple_records/__openerp__.py 1970-01-01 00:00:00 +0000
+++ document_multiple_records/__openerp__.py 2014-03-19 15:30:33 +0000
@@ -0,0 +1,60 @@
+# -*- encoding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# This module copyright (C) 2014 Savoir-faire Linux
+# (<http://www.savoirfairelinux.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/>.
+#
+##############################################################################
+
+{
+ 'name': 'Document Management System for Multiple Records',
+ 'version': '0.1',
+ 'category': 'Knowledge Management',
+ 'summary': 'Document Management System for Multiple Records',
+ 'description': """
+Document Management System for Multiple Records
+==============================================
+
+Contributors
+------------
+* El Hadji Dem (elhadji.dem@xxxxxxxxxxxxxxxxxxxx)
+""",
+ 'author': 'Savoir-faire Linux',
+ 'website': 'www.savoirfairelinux.com',
+ 'license': 'AGPL-3',
+ 'depends': [
+ 'document',
+ ],
+ 'data': [
+ 'document_view.xml',
+ 'security/ir.model.access.csv',
+ 'wizard/document_wizard_view.xml',
+ ],
+ 'js': [
+ 'static/src/js/document.js'
+ ],
+ 'qweb': [
+ 'static/src/xml/document.xml'
+ ],
+ 'test': [],
+ 'demo': [
+ ],
+ 'installable': True,
+ 'auto_install': False,
+}
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added file 'document_multiple_records/document.py'
--- document_multiple_records/document.py 1970-01-01 00:00:00 +0000
+++ document_multiple_records/document.py 2014-03-19 15:30:33 +0000
@@ -0,0 +1,96 @@
+# -*- encoding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# This module copyright (C) 2014 Savoir-faire Linux
+# (<http://www.savoirfairelinux.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 openerp.osv import orm, fields
+
+
+class document_file(orm.Model):
+ _inherit = 'ir.attachment'
+
+ _columns = {
+ 'attachment_document_ids': fields.one2many('ir.attachment.document',
+ 'attachment_id',
+ 'Records'),
+ }
+
+ def create(self, cr, uid, data, context=None):
+ ir_attachment_document_obj = self.pool.get('ir.attachment.document')
+ original_data = {key: data[key] for key in data.keys()}
+ # Don't save this information below
+ if ('res_name', 'res_id', 'res_name') in data.keys():
+ data['res_model'] = False
+ data['res_id'] = False
+ data['res_name'] = False
+ res = super(document_file, self).create(cr, uid, data, context=context)
+ # Create attachment_document_ids with res_model, res_id and res_name
+ if 'res_model' and 'res_id' in original_data:
+ doc_data = {
+ 'attachment_id': res,
+ 'res_model': original_data['res_model'],
+ 'res_id': original_data['res_id'],
+ 'res_name': original_data.get('res_name')
+ or self.pool.get(original_data['res_model']).browse(cr, uid,
+ original_data['res_id'],
+ context=context).name
+ }
+ ir_attachment_document_obj.create(cr, uid, doc_data,
+ context=context)
+ return res
+
+ def unlink(self, cr, uid, ids, context=None, check=True):
+ ir_attach_doc_obj = self.pool.get('ir.attachment.document')
+ if context is None:
+ context = {}
+ # Deleting from dropdown list in the form view
+ if context.get('res_model') and context.get('res_id'):
+ for line in self.browse(cr, uid, ids, context=context):
+ if line.attachment_document_ids:
+ query = [
+ ('res_model', '=', context.get('res_model')),
+ ('res_id', '=', context.get('res_id')),
+ ('attachment_id', '=', ids),
+ ]
+ id_to_unlink = ir_attach_doc_obj.search(cr, uid, query, context=context)
+ result = ir_attach_doc_obj.unlink(cr, uid, id_to_unlink, context=context)
+ else:
+ # Normal delete
+ result = super(document_file, self).unlink(cr, uid, ids, context=context)
+ return result
+
+
+class ir_attachment_document(orm.Model):
+ _description = 'Attachment Documents'
+ _name = 'ir.attachment.document'
+
+ _columns = {
+ 'res_id': fields.integer('Resource ID', readonly=True,
+ help="The record id this is attached to."),
+ 'res_model': fields.char('Resource Model', size=64,
+ readonly=True,
+ help="The database object this attachment will be attached to"),
+ 'res_name': fields.char('Resource Name', type='char',
+ size=128,
+ readonly=True),
+ 'attachment_id': fields.many2one('ir.attachment', 'Attachment'),
+ }
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added file 'document_multiple_records/document_view.xml'
--- document_multiple_records/document_view.xml 1970-01-01 00:00:00 +0000
+++ document_multiple_records/document_view.xml 2014-03-19 15:30:33 +0000
@@ -0,0 +1,30 @@
+<?xml version="1.0"?>
+<openerp>
+<data>
+ <!--Add model list field-->
+ <record model="ir.ui.view" id="view_document_file_multiple_models_form">
+ <field name="name">ir.attachment.multiple.models</field>
+ <field name="model">ir.attachment</field>
+ <field name="inherit_id" ref="document.view_document_file_form"/>
+ <field name="arch" type="xml">
+ <group string="Indexed Content" position="after">
+ <group col="2" colspan="4">
+ <field name="attachment_document_ids" nolabel="1">
+ <tree string="AttachmentDocumentTree" create="false" version="7.0">
+ <field name="res_model"/>
+ <field name="res_id"/>
+ <field name="res_name"/>
+ </tree>
+ <form string="AttachmentDocumentForm">
+ <field name="res_model"/>
+ <field name="res_id"/>
+ <field name="res_name"/>
+ </form>
+ </field>
+ </group>
+ </group>
+ </field>
+ </record>
+</data>
+</openerp>
+
=== added directory 'document_multiple_records/i18n'
=== added file 'document_multiple_records/i18n/document_multiple_records.pot'
--- document_multiple_records/i18n/document_multiple_records.pot 1970-01-01 00:00:00 +0000
+++ document_multiple_records/i18n/document_multiple_records.pot 2014-03-19 15:30:33 +0000
@@ -0,0 +1,140 @@
+# Translation of OpenERP Server.
+# This file contains the translation of the following modules:
+# * document_multiple_records
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: OpenERP Server 7.0\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2014-02-06 19:28+0000\n"
+"PO-Revision-Date: 2014-02-06 14:29-0500\n"
+"Last-Translator: EL Hadji DEM <elhadji.dem@xxxxxxxxxxxxxxxxxxxx>\n"
+"Language-Team: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"Plural-Forms: \n"
+"X-Generator: Poedit 1.5.4\n"
+
+#. module: document_multiple_records
+#: field:ir.attachment.document,res_id:0
+msgid "Resource ID"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment.wizard:0
+msgid "Select document(s)"
+msgstr ""
+
+#. module: document_multiple_records
+#. openerp-web
+#: code:addons/document_multiple_records/static/src/xml/document.xml:7
+#, python-format
+msgid "Add existing Doc..."
+msgstr ""
+
+#. module: document_multiple_records
+#: field:ir.attachment.document,attachment_id:0
+msgid "Attachment"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment.wizard:0
+msgid "AttachmentDocumentWizardTree"
+msgstr ""
+
+#. module: document_multiple_records
+#. openerp-web
+#: code:addons/document_multiple_records/static/src/js/document.js:26
+#: model:ir.actions.act_window,name:document_multiple_records.action_view_document
+#: view:ir.attachment.wizard:0
+#, python-format
+msgid "Add Document"
+msgstr ""
+
+#. module: document_multiple_records
+#: field:ir.attachment.document,res_name:0
+msgid "Resource Name"
+msgstr ""
+
+#. module: document_multiple_records
+#: model:ir.model,name:document_multiple_records.model_ir_attachment_document
+msgid "Attachment Documents"
+msgstr ""
+
+#. module: document_multiple_records
+#: field:ir.attachment,attachmentdocument_ids:0
+msgid "Records"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment:0
+msgid "AttachmentDocumentTree"
+msgstr ""
+
+#. module: document_multiple_records
+#: model:ir.model,name:document_multiple_records.model_ir_attachment
+msgid "ir.attachment"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment:0
+msgid "Indexed Content"
+msgstr ""
+
+#. module: document_multiple_records
+#: model:ir.model,name:document_multiple_records.model_ir_attachment_wizard
+msgid "Attachment wizard"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment:0
+msgid "AttachmentDocumentForm"
+msgstr ""
+
+#. module: document_multiple_records
+#: code:addons/document_multiple_records/wizard/document_wizard.py:46
+#, python-format
+msgid "Error"
+msgstr ""
+
+#. module: document_multiple_records
+#: help:ir.attachment.document,res_model:0
+msgid "The database object this attachment will be attached to"
+msgstr ""
+
+#. module: document_multiple_records
+#: help:ir.attachment.document,res_id:0
+msgid "The record id this is attached to."
+msgstr ""
+
+#. module: document_multiple_records
+#: field:ir.attachment.wizard,attachment_ids:0
+msgid "Attachments"
+msgstr ""
+
+#. module: document_multiple_records
+#: field:ir.attachment.document,res_model:0
+msgid "Resource Model"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment.wizard:0
+msgid "Cancel"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment.wizard:0
+msgid "Apply"
+msgstr ""
+
+#. module: document_multiple_records
+#: view:ir.attachment.wizard:0
+msgid "or"
+msgstr ""
+
+#. module: document_multiple_records
+#: code:addons/document_multiple_records/wizard/document_wizard.py:47
+#, python-format
+msgid "You have to select at least 1 Document. And try again"
+msgstr ""
=== added directory 'document_multiple_records/security'
=== added file 'document_multiple_records/security/ir.model.access.csv'
--- document_multiple_records/security/ir.model.access.csv 1970-01-01 00:00:00 +0000
+++ document_multiple_records/security/ir.model.access.csv 2014-03-19 15:30:33 +0000
@@ -0,0 +1,2 @@
+id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
+access_ir_attachment_document_group_user,ir.attachment.document user,model_ir_attachment_document,base.group_document_user,1,1,1,1
=== added directory 'document_multiple_records/static'
=== added directory 'document_multiple_records/static/src'
=== added directory 'document_multiple_records/static/src/js'
=== added file 'document_multiple_records/static/src/js/document.js'
--- document_multiple_records/static/src/js/document.js 1970-01-01 00:00:00 +0000
+++ document_multiple_records/static/src/js/document.js 2014-03-19 15:30:33 +0000
@@ -0,0 +1,79 @@
+openerp.document_multiple_records = function(instance, m) {
+var _t = instance.web._t,
+ QWeb = instance.web.qweb;
+
+ instance.web.Sidebar.include({
+ redraw: function() {
+ var self = this;
+ this._super.apply(this, arguments);
+ self.$el.find('.oe_sidebar_add_attachment').after(QWeb.render('AddDocfromserver', {widget: self}))
+ self.$el.find('.open').on('click', function (e) {
+ self.on_call_new_view_function();
+ });
+ },
+ on_call_new_view_function: function(state) {
+ var self = this;
+ var view = self.getParent();
+ var ids = ( view.fields_view.type != "form" )? view.groups.get_selection().ids : [ view.datarecord.id ];
+ // you can pass in other data using the context dictionary variable
+ var context = {
+ 'model': view.dataset.model,
+ 'ids': ids,
+ };
+ // the action dictionary variable sends data in the "self.do_action" method
+ var action = {
+ name: _t("Add existing document"),
+ type: 'ir.actions.act_window',
+ res_model: 'ir.attachment.existing.doc',
+ view_mode: 'form',
+ view_type: 'form',
+ views: [[false, 'form']],
+ target: 'new',
+ context: context,
+ };
+ // self.do_action accepts the action parameter and opens the new view
+ self.do_action(action, {
+ // refresh list of documents
+ on_close: function () {
+ self.do_attachement_update(self.dataset, self.model_id);
+ }
+ });
+
+ },
+ on_attachment_delete: function(e) {
+ e.preventDefault();
+ e.stopPropagation();
+ var self = this;
+ var view = self.getParent();
+ self.model_view = view.dataset.model
+ var ids = ( view.fields_view.type != "form" )? view.groups.get_selection().ids : [ view.datarecord.id ];
+ // Context dictionary variable
+ var context = {
+ 'res_model': self.model_view,
+ 'res_id': ids[0],
+ };
+ var $e = $(e.currentTarget);
+ if (confirm(_t("Do you really want to delete this attachment ?"))) {
+ (new instance.web.DataSet(this, 'ir.attachment', context)).unlink([parseInt($e.attr('data-id'), 10)]).done(function() {
+ self.do_attachement_update(self.dataset, self.model_id);
+ });
+ }
+ },
+ do_attachement_update: function(dataset, model_id, args) {
+ var self = this;
+ this.dataset = dataset;
+ this.model_id = model_id;
+ if (args && args[0].error) {
+ this.do_warn(_t('Uploading Error'), args[0].error);
+ }
+ if (!model_id) {
+ this.on_attachments_loaded([]);
+ }
+ else {
+ var dom = [ ['attachment_document_ids.res_model', '=', dataset.model], ['attachment_document_ids.res_id', '=', model_id], ['type', 'in', ['binary', 'url']] ];
+ var ds = new instance.web.DataSetSearch(this, 'ir.attachment', dataset.get_context(), dom);
+ ds.read_slice(['name', 'url', 'type', 'create_uid', 'create_date', 'write_uid', 'write_date'], {}).done(this.on_attachments_loaded);
+ }
+ }
+ });
+};
=== added directory 'document_multiple_records/static/src/xml'
=== added file 'document_multiple_records/static/src/xml/document.xml'
--- document_multiple_records/static/src/xml/document.xml 1970-01-01 00:00:00 +0000
+++ document_multiple_records/static/src/xml/document.xml 2014-03-19 15:30:33 +0000
@@ -0,0 +1,10 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!-- vim:fdl=1:
+-->
+<templates id="template" xml:space="preserve">
+
+<t t-name="AddDocfromserver">
+ <li class="open"><span><b>Add existing document...</b></span></li>
+</t>
+
+</templates>
=== added directory 'document_multiple_records/wizard'
=== added file 'document_multiple_records/wizard/__init__.py'
--- document_multiple_records/wizard/__init__.py 1970-01-01 00:00:00 +0000
+++ document_multiple_records/wizard/__init__.py 2014-03-19 15:30:33 +0000
@@ -0,0 +1,25 @@
+# -*- encoding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# This module copyright (C) 2014 Savoir-faire Linux
+# (<http://www.savoirfairelinux.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 . import document_wizard
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added file 'document_multiple_records/wizard/document_wizard.py'
--- document_multiple_records/wizard/document_wizard.py 1970-01-01 00:00:00 +0000
+++ document_multiple_records/wizard/document_wizard.py 2014-03-19 15:30:33 +0000
@@ -0,0 +1,61 @@
+# -*- encoding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# This module copyright (C) 2014 Savoir-faire Linux
+# (<http://www.savoirfairelinux.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 openerp.osv import fields, orm
+from openerp.tools.translate import _
+
+
+class document_wizard(orm.Model):
+ _name = "ir.attachment.existing.doc"
+ _description = "Add existing document/attachment wizard"
+ _columns = {
+ 'attachment_ids': fields.many2many('ir.attachment',
+ 'document_attachment_rel',
+ 'wizard_id',
+ 'attachment_id',
+ 'Attachments'),
+ }
+
+ def action_apply(self, cr, uid, ids, context=None):
+ if context is None:
+ context = {}
+ ir_attach_obj = self.pool.get('ir.attachment')
+ ir_attach_doc_obj = self.pool.get('ir.attachment.document')
+ ir_model_obj = self.pool.get(context.get('model') or context.get('active_model'))
+
+ name = ir_model_obj.browse(cr, uid, context.get('ids') or context.get('active_ids'), context=context)[0]['name']
+ data = self.read(cr, uid, ids, [], context=context)[0]
+ if not data['attachment_ids']:
+ raise orm.except_orm(_('Error'),
+ _('You have to select at least 1 Document. And try again'))
+ for attach in ir_attach_obj.browse(cr, uid, data['attachment_ids'], context=context):
+ data_attach = {
+ 'res_model': context.get('model') or context.get('active_model'),
+ 'res_id': context.get('ids') and context.get('ids')[0] or context.get('active_id'),
+ 'res_name': name,
+ 'attachment_id': attach.id,
+ }
+ #Created attachment_document_ids
+ ir_attach_doc_obj.create(cr, uid, data_attach, context=context)
+ return {'type': 'ir.actions.act_window_close'}
+
+# vim:expandtab:smartindent:toabstop=4:softtabstop=4:shiftwidth=4:
=== added file 'document_multiple_records/wizard/document_wizard_view.xml'
--- document_multiple_records/wizard/document_wizard_view.xml 1970-01-01 00:00:00 +0000
+++ document_multiple_records/wizard/document_wizard_view.xml 2014-03-19 15:30:33 +0000
@@ -0,0 +1,41 @@
+<?xml version="1.0"?>
+<openerp>
+<data>
+
+ <record id="document_form_view" model="ir.ui.view">
+ <field name="name">Add existing document/attachment</field>
+ <field name="model">ir.attachment.existing.doc</field>
+ <field name="arch" type="xml">
+ <form string="Add existing document/attachment" version="7.0">
+ <group string="Select document(s)" colspan="4">
+ <field name="attachment_ids" nolabel="1">
+ <tree string="AttachmentDocumentWizardTree">
+ <field name="name"/>
+ <field name="create_uid"/>
+ <field name="create_date"/>
+ <field name="type"/>
+ </tree>
+ </field>
+ </group>
+ <footer>
+ <button string="Apply" name="action_apply" type="object" class="oe_highlight"/>
+ or
+ <button string="Cancel" class="oe_link" special="cancel" />
+ </footer>
+ </form>
+ </field>
+ </record>
+
+ <!-- Actions -->
+ <record model="ir.actions.act_window" id="action_view_document">
+ <field name="name">Add existing document/attachment</field>
+ <field name="res_model">ir.attachment.existing.doc</field>
+ <field name="view_type">form</field>
+ <field name="view_mode">tree,form</field>
+ <field name="view_id" ref="document_form_view"/>
+ <field name="target">new</field>
+ </record>
+
+</data>
+</openerp>
+
Follow ups