first commit
This commit is contained in:
@@ -0,0 +1,214 @@
|
||||
<?php
|
||||
class ModelExtensionDashboardChart extends Model {
|
||||
public function getTotalOrdersByDay() {
|
||||
$implode = array();
|
||||
|
||||
foreach ($this->config->get('config_complete_status') as $order_status_id) {
|
||||
$implode[] = "'" . (int)$order_status_id . "'";
|
||||
}
|
||||
|
||||
$order_data = array();
|
||||
|
||||
for ($i = 0; $i < 24; $i++) {
|
||||
$order_data[$i] = array(
|
||||
'hour' => $i,
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, HOUR(date_added) AS hour FROM `" . DB_PREFIX . "order` WHERE order_status_id IN(" . implode(",", $implode) . ") AND DATE(date_added) = DATE(NOW()) GROUP BY HOUR(date_added) ORDER BY date_added ASC");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$order_data[$result['hour']] = array(
|
||||
'hour' => $result['hour'],
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $order_data;
|
||||
}
|
||||
|
||||
public function getTotalOrdersByWeek() {
|
||||
$implode = array();
|
||||
|
||||
foreach ($this->config->get('config_complete_status') as $order_status_id) {
|
||||
$implode[] = "'" . (int)$order_status_id . "'";
|
||||
}
|
||||
|
||||
$order_data = array();
|
||||
|
||||
$date_start = strtotime('-' . date('w') . ' days');
|
||||
|
||||
for ($i = 0; $i < 7; $i++) {
|
||||
$date = date('Y-m-d', $date_start + ($i * 86400));
|
||||
|
||||
$order_data[date('w', strtotime($date))] = array(
|
||||
'day' => date('D', strtotime($date)),
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, date_added FROM `" . DB_PREFIX . "order` WHERE order_status_id IN(" . implode(",", $implode) . ") AND DATE(date_added) >= DATE('" . $this->db->escape(date('Y-m-d', $date_start)) . "') GROUP BY DAYNAME(date_added)");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$order_data[date('w', strtotime($result['date_added']))] = array(
|
||||
'day' => date('D', strtotime($result['date_added'])),
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $order_data;
|
||||
}
|
||||
|
||||
public function getTotalOrdersByMonth() {
|
||||
$implode = array();
|
||||
|
||||
foreach ($this->config->get('config_complete_status') as $order_status_id) {
|
||||
$implode[] = "'" . (int)$order_status_id . "'";
|
||||
}
|
||||
|
||||
$order_data = array();
|
||||
|
||||
for ($i = 1; $i <= date('t'); $i++) {
|
||||
$date = date('Y') . '-' . date('m') . '-' . $i;
|
||||
|
||||
$order_data[date('j', strtotime($date))] = array(
|
||||
'day' => date('d', strtotime($date)),
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, date_added FROM `" . DB_PREFIX . "order` WHERE order_status_id IN(" . implode(",", $implode) . ") AND DATE(date_added) >= '" . $this->db->escape(date('Y') . '-' . date('m') . '-1') . "' GROUP BY DATE(date_added)");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$order_data[date('j', strtotime($result['date_added']))] = array(
|
||||
'day' => date('d', strtotime($result['date_added'])),
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $order_data;
|
||||
}
|
||||
|
||||
public function getTotalOrdersByYear() {
|
||||
$implode = array();
|
||||
|
||||
foreach ($this->config->get('config_complete_status') as $order_status_id) {
|
||||
$implode[] = "'" . (int)$order_status_id . "'";
|
||||
}
|
||||
|
||||
$order_data = array();
|
||||
|
||||
for ($i = 1; $i <= 12; $i++) {
|
||||
$order_data[$i] = array(
|
||||
'month' => date('M', mktime(0, 0, 0, $i)),
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, date_added FROM `" . DB_PREFIX . "order` WHERE order_status_id IN(" . implode(",", $implode) . ") AND YEAR(date_added) = YEAR(NOW()) GROUP BY MONTH(date_added)");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$order_data[date('n', strtotime($result['date_added']))] = array(
|
||||
'month' => date('M', strtotime($result['date_added'])),
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $order_data;
|
||||
}
|
||||
|
||||
public function getTotalCustomersByDay() {
|
||||
$customer_data = array();
|
||||
|
||||
for ($i = 0; $i < 24; $i++) {
|
||||
$customer_data[$i] = array(
|
||||
'hour' => $i,
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, HOUR(date_added) AS hour FROM `" . DB_PREFIX . "customer` WHERE DATE(date_added) = DATE(NOW()) GROUP BY HOUR(date_added) ORDER BY date_added ASC");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$customer_data[$result['hour']] = array(
|
||||
'hour' => $result['hour'],
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $customer_data;
|
||||
}
|
||||
|
||||
public function getTotalCustomersByWeek() {
|
||||
$customer_data = array();
|
||||
|
||||
$date_start = strtotime('-' . date('w') . ' days');
|
||||
|
||||
for ($i = 0; $i < 7; $i++) {
|
||||
$date = date('Y-m-d', $date_start + ($i * 86400));
|
||||
|
||||
$customer_data[date('w', strtotime($date))] = array(
|
||||
'day' => date('D', strtotime($date)),
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, date_added FROM `" . DB_PREFIX . "customer` WHERE DATE(date_added) >= DATE('" . $this->db->escape(date('Y-m-d', $date_start)) . "') GROUP BY DAYNAME(date_added)");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$customer_data[date('w', strtotime($result['date_added']))] = array(
|
||||
'day' => date('D', strtotime($result['date_added'])),
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $customer_data;
|
||||
}
|
||||
|
||||
public function getTotalCustomersByMonth() {
|
||||
$customer_data = array();
|
||||
|
||||
for ($i = 1; $i <= date('t'); $i++) {
|
||||
$date = date('Y') . '-' . date('m') . '-' . $i;
|
||||
|
||||
$customer_data[date('j', strtotime($date))] = array(
|
||||
'day' => date('d', strtotime($date)),
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, date_added FROM `" . DB_PREFIX . "customer` WHERE DATE(date_added) >= '" . $this->db->escape(date('Y') . '-' . date('m') . '-1') . "' GROUP BY DATE(date_added)");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$customer_data[date('j', strtotime($result['date_added']))] = array(
|
||||
'day' => date('d', strtotime($result['date_added'])),
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $customer_data;
|
||||
}
|
||||
|
||||
public function getTotalCustomersByYear() {
|
||||
$customer_data = array();
|
||||
|
||||
for ($i = 1; $i <= 12; $i++) {
|
||||
$customer_data[$i] = array(
|
||||
'month' => date('M', mktime(0, 0, 0, $i)),
|
||||
'total' => 0
|
||||
);
|
||||
}
|
||||
|
||||
$query = $this->db->query("SELECT COUNT(*) AS total, date_added FROM `" . DB_PREFIX . "customer` WHERE YEAR(date_added) = YEAR(NOW()) GROUP BY MONTH(date_added)");
|
||||
|
||||
foreach ($query->rows as $result) {
|
||||
$customer_data[date('n', strtotime($result['date_added']))] = array(
|
||||
'month' => date('M', strtotime($result['date_added'])),
|
||||
'total' => $result['total']
|
||||
);
|
||||
}
|
||||
|
||||
return $customer_data;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user