mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-20 12:58:46 +01:00
Automatically handle link history entries
This commit is contained in:
parent
acd7f43303
commit
aafca99105
@ -24,7 +24,10 @@
|
|||||||
/**
|
/**
|
||||||
* eTemplate history log widget displays a list of changes to the current record.
|
* eTemplate history log widget displays a list of changes to the current record.
|
||||||
* The widget is encapsulated, and only needs the record's ID, and a map of
|
* The widget is encapsulated, and only needs the record's ID, and a map of
|
||||||
* fields:widgets for display
|
* fields:widgets for display.
|
||||||
|
*
|
||||||
|
* It defers its initialization until the tab that it's on is selected, to avoid
|
||||||
|
* wasting time if the user never looks at it.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
var et2_historylog = et2_valueWidget.extend([et2_IDataProvider],{
|
var et2_historylog = et2_valueWidget.extend([et2_IDataProvider],{
|
||||||
@ -48,14 +51,13 @@ var et2_historylog = et2_valueWidget.extend([et2_IDataProvider],{
|
|||||||
appname: this.options.value.app,
|
appname: this.options.value.app,
|
||||||
get_rows: 'historylog::get_rows'
|
get_rows: 'historylog::get_rows'
|
||||||
};
|
};
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
doLoadingFinished: function() {
|
doLoadingFinished: function() {
|
||||||
this._super.apply(this, arguments);
|
this._super.apply(this, arguments);
|
||||||
|
|
||||||
// Find the tab widget, if there is one
|
// Find the tab widget, if there is one
|
||||||
var tabs = this;
|
var tabs = this;
|
||||||
var count = 0;
|
|
||||||
do {
|
do {
|
||||||
tabs = tabs._parent;
|
tabs = tabs._parent;
|
||||||
} while (tabs != this.getRoot() && tabs._type != 'tabbox');
|
} while (tabs != this.getRoot() && tabs._type != 'tabbox');
|
||||||
@ -86,6 +88,9 @@ var count = 0;
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finish initialization which was skipped until tab was selected
|
||||||
|
*/
|
||||||
finishInit: function() {
|
finishInit: function() {
|
||||||
|
|
||||||
// Create the dynheight component which dynamically scales the inner
|
// Create the dynheight component which dynamically scales the inner
|
||||||
@ -164,6 +169,13 @@ var count = 0;
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add in handling for links
|
||||||
|
if(typeof this.options.value['status-widgets']['~link~'] == 'undefined')
|
||||||
|
{
|
||||||
|
this.columns[2].widget.optionValues['~link~'] = this.egw().lang('link');
|
||||||
|
this.options.value['status-widgets']['~link~'] = 'link';
|
||||||
|
}
|
||||||
|
|
||||||
// Per-field widgets - new value & old value
|
// Per-field widgets - new value & old value
|
||||||
this.fields = {};
|
this.fields = {};
|
||||||
for(var key in this.options.value['status-widgets'])
|
for(var key in this.options.value['status-widgets'])
|
||||||
@ -181,7 +193,6 @@ var count = 0;
|
|||||||
nodes: jQuery(widget.getDetachedNodes())
|
nodes: jQuery(widget.getDetachedNodes())
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
// Widget for text diffs
|
// Widget for text diffs
|
||||||
var diff = et2_createWidget('diff', {}, this);
|
var diff = et2_createWidget('diff', {}, this);
|
||||||
this.diff = {
|
this.diff = {
|
||||||
@ -255,6 +266,7 @@ var count = 0;
|
|||||||
}
|
}
|
||||||
else if (self._needsDiffWidget(_data['status'], _data[self.columns[i].id]))
|
else if (self._needsDiffWidget(_data['status'], _data[self.columns[i].id]))
|
||||||
{
|
{
|
||||||
|
// Large text value - span both columns, and show a nice diff
|
||||||
var jthis = jQuery(this);
|
var jthis = jQuery(this);
|
||||||
if(i == 3)
|
if(i == 3)
|
||||||
{
|
{
|
||||||
@ -285,6 +297,7 @@ var count = 0;
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// No widget fallback - display actual value
|
||||||
nodes = '<span>'+_data[self.columns[i].id] + '</span>';
|
nodes = '<span>'+_data[self.columns[i].id] + '</span>';
|
||||||
}
|
}
|
||||||
if(widget) widget.setDetachedAttributes(nodes, {value:_data[self.columns[i].id]});
|
if(widget) widget.setDetachedAttributes(nodes, {value:_data[self.columns[i].id]});
|
||||||
|
Loading…
Reference in New Issue
Block a user