From c2a78a3c0d6789b499c107a2790adab35741da76 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] [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 | 13 +++++++++---- document_page/views/document_page_history.xml | 8 +++++--- 4 files changed, 31 insertions(+), 12 deletions(-) diff --git a/document_page/models/document_page.py b/document_page/models/document_page.py index 3824dc5d..e787341a 100644 --- a/document_page/models/document_page.py +++ b/document_page/models/document_page.py @@ -43,7 +43,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, @@ -139,10 +148,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 8334d6ab..9b5bdb72 100644 --- a/document_page/models/document_page_history.py +++ b/document_page/models/document_page_history.py @@ -15,8 +15,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 78b8f1b3..f91ddab0 100644 --- a/document_page/views/document_page.xml +++ b/document_page/views/document_page.xml @@ -52,16 +52,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 @@ + + + + -