| Current Path : /home/users/unlimited/www/eshop.codeskitter.site/application/models/ |
| Current File : /home/users/unlimited/www/eshop.codeskitter.site/application/models/Promo_code_model.php |
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Promo_code_model extends CI_Model
{
public function __construct()
{
parent::__construct();
$this->load->database();
$this->load->library(['ion_auth', 'form_validation']);
$this->load->helper(['url', 'language', 'function_helper', 'sms_helper']);
}
public function get_promo_code_list($offset = 0, $limit = 10, $sort = 'id', $order = 'ASC')
{
$multipleWhere = '';
if (isset($_GET['offset']))
$offset = $_GET['offset'];
if (isset($_GET['limit']))
$limit = $_GET['limit'];
if (isset($_GET['sort']))
if ($_GET['sort'] == 'id') {
$sort = "id";
} else {
$sort = $_GET['sort'];
}
if (isset($_GET['order']))
$order = $_GET['order'];
if (isset($_GET['search']) and $_GET['search'] != '') {
$search = $_GET['search'];
$multipleWhere = ['p.`id`' => $search, 'p.`promo_code`' => $search, 'p.`message`' => $search, 'p.`start_date`' => $search, 'p.`end_date`' => $search, 'p.`discount`' => $search, 'p.`repeat_usage`' => $search, 'p.`max_discount_amount`' => $search];
}
$count_res = $this->db->select(' COUNT(p.id) as `total` ');
if (isset($multipleWhere) && !empty($multipleWhere)) {
$count_res->or_where($multipleWhere);
}
if (isset($where) && !empty($where)) {
$count_res->where($where);
}
$sc_count = $count_res->get('promo_codes p')->result_array();
foreach ($sc_count as $row) {
$total = $row['total'];
}
$search_res = $this->db->select(' p.`id` as id , p.`promo_code`, p.`image` , p.`message` , p.`start_date` , p.`end_date`, p.`discount` , p.`repeat_usage` ,p.`minimum_order_amount` ,p.`no_of_users` ,p.`discount_type` , p.`max_discount_amount`, p.`no_of_repeat_usage` , p.`status`,p.`is_cashback`,p.`list_promocode`');
if (isset($multipleWhere) && !empty($multipleWhere)) {
$search_res->or_like($multipleWhere);
}
if (isset($where) && !empty($where)) {
$search_res->where($where);
}
$sc_search_res = $search_res->order_by($sort, "desc")->limit($limit, $offset)->get('promo_codes p')->result_array();
$bulkData = array();
$bulkData['total'] = count($sc_search_res);
$rows = array();
$tempRow = array();
foreach ($sc_search_res as $row) {
$row = output_escaping($row);
$operate = '<a href="javascript:void(0)" class="view_btn btn btn-primary action-btn btn-xs mr-1 mb-1 ml-1" title="view" data-id="' . $row['id'] . '" data-url="admin/promo_code" ><i class="fa fa-eye" ></i></a>';
$operate .= ' <a href="' . base_url('admin/promo_code/manage_promo_code?edit_id=' . $row['id']) . '" class="btn btn-success edit_promocode action-btn btn-xs ml-1 mr-1 mb-1" title="Edit" data-id="' . $row['id'] . '" data-target="#add_promocode" data-toggle="modal"><i class="fa fa-pen"></i></a>';
$operate .= '<a class="btn btn-danger action-btn btn-xs ml-1 mr-1 mb-1" href="javascript:void(0)" id="delete-promo-code" title="Delete" data-id="' . $row['id'] . '" ><i class="fa fa-trash"></i></a>';
$tempRow['id'] = $row['id'];
$tempRow['promo_code'] = $row['promo_code'];
$tempRow['message'] = $row['message'];
$tempRow['start_date'] = $row['start_date'];
$tempRow['end_date'] = $row['end_date'];
$tempRow['discount'] = $row['discount'];
$tempRow['repeat_usage'] = ($row['repeat_usage'] == '1') ? 'Allowed' : 'Not Allowed';
$tempRow['min_order_amt'] = $row['minimum_order_amount'];
$tempRow['no_of_users'] = $row['no_of_users'];
$tempRow['discount_type'] = $row['discount_type'];
$tempRow['max_discount_amt'] = $row['max_discount_amount'];
$row['image'] = (isset($row['image']) && !empty($row['image'])) ? base_url() . $row['image'] : base_url() . NO_IMAGE;
$tempRow['image'] = '<div class="image-box-100"><a href=' . $row['image'] . ' data-toggle="lightbox" data-gallery="gallery"><img src=' . $row['image'] . ' class="rounded"></a></div>';
$tempRow['no_of_repeat_usage'] = $row['no_of_repeat_usage'];
if ($row['status'] == '1') {
$tempRow['status'] = '<span class="badge badge-success" >Active</span>';
} else {
$tempRow['status'] = '<span class="badge badge-danger" >Deactive</span>';
}
$tempRow['is_cashback'] = ($row['is_cashback'] == '1') ? '<span class="badge badge-info" >ON</span>' : '<span class="badge badge-warning">OFF</span>';
$tempRow['list_promocode'] = ($row['list_promocode'] == '1') ? '<span class="badge badge-primary" >SHOW</span>' : '<span class="badge badge-secondary">HIDDEN</span>';
$tempRow['operate'] = $operate;
$rows[] = $tempRow;
}
$bulkData['rows'] = $rows;
print_r(json_encode($bulkData));
}
public function get_promo_codes($limit = "", $offset = '', $sort = 'u.id', $order = 'DESC', $search = NULL)
{
$multipleWhere = '';
if (isset($search) and $search != '') {
$multipleWhere = ['p.`id`' => $search, 'p.`promo_code`' => $search, 'p.`message`' => $search, 'p.`start_date`' => $search, 'p.`end_date`' => $search, 'p.`discount`' => $search, 'p.`repeat_usage`' => $search, 'p.`max_discount_amount`' => $search];
}
$count_res = $this->db->select(' COUNT(p.id) as `total` ');
if (isset($multipleWhere) && !empty($multipleWhere)) {
$count_res->or_where($multipleWhere);
}
$where = "(CURDATE() between start_date AND end_date) and status = 1 and list_promocode = 1";
$count_res->where($where);
$sc_count = $count_res->get('promo_codes p')->result_array();
foreach ($sc_count as $row) {
$total = $row['total'];
}
$search_res = $this->db->select(' p.`id` as id ,datediff(end_date, start_date ) as remaining_days, p.`promo_code`, p.`image` , p.`message` , p.`start_date` , p.`end_date`, p.`discount` , p.`repeat_usage` ,p.`minimum_order_amount` ,p.`no_of_users` ,p.`discount_type` , p.`max_discount_amount`, p.`no_of_repeat_usage` , p.`status`,p.`is_cashback`,p.`list_promocode`');
if (isset($multipleWhere) && !empty($multipleWhere)) {
$search_res->or_like($multipleWhere);
}
$where = "(CURDATE() between start_date AND end_date) and status = 1 and list_promocode = 1";
$search_res->where($where);
$sc_search_res = $search_res->order_by($sort, $order)->limit($limit, $offset)->get('promo_codes p')->result_array();
$bulkData = array();
$bulkData['error'] = (empty($sc_search_res)) ? true : false;
$bulkData['message'] = (empty($sc_search_res)) ? 'Promo code(s) does not exist' : 'Promo code(s) retrieved successfully';
$bulkData['total'] = (empty($sc_search_res)) ? 0 : $total;
$rows = array();
$tempRow = array();
foreach ($sc_search_res as $row) {
$row = output_escaping($row);
$tempRow['id'] = $row['id'];
$tempRow['promo_code'] = $row['promo_code'];
$tempRow['message'] = $row['message'];
$tempRow['start_date'] = $row['start_date'];
$tempRow['end_date'] = $row['end_date'];
$tempRow['discount'] = $row['discount'];
$tempRow['repeat_usage'] = ($row['repeat_usage'] == '1') ? 'Allowed' : 'Not Allowed';
$tempRow['min_order_amt'] = $row['minimum_order_amount'];
$tempRow['no_of_users'] = $row['no_of_users'];
$tempRow['discount_type'] = $row['discount_type'];
$tempRow['max_discount_amt'] = $row['max_discount_amount'];
$tempRow['image'] = (isset($row['image']) && !empty($row['image'])) ? base_url() . $row['image'] : base_url() . NO_IMAGE;
$tempRow['no_of_repeat_usage'] = $row['no_of_repeat_usage'];
$tempRow['status'] = $row['status'];
$tempRow['is_cashback'] = $row['is_cashback'];
$tempRow['list_promocode'] = $row['list_promocode'];
$tempRow['remaining_days'] = $row['remaining_days'];
$rows[] = $tempRow;
}
$bulkData['data'] = $rows;
if (!empty($bulkData)) {
return $bulkData;
} else {
return $bulkData = [];
}
}
public function add_promo_code_details($data)
{
$data = escape_array($data);
$promo_data = [
'promo_code' => $data['promo_code'],
'message' => $data['message'],
'start_date' => $data['start_date'],
'end_date' => $data['end_date'],
'no_of_users' => $data['no_of_users'],
'minimum_order_amount' => $data['minimum_order_amount'],
'discount' => $data['discount'],
'discount_type' => $data['discount_type'],
'max_discount_amount' => $data['max_discount_amount'],
'repeat_usage' => $data['repeat_usage'],
'status' => $data['status'],
'image' => $data['image'],
'is_cashback' => (isset($data['is_cashback']) && $data['is_cashback'] == 'on') ? '1' : '0',
'list_promocode' => (isset($data['list_promocode']) && $data['list_promocode'] == 'on') ? '1' : '0'
];
if ($data['repeat_usage'] == '1') {
$promo_data['no_of_repeat_usage'] = $data['no_of_repeat_usage'];
}
if (isset($data['edit_promo_code']) && !empty($data['edit_promo_code'])) {
$this->db->set($promo_data)->where('id', $data['edit_promo_code'])->update('promo_codes');
} else {
$this->db->insert('promo_codes', $promo_data);
}
}
function settle_cashback_discount()
{
$return = false;
$date = date('Y-m-d');
$settings = get_settings('system_settings', true);
$returnable_where = "oi.active_status='delivered' AND o.promo_code != '' AND o.promo_discount <= 0 GROUP BY `o`.`id` HAVING date = '" . $date . "'";
$returnable_data = $this->db->select("o.id,o.date_added,o.total,o.final_total,o.promo_code,o.user_id,p.is_returnable,(date_format(o.date_added,'%Y-%m-%d')) as date ")
->join('order_items oi', 'oi.order_id=o.id', 'left')
->join('product_variants pv', 'oi.product_variant_id=pv.id', 'left')
->join('products p', 'p.id=pv.product_id', 'left')
->where($returnable_where)
->get('orders o')->result_array();
foreach ($returnable_data as $result) {
$res = $this->db->select('oi.id as item_id, oi.order_id,p.is_returnable')
->join('product_variants pv', 'oi.product_variant_id = pv.id', 'left')
->join('products p', 'p.id = pv.product_id')
->where("oi.order_id", $result['id'])
->where_in('p.is_returnable', [0, 1])
->get('order_items oi')->result_array();
$returnable_status = array_column($res, 'is_returnable');
if (in_array("1", $returnable_status)) {
$return = true;
} else {
$return = false;
}
}
if ($return == true) {
$select = "DATE_ADD(date_format(o.date_added,'%Y-%m-%d'), INTERVAL " . $settings['max_product_return_days'] . " DAY) as date";
} elseif ($return == false) {
$select = "(date_format(o.date_added,'%Y-%m-%d')) as date";
} else {
$select = "(date_format(o.date_added,'%Y-%m-%d')) as date";
}
$where = "oi.active_status='delivered' AND o.promo_code != '' AND o.promo_discount <= 0 GROUP BY `o`.`id` HAVING date = '" . $date . "'";
$data = $this->db->select("o.id,o.date_added,o.total,o.final_total,o.promo_code,o.user_id,$select ")
->join('order_items oi', 'oi.order_id=o.id', 'left')
->where($where)
->get('orders o')->result_array();
$wallet_updated = false;
if (!empty($data)) {
foreach ($data as $row) {
$promo_code = $row['promo_code'];
$user_id = $row['user_id'];
$final_total = $row['final_total'];
$res = validate_promo_code($promo_code, $user_id, $final_total);
$response = update_wallet_balance('credit', $user_id, $res['data'][0]['final_discount'], 'Discounted Amount Credited for Order Item ID : ' . $row['id']);
if ($response['error'] == false && $response['error'] == '') {
update_details(['total_payable' => $res['data'][0]['final_total'], 'final_total' => $res['data'][0]['final_total'], 'promo_discount' => $res['data'][0]['final_discount']], ['id' => $row['id']], 'orders');
$wallet_updated = true;
$response_data['error'] = false;
$response_data['message'] = 'Discount Added Successfully...';
} else {
$wallet_updated = false;
$response_data['error'] = true;
$response_data['message'] = 'Discount not Added';
}
}
if ($wallet_updated == true) {
$user_ids = array_values(array_unique(array_column($data, "user_id")));
foreach ($user_ids as $user) {
$settings = get_settings('system_settings', true);
$firebase_project_id = get_settings('firebase_project_id');
$service_account_file = get_settings('service_account_file');
//custom message
$app_name = isset($settings['app_name']) && !empty($settings['app_name']) ? $settings['app_name'] : '';
$user_res = fetch_details('users', ['id' => $user], 'username,fcm_id,email,mobile,platform_type');
$custom_notification = fetch_details('custom_notifications', ['type' => "settle_cashback_discount"], '');
$hashtag_cutomer_name = '< cutomer_name >';
$hashtag_application_name = '< application_name >';
$string = json_encode(isset($custom_notification[0]['message']) ? $custom_notification[0]['message'] : '', JSON_UNESCAPED_UNICODE);
$hashtag = html_entity_decode($string);
$data = str_replace(array($hashtag_cutomer_name, $hashtag_application_name), array($user_res[0]['username'], $app_name), $hashtag);
$message = output_escaping(trim($data, '"'));
$customer_title = (!empty($custom_notification)) ? $custom_notification[0]['title'] : "Discounted Amount Credited";
$customer_msg = (!empty($custom_notification)) ? $message : 'Hello Dear ' . $user_res[0]['username'] . 'Discounted Amount Credited, which orders are delivered. Please take note of it! Regards' . $app_name . '';
send_mail($user_res[0]['email'], $customer_title, $customer_msg);
(notify_event(
"settle_cashback_discount",
["customer" => [$user_res[0]['email']]],
["customer" => [$user_res[0]['mobile']]],
["users.mobile" => $user_res[0]['mobile']]
));
$fcm_ids = array();
if (!empty($user_res[0]['fcm_id']) && isset($firebase_project_id) && isset($service_account_file) && !empty($firebase_project_id) && !empty($service_account_file)) {
$fcmMsg = array(
'title' => $customer_title,
'body' => $customer_msg,
'type' => "Discounted",
);
// Step 1: Group by platform
$groupedByPlatform = [];
foreach ($user_res as $item) {
$platform = $item['platform_type'];
$groupedByPlatform[$platform][] = $item['fcm_id'];
}
// Step 2: Chunk each platform group into arrays of 1000
$fcm_ids = [];
foreach ($groupedByPlatform as $platform => $fcmIds) {
$fcm_ids[$platform] = array_chunk($fcmIds, 1000);
}
$fcm_ids[0][] = $fcm_ids;
send_notification($fcmMsg, $fcm_ids, $fcmMsg);
}
}
} else {
$response_data['error'] = true;
$response_data['message'] = 'Discounted not Added';
}
} else {
$response_data['error'] = true;
$response_data['message'] = 'Orders Not Found';
}
print_r(json_encode($response_data));
}
function settle_referal_cashback_discount()
{
$return = false;
$date = date('Y-m-d');
$settings = get_settings('system_settings', true);
$max_retun_day = $settings['max_product_return_days'];
$is_refer_earn_on = $settings['is_refer_earn_on'];
$min_refer_earn_order_amount = $settings['min_refer_earn_order_amount'];
$refer_earn_bonus_for_user = $settings['refer_earn_bonus_for_user'];
$refer_earn_method_for_user = $settings['refer_earn_method_for_user'];
$refer_earn_method_for_referal = $settings['refer_earn_method_for_referal'];
$max_refer_earn_amount_for_user = $settings['max_refer_earn_amount_for_user'];
$refer_earn_amount_for_referal = $settings['refer_earn_amount_for_referal'];
if ($is_refer_earn_on == '1') {
// for referal cashback discount
$this->db->select('*');
$this->db->from('refer_and_earn');
$this->db->where('is_user_cashback_settled', 0);
$user_query = $this->db->get();
$user_ids = array_column($user_query->result_array(), 'user_id'); // Extract user IDs into an array
$referal_ids = array_column($user_query->result_array(), 'referal_id');
if (!empty($user_ids)) {
// Subquery to get the first order_id for each user
$this->db->select('user_id, MIN(id) as first_order_id');
$this->db->from('orders');
$this->db->where_in('user_id', $user_ids);
$this->db->where('total_payable >', $min_refer_earn_order_amount);
$this->db->group_by('user_id');
$subquery = $this->db->get_compiled_select();
// Main query to get order and order items using the first order_id from the subquery
$this->db->select('o.*, oi.*, pv.id as product_variant_id, pv.product_id as product_id, p.id, p.is_returnable,
DATE_ADD(date_format(o.date_added,"%Y-%m-%d"), INTERVAL ' . $max_retun_day . ' DAY) as date');
$this->db->from('orders o');
$this->db->join('order_items oi', 'o.id = oi.order_id', 'inner');
$this->db->join('product_variants pv', 'oi.product_variant_id = pv.id', 'inner');
$this->db->join('products p', 'pv.product_id = p.id', 'inner');
$this->db->join("($subquery) as first_orders", 'o.id = first_orders.first_order_id', 'inner');
// Filter to get only order items with status 'delivered'
$this->db->where('oi.active_status', 'delivered');
// Filter to get only products that are returnable
$this->db->where('p.is_returnable', 1);
// Execute the query and get the result as an array
$order_query = $this->db->get();
$first_delivered_returnable_orders = $order_query->result_array();
if (!empty($first_delivered_returnable_orders)) {
// Iterate over each order
foreach ($first_delivered_returnable_orders as $order) {
if (in_array($order['user_id'], $user_ids)) {
// Calculate the return amount for each product
if ($refer_earn_method_for_user == 'amount') {
$return_amount = $refer_earn_bonus_for_user;
if ($return_amount > $max_refer_earn_amount_for_user) {
$return_amount = update_wallet_balance('credit', $order['user_id'], $max_refer_earn_amount_for_user, 'Referal amount credited successfully.');
update_details(['is_user_cashback_settled' => 1], ['is_user_cashback_settled' => 0, 'user_id' => $order['user_id']], 'refer_and_earn');
$wallet_updated = true;
$response_data['error'] = false;
$response_data['message'] = 'Referal amount credited successfully.';
} else {
$return_amount = update_wallet_balance('credit', $order['user_id'], $return_amount, 'Referal amount credited successfully.');
update_details(['is_user_cashback_settled' => 1], ['is_user_cashback_settled' => 0, 'user_id' => $order['user_id']], 'refer_and_earn');
$wallet_updated = true;
$response_data['error'] = false;
$response_data['message'] = 'Referal amount credited successfully.';
}
} else if ($refer_earn_method_for_user == 'percentage') {
$return_amount = $order['total_payable'] * ($refer_earn_bonus_for_user / 100);
if ($return_amount > $max_refer_earn_amount_for_user) {
$return_amount = update_wallet_balance('credit', $order['user_id'], $max_refer_earn_amount_for_user, 'Referal amount credited successfully.');
update_details(['is_user_cashback_settled' => 1], ['is_user_cashback_settled' => 0, 'user_id' => $order['user_id']], 'refer_and_earn');
$wallet_updated = true;
$response_data['error'] = false;
$response_data['message'] = 'Referal amount credited successfully.';
} else {
$return_amount = update_wallet_balance('credit', $order['user_id'], $return_amount, 'Referal amount credited successfully.');
update_details(['is_user_cashback_settled' => 1], ['is_user_cashback_settled' => 0, 'user_id' => $order['user_id']], 'refer_and_earn');
$wallet_updated = true;
$response_data['error'] = false;
$response_data['message'] = 'Referal amount credited successfully.';
}
}
}
}
} else {
$response_data['error'] = true;
$response_data['message'] = 'Orders not found for settle referal amount.';
}
} else {
$response_data['error'] = true;
$response_data['message'] = 'Users not found for settle referal amount.';
}
print_r(json_encode($response_data));
}
}
function settle_referal_cashback_discount_for_referal()
{
$return = false;
$date = date('Y-m-d');
$settings = get_settings('system_settings', true);
$max_retun_day = $settings['max_product_return_days'];
$is_refer_earn_on = $settings['is_refer_earn_on'];
$min_refer_earn_order_amount = $settings['min_refer_earn_order_amount'];
$refer_earn_bonus = $settings['refer_earn_bonus'];
$refer_earn_method_for_user = $settings['refer_earn_method_for_user'];
$refer_earn_method_for_referal = $settings['refer_earn_method_for_referal'];
$max_refer_earn_amount_for_user = $settings['max_refer_earn_amount_for_user'];
$refer_earn_amount_for_referal = $settings['refer_earn_bonus_for_referal'];
if ($is_refer_earn_on == '1') {
// for referal cashback discount
$this->db->select('*');
$this->db->from('refer_and_earn');
$this->db->where('is_reffral_settled', 0);
$user_query = $this->db->get();
$user_ids = array_column($user_query->result_array(), 'user_id'); // Extract user IDs into an array
$referal_ids = array_column($user_query->result_array(), 'referal_id');
if (!empty($user_ids)) {
// Subquery to get the first order_id for each user
$this->db->select('user_id, MIN(id) as first_order_id');
$this->db->from('orders');
$this->db->where_in('user_id', $user_ids);
$this->db->where('total_payable >', $min_refer_earn_order_amount);
$this->db->group_by('user_id');
$subquery = $this->db->get_compiled_select();
// Main query to get order and order items using the first order_id from the subquery
$this->db->select('o.*, oi.*, pv.id as product_variant_id, pv.product_id as product_id, p.id, p.is_returnable,
DATE_ADD(date_format(o.date_added,"%Y-%m-%d"), INTERVAL ' . $max_retun_day . ' DAY) as date');
$this->db->from('orders o');
$this->db->join('order_items oi', 'o.id = oi.order_id', 'inner');
$this->db->join('product_variants pv', 'oi.product_variant_id = pv.id', 'inner');
$this->db->join('products p', 'pv.product_id = p.id', 'inner');
$this->db->join("($subquery) as first_orders", 'o.id = first_orders.first_order_id', 'inner');
// Filter to get only order items with status 'delivered'
$this->db->where('oi.active_status', 'delivered');
// Filter to get only products that are returnable
$this->db->where('p.is_returnable', 1);
// Execute the query and get the result as an array
$order_query = $this->db->get();
$first_delivered_returnable_orders = $order_query->result_array();
if (!empty($first_delivered_returnable_orders)) {
// Calculate the return amount for each product
if ($refer_earn_method_for_referal == 'amount') {
foreach ($referal_ids as $referal_id) {
$return_amount = update_wallet_balance('credit', $referal_id, $refer_earn_amount_for_referal, 'Referal amount credited successfully.');
if ($return_amount['error'] == false && $return_amount['error'] == '') {
update_details(['is_reffral_settled' => 1], ['is_reffral_settled' => 0, 'referal_id' => $referal_id], 'refer_and_earn');
$wallet_updated = true;
$response_data['error'] = false;
$response_data['message'] = 'Referal amount credited successfully.';
} else {
$wallet_updated = false;
$response_data['error'] = true;
$response_data['message'] = 'Discount not Added';
}
}
}
} else {
$response_data['error'] = true;
$response_data['message'] = 'Orders not found for settle referal amount.';
}
} else {
$response_data['error'] = true;
$response_data['message'] = 'Users not found for settle referal amount.';
}
print_r(json_encode($response_data));
}
}
}