Orders.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace App\Models;
  3. use Illuminate\Database\Eloquent\Model;
  4. use DB;
  5. use OwenIt\Auditing\Contracts\Audit;
  6. use OwenIt\Auditing\Contracts\Auditable;
  7. class Orders extends Model implements Auditable
  8. {
  9. use \OwenIt\Auditing\Auditable;
  10. protected $auditInclude = [
  11. 'status',
  12. ];
  13. //
  14. protected $table = "tb_dm_orders";
  15. public function waiters(){
  16. return $this->hasOne('App\Models\Waiters','id','waiter_id');
  17. }
  18. public function tables(){
  19. return $this->hasOne('App\Models\RestoTables','id','table_id');
  20. }
  21. public function orderItems(){
  22. return $this->hasMany('App\Models\OrderItems','order_id','id')->where("status",1);
  23. }
  24. public function orderCollectivePrice(){
  25. return $this->hasMany('App\Models\OrderItems','order_id','id')->select(DB::raw('sum(tb_dm_order_items.qty*tb_dm_order_items.price) AS total_price'))->where("status",1);
  26. }
  27. public function order_activities(){
  28. return $this->hasMany('App\Models\OrderActivities','order_id','id')->orderBy('created_at','DESC');
  29. }
  30. public function customers(){
  31. return $this->belongsTo('App\Models\Customers','customer_id','id');
  32. }
  33. public function recipients(){
  34. return $this->belongsTo('App\Models\Recipients','recipient_id','id');
  35. }
  36. public function restaurants(){
  37. return $this->belongsTo('App\Models\Restaurants','resto_id','id');
  38. }
  39. public function outlet(){
  40. return $this->belongsTo('App\Models\Outlets','outlet_id','id');
  41. }
  42. public function order_with_discounts(){
  43. return $this->hasOne('App\Models\DiscountWithOrder','order_id','id')->with('discounts');
  44. }
  45. public function loyalty_with_orders(){
  46. return $this->hasOne('App\Models\CustomerLoyaltyHistories','order_id','id')->where('type','used');
  47. }
  48. public function getActualPriceAttribute(){
  49. $discount = ($this->order_with_discounts);
  50. $final_price =$this->total_price;
  51. $discounted_delivery_price = 0;
  52. if(isset($discount) && $discount->discount_type=="percentage"){
  53. $is_whole_order_discount = $discount->is_for_whole_order=="Yes"?true:false;
  54. if($discount->discount_type=="percentage")
  55. $applied_discount = $discount->discount_value/100;
  56. else
  57. $applied_discount = $discount->discount_value;
  58. if($discount->is_delivery_discount=="Yes"){
  59. if($discount->delivery_discount_type=="percentage")
  60. $applied_delivery_discount = $discount->delivery_discount_value/100;
  61. else
  62. $applied_delivery_discount = $discount->delivery_discount_value;
  63. }
  64. if(isset($discount) && $discount->is_delivery_discount=="Yes" && $this->delivery_fee > 0){
  65. if($discount->delivery_discount_type=="percentage")
  66. $discounted_delivery_price = $this->delivery_fee * $applied_delivery_discount;
  67. else
  68. $discounted_delivery_price = $applied_delivery_discount;
  69. }
  70. if($is_whole_order_discount){
  71. $final_price = $final_price - ($final_price * $applied_discount) ;
  72. }
  73. }
  74. $order_loyalty = $this->loyalty_with_orders;
  75. $is_loyalty = isset($order_loyalty)?true:false;
  76. if($is_loyalty){
  77. $final_price = $final_price - $order_loyalty->used_redeemable_amount;
  78. }
  79. $final_price = $final_price + ($this->delivery_fee - $discounted_delivery_price);
  80. return number_format($final_price);
  81. }
  82. }