PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/seoshop.live/wp-content/plugins/cart66/models/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/seoshop.live/wp-content/plugins/cart66/models/Cart66DataTables.php

<?php
Class Cart66DataTables {
  
  public static function sortProductSearch($a, $b) {
    if(isset($_GET['iSortCol_0'])){
  		for($i=0; $i<intval($_GET['iSortingCols']); $i++){
  			if(isset($_GET['bSortable_' . intval($_GET['iSortCol_' . $i])]) && $_GET['bSortable_' . intval($_GET['iSortCol_' . $i])] == "true"){
  			  if($_GET['iSortCol_' . $i] == 0) {
  			    $value = 'name';
  			  }
  			  elseif($_GET['iSortCol_' . $i] == 1) {
  			    $value = 'quantity';
  			  }
  			  else {
  			    $value = 'sales_amount';
  			  }
  			  if($_GET['sSortDir_0'] == 'asc') {
  			    $result = strnatcmp($a[$value], $b[$value]);
  			  }
  				else {
  				  $result = strnatcmp($b[$value], $a[$value]);
  				}
  			}
  		}
  	}
    return $result;
  }
  
  public function productsSearch() {
    $where = "";
  	if(isset($_GET['sSearch']) && $_GET['sSearch'] != ""){
  		$where = $_GET['sSearch'];
  	}
  	
    $products = self::productSalesForMonth();
    foreach($products as $k => $p) {
      if(!preg_match("/$where/i", $p['name']) && !preg_match("/$where/i", $p['quantity']) && !preg_match("/$where/i", $p['sales_amount'])) {
        unset($products[$k]);
      }
    }
    
    return $products;
  }
  
  public static function dashboardProductsTable() {
    
    $iFilteredTotal = self::productsSearch();
  	
  	$data = array();
  	$products = self::productSalesForMonth();
  	$productsSearch = self::productsSearch();
  	
  	uasort($productsSearch, array('Cart66DataTables', 'sortProductSearch'));
  	
  	if(isset($_GET['iDisplayStart']) && $_GET['iDisplayLength'] != '-1'){
  		$limit = array_slice($productsSearch, $_GET['iDisplayStart'], $_GET['iDisplayLength']);
  	}
  	
  	foreach($limit as $p) {
  	  $data[] = array(
    	  $p['name'],
    	  $p['quantity'],
    	  Cart66Common::currency($p['sales_amount'])
    	);
  	}
  	$array = array(
  	 'sEcho' => $_GET['sEcho'],
  	 'iTotalRecords' => count($products),
  	 'iTotalDisplayRecords' => count($productsSearch),
  	 'aaData' => $data
  	);
  	echo json_encode($array);
  	die();
  }
  
  public static function inventoryTable() {
    $columns = array(
      'id',
      'name',
      'options_1',
      'options_2'
    );
    
    if (isset($_GET['iSortCol_0'])){
      $sortingColumns = array(
        0 => 0,
        1 => 1,
        2 => 2,
        3 => 3
      );
      $_GET['iSortCol_0'] = $sortingColumns[$_GET['iSortCol_0']];
    }
    
    $indexColumn = "id";
    $tableName = Cart66Common::getTableName('products');
    
    $where = self::dataTablesWhere($columns);
  	$limit = self::dataTablesLimit() == '' ? null : self::dataTablesLimit();
  	$order = self::dataTablesOrder($columns);
  	
    $iTotal = self::totalRows($indexColumn, $tableName);
    $iFilteredTotal = self::filteredRows($indexColumn, $tableName, $where);
  	
  	$data = array();
  	$product = new Cart66Product();
  	$products = $product->getModels($where, $order, $limit);
  	$save = false;
  	$ikeyList = array();
    foreach($products as $p) {
      $p->insertInventoryData();
      $combos = $p->getAllOptionCombinations();
      if(count($combos)) {
        foreach($combos as $c) {
          $k = $p->getInventoryKey($c);
          $ikeyList[] = $k;
          if($save) { $p->updateInventoryFromPost($k); }
          $data[] = array(
            $p->isInventoryTracked($k),
            $p->name,
            $c,
            $p->getInventoryCount($k),
            $k
          );
        }
      }
      else {
        $k = $p->getInventoryKey();
        $ikeyList[] = $k;
        if($save) { $p->updateInventoryFromPost($k); }
        $data[] = array(
          $p->isInventoryTracked($k),
          $p->name,
          $c='',
          $p->getInventoryCount($k),
          $k
        );
      }
    }
  
    if($save) { $p->pruneInventory($ikeyList); }
  	
  	$array = array(
  	 'sEcho' => $_GET['sEcho'],
  	 'iTotalRecords' => $iTotal[0],
  	 'iTotalDisplayRecords' => $iFilteredTotal[0],
  	 'aaData' => $data
  	);
  	echo json_encode($array);
  	die();
  }
  
  public static function accountsTable() {
    $columns = array(
      'a.id', 
      'a.first_name', 
      'a.last_name',
      'a.username', 
      'a.email',
      'a.notes',
      's.subscription_plan_name',
      's.feature_level',
      's.active_until',
    );
    $indexColumn = "DISTINCT a.id";
    $tableName = Cart66Common::getTableName('accounts') . ' as a, ' . Cart66Common::getTableName('account_subscriptions') . ' as s';
    
    if (isset($_GET['iSortCol_0'])){
      $sortingColumns = array(
        0 => 0,
        1 => 1,
        2 => 3,
        3 => 4,
        4 => 6,
        5 => 7,
        6 => 8,
        7 => 9
      );
      $_GET['iSortCol_0'] = $sortingColumns[$_GET['iSortCol_0']];
    }
    
    $where = self::dataTablesWhere($columns) == '' ? 'WHERE s.account_id = a.id' : self::dataTablesWhere($columns) . ' AND s.account_id = a.id ';
  	$limit = self::dataTablesLimit() == '' ? null : self::dataTablesLimit();
  	$order = self::dataTablesOrder($columns);
    
    $iTotal = self::totalRows($indexColumn, $tableName, 'WHERE s.account_id = a.id');
    $iFilteredTotal = self::filteredRows($indexColumn, $tableName, $where);
  	$data = array();
  	$account = new Cart66Account();
  	$accounts = $account->getModels($where, $order, $limit, $tableName, $indexColumn);
  	foreach($accounts as $a) {
      $planName = 'No Active Subscription';
      $featureLevel = 'No Access';
      $activeUntil = 'Expired';
      if($sub = $a->getCurrentAccountSubscription(true)) {
        $planName = $sub->subscriptionPlanName;
        $featureLevel = $sub->isActive() ? $sub->featureLevel : 'No Access - Expired';
        $activeUntil = $sub->isActive() ? date('m/d/Y', strtotime($sub->activeUntil)) : 'No Access';
        $activeUntil = ($sub->lifetime == 1) ? "Lifetime" : $activeUntil;
        $type = 'Manual';
        if($sub->isPayPalSubscription()) {
          $type = 'PayPal';
        }
        elseif($sub->isSpreedlySubscription()) {
          $type = 'Spreedly';
        }
      }
      else {
        $planName = 'No plan available';
        $featureLevel = 'No Feature Level';
        $activeUntil = 'No Access';
        $type = 'None';
      }
  	  
  	  $data[] = array(
  	    $a->id, 
  	    $a->first_name . ' ' . $a->last_name,
  	    $a->username,
  	    $a->email,
  	    $planName,
  	    $featureLevel,
  	    $activeUntil,
  	    $type,
  	    $a->notes,
  	    $a->getOrderIdLink()
  	  );
  	}

  	$array = array(
  	 'sEcho' => $_GET['sEcho'],
  	 'iTotalRecords' => $iTotal[0],
  	 'iTotalDisplayRecords' => $iFilteredTotal[0],
  	 'aaData' => $data
  	);
  	echo json_encode($array);
  	die();
  }
  
  public static function promotionsTable() {
    $columns = array(
      'id', 
      'name', 
      'code', 
      'amount', 
      'min_order', 
      'enable', 
      'effective_from', 
      'effective_to', 
      'redemptions', 
      'apply_to'
    );
    $indexColumn = "id";
    $tableName = Cart66Common::getTableName('promotions');
    if (isset($_GET['iSortCol_0'])){
      $sortingColumns = array(
        0 => 0,
        1 => 1,
        2 => 2,
        3 => 3,
        4 => 4,
        5 => 5,
        6 => 6,
        7 => 8,
        8 => 9
      );
      $_GET['iSortCol_0'] = $sortingColumns[$_GET['iSortCol_0']];
    }
    $where = self::dataTablesWhere($columns);
  	$limit = self::dataTablesLimit() == '' ? null : self::dataTablesLimit();
  	$order = self::dataTablesOrder($columns);
    
    $iTotal = self::totalRows($indexColumn, $tableName);
    $iFilteredTotal = self::filteredRows($indexColumn, $tableName, $where);
  	
  	$data = array();
  	$promotion = new Cart66Promotion();
  	$promotions = $promotion->getModels($where, $order, $limit);
  	//Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] " . print_r($promotions));
  	foreach($promotions as $p) {
  	  $data[] = array(
  	    $p->id, 
  	    $p->name, 
  	    $p->getCodeAt(), 
  	    $p->getAmountDescription(), 
  	    $p->getMinOrderDescription(), 
  	    $p->enable == 1 ? 'Yes' : 'No',
  	    $p->effectiveDates(),
  	    ($p->redemptions < 1) ? __('Never', 'cart66') : ( ($p->redemptions == 1) ? $p->redemptions . ' ' . __('time', 'cart66') : $p->redemptions . ' ' . __('times', 'cart66')),
  	    ($p->apply_to == 'products') ? __("Products", 'cart66') : ( ($p->apply_to == 'shipping') ? __("Shipping", 'cart66') : ( ($p->apply_to == 'subtotal') ? __("Subtotal", 'cart66') : __("Cart Total", 'cart66') ) )
  	  );
  	}
  	
  	$array = array(
  	 'sEcho' => $_GET['sEcho'],
  	 'iTotalRecords' => $iTotal[0],
  	 'iTotalDisplayRecords' => $iFilteredTotal[0],
  	 'aaData' => $data
  	);
  	echo json_encode($array);
  	die();
  }
  
  public static function ordersTable() {
    $columns = array( 'id', 'trans_id', 'bill_first_name', 'bill_last_name', 'total', 'ordered_on', 'shipping_method', 'status', 'email', 'notes', 'authorization' );
    $indexColumn = "id";
    $tableName = Cart66Common::getTableName('orders');

    $where = self::dataTablesWhere($columns, 'status', 'checkout_pending', '!=');
    if($where == ""){
      $where = "WHERE `status` != 'checkout_pending'";
    }
    else {
      $where .= " AND `status` != 'checkout_pending'";
    }
    $limit = self::dataTablesLimit() == '' ? null : self::dataTablesLimit();
    $orderBy = self::dataTablesOrder($columns);
    
    $iTotal = self::totalRows($indexColumn, $tableName);
    $iFilteredTotal = self::filteredRows($indexColumn, $tableName, $where);
    
    $data = array();
    $order = new Cart66Order();
    $orders = $order->getOrderRows($where, $orderBy, $limit);
    foreach($orders as $o) {
      $data[] = array(
        $o->id,
        $o->trans_id,
        $o->bill_first_name,
        $o->bill_last_name,
        Cart66Common::currency($o->total),
        date('m/d/Y', strtotime($o->ordered_on)),
        $o->shipping_method,
        $o->status,
        $o->notes
      );
    }
    
    $array = array(
      'sEcho' => $_GET['sEcho'],
      'iTotalRecords' => $iTotal[0],
      'iTotalDisplayRecords' => $iFilteredTotal[0],
      'aaData' => $data
    );
    echo json_encode($array);
    die();
  }
  
  public static function productsTable() {
    $columns = array( 'id', 'item_number', 'name', 'price', 'taxable', 'shipped' );
    $indexColumn = "id";
    $tableName = Cart66Common::getTableName('products');
    
    $where = self::dataTablesWhere($columns);
  	$limit = self::dataTablesLimit() == '' ? null : self::dataTablesLimit();
  	$order = self::dataTablesOrder($columns);
    
    if($where == null) {
      $where = "where spreedly_subscription_id = 0 and is_paypal_subscription = 0";
    }
    else {
      $where .= " AND spreedly_subscription_id = 0 AND is_paypal_subscription = 0";
    }
    
    $iTotal = self::totalRows($indexColumn, $tableName, $where);
    $iFilteredTotal = self::filteredRows($indexColumn, $tableName, $where);
  	
  	$data = array();
  	$product = new Cart66Product();
  	$products = $product->getNonSubscriptionProducts($where, $order, $limit);
  	foreach($products as $p) {
  	  $gfTitles = self::gfData();
  	  if($p->gravityFormId > 0 && isset($gfTitles) && isset($gfTitles[$p->gravityFormId])) {
         $gfTitles = '<br/><em>Linked To Gravity Form: ' . $gfTitles[$p->gravityFormId] . '</em>';
      }
      else {
        $gfTitles = '';
      }
  	  $data[] = array(
  	    $p->id,
  	    $p->item_number,
  	    $p->name . $gfTitles,
  	    Cart66Common::currency($p->price),
  	    $p->taxable? ' Yes' : 'No',
  	    $p->shipped? ' Yes' : 'No'
  	  );
  	}
  	$array = array(
  	 'sEcho' => $_GET['sEcho'],
  	 'iTotalRecords' => $iTotal[0],
  	 'iTotalDisplayRecords' => $iFilteredTotal[0],
  	 'aaData' => $data
  	);
  	echo json_encode($array);
  	die();
  }
  
  public static function spreedlyTable() {
    $columns = array( 'id', 'item_number', 'name', 'price', 'taxable', 'shipped' );
    $indexColumn = "id";
    $tableName = Cart66Common::getTableName('products');
    
    $where = self::dataTablesWhere($columns);
  	$limit = self::dataTablesLimit() == '' ? null : self::dataTablesLimit();
  	$order = self::dataTablesOrder($columns);
    
    if($where == null) {
      $where = "where spreedly_subscription_id > 0";
    }
    else {
      $where .= " AND spreedly_subscription_id > 0";
    }
    
    $iTotal = self::totalRows($indexColumn, $tableName, $where);
    $iFilteredTotal = self::filteredRows($indexColumn, $tableName, $where);
  	
  	$data = array();
  	$spreedly = new Cart66Product();
  	$spreedlys = $spreedly->getSpreedlyProducts($where, $order, $limit);
  	foreach($spreedlys as $s) {
  	  $gfTitles = self::gfData();
  	  if($s->gravityFormId > 0 && isset($gfTitles) && isset($gfTitles[$s->gravityFormId])) {
         $gfTitles = '<br/><em>Linked To Gravity Form: ' . $gfTitles[$s->gravityFormId] . '</em>';
      }
      else {
        $gfTitles = '';
      }
  	  $data[] = array(
  	    $s->id,
  	    $s->item_number,
  	    $s->name . $gfTitles,
  	    $s->getPriceDescription(),
  	    $s->taxable? ' Yes' : 'No',
  	    $s->shipped? ' Yes' : 'No'
  	  );
  	}
  	$array = array(
  	 'sEcho' => $_GET['sEcho'],
  	 'iTotalRecords' => $iTotal[0],
  	 'iTotalDisplayRecords' => $iFilteredTotal[0],
  	 'aaData' => $data
  	);
  	echo json_encode($array);
  	die();
  }
  
  public static function paypalSubscriptionsTable() {
    $columns = array( 'id', 'item_number', 'name', 'feature_level', 'setup_fee', 'price', 'billing_cycles', 'offer_trial', 'start_recurring_number', 'start_recurring_unit' );
    $indexColumn = "id";
    $tableName = Cart66Common::getTableName('products');
    
    $where = self::dataTablesWhere($columns);
  	$limit = self::dataTablesLimit() == '' ? null : self::dataTablesLimit();
  	$order = self::dataTablesOrder($columns);
    
    if($where == null) {
      $where = "WHERE is_paypal_subscription>0";
    }
    else {
      $where .= " AND is_paypal_subscription>0";
    }

    $iTotal = self::totalRows($indexColumn, $tableName, $where);
    $iFilteredTotal = self::filteredRows($indexColumn, $tableName, $where);
  	
  	$data = array();
  	$subscription = new Cart66PayPalSubscription();
  	$subscriptions = $subscription->getModels($where, $order, $limit);
  	foreach($subscriptions as $s) {
  	  $gfTitles = self::gfData();
  	  if($s->gravityFormId > 0 && isset($gfTitles) && isset($gfTitles[$s->gravityFormId])) {
         $gfTitles = '<br/><em>Linked To Gravity Form: ' . $gfTitles[$s->gravityFormId] . '</em>';
      }
      else {
        $gfTitles = '';
      }
  	  $data[] = array(
  	    $s->id,
  	    $s->item_number,
  	    $s->name . $gfTitles,
  	    $s->featureLevel,
  	    Cart66Common::currency($s->setupFee),
  	    $s->getPriceDescription(false),
  	    $s->getBillingCycleDescription(),
  	    $s->getTrialPriceDescription(),
  	    $s->getStartRecurringDescription()
  	  );
  	}
  	Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] " . json_encode($data));
  	$array = array(
  	 'sEcho' => $_GET['sEcho'],
  	 'iTotalRecords' => $iTotal[0],
  	 'iTotalDisplayRecords' => $iFilteredTotal[0],
  	 'aaData' => $data
  	);
  	echo json_encode($array);
  	die();
  }
  
  public function gfData() {
    global $wpdb;
    $gfTitles = array();
    if(CART66_PRO && class_exists('RGFormsModel')) {
      require_once(CART66_PATH . "/pro/models/Cart66GravityReader.php");
      $forms = Cart66Common::getTableName('rg_form', '');
      $sql = "SELECT id, title from $forms where is_active=1 order by title";
      $results = $wpdb->get_results($sql);
      foreach($results as $r) {
        $gfTitles[$r->id] = $r->title;
      }
    }
    return $gfTitles;
  }
  
  public function totalRows($indexColumn, $tableName, $where=null) {
    global $wpdb;
    $sql = "
    	SELECT COUNT(" . $indexColumn . ")
    	FROM $tableName
    	$where
    ";
    $sql = $wpdb->get_results($sql, ARRAY_N);
    return $sql[0];
  }
  
  public function filteredRows($indexColumn, $tableName, $where) {
    global $wpdb;
    $sqlTotal = "
      SELECT COUNT(" . $indexColumn . ")
    	FROM $tableName
    	$where
    ";
    $sqlTotal = $wpdb->get_results($sqlTotal, ARRAY_N);
    return $sqlTotal;
  }
  
  public function dataTablesWhere($columns) {
    $where = "";
  	if($_GET['sSearch'] != ""){
  		$where = "WHERE (";
  		for ($i=0; $i<count($columns); $i++){
  			$where .= $columns[$i] . " LIKE '%" . mysql_real_escape_string($_GET['sSearch']) . "%' OR ";
  		}
  		$where = substr_replace($where, "", -3) . ')';
  	}

  	for($i=0; $i<count($columns); $i++){
  		if(isset($_GET['bSearchable_' . $i]) && $_GET['bSearchable_' . $i] == "true" && $_GET['sSearch_' . $i] != ''){
  			if($where == ""){
  				$where = "WHERE ";
  			}
  			else {
  				$where .= " AND ";
  			}
  			$where .= $columns[$i] . " LIKE '%" . mysql_real_escape_string($_GET['sSearch_' . $i]) . "%' ";
  		}
  	}
    return $where;
  }
  
  public function dataTablesLimit() {
    $limit = "";
  	if(isset($_GET['iDisplayStart']) && $_GET['iDisplayLength'] != '-1'){
  		$limit = mysql_real_escape_string($_GET['iDisplayStart']) . ", " . mysql_real_escape_string($_GET['iDisplayLength']);
  	}
    return $limit;
  }
  
  public function dataTablesOrder($columns) {
    if(isset($_GET['iSortCol_0'])){
  		$order = "ORDER BY  ";
  		for($i=0; $i<intval($_GET['iSortingCols']); $i++){
  			if(isset($_GET['bSortable_' . intval($_GET['iSortCol_' . $i])]) && $_GET['bSortable_' . intval($_GET['iSortCol_' . $i])] == "true"){
  				$order .= $columns[intval($_GET['iSortCol_' . $i])] . "
  				 	" . mysql_real_escape_string($_GET['sSortDir_' . $i]) . ", ";
  			}
  		}

  		$order = substr_replace($order, "", -2);
  		if($order == "ORDER BY"){
  			$order = "";
  		}
  	}
  	return $order;
  }
  
  public static function productSalesForMonth() {
    $data = array();

    foreach(self::getSalesForMonth() as $order_items) {
      if(isset($data[$order_items->product_id])) {
        $data[$order_items->product_id]['quantity'] = $data[$order_items->product_id]['quantity'] + $order_items->quantity;
        $data[$order_items->product_id]['sales_amount'] = ($order_items->product_price * $order_items->quantity) + $data[$order_items->product_id]['sales_amount'];
      }
      else {
        $data[$order_items->product_id] = array(
          'quantity' => $order_items->quantity, 
          'name' => $order_items->description,
          'sales_amount' => $order_items->product_price * $order_items->quantity
        );
      }
    }
    return $data;
  }

  public static function totalSalesForMonth($data) {
    $results = array();
    foreach($data as $d) {
      if(isset($results['total_sales']['total_amount'])) {
        $results['total_sales']['total_amount'] = $d['sales_amount'] + $results['total_sales']['total_amount'];
      }
      else {
        $results['total_sales']['total_amount'] = $d['sales_amount'];
      }
      if(isset($results['total_sales']['total_quantity'])) {
        $results['total_sales']['total_quantity'] = $d['quantity'] + $results['total_sales']['total_quantity'];
      }
      else {
        $results['total_sales']['total_quantity'] = $d['quantity'];
      }
    }
    return $results;
  }

  public static function getSalesForMonth() {
    $thisMonth = Cart66Common::localTs();
    $year =  date('Y', "$thisMonth");
    $month =  date('n', "$thisMonth");
    $orders = Cart66Common::getTableName('orders');
    $orderItems = Cart66Common::getTableName('order_items');
    $products = Cart66Common::getTableName('products');
    $start = date('Y-m-d 00:00:00', strtotime($month . '/1/' . $year));
    $end = date('Y-m-d 00:00:00', strtotime($month . '/1/' . $year . ' +1 month'));

    $sql = "SELECT 
        oi.id, 
        oi.description, 
        oi.product_id, 
        oi.product_price, 
        o.ordered_on,
        oi.quantity
      from 
        $products as p,
        $orders as o, 
        $orderItems as oi 
      where
        oi.product_id = p.id and
        oi.order_id = o.id and
        o.ordered_on >= '$start' and 
        o.ordered_on < '$end'
    ";
    global $wpdb;
    $results = $wpdb->get_results($sql);
    return $results;
  }
  
}