Viewing file: Purchase.php (6.61 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace App\Models;
use Carbon\Carbon; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Facades\Auth;
class Purchase extends Model { use HasFactory;
protected $fillable = [ 'purchase_id', 'vender_id', 'warehouse_id', 'purchase_date', 'purchase_number', 'discount_apply', 'category_id', 'created_by', ]; public static $statues = [ 'Draft', 'Sent', 'Unpaid', 'Partialy Paid', 'Paid', ]; public function vender() { return $this->hasOne('App\Models\Vender', 'id', 'vender_id'); }
public function tax() { return $this->hasOne('App\Models\Tax', 'id', 'tax_id'); }
public function items() { return $this->hasMany('App\Models\PurchaseProduct', 'purchase_id', 'id'); } public function payments() { return $this->hasMany('App\Models\PurchasePayment', 'purchase_id', 'id'); } public function category() { return $this->hasOne('App\Models\ProductServiceCategory', 'id', 'category_id'); } public function getSubTotal() {
$subTotal = 0; foreach($this->items as $product) {
$subTotal += ($product->price * $product->quantity); }
return $subTotal; } public function getTotal() {
return ($this->getSubTotal() -$this->getTotalDiscount()) + $this->getTotalTax(); } // public function getTotalTax() // { // $totalTax = 0; // foreach($this->items as $product) // { // $taxes = Utility::totalTaxRate($product->tax);
// $totalTax += ($taxes / 100) * ($product->price * $product->quantity - $product->discount) ;
// }
// return $totalTax; // }
public function getTotalTax() { $taxData = Utility::getTaxData(); $totalTax = 0; foreach($this->items as $product) { // $taxes = Utility::totalTaxRate($product->tax);
$taxArr = explode(',', $product->tax); $taxes = 0; foreach ($taxArr as $tax) { // $tax = TaxRate::find($tax); $taxes += !empty($taxData[$tax]['rate']) ? $taxData[$tax]['rate'] : 0; }
$totalTax += ($taxes / 100) * ($product->price * $product->quantity); }
return $totalTax; } public function getTotalDiscount() { $totalDiscount = 0; foreach($this->items as $product) { $totalDiscount += $product->discount; }
return $totalDiscount; } public function getDue() { $due = 0; foreach($this->payments as $payment) { $due += $payment->amount; }
return ($this->getTotal() - $due); } public function lastPayments() { return $this->hasOne('App\Models\PurchasePayment', 'id', 'purchase_id'); }
public function taxes() { return $this->hasOne('App\Models\Tax', 'id', 'tax'); }
public static function getPurchaseData($month = '') {
if ($month == 'true') { $purchaseProducts = \DB::table('purchase_products') ->select('purchase_products.id as purchase', \DB::raw('SUM(purchase_products.quantity) as quantity'), \DB::raw('SUM(discount) as total_discount'), \DB::raw('tax as tax'), \DB::raw('SUM(price) as price')) ->leftJoin('purchases', 'purchase_products.purchase_id', 'purchases.id') ->where(\DB::raw('MONTH(purchases.created_at)'), '=', [date('m')]) ->where('purchases.created_by', \Auth::user()->creatorId()) ->groupBy('purchase') ->get() ->keyBy('purchase'); } else { $purchaseProducts = \DB::table('purchase_products') ->select('purchase_products.id as purchase', \DB::raw('SUM(quantity) as quantity'), \DB::raw('SUM(discount) as total_discount'), \DB::raw('tax as tax'), \DB::raw('SUM(price) as price')) ->leftJoin('purchases', 'purchase_products.purchase_id', 'purchases.id') ->where('purchases.created_by', \Auth::user()->creatorId()) ->groupBy('purchase') ->get() ->keyBy('purchase'); } $total = 0;
foreach($purchaseProducts as $purchase) { $getTaxData = Utility::getTaxData(); $totalTaxPrice = 0; if (!empty($purchase->tax)) { foreach (explode(',', $purchase->tax) as $tax) { $taxPrice = \Utility::taxRate($getTaxData[$tax]['rate'], $purchase->price, $purchase->quantity , $purchase->total_discount); $totalTaxPrice += $taxPrice; } }
$total += ($purchase->price * $purchase->quantity) + $totalTaxPrice - $purchase->total_discount;
} return $total; }
public static function totalPurchaseAmount($month = false) {
$purchasedAmount = self::getPurchaseData($month);
return Auth::user()->priceFormat($purchasedAmount); }
public static function getPurchaseReportChart() { $purchases = Purchase::whereDate('created_at', '>', Carbon::now()->subDays(10)) ->where('created_by', '=', Auth::user()->creatorId()) ->orderBy('created_at')->get()->groupBy( function ($val) { return Carbon::parse($val->created_at)->format('dm'); });
$total = []; if (!empty($purchases) && count($purchases) > 0) { foreach ($purchases as $day => $onepurchase) { $totals = 0; foreach ($onepurchase as $purchase) { $totals += $purchase->getTotal(); } $total[$day] = $totals; } } $d = date("d"); $m = date("m"); $y = date("Y");
for ($i = 0; $i <= 9; $i++) { $date = date('Y-m-d', mktime(0, 0, 0, $m, ($d - $i), $y)); $purchasesArray['label'][] = $date; $date = date('dm', strtotime($date)); $purchasesArray['value'][] = array_key_exists($date, $total) ? $total[$date] : 0;; }
return $purchasesArray; }
}
|