← Back to team overview

savoirfairelinux-openerp team mailing list archive

[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