updated plugin Connect Matomo version 1.1.5
This commit is contained in:
@ -2,65 +2,76 @@
|
||||
|
||||
namespace WP_Piwik\Widget;
|
||||
|
||||
class Overview extends \WP_Piwik\Widget
|
||||
{
|
||||
class Overview extends \WP_Piwik\Widget {
|
||||
|
||||
public $className = __CLASS__;
|
||||
public $class_name = __CLASS__;
|
||||
|
||||
protected function configure($prefix = '', $params = array())
|
||||
{
|
||||
$timeSettings = $this->getTimeSettings();
|
||||
$this->parameter = array(
|
||||
'idSite' => self::$wpPiwik->getPiwikSiteId($this->blogId),
|
||||
'period' => isset($params['period']) ? $params['period'] : $timeSettings['period'],
|
||||
'date' => isset($params['date']) ? $params['date'] : $timeSettings['date'],
|
||||
'description' => $timeSettings['description']
|
||||
);
|
||||
$this->title = !$this->isShortcode ? $prefix . __('Overview', 'wp-piwik') . ' (' . __($this->pageId == 'dashboard' ? $this->rangeName() : $timeSettings['description'], 'wp-piwik') . ')' : ($params['title'] ? $params['title'] : '');
|
||||
$this->method = 'VisitsSummary.get';
|
||||
}
|
||||
protected function configure( $prefix = '', $params = array() ) {
|
||||
$time_settings = $this->get_time_settings();
|
||||
$this->parameter = array(
|
||||
'idSite' => self::$wp_piwik->get_piwik_site_id( $this->blog_id ),
|
||||
'period' => isset( $params['period'] ) ? $params['period'] : $time_settings['period'],
|
||||
'date' => isset( $params['date'] ) ? $params['date'] : $time_settings['date'],
|
||||
'description' => $time_settings['description'],
|
||||
);
|
||||
$this->title = ! $this->is_shortcode ? $prefix . __( 'Overview', 'wp-piwik' ) . ' (' . ( 'dashboard' === $this->page_id ? $this->range_name() : $time_settings['description'] ) . ')' : ( $params['title'] ? $params['title'] : '' );
|
||||
$this->method = 'VisitsSummary.get';
|
||||
}
|
||||
|
||||
public function show()
|
||||
{
|
||||
$response = self::$wpPiwik->request($this->apiID[$this->method]);
|
||||
if (!empty($response['result']) && $response['result'] = 'error')
|
||||
echo '<strong>' . __('Piwik error', 'wp-piwik') . ':</strong> ' . htmlentities($response['message'], ENT_QUOTES, 'utf-8');
|
||||
else {
|
||||
if (in_array($this->parameter['date'], array('last30', 'last60', 'last90'))) {
|
||||
$result = array();
|
||||
if (is_array($response)) {
|
||||
foreach ($response as $data)
|
||||
foreach ($data as $key => $value)
|
||||
if (isset($result[$key]) && is_numeric($value))
|
||||
$result[$key] += $value;
|
||||
elseif (is_numeric($value))
|
||||
$result[$key] = $value;
|
||||
else
|
||||
$result[$key] = 0;
|
||||
if (isset($result['nb_visits']) && $result['nb_visits'] > 0) {
|
||||
$result['nb_actions_per_visit'] = round($result['nb_actions'] / $result['nb_visits'], 1);
|
||||
$result['bounce_rate'] = round($result['bounce_count'] / $result['nb_visits'] * 100, 1) . '%';
|
||||
$result['avg_time_on_site'] = round($result['sum_visit_length'] / $result['nb_visits'], 0);
|
||||
} else $result['nb_actions_per_visit'] = $result['bounce_rate'] = $result['avg_time_on_site'] = 0;
|
||||
}
|
||||
$response = $result;
|
||||
}
|
||||
$time = isset($response['sum_visit_length']) ? $this->timeFormat($response['sum_visit_length']) : '-';
|
||||
$avgTime = isset($response['avg_time_on_site']) ? $this->timeFormat($response['avg_time_on_site']) : '-';
|
||||
$tableHead = null;
|
||||
$tableBody = array(array(__('Visitors', 'wp-piwik') . ':', $this->value($response, 'nb_visits')));
|
||||
if ($this->value($response, 'nb_uniq_visitors') != '-')
|
||||
array_push($tableBody, array(__('Unique visitors', 'wp-piwik') . ':', $this->value($response, 'nb_uniq_visitors')));
|
||||
array_push($tableBody,
|
||||
array(__('Page views', 'wp-piwik') . ':', $this->value($response, 'nb_actions') . ' (Ø ' . $this->value($response, 'nb_actions_per_visit') . ')'),
|
||||
array(__('Total time spent', 'wp-piwik') . ':', $time . ' (Ø ' . $avgTime . ')'),
|
||||
array(__('Bounce count', 'wp-piwik') . ':', $this->value($response, 'bounce_count') . ' (' . $this->value($response, 'bounce_rate') . ')')
|
||||
);
|
||||
if (!in_array($this->parameter['date'], array('last30', 'last60', 'last90')))
|
||||
array_push($tableBody, array(__('Time/visit', 'wp-piwik') . ':', $avgTime), array(__('Max. page views in one visit', 'wp-piwik') . ':', $this->value($response, 'max_actions')));
|
||||
$tableFoot = (self::$settings->getGlobalOption('piwik_shortcut') ? array(__('Shortcut', 'wp-piwik') . ':', '<a href="' . self::$settings->getGlobalOption('piwik_url') . '" target="_BLANK">Matomo</a>' . (isset($aryConf['inline']) && $aryConf['inline'] ? ' - <a href="?page=wp-piwik_stats">WP-Piwik</a>' : '')) : null);
|
||||
$this->table($tableHead, $tableBody, $tableFoot);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
public function show() {
|
||||
$response = self::$wp_piwik->request( $this->api_id[ $this->method ] );
|
||||
if ( ! empty( $response['result'] ) && 'error' === $response['result'] ) {
|
||||
echo '<strong>' . esc_html__( 'Piwik error', 'wp-piwik' ) . ':</strong> ' . esc_html( $response['message'] );
|
||||
} else {
|
||||
if ( in_array( $this->parameter['date'], array( 'last30', 'last60', 'last90' ), true ) ) {
|
||||
$result = array();
|
||||
if ( is_array( $response ) ) {
|
||||
foreach ( $response as $data ) {
|
||||
foreach ( $data as $key => $value ) {
|
||||
if ( isset( $result[ $key ] ) && is_numeric( $value ) ) {
|
||||
$result[ $key ] += $value;
|
||||
} elseif ( is_numeric( $value ) ) {
|
||||
$result[ $key ] = $value;
|
||||
} else {
|
||||
$result[ $key ] = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
if ( isset( $result['nb_visits'] ) && $result['nb_visits'] > 0 ) {
|
||||
$result['nb_actions_per_visit'] = round( $result['nb_actions'] / $result['nb_visits'], 1 );
|
||||
$result['bounce_rate'] = round( $result['bounce_count'] / $result['nb_visits'] * 100, 1 ) . '%';
|
||||
$result['avg_time_on_site'] = round( $result['sum_visit_length'] / $result['nb_visits'], 0 );
|
||||
} else {
|
||||
$result['nb_actions_per_visit'] = 0;
|
||||
$result['bounce_rate'] = 0;
|
||||
$result['avg_time_on_site'] = 0;
|
||||
}
|
||||
}
|
||||
$response = $result;
|
||||
}
|
||||
$time = isset( $response['sum_visit_length'] ) ? $this->time_format( $response['sum_visit_length'] ) : '-';
|
||||
$avg_time = isset( $response['avg_time_on_site'] ) ? $this->time_format( $response['avg_time_on_site'] ) : '-';
|
||||
$table_head = null;
|
||||
$table_body = array( array( __( 'Visitors', 'wp-piwik' ) . ':', $this->value( $response, 'nb_visits' ) ) );
|
||||
if ( '-' !== $this->value( $response, 'nb_uniq_visitors' ) ) {
|
||||
array_push( $table_body, array( __( 'Unique visitors', 'wp-piwik' ) . ':', $this->value( $response, 'nb_uniq_visitors' ) ) );
|
||||
}
|
||||
array_push(
|
||||
$table_body,
|
||||
array( __( 'Page views', 'wp-piwik' ) . ':', $this->value( $response, 'nb_actions' ) . ' (Ø ' . $this->value( $response, 'nb_actions_per_visit' ) . ')' ),
|
||||
array( __( 'Total time spent', 'wp-piwik' ) . ':', $time . ' (Ø ' . $avg_time . ')' ),
|
||||
array( __( 'Bounce count', 'wp-piwik' ) . ':', $this->value( $response, 'bounce_count' ) . ' (' . $this->value( $response, 'bounce_rate' ) . ')' )
|
||||
);
|
||||
if ( ! in_array( $this->parameter['date'], array( 'last30', 'last60', 'last90' ), true ) ) {
|
||||
array_push( $table_body, array( __( 'Time/visit', 'wp-piwik' ) . ':', $avg_time ), array( __( 'Max. page views in one visit', 'wp-piwik' ) . ':', $this->value( $response, 'max_actions' ) ) );
|
||||
}
|
||||
$table_foot = self::$settings->get_global_option( 'piwik_shortcut' )
|
||||
? array(
|
||||
esc_html__( 'Shortcut', 'wp-piwik' ) . ':',
|
||||
'<a href="' . esc_attr( self::$settings->get_global_option( 'piwik_url' ) ) . '" target="_BLANK">Matomo</a>',
|
||||
)
|
||||
: null;
|
||||
$this->table( $table_head, $table_body, $table_foot );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user