add piwik installation
This commit is contained in:
parent
90aa4ef157
commit
8c5d4f0c31
3197 changed files with 563902 additions and 0 deletions
129
www/analytics/core/View/ReportsByDimension.php
Normal file
129
www/analytics/core/View/ReportsByDimension.php
Normal file
|
|
@ -0,0 +1,129 @@
|
|||
<?php
|
||||
/**
|
||||
* Piwik - Open source web analytics
|
||||
*
|
||||
* @link http://piwik.org
|
||||
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
|
||||
*
|
||||
*/
|
||||
namespace Piwik\View;
|
||||
|
||||
use Piwik\FrontController;
|
||||
use Piwik\Piwik;
|
||||
use Piwik\Url;
|
||||
use Piwik\View;
|
||||
|
||||
/**
|
||||
* A facade that makes it easier to use the '_reportsByDimension.twig' template.
|
||||
*
|
||||
* This view will output HTML that displays a list of report names by category and
|
||||
* loads them by AJAX when clicked. The loaded report is displayed to the right
|
||||
* of the report listing.
|
||||
*/
|
||||
class ReportsByDimension extends View
|
||||
{
|
||||
/**
|
||||
* Constructor.
|
||||
*
|
||||
* @param string $id
|
||||
*/
|
||||
public function __construct($id)
|
||||
{
|
||||
parent::__construct('@CoreHome/ReportsByDimension/_reportsByDimension');
|
||||
$this->dimensionCategories = array();
|
||||
$this->id = $id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a report to the list of reports to display.
|
||||
*
|
||||
* @param string $category The report's category. Can be a i18n token.
|
||||
* @param string $title The report's title. Can be a i18n token.
|
||||
* @param string $action The controller action used to load the report, ie, Referrers.getAll
|
||||
* @param array $params The list of query parameters to use when loading the report.
|
||||
* This list overrides query parameters currently in use. For example,
|
||||
* array('idSite' => 2, 'viewDataTable' => 'goalsTable')
|
||||
* would mean the goals report for site w/ ID=2 will always be loaded.
|
||||
*/
|
||||
public function addReport($category, $title, $action, $params = array())
|
||||
{
|
||||
list($module, $action) = explode('.', $action);
|
||||
$params = array('module' => $module, 'action' => $action) + $params;
|
||||
|
||||
$categories = $this->dimensionCategories;
|
||||
$categories[$category][] = array(
|
||||
'title' => $title,
|
||||
'params' => $params,
|
||||
'url' => Url::getCurrentQueryStringWithParametersModified($params)
|
||||
);
|
||||
$this->dimensionCategories = $categories;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a set of reports to the list of reports to display.
|
||||
*
|
||||
* @param array $reports An array containing report information. The array requires
|
||||
* the 'category', 'title', 'action' and 'params' elements.
|
||||
* For information on what they should contain, @see addReport.
|
||||
*/
|
||||
public function addReports($reports)
|
||||
{
|
||||
foreach ($reports as $report) {
|
||||
$this->addReport($report['category'], $report['title'], $report['action'], $report['params']);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string The ID specified in the constructor, usually the plugin name
|
||||
*/
|
||||
public function getId()
|
||||
{
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Renders this view.
|
||||
*
|
||||
* @return string The rendered view.
|
||||
*/
|
||||
public function render()
|
||||
{
|
||||
/**
|
||||
* Triggered before rendering {@link ReportsByDimension} views.
|
||||
*
|
||||
* Plugins can use this event to configure {@link ReportsByDimension} instances by
|
||||
* adding or removing reports to display.
|
||||
*
|
||||
* @param ReportsByDimension $this The view instance.
|
||||
*/
|
||||
Piwik::postEvent('View.ReportsByDimension.render', array($this));
|
||||
|
||||
$this->firstReport = "";
|
||||
|
||||
// if there are reports & report categories added, render the first one so we can
|
||||
// display it initially
|
||||
$categories = $this->dimensionCategories;
|
||||
if (!empty($categories)) {
|
||||
$firstCategory = reset($categories);
|
||||
$firstReportInfo = reset($firstCategory);
|
||||
|
||||
$oldGet = $_GET;
|
||||
$oldPost = $_POST;
|
||||
|
||||
foreach ($firstReportInfo['params'] as $key => $value) {
|
||||
$_GET[$key] = $value;
|
||||
}
|
||||
|
||||
$_POST = array();
|
||||
|
||||
$module = $firstReportInfo['params']['module'];
|
||||
$action = $firstReportInfo['params']['action'];
|
||||
$this->firstReport = FrontController::getInstance()->fetchDispatch($module, $action);
|
||||
|
||||
$_GET = $oldGet;
|
||||
$_POST = $oldPost;
|
||||
}
|
||||
|
||||
return parent::render();
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue