Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/VisitsSummary/Controller.php')
-rw-r--r--plugins/VisitsSummary/Controller.php134
1 files changed, 23 insertions, 111 deletions
diff --git a/plugins/VisitsSummary/Controller.php b/plugins/VisitsSummary/Controller.php
index 336ee26937..ca141b7ed8 100644
--- a/plugins/VisitsSummary/Controller.php
+++ b/plugins/VisitsSummary/Controller.php
@@ -12,8 +12,9 @@ use Piwik\API\Request;
use Piwik\Common;
use Piwik\DataTable;
use Piwik\DataTable\Row;
+use Piwik\FrontController;
use Piwik\Piwik;
-use Piwik\Plugins\Actions\API as APIActions;
+use Piwik\Plugins\CoreVisualizations\Visualizations\Sparklines;
use Piwik\Site;
use Piwik\Translation\Translator;
use Piwik\View;
@@ -35,38 +36,32 @@ class Controller extends \Piwik\Plugin\Controller
parent::__construct();
}
- public function index()
+ /**
+ * @deprecated used to be a widgetized URL. There to not break widget URLs
+ */
+ public function getSparklines()
{
- $view = new View('@VisitsSummary/index');
- $this->setPeriodVariablesView($view);
- $view->graphEvolutionVisitsSummary = $this->getEvolutionGraph(array(), array('nb_visits'), 'getIndexGraph');
- $this->setSparklinesAndNumbers($view);
- return $view->render();
- }
+ $_GET['forceView'] = '1';
+ $_GET['viewDataTable'] = Sparklines::ID;
- // sparkline.js:81 dataTable.trigger('reload', …); does not remove the old headline,
- // so when updating this graph (such as when selecting a different metric)
- // ONLY the graph should be returned
- public function getIndexGraph()
- {
- return $this->getEvolutionGraph(array(), array(), __FUNCTION__);
+ return FrontController::getInstance()->fetchDispatch('VisitsSummary', 'get');
}
- public function getSparklines()
+ /**
+ * @deprecated used to be a widgetized URL. There to not break widget URLs
+ */
+ public function index()
{
- $view = new View('@VisitsSummary/getSparklines');
- $this->setPeriodVariablesView($view);
- $this->setSparklinesAndNumbers($view);
- return $view->render();
+ $_GET['containerId'] = 'VisitOverviewWithGraph';
+
+ return FrontController::getInstance()->fetchDispatch('CoreHome', 'renderWidgetContainer');
}
- public function getEvolutionGraph(array $columns = array(), array $defaultColumns = array(), $callingAction = __FUNCTION__)
+ public function getEvolutionGraph()
{
- if (empty($columns)) {
- $columns = Common::getRequestVar('columns', false);
- if (false !== $columns) {
- $columns = Piwik::getArrayFromApiParameter($columns);
- }
+ $columns = Common::getRequestVar('columns', false);
+ if (false !== $columns) {
+ $columns = Piwik::getArrayFromApiParameter($columns);
}
$documentation = $this->translator->translate('VisitsSummary_VisitsSummaryDocumentation') . '<br />'
@@ -116,11 +111,11 @@ class Controller extends \Piwik\Plugin\Controller
}
// $callingAction may be specified to distinguish between
// "VisitsSummary_WidgetLastVisits" and "VisitsSummary_WidgetOverviewGraph"
- $view = $this->getLastUnitGraphAcrossPlugins($this->pluginName, $callingAction, $columns,
+ $view = $this->getLastUnitGraphAcrossPlugins($this->pluginName, __FUNCTION__, $columns,
$selectableColumns, $documentation);
- if (empty($view->config->columns_to_display) && !empty($defaultColumns)) {
- $view->config->columns_to_display = $defaultColumns;
+ if (empty($view->config->columns_to_display)) {
+ $view->config->columns_to_display = array('nb_visits');
}
return $this->renderView($view);
@@ -137,87 +132,4 @@ class Controller extends \Piwik\Plugin\Controller
return empty($result) ? new DataTable() : $result;
}
-
- public static function getVisits()
- {
- $requestString = "method=VisitsSummary.getVisits" .
- "&format=original" .
- "&disable_generic_filters=1";
- $request = new Request($requestString);
- return $request->process();
- }
-
- protected function setSparklinesAndNumbers($view)
- {
- $view->urlSparklineNbVisits = $this->getUrlSparkline('getEvolutionGraph', array('columns' => $view->displayUniqueVisitors ? array('nb_visits', 'nb_uniq_visitors') : array('nb_visits')));
- $view->urlSparklineNbUsers = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('nb_users')));
- $view->urlSparklineNbPageviews = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('nb_pageviews', 'nb_uniq_pageviews')));
- $view->urlSparklineNbDownloads = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('nb_downloads', 'nb_uniq_downloads')));
- $view->urlSparklineNbOutlinks = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('nb_outlinks', 'nb_uniq_outlinks')));
- $view->urlSparklineAvgVisitDuration = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('avg_time_on_site')));
- $view->urlSparklineMaxActions = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('max_actions')));
- $view->urlSparklineActionsPerVisit = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('nb_actions_per_visit')));
- $view->urlSparklineBounceRate = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('bounce_rate')));
- $view->urlSparklineAvgGenerationTime = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('avg_time_generation')));
-
- $idSite = Common::getRequestVar('idSite');
- $displaySiteSearch = Site::isSiteSearchEnabledFor($idSite);
- if ($displaySiteSearch) {
- $view->urlSparklineNbSearches = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('nb_searches', 'nb_keywords')));
- }
- $view->displaySiteSearch = $displaySiteSearch;
-
- $dataTableVisit = self::getVisitsSummary();
- $dataRow = $dataTableVisit->getRowsCount() == 0 ? new Row() : $dataTableVisit->getFirstRow();
- $view->nbUniqVisitors = (int)$dataRow->getColumn('nb_uniq_visitors');
- $view->nbUsers = (int)$dataRow->getColumn('nb_users');
- $nbVisits = (int)$dataRow->getColumn('nb_visits');
- $view->nbVisits = $nbVisits;
-
- $view->averageVisitDuration = $dataRow->getColumn('avg_time_on_site');
- $view->bounceRate = $dataRow->getColumn('bounce_rate');
- $view->maxActions = (int)$dataRow->getColumn('max_actions');
- $view->nbActionsPerVisit = $dataRow->getColumn('nb_actions_per_visit');
-
- if (Common::isActionsPluginEnabled()) {
- $view->showActionsPluginReports = true;
-
- $dataTableActions = Request::processRequest("Actions.get", array(
- 'idSite' => $idSite,
- 'period' => Common::getRequestVar('period'),
- 'date' => Common::getRequestVar('date'),
- 'segment' => Request::getRawSegmentFromRequest()
- ), $defaultParams = array());
-
- $dataActionsRow =
- $dataTableActions->getRowsCount() == 0 ? new Row() : $dataTableActions->getFirstRow();
-
- $view->nbPageviews = (int)$dataActionsRow->getColumn('nb_pageviews');
- $view->nbUniquePageviews = (int)$dataActionsRow->getColumn('nb_uniq_pageviews');
- $view->nbDownloads = (int)$dataActionsRow->getColumn('nb_downloads');
- $view->nbUniqueDownloads = (int)$dataActionsRow->getColumn('nb_uniq_downloads');
- $view->nbOutlinks = (int)$dataActionsRow->getColumn('nb_outlinks');
- $view->nbUniqueOutlinks = (int)$dataActionsRow->getColumn('nb_uniq_outlinks');
- $view->averageGenerationTime = $dataActionsRow->getColumn('avg_time_generation');
-
- if ($displaySiteSearch) {
- $view->nbSearches = (int)$dataActionsRow->getColumn('nb_searches');
- $view->nbKeywords = (int)$dataActionsRow->getColumn('nb_keywords');
- }
-
- // backward compatibility:
- // show actions if the finer metrics are not archived
- $view->showOnlyActions = false;
- if ($dataActionsRow->getColumn('nb_pageviews')
- + $dataActionsRow->getColumn('nb_downloads')
- + $dataActionsRow->getColumn('nb_outlinks') == 0
- && $dataRow->getColumn('nb_actions') > 0
- ) {
- $view->showOnlyActions = true;
- $view->nbActions = $dataRow->getColumn('nb_actions');
- $view->urlSparklineNbActions = $this->getUrlSparkline('getEvolutionGraph', array('columns' => array('nb_actions')));
- }
- }
-
- }
}