forked from vergnet/site-accueil-insa
423 lines
18 KiB
PHP
423 lines
18 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* Matomo - free/libre analytics platform
|
||
|
*
|
||
|
* @link https://matomo.org
|
||
|
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
|
||
|
*
|
||
|
*/
|
||
|
namespace Piwik\Plugins\Goals;
|
||
|
|
||
|
use Piwik\API\Request;
|
||
|
use Piwik\Columns\ComputedMetricFactory;
|
||
|
use Piwik\Columns\Dimension;
|
||
|
use Piwik\Columns\MetricsList;
|
||
|
use Piwik\Common;
|
||
|
use Piwik\Piwik;
|
||
|
use Piwik\Plugin\ArchivedMetric;
|
||
|
use Piwik\Plugin\ComputedMetric;
|
||
|
use Piwik\Plugin\ReportsProvider;
|
||
|
use Piwik\Plugins\CoreHome\SystemSummary;
|
||
|
use Piwik\Tracker\GoalManager;
|
||
|
use Piwik\Category\Subcategory;
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
*/
|
||
|
class Goals extends \Piwik\Plugin
|
||
|
{
|
||
|
public static function getReportsWithGoalMetrics()
|
||
|
{
|
||
|
$dimensions = self::getAllReportsWithGoalMetrics();
|
||
|
|
||
|
$dimensionsByGroup = array();
|
||
|
foreach ($dimensions as $dimension) {
|
||
|
$group = $dimension['category'];
|
||
|
// move "Custom Variables" report to the "Goals/Sales by User attribute" category
|
||
|
if ($dimension['module'] === 'CustomVariables'
|
||
|
|| $dimension['action'] == 'getVisitInformationPerServerTime') {
|
||
|
$group = 'VisitsSummary_VisitsSummary';
|
||
|
}
|
||
|
unset($dimension['category']);
|
||
|
$dimensionsByGroup[$group][] = $dimension;
|
||
|
}
|
||
|
|
||
|
return $dimensionsByGroup;
|
||
|
}
|
||
|
|
||
|
public static function getGoalIdFromGoalColumn($columnName)
|
||
|
{
|
||
|
if (strpos($columnName, 'goal_') === 0) {
|
||
|
$column = str_replace(array('goal_'), '', $columnName);
|
||
|
return (int) $column;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public static function makeGoalColumn($idGoal, $column, $forceInt = true)
|
||
|
{
|
||
|
if ($forceInt) { // in non-archiver code idGoal can be, eg, ecommerceOrder
|
||
|
$idGoal = (int) $idGoal;
|
||
|
}
|
||
|
|
||
|
return 'goal_'. $idGoal . '_' . $column;
|
||
|
}
|
||
|
|
||
|
public static function getGoalColumns($idGoal)
|
||
|
{
|
||
|
$columns = array(
|
||
|
'nb_conversions',
|
||
|
'nb_visits_converted',
|
||
|
'revenue',
|
||
|
);
|
||
|
if ($idGoal === false) {
|
||
|
return $columns;
|
||
|
}
|
||
|
// Orders
|
||
|
if ($idGoal === GoalManager::IDGOAL_ORDER) {
|
||
|
$columns = array_merge($columns, array(
|
||
|
'revenue_subtotal',
|
||
|
'revenue_tax',
|
||
|
'revenue_shipping',
|
||
|
'revenue_discount',
|
||
|
));
|
||
|
}
|
||
|
// Abandoned carts & orders
|
||
|
if ($idGoal <= GoalManager::IDGOAL_ORDER) {
|
||
|
$columns[] = 'items';
|
||
|
}
|
||
|
return $columns;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @see \Piwik\Plugin::registerEvents
|
||
|
*/
|
||
|
public function registerEvents()
|
||
|
{
|
||
|
$hooks = array(
|
||
|
'AssetManager.getStylesheetFiles' => 'getStylesheetFiles',
|
||
|
'Tracker.Cache.getSiteAttributes' => 'fetchGoalsFromDb',
|
||
|
'API.getReportMetadata.end' => 'getReportMetadataEnd',
|
||
|
'SitesManager.deleteSite.end' => 'deleteSiteGoals',
|
||
|
'Translate.getClientSideTranslationKeys' => 'getClientSideTranslationKeys',
|
||
|
'Metrics.getDefaultMetricTranslations' => 'addMetricTranslations',
|
||
|
'Category.addSubcategories' => 'addSubcategories',
|
||
|
'Metric.addMetrics' => 'addMetrics',
|
||
|
'Metric.addComputedMetrics' => 'addComputedMetrics',
|
||
|
'System.addSystemSummaryItems' => 'addSystemSummaryItems',
|
||
|
);
|
||
|
return $hooks;
|
||
|
}
|
||
|
|
||
|
public function addSystemSummaryItems(&$systemSummary)
|
||
|
{
|
||
|
$goalModel = new Model();
|
||
|
$numGoals = $goalModel->getActiveGoalCount();
|
||
|
|
||
|
$systemSummary[] = new SystemSummary\Item($key = 'goals', Piwik::translate('Goals_NGoals', $numGoals), $value = null, array('module' => 'Goals', 'action' => 'manage'), $icon = 'icon-goal', $order = 7);
|
||
|
}
|
||
|
|
||
|
public function addComputedMetrics(MetricsList $list, ComputedMetricFactory $computedMetricFactory)
|
||
|
{
|
||
|
$idSite = Common::getRequestVar('idSite', 0, 'int');
|
||
|
$goals = Request::processRequest('Goals.getGoals', ['idSite' => $idSite, 'filter_limit' => '-1'], $default = []);
|
||
|
|
||
|
foreach ($goals as $goal) {
|
||
|
$metric = $computedMetricFactory->createComputedMetric('goal_' . $goal['idgoal'] . '_conversion', 'nb_uniq_visitors', ComputedMetric::AGGREGATION_RATE);
|
||
|
$goalName = '"' . Piwik::translate('Goals_GoalX', $goal['name']) . '"';
|
||
|
$metricName = Piwik::translate('Goals_ConversionRate', $goalName);
|
||
|
$metric->setTranslatedName($metricName);
|
||
|
$list->addMetric($metric);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function addMetrics(MetricsList $metricsList)
|
||
|
{
|
||
|
$idSite = Common::getRequestVar('idSite', 0, 'int');
|
||
|
$goals = Request::processRequest('Goals.getGoals', ['idSite' => $idSite, 'filter_limit' => '-1'], $default = []);
|
||
|
|
||
|
foreach ($goals as $goal) {
|
||
|
$custom = new GoalDimension($goal, 'idgoal', 'Conversions goal "' . $goal['name'] . '" (ID ' . $goal['idgoal'] .' )');
|
||
|
$custom->setType(Dimension::TYPE_NUMBER);
|
||
|
$custom->setSqlSegment('count(distinct log_conversion.idvisit, log_conversion.buster)');
|
||
|
|
||
|
$metric = new ArchivedMetric($custom, ArchivedMetric::AGGREGATION_SUM);
|
||
|
$metric->setQuery('count(distinct log_conversion.idvisit, log_conversion.buster)');
|
||
|
$metric->setTranslatedName($custom->getName());
|
||
|
$metric->setDocumentation('The number of times this goal was converted.');
|
||
|
$metric->setCategory($custom->getCategoryId());
|
||
|
$metric->setName('goal_' . $goal['idgoal'] . '_conversion');
|
||
|
$metricsList->addMetric($metric);
|
||
|
|
||
|
$custom = new GoalDimension($goal, 'revenue', 'Revenue goal "' . $goal['name'] . '" (ID ' . $goal['idgoal'] .' )');
|
||
|
$custom->setType(Dimension::TYPE_MONEY);
|
||
|
$metric = new ArchivedMetric($custom, ArchivedMetric::AGGREGATION_SUM);
|
||
|
$metric->setTranslatedName($custom->getName());
|
||
|
$metric->setName('goal_' . $goal['idgoal'] . '_revenue');
|
||
|
$metric->setDocumentation('The amount of revenue that was generated by converting this goal.');
|
||
|
$metric->setCategory($custom->getCategoryId());
|
||
|
$metricsList->addMetric($metric);
|
||
|
|
||
|
$custom = new GoalDimension($goal, 'visitor_seconds_since_first', 'Days to conversion goal "' . $goal['name'] . '" (ID ' . $goal['idgoal'] .' )');
|
||
|
$custom->setType(Dimension::TYPE_NUMBER);
|
||
|
$metric = new ArchivedMetric($custom, ArchivedMetric::AGGREGATION_SUM);
|
||
|
$metric->setTranslatedName($custom->getName());
|
||
|
$metric->setCategory($custom->getCategoryId());
|
||
|
$metric->setDocumentation('The number of days it took a visitor to convert this goal.');
|
||
|
$metric->setName('goal_' . $goal['idgoal'] . '_daystoconversion');
|
||
|
$metric->setQuery('sum(floor(log_visit.visitor_seconds_since_first / 86400))');
|
||
|
$metricsList->addMetric($metric);
|
||
|
|
||
|
$custom = new GoalDimension($goal, 'visitor_count_visits', 'Visits to conversion goal "' . $goal['name'] . '" (ID ' . $goal['idgoal'] .' )');
|
||
|
$custom->setType(Dimension::TYPE_NUMBER);
|
||
|
$metric = new ArchivedMetric($custom, ArchivedMetric::AGGREGATION_SUM);
|
||
|
$metric->setTranslatedName($custom->getName());
|
||
|
$metric->setCategory($custom->getCategoryId());
|
||
|
$metric->setDocumentation('The number of visits it took a visitor to convert this goal.');
|
||
|
$metric->setName('goal_' . $goal['idgoal'] . '_visitstoconversion');
|
||
|
$metricsList->addMetric($metric);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function addSubcategories(&$subcategories)
|
||
|
{
|
||
|
$idSite = Common::getRequestVar('idSite', 0, 'int');
|
||
|
|
||
|
if (!$idSite) {
|
||
|
// fallback for eg API.getReportMetadata which uses idSites
|
||
|
$idSite = Common::getRequestVar('idSites', 0, 'int');
|
||
|
|
||
|
if (!$idSite) {
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$goals = Request::processRequest('Goals.getGoals', ['idSite' => $idSite, 'filter_limit' => '-1'], $default = []);
|
||
|
|
||
|
$order = 900;
|
||
|
foreach ($goals as $goal) {
|
||
|
$category = new Subcategory();
|
||
|
$category->setName($goal['name']);
|
||
|
$category->setCategoryId('Goals_Goals');
|
||
|
$category->setId($goal['idgoal']);
|
||
|
$category->setOrder($order++);
|
||
|
$subcategories[] = $category;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function addMetricTranslations(&$translations)
|
||
|
{
|
||
|
$metrics = array(
|
||
|
'orders' => 'General_EcommerceOrders',
|
||
|
'ecommerce_revenue' => 'General_ProductRevenue',
|
||
|
'revenue_per_visit' => 'General_ColumnValuePerVisit',
|
||
|
'quantity' => 'General_Quantity',
|
||
|
'avg_price' => 'General_AveragePrice',
|
||
|
'avg_quantity' => 'General_AverageQuantity',
|
||
|
'revenue_subtotal' => 'General_Subtotal',
|
||
|
'revenue_tax' => 'General_Tax',
|
||
|
'revenue_shipping' => 'General_Shipping',
|
||
|
'revenue_discount' => 'General_Discount',
|
||
|
'avg_order_revenue' => 'General_AverageOrderValue'
|
||
|
);
|
||
|
|
||
|
$metrics = array_map(array('\\Piwik\\Piwik', 'translate'), $metrics);
|
||
|
|
||
|
$translations = array_merge($translations, $metrics);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Delete goals recorded for this site
|
||
|
*/
|
||
|
public function deleteSiteGoals($idSite)
|
||
|
{
|
||
|
$model = new Model();
|
||
|
$model->deleteGoalsForSite($idSite);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the Metadata for the Goals plugin API.
|
||
|
* The API returns general Goal metrics: conv, conv rate and revenue globally
|
||
|
* and for each goal.
|
||
|
*
|
||
|
* Also, this will update metadata of all other reports that have Goal segmentation
|
||
|
*/
|
||
|
public function getReportMetadataEnd(&$reports, $info)
|
||
|
{
|
||
|
// Processed in AddColumnsProcessedMetricsGoal
|
||
|
// These metrics will also be available for some reports, for each goal
|
||
|
// Example: Conversion rate for Goal 2 for the keyword 'piwik'
|
||
|
$goalProcessedMetrics = array(
|
||
|
'revenue_per_visit' => Piwik::translate('General_ColumnValuePerVisit'),
|
||
|
);
|
||
|
|
||
|
$goalMetrics = array(
|
||
|
'nb_conversions' => Piwik::translate('Goals_ColumnConversions'),
|
||
|
'conversion_rate' => Piwik::translate('General_ColumnConversionRate'),
|
||
|
'revenue' => Piwik::translate('General_ColumnRevenue')
|
||
|
);
|
||
|
|
||
|
$reportsWithGoals = self::getAllReportsWithGoalMetrics();
|
||
|
|
||
|
foreach ($reportsWithGoals as $reportWithGoals) {
|
||
|
// Select this report from the API metadata array
|
||
|
// and add the Goal metrics to it
|
||
|
foreach ($reports as &$apiReportToUpdate) {
|
||
|
// We do not add anything for Action reports, as no overall metrics are processed there at the moment
|
||
|
if ($apiReportToUpdate['module'] === 'Actions') {
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
if ($apiReportToUpdate['module'] == $reportWithGoals['module']
|
||
|
&& $apiReportToUpdate['action'] == $reportWithGoals['action']
|
||
|
&& empty($apiReportToUpdate['parameters'])) {
|
||
|
$apiReportToUpdate['metricsGoal'] = $goalMetrics;
|
||
|
$apiReportToUpdate['processedMetricsGoal'] = $goalProcessedMetrics;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
private static function getAllReportsWithGoalMetrics()
|
||
|
{
|
||
|
$reportsWithGoals = array();
|
||
|
|
||
|
$reports = new ReportsProvider();
|
||
|
|
||
|
foreach ($reports->getAllReports() as $report) {
|
||
|
if ($report->hasGoalMetrics() && $report->isEnabled()) {
|
||
|
$reportsWithGoals[] = array(
|
||
|
'category' => $report->getCategoryId(),
|
||
|
'name' => $report->getName(),
|
||
|
'module' => $report->getModule(),
|
||
|
'action' => $report->getAction(),
|
||
|
'parameters' => $report->getParameters()
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$reportsWithGoals[] = array('category' => 'General_Visit',
|
||
|
'name' => Piwik::translate('Goals_VisitsUntilConv'),
|
||
|
'module' => 'Goals',
|
||
|
'action' => 'getVisitsUntilConversion',
|
||
|
'viewDataTable' => 'table',
|
||
|
);
|
||
|
$reportsWithGoals[] = array('category' => 'General_Visit',
|
||
|
'name' => Piwik::translate('Goals_DaysToConv'),
|
||
|
'module' => 'Goals',
|
||
|
'action' => 'getDaysToConversion',
|
||
|
'viewDataTable' => 'table',
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
* Triggered when gathering all reports that contain Goal metrics. The list of reports
|
||
|
* will be displayed on the left column of the bottom of every _Goals_ page.
|
||
|
*
|
||
|
* If plugins define reports that contain goal metrics (such as **conversions** or **revenue**),
|
||
|
* they can use this event to make sure their reports can be viewed on Goals pages.
|
||
|
*
|
||
|
* **Example**
|
||
|
*
|
||
|
* public function getReportsWithGoalMetrics(&$reports)
|
||
|
* {
|
||
|
* $reports[] = array(
|
||
|
* 'category' => Piwik::translate('MyPlugin_myReportCategory'),
|
||
|
* 'name' => Piwik::translate('MyPlugin_myReportDimension'),
|
||
|
* 'module' => 'MyPlugin',
|
||
|
* 'action' => 'getMyReport'
|
||
|
* );
|
||
|
* }
|
||
|
*
|
||
|
* @param array &$reportsWithGoals The list of arrays describing reports that have Goal metrics.
|
||
|
* Each element of this array must be an array with the following
|
||
|
* properties:
|
||
|
*
|
||
|
* - **category**: The report category. This should be a translated string.
|
||
|
* - **name**: The report's translated name.
|
||
|
* - **module**: The plugin the report is in, eg, `'UserCountry'`.
|
||
|
* - **action**: The API method of the report, eg, `'getCountry'`.
|
||
|
* @ignore
|
||
|
* @deprecated since 2.5.0
|
||
|
*/
|
||
|
Piwik::postEvent('Goals.getReportsWithGoalMetrics', array(&$reportsWithGoals));
|
||
|
|
||
|
return $reportsWithGoals;
|
||
|
}
|
||
|
|
||
|
public function getStylesheetFiles(&$stylesheets)
|
||
|
{
|
||
|
$stylesheets[] = "plugins/Goals/stylesheets/goals.css";
|
||
|
}
|
||
|
|
||
|
public function fetchGoalsFromDb(&$array, $idSite)
|
||
|
{
|
||
|
// add the 'goal' entry in the website array
|
||
|
$array['goals'] = API::getInstance()->getGoals($idSite);
|
||
|
}
|
||
|
|
||
|
public function getClientSideTranslationKeys(&$translationKeys)
|
||
|
{
|
||
|
$translationKeys[] = 'Goals_AddGoal';
|
||
|
$translationKeys[] = 'Goals_AddNewGoal';
|
||
|
$translationKeys[] = 'Goals_UpdateGoal';
|
||
|
$translationKeys[] = 'Goals_DeleteGoalConfirm';
|
||
|
$translationKeys[] = 'Goals_Ecommerce';
|
||
|
$translationKeys[] = 'Goals_Optional';
|
||
|
$translationKeys[] = 'Goals_TimeInMinutes';
|
||
|
$translationKeys[] = 'Goals_Pattern';
|
||
|
$translationKeys[] = 'Goals_ClickToViewThisGoal';
|
||
|
$translationKeys[] = 'Goals_ManageGoals';
|
||
|
$translationKeys[] = 'Goals_GoalName';
|
||
|
$translationKeys[] = 'Goals_GoalIsTriggeredWhen';
|
||
|
$translationKeys[] = 'Goals_ThereIsNoGoalToManage';
|
||
|
$translationKeys[] = 'Goals_ManuallyTriggeredUsingJavascriptFunction';
|
||
|
$translationKeys[] = 'Goals_VisitUrl';
|
||
|
$translationKeys[] = 'Goals_ClickOutlink';
|
||
|
$translationKeys[] = 'Goals_SendEvent';
|
||
|
$translationKeys[] = 'Goals_GoalIsTriggered';
|
||
|
$translationKeys[] = 'Goals_WhereThe';
|
||
|
$translationKeys[] = 'Goals_URL';
|
||
|
$translationKeys[] = 'Goals_Contains';
|
||
|
$translationKeys[] = 'Goals_IsExactly';
|
||
|
$translationKeys[] = 'Goals_MatchesExpression';
|
||
|
$translationKeys[] = 'Goals_AllowMultipleConversionsPerVisit';
|
||
|
$translationKeys[] = 'Goals_HelpOneConversionPerVisit';
|
||
|
$translationKeys[] = 'Goals_DefaultRevenueHelp';
|
||
|
$translationKeys[] = 'Goals_DefaultRevenueLabel';
|
||
|
$translationKeys[] = 'Goals_GoalRevenue';
|
||
|
$translationKeys[] = 'Goals_Filename';
|
||
|
$translationKeys[] = 'Goals_ExternalWebsiteUrl';
|
||
|
$translationKeys[] = 'Goals_VisitDuration';
|
||
|
$translationKeys[] = 'Goals_AtLeastMinutes';
|
||
|
$translationKeys[] = 'Goals_VisitPageTitle';
|
||
|
$translationKeys[] = 'Intl_NMinutes';
|
||
|
$translationKeys[] = 'Goals_PageTitle';
|
||
|
$translationKeys[] = 'Goals_UseEventValueAsRevenue';
|
||
|
$translationKeys[] = 'Goals_EventValueAsRevenueHelp';
|
||
|
$translationKeys[] = 'Goals_EventValueAsRevenueHelp2';
|
||
|
$translationKeys[] = 'Events_EventCategory';
|
||
|
$translationKeys[] = 'Goals_WhereVisitedPageManuallyCallsJavascriptTrackerLearnMore';
|
||
|
$translationKeys[] = 'Goals_LearnMoreAboutGoalTrackingDocumentation';
|
||
|
$translationKeys[] = 'Goals_EcommerceReports';
|
||
|
$translationKeys[] = 'SitesManager_WebsitesManagement';
|
||
|
$translationKeys[] = 'Goals_CaseSensitive';
|
||
|
$translationKeys[] = 'Goals_Download';
|
||
|
$translationKeys[] = 'Events_EventAction';
|
||
|
$translationKeys[] = 'Events_EventCategory';
|
||
|
$translationKeys[] = 'Events_EventName';
|
||
|
$translationKeys[] = 'Goals_YouCanEnableEcommerceReports';
|
||
|
$translationKeys[] = 'Goals_CategoryTextGeneral_Actions';
|
||
|
$translationKeys[] = 'General_ForExampleShort';
|
||
|
$translationKeys[] = 'General_Id';
|
||
|
$translationKeys[] = 'General_Description';
|
||
|
$translationKeys[] = 'General_ColumnRevenue';
|
||
|
$translationKeys[] = 'General_Edit';
|
||
|
$translationKeys[] = 'General_Delete';
|
||
|
$translationKeys[] = 'General_OperationGreaterThan';
|
||
|
$translationKeys[] = 'General_Yes';
|
||
|
$translationKeys[] = 'General_No';
|
||
|
$translationKeys[] = 'General_OrCancel';
|
||
|
}
|
||
|
}
|