Your IP : 18.220.25.158


Current Path : /var/www/ooareogundevinitiative/wp-content/plugins/newsletter/statistics/
Upload File :
Current File : /var/www/ooareogundevinitiative/wp-content/plugins/newsletter/statistics/index.php

<?php
/* @var $wpdb wpdb */
/* @var $this NewsletterStatistics */

defined('ABSPATH') || exit;

require_once NEWSLETTER_INCLUDES_DIR . '/controls.php';
$controls = new NewsletterControls();

wp_enqueue_script('tnp-chart');

// Optimized query with a reduced set of fields
$emails = $wpdb->get_results("select send_on, id, subject, total, status, type from " . NEWSLETTER_EMAILS_TABLE . " where status='sent' and type='message' order by send_on desc limit 10");

$report = new TNP_Statistics();

$overview_labels = array();
$overview_titles = array();
$overview_open_rate = array();
$overview_click_rate = array();

$total_sent = 0;
$open_count_total = 0;
$click_count_total = 0;
foreach ($emails as $email) {
    $data = $this->get_statistics($email);

    $entry = array();

    if (empty($data->total)) {
        continue;
    }

    // Used later for the tabled view
    $email->report = $data;

    $report->total += $data->total;
    $report->open_count += $data->open_count;
    $report->click_count += $data->click_count;

    $overview_labels[] = strftime('%a, %e %b %y', $email->send_on);

    $overview_open_rate[] = $data->open_rate;
    $overview_click_rate[] = $data->click_rate;
    $overview_titles[] = $email->subject;
}

$report->update();

$overview_labels = array_reverse($overview_labels);
$overview_open_rate = array_reverse($overview_open_rate);
$overview_click_rate = array_reverse($overview_click_rate);

if (empty($emails)) {
    $controls->warnings[] = __('No newsletters have been sent till now', 'newsletter');
}
?>

<script>
    var titles = <?php echo json_encode(array_reverse($overview_titles)) ?>;
</script>

<div class="wrap tnp-statistics tnp-statistics-index" id="tnp-wrap">
    <?php include NEWSLETTER_DIR . '/tnp-header.php' ?>
    <div id="tnp-heading">
        <h2><?php _e('Overall basic statistics (last 20 newsletters)', 'newsletter') ?></h2>
        <p>More details, including Automated and Autoresponder newsletter statistics are available with the <a href="https://www.thenewsletterplugin.com/reports?utm_source=plugin&utm_campaign=newsletter-reports" target="_blank">Reports Addon</a>.</p>
    </div>

    <div id="tnp-body" class="tnp-statistics">

        <div class="row">
            <div class="col-md-3">
                <div class="tnp-widget tnp-number">
                    <h3>Emails Sent</h3>
                    <div class="tnp-icon"><i class="fas fa-users"></i></div>
                    <div class="tnp-value"><?php echo number_format_i18n($report->total, 0) ?></div>
                </div>
            </div>

            <div class="col-md-3">
                <div class="tnp-widget tnp-number">
                    <h3>Overall Opens</h3>
                    <div class="tnp-icon tnp-blue"><i class="fas fa-envelope-open"></i></div>
                    <div class="tnp-value"><?php echo $report->open_rate; ?>%</div>
                    <div class="tnp-value-2">(<?php echo $report->open_count; ?>)</div>
                </div>
            </div>

            <div class="col-md-3">
                <div class="tnp-widget tnp-number">
                    <h3>Overall Clicks</h3>
                    <div class="tnp-icon tnp-orange"><i class="fas fa-mouse-pointer"></i></div>
                    <div class="tnp-value"><?php echo $report->click_rate; ?>%</div>
                    <div class="tnp-value-2">(<?php echo $report->click_count; ?>)</div>
                </div>
            </div>

            <div class="col-md-3">
                <div class="tnp-widget tnp-number tnp-inactive">
                    <h3>Overall Reactivity</h3>
                    <div class="tnp-icon tnp-gray"><i class="fas fa-star"></i></div>
                    <div class="tnp-value">-%</div>
                </div>
            </div>
        </div>

        <div class="row">

            <div class="col-md-6">
                <div class="tnp-widget">
                    <h3>Open rate</h3>

                    <div id="tnp-opens-chart">            
                        <canvas id="tnp-opens-chart-canvas"></canvas>
                    </div>

                    <script type="text/javascript">
                        var open_config = {
                            type: 'line',
                            data: {
                                labels: <?php echo json_encode($overview_labels) ?>,
                                datasets: [
                                    {
                                        label: "Open",
                                        fill: false,
                                        strokeColor: "#2980b9",
                                        backgroundColor: "#2980b9",
                                        borderColor: "#2980b9",
                                        //pointBorderColor: "#27AE60",
                                        pointBackgroundColor: "#2980b9",
                                        data: <?php echo json_encode($overview_open_rate) ?>
                                    }
                                ]
                            },
                            options: {
                                scales: {
                                    xAxes: [{type: "category", "id": "x-axis-1", gridLines: {display: false}, ticks: {fontFamily: "Source Sans Pro"}}],
                                    yAxes: [
                                        {type: "linear", "id": "y-axis-1", gridLines: {display: false}, ticks: {fontColor: "#333", fontFamily: "Source Sans Pro"}}
                                    ]
                                },
                                tooltips: {
                                    callbacks: {
                                        afterTitle: function (data) {
                                            return titles[data[0].index];
                                        },
                                        label: function (tooltipItem, data) {
                                            return data.datasets[0].label + ": " + data.datasets[0].data[tooltipItem.index] + "%";

                                        }
                                    }
                                }
                            }
                        };

                        jQuery(document).ready(function ($) {
                            eventsLineChart = new Chart("tnp-opens-chart-canvas", open_config);
                        });
                    </script>

                </div>
            </div>

            <div class="col-md-6">
                <div class="tnp-widget">
                    <h3>Click rate</h3>


                    <div id="tnp-clicks-chart">
                        <canvas id="tnp-clicks-chart-canvas"></canvas>
                    </div>

                    <script type="text/javascript">
                        var click_config = {
                            type: 'line',
                            data: {
                                labels: <?php echo json_encode($overview_labels) ?>,
                                datasets: [

                                    {
                                        label: "Click",
                                        fill: false,
                                        strokeColor: "#2980b9",
                                        backgroundColor: "#2980b9",
                                        borderColor: "#2980b9",
                                        pointBorderColor: "#2980b9",
                                        pointBackgroundColor: "#2980b9",
                                        data: <?php echo json_encode($overview_click_rate) ?>,
                                    }
                                ]
                            },
                            options: {
                                scales: {
                                    xAxes: [{type: "category", "id": "x-axis-1", gridLines: {display: false}, ticks: {fontFamily: "Source Sans Pro"}}],
                                    yAxes: [
                                        {type: "linear", "id": "y-axis-1", gridLines: {display: false}, ticks: {fontColor: "#333", fontFamily: "Source Sans Pro"}}
                                    ]
                                },
                                tooltips: {
                                    callbacks: {
                                        afterTitle: function (data) {
                                            return titles[data[0].index];
                                        },
                                        label: function (tooltipItem, data) {
                                            return data.datasets[0].label + ": " + data.datasets[0].data[tooltipItem.index] + "%";
                                        }
                                    }
                                }
                            }
                        };

                        jQuery(document).ready(function ($) {
                            eventsLineChart = new Chart("tnp-clicks-chart-canvas", click_config);
                        });
                    </script>


                </div>

            </div>
        </div>

    </div>
    <?php include NEWSLETTER_DIR . '/tnp-footer.php' ?>
</div>