protected function CityHits::_getData in Visitors 8.2
Returns a table content.
Parameters
array $header: Table header configuration.
Return value
array Array representing the table content.
1 call to CityHits::_getData()
- CityHits::display in src/
Controller/ Report/ CityHits.php - Returns a city hits page.
File
- src/
Controller/ Report/ CityHits.php, line 130 - Contains Drupal\visitors\Controller\Report\CityHits.
Class
Namespace
Drupal\visitors\Controller\ReportCode
protected function _getData($header, $country, $city) {
$items_per_page = \Drupal::config('visitors.config')
->get('items_per_page');
$original_country = $country == '(none)' ? '' : $country;
$original_city = $city == '(none)' ? '' : $city;
$query = \Drupal::database()
->select('visitors', 'v')
->extend('Drupal\\Core\\Database\\Query\\PagerSelectExtender')
->extend('Drupal\\Core\\Database\\Query\\TableSortExtender');
$query
->leftJoin('users_field_data', 'u', 'u.uid=v.visitors_id');
$query
->fields('v', array(
'visitors_id',
'visitors_uid',
'visitors_date_time',
'visitors_title',
'visitors_path',
'visitors_url',
));
$query
->fields('u', array(
'name',
'uid',
));
$query
->condition('v.visitors_country_name', $original_country);
$query
->condition('v.visitors_city', $original_city);
visitors_date_filter_sql_condition($query);
$query
->orderByHeader($header);
$query
->limit($items_per_page);
$count_query = \Drupal::database()
->select('visitors', 'v');
$count_query
->addExpression('COUNT(*)');
$count_query
->condition('v.visitors_country_name', $original_country);
$count_query
->condition('v.visitors_city', $original_city);
visitors_date_filter_sql_condition($count_query);
$query
->setCountQuery($count_query);
$results = $query
->execute();
$rows = array();
$page = isset($_GET['page']) ? (int) $_GET['page'] : '';
$i = 0 + $page * $items_per_page;
foreach ($results as $data) {
$user = \Drupal::entityTypeManager()
->getStorage('user')
->load($data->visitors_uid);
$username = array(
'#type' => 'username',
'#account' => $user,
);
$rows[] = array(
++$i,
$data->visitors_id,
$this->date
->format($data->visitors_date_time, 'short'),
/*check_plain(
$data->visitors_title) . '<br/>' . l($data->visitors_path,
$data->visitors_url
),*/
$data->visitors_url,
\Drupal::service('renderer')
->render($username),
Link::fromTextAndUrl($this
->t('details'), Url::fromRoute('visitors.hit_details', array(
"hit_id" => $data->visitors_id,
))),
);
}
return $rows;
}