From a6c6ddbc806b2e5ca52f27cdc4befce2fe69244f Mon Sep 17 00:00:00 2001 From: Nathan Gray Date: Mon, 25 Jun 2012 23:38:26 +0000 Subject: [PATCH] Improve handling of history diff to make sure there's only one column --- etemplate/js/et2_widget_historylog.js | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/etemplate/js/et2_widget_historylog.js b/etemplate/js/et2_widget_historylog.js index b131e82352..c5c41523c8 100644 --- a/etemplate/js/et2_widget_historylog.js +++ b/etemplate/js/et2_widget_historylog.js @@ -299,7 +299,8 @@ var et2_historylog = et2_valueWidget.extend([et2_IDataProvider],{ { nodes = self.columns[i].nodes.clone(); } - else if (self._needsDiffWidget(_data['status'], _data[self.columns[i].id])) + else if (self._needsDiffWidget(_data['status'], _data[self.columns[self.OLD_VALUE].id]) || + self._needsDiffWidget(_data['status'], _data[self.columns[self.NEW_VALUE].id])) { // Large text value - span both columns, and show a nice diff var jthis = jQuery(this); @@ -317,17 +318,15 @@ var et2_historylog = et2_valueWidget.extend([et2_IDataProvider],{ // Skip column 4 jthis.parents("td").attr("colspan", 2) .css("border-right", "none"); - jthis.css("width", (self.dataview.columnMgr.columnWidths[i] + self.dataview.columnMgr.columnWidths[i+1]-8)+'px'); + jthis.css("width", (self.dataview.columnMgr.columnWidths[i] + self.dataview.columnMgr.columnWidths[i+1]-10)+'px'); if(widget) widget.setDetachedAttributes(nodes, { value:_data[self.columns[i].id], label: jthis.parents("td").prev().text() }); - } - else if (i == 4) - { + // Skip column 4 - jthis.parents("td").remove(); + jthis.parents("td").next().remove(); } } else @@ -347,6 +346,11 @@ var et2_historylog = et2_valueWidget.extend([et2_IDataProvider],{ * How to tell if the row needs a diff widget or not */ _needsDiffWidget: function(columnName, value) { + if(typeof value !== "string") + { + this.egw().debug("warning", "Crazy diff value", value); + return false; + } return columnName == 'note' || columnName == 'description' || (value && (value.length > 50 || value.match(/\n/g))) }, });