4 +--------------------------------------------------------------------+
5 | CiviCRM version 4.4 |
6 +--------------------------------------------------------------------+
7 | Copyright CiviCRM LLC (c) 2004-2013 |
8 +--------------------------------------------------------------------+
9 | This file is a part of CiviCRM. |
11 | CiviCRM is free software; you can copy, modify, and distribute it |
12 | under the terms of the GNU Affero General Public License |
13 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
15 | CiviCRM is distributed in the hope that it will be useful, but |
16 | WITHOUT ANY WARRANTY; without even the implied warranty of |
17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
18 | See the GNU Affero General Public License for more details. |
20 | You should have received a copy of the GNU Affero General Public |
21 | License and the CiviCRM Licensing Exception along |
22 | with this program; if not, contact CiviCRM LLC |
23 | at info[AT]civicrm[DOT]org. If you have questions about the |
24 | GNU Affero General Public License or the licensing of CiviCRM, |
25 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
26 +--------------------------------------------------------------------+
32 * @copyright CiviCRM LLC (c) 2004-2013
38 * Page for displaying list of Reprot templates available
40 class CRM_Report_Page_TemplateList
extends CRM_Core_Page
{
42 public static function &info($compID = NULL, $grouping = NULL) {
43 $all = CRM_Utils_Request
::retrieve('all', 'Boolean', CRM_Core_DAO
::$_nullObject,
50 $compClause = " AND v.component_id IS NULL ";
52 $compClause = " AND v.component_id = {$compID} ";
56 $compClause = " AND v.grouping = '{$grouping}' ";
59 SELECT v.id, v.value, v.label, v.description, v.component_id,
61 WHEN comp.name IS NOT NULL THEN SUBSTRING(comp.name, 5)
62 WHEN v.grouping IS NOT NULL THEN v.grouping
64 END as component_name,
66 inst.id as instance_id
67 FROM civicrm_option_value v
68 INNER JOIN civicrm_option_group g
69 ON (v.option_group_id = g.id AND g.name = 'report_template')
70 LEFT JOIN civicrm_report_instance inst
71 ON v.value = inst.report_id
72 LEFT JOIN civicrm_component comp
73 ON v.component_id = comp.id
77 $sql .= " WHERE v.is_active = 1 {$compClause}";
79 $sql .= " ORDER BY v.weight ";
81 $dao = CRM_Core_DAO
::executeQuery($sql);
83 $config = CRM_Core_Config
::singleton();
84 while ($dao->fetch()) {
85 if ($dao->component_name
!= 'Contact' && $dao->component_name
!= $dao->grouping
&&
86 !in_array("Civi{$dao->component_name}", $config->enableComponents
)
90 $rows[$dao->component_name
][$dao->value
]['title'] = $dao->label
;
91 $rows[$dao->component_name
][$dao->value
]['description'] = $dao->description
;
92 $rows[$dao->component_name
][$dao->value
]['url'] = CRM_Utils_System
::url('civicrm/report/' . trim($dao->value
, '/'), 'reset=1');
93 if ($dao->instance_id
) {
94 $rows[$dao->component_name
][$dao->value
]['instanceUrl'] = CRM_Utils_System
::url('civicrm/report/list',
95 "reset=1&ovid={$dao->id}"
104 * run this page (figure out the action needed and perform it).
109 $compID = CRM_Utils_Request
::retrieve('compid', 'Positive', $this);
110 $grouping = CRM_Utils_Request
::retrieve('grp', 'String', $this);
111 $rows = self
::info($compID, $grouping);
112 $this->assign('list', $rows);
114 return parent
::run();