forked from rebillar/site-accueil-insa
74 lines
No EOL
2.4 KiB
PHP
74 lines
No EOL
2.4 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\API\DataTable;
|
|
|
|
use Piwik\DataTable\Row;
|
|
use Piwik\DataTable;
|
|
|
|
class MergeDataTables
|
|
{
|
|
/**
|
|
* Merge the columns of two data tables. Only takes into consideration the first row of each table.
|
|
* Manipulates the first table.
|
|
*
|
|
* @param DataTable|DataTable\Map $table1 The table to eventually filter.
|
|
* @param DataTable|DataTable\Map $table2 Whether to delete rows with no visits or not.
|
|
*/
|
|
public function mergeDataTables($table1, $table2)
|
|
{
|
|
// handle table arrays
|
|
if ($table1 instanceof DataTable\Map && $table2 instanceof DataTable\Map) {
|
|
$subTables1 = $table1->getDataTables();
|
|
foreach ($table2->getDataTables() as $index => $subTable2) {
|
|
if (!array_key_exists($index, $subTables1)) {
|
|
$subTable1 = $this->makeNewDataTable($subTable2);
|
|
$table1->addTable($subTable1, $index);
|
|
} else {
|
|
$subTable1 = $subTables1[$index];
|
|
}
|
|
$this->mergeDataTables($subTable1, $subTable2);
|
|
}
|
|
return;
|
|
}
|
|
|
|
$firstRow2 = $table2->getFirstRow();
|
|
if (!($firstRow2 instanceof Row)) {
|
|
return;
|
|
}
|
|
|
|
$firstRow1 = $table1->getFirstRow();
|
|
if (empty($firstRow1)) {
|
|
$firstRow1 = $table1->addRow(new Row());
|
|
}
|
|
|
|
foreach ($firstRow2->getColumns() as $metric => $value) {
|
|
$firstRow1->setColumn($metric, $value);
|
|
}
|
|
}
|
|
|
|
private function makeNewDataTable(DataTable\DataTableInterface $subTable2)
|
|
{
|
|
if ($subTable2 instanceof DataTable\Map) {
|
|
$result = new DataTable\Map();
|
|
$result->setKeyName($subTable2->getKeyName());
|
|
return $result;
|
|
} else if ($subTable2 instanceof DataTable\Simple) {
|
|
$result = new DataTable\Simple();
|
|
$result->setAllTableMetadata($subTable2->getAllTableMetadata());
|
|
return $result;
|
|
} else if ($subTable2 instanceof DataTable) {
|
|
$result = new DataTable();
|
|
$result->setAllTableMetadata($subTable2->getAllTableMetadata());
|
|
return $result;
|
|
} else {
|
|
throw new \Exception("Unknown datatable type: " . get_class($subTable2));
|
|
}
|
|
}
|
|
|
|
} |