middleware('active.account'); } public function index() { $data = [ ]; return view('user.order.index', $data); } public function detail($id) { $user = User::find(\Auth::user()->id); $shopping_order = ShoppingOrder::findOrFail($id); if($shopping_order->auth_user_id !== $user->id){ abort(404); } $shopping_order->getLastShoppingPayment(); $data = [ 'shopping_order' => $shopping_order, 'isAdmin' => false, ]; return view('user.order.detail', $data); } public function ordersDatatable(){ $user = User::find(\Auth::user()->id); $query = ShoppingOrder::with('shopping_user', 'shopping_payments')->select('shopping_orders.*')->where('auth_user_id', '=', $user->id)->where('txaction', '!=', NULL); return \DataTables::eloquent($query) ->addColumn('id', function (ShoppingOrder $ShoppingOrder) { return ''; }) ->addColumn('created_at', function (ShoppingOrder $ShoppingOrder) { return $ShoppingOrder->created_at->format("d.m.Y"); }) ->addColumn('txaction', function (ShoppingOrder $ShoppingOrder) { return Payment::getShoppingOrderBadge($ShoppingOrder); }) ->addColumn('total_shipping', function (ShoppingOrder $ShoppingOrder) { return $ShoppingOrder->getFormattedTotalShipping()." €"; }) ->addColumn('payment', function (ShoppingOrder $ShoppingOrder) { return $ShoppingOrder->getLastShoppingPayment('getPaymentType'); }) ->addColumn('shipped', function (ShoppingOrder $ShoppingOrder) { return ''.$ShoppingOrder->getShippedType().''; }) ->addColumn('payment_for', function (ShoppingOrder $ShoppingOrder) { return ''.$ShoppingOrder->getPaymentForType().''; }) ->addColumn('reference', function (ShoppingOrder $ShoppingOrder) { return $ShoppingOrder->getLastShoppingPayment('reference'); }) ->orderColumn('id', 'id $1') ->orderColumn('txaction', 'txaction $1') ->orderColumn('payment_for', 'payment_for $1') ->orderColumn('shipped', 'shipped $1') ->orderColumn('total_shipping', 'total_shipping $1') ->rawColumns(['id', 'txaction', 'payment_for', 'shipped']) ->make(true); } public function delivery($for, $id=null) { $user = User::find(\Auth::user()->id); $shopping_user = null; $delivery_id = null; if($for === 'ot'){ $shopping_user = $this->checkShoppingUser($id, $user); $delivery_id = $shopping_user->id; if(!$this->checkShoppingCountry($for, $delivery_id) && !\Session()->has('custom-error')){ \Session()->flash('custom-error', __('validation.custom.shipping_not_found')); return redirect(route('user_order_my_delivery', [$for, $delivery_id])); } } if(Request::get('action') === 'next'){ Yard::instance('shopping')->destroy(); if(Request::get('switchers-radio-is-for') === 'ot'){ $delivery_id = $id; } return redirect(route('user_order_my_list', [Request::get('switchers-radio-is-for'), $delivery_id])); } $data = [ 'shopping_user' => $shopping_user, 'isAdmin' => false, 'isView' => 'customer', 'for' => $for, 'delivery_id' => $delivery_id, ]; return view('user.order.delivery', $data); } public function list($for, $id=null) { $user = User::find(\Auth::user()->id); $shopping_user = null; $delivery_id = null; if($for === 'ot'){ $shopping_user = $this->checkShoppingUser($id, $user); $delivery_id = $shopping_user->id; } $shipping_country_id = $this->checkShoppingCountry($for, $id); if(!$shipping_country_id){ \Session()->flash('custom-error', __('validation.custom.shipping_not_found')); return redirect(route('user_order_my_delivery', [$for, $delivery_id])); } Yard::instance('shopping')->setShippingCountryWithPrice($shipping_country_id, $for); if($for === 'cr'){ Yard::instance('shopping')->setGlobalTaxRate(0); Yard::instance('shopping')->setShoppingUser($user, false); }else{ Yard::instance('shopping')->setShoppingUser($user, true); } $data = [ 'shopping_user' => $shopping_user, 'user' => $user, 'isAdmin' => false, 'isView' => 'customer', 'for' => $for, 'delivery_id' => $delivery_id, 'comp_products' => $this->getCompProducts($for), ]; return view('user.order.list', $data); } public function payment($for, $id=null){ $data = Request::all(); $user = User::find(Auth::user()->id); $rules = array( 'shipping_salutation' => 'required', 'shipping_firstname' => 'required', 'shipping_lastname' => 'required', 'shipping_address' => 'required', 'shipping_zipcode' => 'required', 'shipping_city' => 'required', 'shipping_state' => 'required', ); $validator = Validator::make(Request::all(), $rules); if ($validator->fails()) { return back()->withErrors($validator)->withInput(Request::all()); } if(Yard::instance('shopping')->getNumComp() > 0){ if(!isset($data['switchers-comp-product'])){ $validator->errors()->add('switchers-comp-product', __('Bitte wähle ein Kompensationsprodukt aus')); }else{ if(!is_array($data['switchers-comp-product'])){ $validator->errors()->add('switchers-comp-product', __('Bitte wähle ein Kompensationsprodukt aus')); }else{ if(count($data['switchers-comp-product']) !== Yard::instance('shopping')->getNumComp()){ $validator->errors()->add('switchers-comp-product', __('Bitte wähle :count Kompensationsprodukte aus', ['count'=>Yard::instance('shopping')->getNumComp()])); } } } if ($validator->errors()->count()) { return back()->withErrors($validator)->withInput(Request::all()); } } /* do { $identifier = Util::getToken(); } while( ShoppingInstance::where('identifier', $identifier)->count() ); */ $identifier = Util::getToken(); $data['is_from'] = 'user_order'; $data['is_for'] = $for; $data['shopping_user_id'] = $id; unset($data['quantity']); unset($data['_token']); Yard::instance('shopping')->putYardExtra('shopping_data', $data); /*ShoppingInstance::create([ 'identifier' => $identifier, 'user_shop_id' => 1, //is first faker shop for buy intern 'auth_user_id' => Auth::user()->id, 'payment' => 2, //Vertriebspartner Shop 'subdomain' => url('/'), 'country_id' => Yard::instance('shopping')->getShippingCountryId(), 'shopping_data' => $data, 'back' => url()->previous(), ]); Yard::instance('shopping')->store($identifier); */ //add to DB //$path = route('checkout.checkout_card', ['identifier'=>$identifier]); UserHistory::create(['user_id' => $user->id, 'action'=>'user_order_payment', 'status'=>1, 'product_id'=>null, 'identifier'=>$identifier]); //$path = str_replace('http', 'https', $path); //return redirect()->secure($path); return redirect(route('user_checkout', [$identifier])); } private function checkShoppingCountry($for, $id=null){ $country_id = null; if($for === 'me' || $for === 'mp' || $for === 'cr'){ $user = User::find(\Auth::user()->id); if($user->same_as_billing){ $country_id = $user->account->country_id; }else{ $country_id = $user->account->shipping_country_id; } } if($for === 'ot' && $id){ $shopping_user = ShoppingUser::findOrFail($id); if($shopping_user->same_as_billing){ $country_id = $shopping_user->billing_country_id; }else{ $country_id = $shopping_user->shipping_country_id; } } if($country_id){ if($shipping_country = ShippingCountry::whereCountryId($country_id)->first()){ return $shipping_country->id; } } return false; } private function checkShoppingUser($id, $user){ if($id === null){ abort(403, 'Error: Keine User ID'); } $shopping_user = ShoppingUser::findOrFail($id); if($shopping_user->member_id !== $user->id){ abort(403, 'Error: Falsche User ID'); } $shopping_user = ShoppingUser::findOrFail($id); if($shopping_user->is_like){ abort(403, 'Error: Kunde in Prüfung'); } return $shopping_user; } public function datatable(){ $not_show_pids = ProductBuy::getNotShowProductIDs(Auth::user()->id); switch (Request::get('shipping_is_for')) { case 'me': $query = Product::select('products.*')->where('active', true)->whereJsonContains('show_on', '2'); break; case 'mp': $query = Product::select('products.*')->where('active', true)->whereJsonContains('show_on', '2'); break; case 'cr': $query = Product::select('products.*')->where('active', true)->whereJsonContains('show_on', '6'); break; case 'ot': $query = Product::select('products.*')->where('active', true)->whereJsonContains('show_on', '1'); break; } foreach($not_show_pids as $not_show_pid){ $query->where('id', '!=', $not_show_pid); } return \DataTables::eloquent($query) ->addColumn('product', function (Product $product) { $cartItem = Yard::instance('shopping')->getCartItemByProduct($product->id); $qty = isset($cartItem->qty) ? $cartItem->qty : 0; $rowId = isset($cartItem->rowId) ? $cartItem->rowId : ''; return ''.$product->name.'
'; }) /* ->addColumn('add_card', function (Product $product) { return ''; }) ->addColumn('quantity', function (Product $product) { $cartItem = Yard::instance('shopping')->getCartItemByProduct($product->id); $qty = isset($cartItem->qty) ? $cartItem->qty : 0; $rowId = isset($cartItem->rowId) ? $cartItem->rowId : ''; return '
'; })*/ ->addColumn('category', function (Product $product) { $ret = ""; foreach($product->categories as $category){ $ret .= '
'.$category->category->name.'
'; } return $ret; }) ->addColumn('picture', function (Product $product) { if(count($product->images)){ return '
'; } return ""; }) ->addColumn('price_net', function (Product $product) { return $product->getFormattedPriceWith(true, false). "€"; }) ->addColumn('price_gross', function (Product $product) { return $product->getFormattedPriceWith(false, false). "€"; }) ->addColumn('price_vk_gross', function (Product $product) { return $product->getFormattedPriceWith(false, false). "€"; }) ->addColumn('single_commission', function (Product $product) { return $product->single_commission ? 'Handelspanne: '.$product->getFormattedValueCommission().' %' : 'Staffelprovision '; }) ->addColumn('action', function (Product $product) { return ''; }) ->filterColumn('product', function($query, $keyword) { if($keyword != ""){ $query->where('name', 'LIKE', '%'.$keyword.'%'); } }) ->orderColumn('name', 'name $1') ->orderColumn('product', 'name $1') ->orderColumn('number', 'number $1') ->orderColumn('points', 'points $1') ->orderColumn('price_net', 'price_net $1') ->orderColumn('price_gross', 'price_gross $1') ->orderColumn('price_vk_gross', 'price $1') ->orderColumn('contents_total', 'contents_total $1') ->orderColumn('single_commission', 'single_commission $1') ->orderColumn('weight', 'weight $1') // ->orderColumn('category', 'weight $1') /*->orderColumn('category', function ($query, $order) { $query->whereHas('categories', function ($q) use ($order) { // $q->select('sent_at')->where('sent_at', DB::raw("(select max('sent_at') customer_mails)")); //) })->orderBy( ProductCategory::select('id') ->whereColumn('product_id', 'produkt.id') ->orderBy('id', 'DESC') ->limit(1) , $order); })*/ ->rawColumns(['add_card', 'category', 'product', 'quantity', 'picture', 'action', 'single_commission']) ->make(true); } public function performRequest(){ if(Request::ajax()) { $data = Request::all(); $is_for = isset($data['shipping_is_for']) ? $data['shipping_is_for'] : 'ot'; $data['comp_products'] = $this->getCompProducts($is_for); if($data['action'] === 'updateCart' && isset($data['product_id'])){ if($product = Product::find($data['product_id'])){ $image = ""; if($product->images->count()){ $image = $product->images->first()->slug; } //get the card item $cartItem = Yard::instance('shopping')->add($product->id, $product->getLang('name'), 1, $product->getPriceWith(false, true), $product->tax, [ 'image' => $image, 'slug' => $product->slug, 'weight' => $product->weight, 'single_commission' => $product->single_commission, 'amount_commission' => $product->amount_commission, 'value_commission' => $product->value_commission, 'partner_commission' => $product->partner_commission, ]); Yard::setTax($cartItem->rowId, $product->tax); if(isset($data['qty']) && $data['qty'] > 0){ Yard::instance('shopping')->update($cartItem->rowId, $data['qty']); }else{ //if 0 get the item by qty:1 and remove it Yard::instance('shopping')->remove($cartItem->rowId); } // Yard::instance('shopping')->reCalculate(); $this->checkCompProduct(Yard::instance('shopping')->getNumComp()); $html_card = view("user.order.yard_view_form", $data)->render(); $html_comp = view("user.order.comp_product", $data)->render(); return response()->json(['response' => true, 'data'=>$data, 'html_card'=>$html_card, 'html_comp'=>$html_comp]); } } if($data['action'] === 'reCalculateCart') { //set use_payment_credit $data['reduce_payment_credit'] = $data['reduce_payment_credit'] == 'true' ? true: false; Yard::instance('shopping')->setReducePaymentCredit($data['reduce_payment_credit']); Yard::instance('shopping')->reCalculate(); $html_card = view("user.order.yard_view_form", $data)->render(); $html_comp = view("user.order.comp_product", $data)->render(); return response()->json(['response' => true, 'data'=>$data, 'html_card'=>$html_card, 'html_comp'=>$html_comp]); } if($data['action'] === 'clearCart') { Yard::instance('shopping')->destroy(); return response()->json(['response' => true, 'data'=>Yard::instance('shopping')->count(), 'html_card'=>'', 'html_comp'=>'']); } if($data['action'] === 'updateShippingCountry') { if(isset($data['shipping_country_id'])){ if($shipping_country = ShippingCountry::find($data['shipping_country_id'])){ Yard::instance('shopping')->setShippingCountryWithPrice($shipping_country->id, $is_for); $this->checkCompProduct(Yard::instance('shopping')->getNumComp()); } } $html_card = view("user.order.yard_view_form", $data)->render(); $html_comp = view("user.order.comp_product", $data)->render(); return response()->json(['response' => true, 'data'=>$data, 'html_card'=>$html_card, 'html_comp'=>$html_comp]); } if($data['action'] === 'updateCompProduct'){ // $data['comp_product_id'] // $data['comp_num'] //count_comp_products $this->updateCompProduct($data); Yard::instance('shopping')->reCalculateShippingPrice(); $html_card = view("user.order.yard_view_form", $data)->render(); $html_comp = view("user.order.comp_product", $data)->render(); return response()->json(['response' => true, 'data'=>$data, 'html_card'=>$html_card, 'html_comp'=>$html_comp]); } return response()->json(['response' => false, 'data'=>$data]); } } private function checkCompProduct($count_comp_products){ foreach (Yard::instance('shopping')->content() as $row) { //wenn gleich löschen, da neue Versandkosten if($row->options->comp > $count_comp_products) { Yard::instance('shopping')->remove($row->rowId); } } } private function updateCompProduct($data){ //clear old foreach (Yard::instance('shopping')->content() as $row) { //wenn kleiner wurde ein produkt entfernt aufgrund der Anzahl //wenn gleich löschen, da neue Versandkosten if($row->options->comp === $data['comp_num'] || $row->options->comp > $data['count_comp_products']) { Yard::instance('shopping')->remove($row->rowId); } } if(isset($data['comp_product_id'])) { if ($product = Product::find($data['comp_product_id'])) { $image = ""; if ($product->images->count()) { $image = $product->images->first()->slug; } $cartItem = Yard::instance('shopping')->add($product->id, $product->getLang('name'), 1, 0, 0, [ 'image' => $image, 'slug' => $product->slug, 'weight' => 0, 'single_commission' => 0, 'amount_commission' => 0, 'value_commission' => 0, 'partner_commission' => 0, 'comp' => $data['comp_num'], 'product_id' => $product->id ]); Yard::setTax($cartItem->rowId, 0); } } } private function getCompProducts($for){ if($for === 'me' && \App\Models\Setting::getContentBySlug('order_partner_is_comp_me')){ return Product::whereActive(true)->whereJsonContains('show_on', ['2'])->where('shipping_addon', true)->orderBy('pos', 'DESC')->get(); } if($for === 'ot' && \App\Models\Setting::getContentBySlug('order_partner_is_comp_ot')){ return Product::whereActive(true)->whereJsonContains('show_on', ['1'])->where('shipping_addon', true)->orderBy('pos', 'DESC')->get(); } return null; } }