From 31d95fe243ed81cac722f70294fbab6bf76abfc8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Todorovich?= Date: Fri, 20 Apr 2018 10:42:10 -0300 Subject: [PATCH 1/4] [document_page] FIX creating history when there are no changes made. Add history name field, to name revisions. Modified views to allow setting this field. --- document_page/models/document_page.py | 17 ++++++++++++++--- document_page/models/document_page_history.py | 5 +++-- document_page/views/document_page.xml | 14 +++++++++----- document_page/views/document_page_history.xml | 8 +++++--- 4 files changed, 31 insertions(+), 13 deletions(-) diff --git a/document_page/models/document_page.py b/document_page/models/document_page.py index 24524210..80ffd053 100644 --- a/document_page/models/document_page.py +++ b/document_page/models/document_page.py @@ -42,7 +42,16 @@ class DocumentPage(models.Model): ) # no-op computed field - summary = fields.Char( + draft_name = fields.Char( + string='Name', + help='Name for the changes made', + compute=lambda x: x, + inverse=lambda x: x, + ) + + # no-op computed field + draft_summary = fields.Char( + string='Summary', help='Describe the changes made', compute=lambda x: x, inverse=lambda x: x, @@ -124,10 +133,12 @@ class DocumentPage(models.Model): @api.multi def _inverse_content(self): for rec in self: - if rec.type == 'content': + if rec.type == 'content' and \ + rec.content != rec.history_head.content: rec._create_history({ + 'name': rec.draft_name, + 'summary': rec.draft_summary, 'content': rec.content, - 'summary': rec.summary, }) @api.multi diff --git a/document_page/models/document_page_history.py b/document_page/models/document_page_history.py index a5e70e78..00317854 100644 --- a/document_page/models/document_page_history.py +++ b/document_page/models/document_page_history.py @@ -14,8 +14,9 @@ class DocumentPageHistory(models.Model): _order = 'id DESC' page_id = fields.Many2one('document.page', 'Page', ondelete='cascade') - summary = fields.Char('Summary', index=True) - content = fields.Text("Content") + name = fields.Char(index=True) + summary = fields.Char(index=True) + content = fields.Text() diff = fields.Text(compute='_compute_diff') @api.multi diff --git a/document_page/views/document_page.xml b/document_page/views/document_page.xml index f19341a5..b291673e 100644 --- a/document_page/views/document_page.xml +++ b/document_page/views/document_page.xml @@ -54,17 +54,21 @@ - + diff --git a/document_page/views/document_page_history.xml b/document_page/views/document_page_history.xml index b0b49faf..dd08afa2 100755 --- a/document_page/views/document_page_history.xml +++ b/document_page/views/document_page_history.xml @@ -9,6 +9,7 @@ + @@ -46,11 +47,12 @@ + + + + - From 57468bd4b314ac0e8189b5900de3da31838dfc06 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Todorovich?= Date: Mon, 23 Apr 2018 16:27:38 -0300 Subject: [PATCH 2/4] [document_page] FIX BUG: UI hanging when editing content. This was due to the api.depends on _compute_diff. Removing it because it's not really necessary since the field is not stored. --- document_page/models/document_page_history.py | 1 - 1 file changed, 1 deletion(-) diff --git a/document_page/models/document_page_history.py b/document_page/models/document_page_history.py index 00317854..31411ba7 100644 --- a/document_page/models/document_page_history.py +++ b/document_page/models/document_page_history.py @@ -20,7 +20,6 @@ class DocumentPageHistory(models.Model): diff = fields.Text(compute='_compute_diff') @api.multi - @api.depends('content', 'page_id.history_ids') def _compute_diff(self): """Shows a diff between this version and the previous version""" history = self.env['document.page.history'] From 8612f78b7b7289d0837989d92f7dd1068050d569 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Todorovich?= Date: Tue, 24 Apr 2018 15:06:39 -0300 Subject: [PATCH 3/4] [document_page] page_id should be readonly. Improve active field --- document_page/models/document_page.py | 2 ++ document_page/views/document_page.xml | 5 +++++ document_page/views/document_page_history.xml | 2 +- 3 files changed, 8 insertions(+), 1 deletion(-) diff --git a/document_page/models/document_page.py b/document_page/models/document_page.py index 80ffd053..3cb3b527 100644 --- a/document_page/models/document_page.py +++ b/document_page/models/document_page.py @@ -21,6 +21,8 @@ class DocumentPage(models.Model): default="content" ) + active = fields.Boolean(default=True) + parent_id = fields.Many2one( 'document.page', 'Category', diff --git a/document_page/views/document_page.xml b/document_page/views/document_page.xml index b291673e..c9681ff5 100644 --- a/document_page/views/document_page.xml +++ b/document_page/views/document_page.xml @@ -38,6 +38,11 @@
+
+ +

diff --git a/document_page/views/document_page_history.xml b/document_page/views/document_page_history.xml index dd08afa2..413fd6e4 100755 --- a/document_page/views/document_page_history.xml +++ b/document_page/views/document_page_history.xml @@ -40,7 +40,7 @@ -

+

From 91d7b9e1440ae0232f9c97e66fcc497cc420cf4c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Todorovich?= Date: Tue, 24 Apr 2018 15:37:00 -0300 Subject: [PATCH 4/4] [document_page] Update version number --- document_page/__manifest__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/document_page/__manifest__.py b/document_page/__manifest__.py index 29e548cc..a6573d96 100644 --- a/document_page/__manifest__.py +++ b/document_page/__manifest__.py @@ -4,7 +4,7 @@ { 'name': 'Document Page', - 'version': '11.0.1.0.0', + 'version': '11.0.2.0.0', 'category': 'Knowledge Management', 'author': 'OpenERP SA, Odoo Community Association (OCA)', 'images': [