mirror of
https://github.com/silverstripe/silverstripe-reports
synced 2024-10-22 11:05:53 +02:00
102 lines
2.5 KiB
PHP
102 lines
2.5 KiB
PHP
<?php
|
|
/**
|
|
* Reports section of the CMS.
|
|
*
|
|
* All reports that should show in the ReportAdmin section
|
|
* of the CMS need to subclass {@link SS_Report}, and implement
|
|
* the appropriate methods and variables that are required.
|
|
*
|
|
* @see SS_Report
|
|
*
|
|
* @package cms
|
|
* @subpackage reports
|
|
*/
|
|
class ReportAdmin extends LeftAndMain {
|
|
|
|
static $url_segment = 'reports';
|
|
|
|
static $url_rule = '/$Action/$ID';
|
|
|
|
static $menu_title = 'Reports';
|
|
|
|
static $template_path = null; // defaults to (project)/templates/email
|
|
|
|
static $tree_class = 'SS_Report';
|
|
|
|
public function init() {
|
|
parent::init();
|
|
|
|
Requirements::css(CMS_DIR . '/css/ReportAdmin.css');
|
|
|
|
// Set custom options for TinyMCE specific to ReportAdmin
|
|
HtmlEditorConfig::get('cms')->setOption('ContentCSS', project() . '/css/editor.css');
|
|
HtmlEditorConfig::get('cms')->setOption('Lang', i18n::get_tinymce_lang());
|
|
|
|
// Always block the HtmlEditorField.js otherwise it will be sent with an ajax request
|
|
Requirements::block(SAPPHIRE_DIR . '/javascript/HtmlEditorField.js');
|
|
}
|
|
|
|
/**
|
|
* Does the parent permission checks, but also
|
|
* makes sure that instantiatable subclasses of
|
|
* {@link Report} exist. By default, the CMS doesn't
|
|
* include any Reports, so there's no point in showing
|
|
*
|
|
* @param Member $member
|
|
* @return boolean
|
|
*/
|
|
function canView($member = null) {
|
|
if(!$member && $member !== FALSE) $member = Member::currentUser();
|
|
|
|
if(!parent::canView($member)) return false;
|
|
|
|
$hasViewableSubclasses = false;
|
|
foreach($this->Reports() as $report) {
|
|
if($report->canView($member)) return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
function currentPageID() {
|
|
$id = parent::currentPageID();
|
|
$reports = SS_Report::get_reports('ReportAdmin');
|
|
return (isset($reports[$id])) ? $reports[$id] : null;
|
|
}
|
|
|
|
/**
|
|
* Return a SS_List of SS_Report subclasses
|
|
* that are available for use.
|
|
*
|
|
* @return SS_List
|
|
*/
|
|
public function Reports() {
|
|
$output = new ArrayList();
|
|
foreach(SS_Report::get_reports('ReportAdmin') as $report) {
|
|
if($report->canView()) $output->push($report);
|
|
}
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Determine if we have reports and need
|
|
* to display the "Reports" main menu item
|
|
* in the CMS.
|
|
*
|
|
* The test for an existance of a report
|
|
* is done by checking for a subclass of
|
|
* "SS_Report" that exists.
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public static function has_reports() {
|
|
return sizeof(SS_Report::get_reports('ReportAdmin')) > 0;
|
|
}
|
|
|
|
public function updatereport() {
|
|
FormResponse::load_form($this->EditForm()->forTemplate());
|
|
return FormResponse::respond();
|
|
}
|
|
}
|
|
|
|
?>
|