From 64fbc7810f933492e29e1847d7b0ca56efb3c3d7 Mon Sep 17 00:00:00 2001 From: Nathan Gray Date: Mon, 18 Aug 2014 20:22:11 +0000 Subject: [PATCH] Create & use a flag 'no_actions' to disable actions for sum rows --- etemplate/js/et2_dataview_controller.js | 28 ++++++++++++++---------- timesheet/inc/class.timesheet_ui.inc.php | 4 ++++ 2 files changed, 20 insertions(+), 12 deletions(-) diff --git a/etemplate/js/et2_dataview_controller.js b/etemplate/js/et2_dataview_controller.js index 33b76cc85d..07fdbaf584 100644 --- a/etemplate/js/et2_dataview_controller.js +++ b/etemplate/js/et2_dataview_controller.js @@ -634,20 +634,24 @@ var et2_dataview_controller = Class.extend({ var links = null; - // Get the action links if the links callback is set - if (this.self._linkCallback) + // Look for a flag in the row to avoid actions. Use for sums or extra header rows. + if(!_data.no_actions) { - links = this.self._linkCallback.call( - this.self._context, - _data, - this.entry.idx, - this.entry.uid - ); - } + // Get the action links if the links callback is set + if (this.self._linkCallback) + { + links = this.self._linkCallback.call( + this.self._context, + _data, + this.entry.idx, + this.entry.uid + ); + } - // Register the row in the selection manager - this.self._selectionMgr.registerRow(this.entry.uid, this.entry.idx, - tr, links); + // Register the row in the selection manager + this.self._selectionMgr.registerRow(this.entry.uid, this.entry.idx, + tr, links); + } // Invalidate the current row entry this.entry.row.invalidate(); diff --git a/timesheet/inc/class.timesheet_ui.inc.php b/timesheet/inc/class.timesheet_ui.inc.php index a37408061d..fdc42afa0d 100644 --- a/timesheet/inc/class.timesheet_ui.inc.php +++ b/timesheet/inc/class.timesheet_ui.inc.php @@ -705,6 +705,10 @@ class timesheet_ui extends timesheet_bo // Remove fake modified date, it breaks nextmatch checks unset($row['ts_modified']); + + // Set flag to avoid actions on these rows + $row['no_actions'] = true; + switch($row['ts_id']) { case 0: // day-sum