قرینه از
https://github.com/matomo-org/matomo.git
synced 2025-08-22 15:07:44 +00:00

* Add missing metric tooltips to real time report * Add documentation for revenue per visit column * Correctly set available metrics for user location reports * Add metric documentation for nb_visits_converted * Adds metric documentation for nb_visits_percentage * Add missing metric documentations for custom dimensions * Fix bounce rate metric documentation for entry page urls report * Fix visits / unique visitors metric documentation in event reports * Fix visits percentage metric documentation * Adds documentation for conversions metric * Adjust metric documentation for ecommerce product reports * updates expected test files tests * prefer using default documentation for glossary * Change how documentation in metric glossary are computed * use unique ids for xss test metrics * updates expected UI test files * Add metric documentation for conversions in pages reports * Improve conversion metric documentation * updates expected test files * Apply suggestions from code review Co-authored-by: Michal Kleiner <michal@innocraft.com> * updates expected test files * fix cs --------- Co-authored-by: Michal Kleiner <michal@innocraft.com>
99 خطوط
2.9 KiB
PHP
99 خطوط
2.9 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Matomo - free/libre analytics platform
|
|
*
|
|
* @link https://matomo.org
|
|
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
|
|
*/
|
|
|
|
namespace Piwik\Plugins\Goals\Columns\Metrics;
|
|
|
|
use Piwik\Archive\DataTableFactory;
|
|
use Piwik\Columns\Dimension;
|
|
use Piwik\DataTable;
|
|
use Piwik\DataTable\Row;
|
|
use Piwik\Metrics;
|
|
use Piwik\Metrics\Formatter;
|
|
use Piwik\Piwik;
|
|
use Piwik\Plugin\ProcessedMetric;
|
|
use Piwik\Tracker\GoalManager;
|
|
|
|
/**
|
|
* The amount of revenue per visit (or per conversion if there are no visits). Calculated as:
|
|
*
|
|
* sum(revenue for all goals) / (nb_visits or nb_conversions if no visits)
|
|
*
|
|
* Goal revenue and nb_visits & nb_conversions are calculated by the archiving process.
|
|
*/
|
|
class RevenuePerVisit extends ProcessedMetric
|
|
{
|
|
private $idSite;
|
|
|
|
public function getName()
|
|
{
|
|
return 'revenue_per_visit';
|
|
}
|
|
|
|
public function getTranslatedName()
|
|
{
|
|
return Piwik::translate('General_ColumnValuePerVisit');
|
|
}
|
|
|
|
public function getDocumentation()
|
|
{
|
|
return Piwik::translate('General_ColumnValuePerVisitDocumentation');
|
|
}
|
|
|
|
public function getDependentMetrics()
|
|
{
|
|
return array('revenue', 'nb_visits', 'nb_conversions','goals');
|
|
}
|
|
|
|
public function compute(Row $row)
|
|
{
|
|
$mappingFromNameToIdGoal = Metrics::getMappingFromNameToIdGoal();
|
|
$goals = $this->getMetric($row, 'goals') ?: array();
|
|
|
|
$revenue = 0;
|
|
foreach ($goals as $goalId => $goalMetrics) {
|
|
if (is_numeric($goalId) && $goalId < GoalManager::IDGOAL_ORDER) {
|
|
continue;
|
|
}
|
|
|
|
if (!is_numeric($goalId) && $goalId != Piwik::LABEL_ID_GOAL_IS_ECOMMERCE_ORDER) {
|
|
continue;
|
|
}
|
|
|
|
$revenue += (int) $this->getMetric($goalMetrics, 'revenue', $mappingFromNameToIdGoal);
|
|
}
|
|
|
|
if ($revenue == 0) {
|
|
$revenue = (int) $this->getMetric($row, 'revenue');
|
|
}
|
|
|
|
$nbVisits = (int) $this->getMetric($row, 'nb_visits');
|
|
$conversions = (int) $this->getMetric($row, 'nb_conversions');
|
|
|
|
// If no visit for this metric, but some conversions, we still want to display some kind of "revenue per visit"
|
|
// even though it will actually be in this edge case "Revenue per conversion"
|
|
return Piwik::getQuotientSafe($revenue, $nbVisits == 0 ? $conversions : $nbVisits, GoalManager::REVENUE_PRECISION);
|
|
}
|
|
|
|
public function format($value, Formatter $formatter)
|
|
{
|
|
return $formatter->getPrettyMoney($value, $this->idSite);
|
|
}
|
|
|
|
public function beforeFormat($report, DataTable $table)
|
|
{
|
|
$this->idSite = DataTableFactory::getSiteIdFromMetadata($table);
|
|
return !empty($this->idSite); // skip formatting if there is no site to get currency info from
|
|
}
|
|
|
|
public function getSemanticType(): ?string
|
|
{
|
|
return Dimension::TYPE_MONEY;
|
|
}
|
|
}
|