middleware('active.account'); } public function delivery($for, $id = null) { $user = User::find(Auth::user()->id); $shopping_user = null; $delivery_id = null; if (strpos($for, 'ot') !== false) { $shopping_user = Shop::checkShoppingUser($id, $user); $delivery_id = $shopping_user->id; if (! Shop::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 (strpos(Request::get('switchers-radio-is-for'), 'ot') !== false) { $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 (strpos($for, 'ot') !== false) { $shopping_user = Shop::checkShoppingUser($id, $user); $delivery_id = $shopping_user->id; } if ($for === 'ot-customer') { // noch nicht implementiert // Liederung an ot-customer (Kunden) Zahlung und Rechnung geht an Kunden UserService::initCustomerYard($shopping_user, $for); } else { // Lieferung an user oder ot-member (Kunden) rechnung geht an User // lieferland und rechnungsland prüfen $shipping_country_id = Shop::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])); } UserService::initUserYard($user, $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 = [ '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()); } // hier prüfen, ob versand etc richtig berechnet wurde $this->checkSendYardForPayment($data, $id); 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; $data['user_price_infos'] = Yard::instance('shopping')->getUserPriceInfos(); 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 checkSendYardForPayment($data, $id) { $user = User::find(Auth::user()->id); $shopping_user = null; if (strpos($data['shipping_is_for'], 'ot') !== false) { $shopping_user = Shop::checkShoppingUser($id, $user); } $shipping_country_id = Shop::checkShoppingCountry($data['shipping_is_for'], $id); if (! $shipping_country_id) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'no shipping_country_id found | Yard identifier: '.$identifier, $data); abort(403, __('msg.shipping_country_was_not_found')); } // must be the same shipping country if ($shipping_country_id != Yard::instance('shopping')->getShippingCountryId()) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'shipping_country_id is not the same from Yard | Yard identifier: '.$identifier, $data); abort(403, __('msg.shipping_country_was_not_correctly')); } if ($data['shipping_is_for'] !== 'ot-customer') { if (Yard::instance('shopping')->shipping_free) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'Yard can by not shipping_free | Yard identifier: '.$identifier, $data); abort(403, __('msg.shopping_cart_was_shipping_free')); } } if ($data['shipping_is_for'] === 'ot-customer') { if (! $user->shop) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'User has no Shop for an User to Customer order| Yard identifier: '.$identifier, $data); abort(403, __('msg.shopping_cart_was_not_user_shop')); } } $shipping_price = Shop::getShippingPriceByShippingCountryId($shipping_country_id, Yard::instance('shopping')->weight()); // for other and has weight - check if (strpos($data['shipping_is_for'], 'ot') !== false && $data['shipping_is_for'] !== 'ot-customer' && Yard::instance('shopping')->weight() > 0) { if (! Yard::instance('shopping')->getShippingPrice() || Yard::instance('shopping')->getShippingPrice() == 0) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'Yard OT shipping_price is 0 or | Yard identifier: '.$identifier, $data); abort(403, __('msg.shipping_cost_cannot_be_0')); } if (Yard::instance('shopping')->getShippingPrice() != $shipping_price->price) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'Yard OT shipping_price is not the same from shipping_price | Yard identifier: '.$identifier, $data); abort(403, __('msg.shipping_costs_were_not_calculated_correctly')); } } if ($data['shipping_is_for'] == 'me' && Yard::instance('shopping')->weight() > 0) { if (! Yard::instance('shopping')->getShippingPrice() || Yard::instance('shopping')->getShippingPrice() == 0) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'Yard ME shipping_price is 0 or | Yard identifier: '.$identifier, $data); abort(403, __('msg.shipping_cost_cannot_be_0')); } if (Yard::instance('shopping')->getShippingPrice() != $shipping_price->price_comp) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'Yard ME shipping_price is not the same from shipping_price | Yard identifier: '.$identifier, $data); abort(403, __('msg.shipping_costs_were_not_calculated_correctly')); } if (Yard::instance('shopping')->getNumComp() != $shipping_price->num_comp) { $identifier = 'error-'.time().mt_rand(1000000, 9999999); Yard::instance('shopping')->store($identifier); $data['user_id'] = Auth::user()->id; $data['shopping_user_id'] = $id; MyLog::writeLog('payment', 'error', 'Yard num_comp is 0 | Yard identifier: '.$identifier, $data); abort(403, __('msg.compensation_products_cannot_be_0')); } } } 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 : ''; if ($product->isOutOfStock()) { $controls = '
'.e($product->outOfStockNotice()).'
'; } else { $controls = '
'; } return ''.$product->name.'
'.$controls; }) /* ->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 // Yard::instance('shopping')->add($product->id, $product->getLang('name'), 1, $product->price, $product->tax, ['image' => $image, 'slug' => $product->slug, 'weight' => $product->weight]); $cartItem = Yard::instance('shopping')->add($product->id, $product->getLang('name'), 1, $product->price, $product->tax, // $product->getPriceWith(Yard::instance('shopping')->getUserTaxFree(), true, Yard::instance('shopping')->getUserCountry()), $product->getTaxWith(Yard::instance('shopping')->getUserCountry()), //$product->tax, true? [ '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, ]); if (Yard::instance('shopping')->getUserTaxFree()) { // Yard::setTax($cartItem->rowId, 0); Yard::instance('shopping')->setGlobalTaxRate(0); } else { // Yard::setTax($cartItem->rowId, $product->getTaxWith(Yard::instance('shopping')->getUserCountry())); } 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); // $is_for == 'ot' or 'me' $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' && Setting::getContentBySlug('order_partner_is_comp_me')) { return Product::whereActive(true) ->where(function ($query) { $query->whereRaw("JSON_CONTAINS(show_on, '\"2\"')") ->orWhereRaw("JSON_CONTAINS(show_on, '\"11\"')"); }) ->where('shipping_addon', true) ->orderBy('pos', 'DESC') ->get(); } if ($for === 'ot' && Setting::getContentBySlug('order_partner_is_comp_ot')) { return Product::whereActive(true) ->where(function ($query) { $query->whereRaw("JSON_CONTAINS(show_on, '\"1\"')") ->orWhereRaw("JSON_CONTAINS(show_on, '\"11\"')"); }) ->where('shipping_addon', true) ->orderBy('pos', 'DESC') ->get(); } return null; } }