middleware('admin'); $this->productRepo = $productRepo; } public function index() { if(Request::get('show_active_products')){ set_user_attr('show_active_products', Request::get('show_active_products')); } if(get_user_attr('show_active_products') === "true"){ $values = Product::where('active', true)->orderBy('pos', 'DESC')->orderBy('id', 'DESC')->get(); }else{ $values = Product::orderBy('pos', 'DESC')->orderBy('id', 'DESC')->get(); } $data = [ 'values' => $values ]; return view('admin.product.index', $data); } public function edit($id) { if($id === "new"){ $model = new Product(); $model->active = true; }else{ $model = Product::findOrFail($id); } $country_for_prices = Country::where('own_eur', '=', true)->orWhere('currency', '=', true)->get(); $data = [ 'product' => $model, 'country_for_prices' => $country_for_prices, ]; return view('admin.product.edit', $data); } public function store() { $data = Request::all(); $rules = array( 'name' => 'required', ); /*if(isset($data['number']) && $data['number'] != ""){ $rules['number'] = 'int'; }*/ if(isset($data['wp_number'])){ if($data['id'] !== "new"){ $model = Product::findOrFail($data['id']); $rules['wp_number'] = 'unique:products,wp_number,'.$model->id; }else{ $rules['wp_number'] = 'unique:products,wp_number'; } } $validator = Validator::make(Request::all(), $rules); if($data['id'] === "new"){ $model = new Product(); }else{ $model = Product::findOrFail($data['id']); } $country_for_prices = Country::where('own_eur', '=', true)->orWhere('currency', '=', true)->get(); $data = [ 'product' => $model, 'country_for_prices' => $country_for_prices, ]; if ($validator->fails()) { return view('admin.product.edit', $data)->withErrors($validator); } else { $product = $this->productRepo->update(Request::all()); \Session()->flash('alert-save', true); return redirect(route('admin_product_edit', [$product->id])); } \Session()->flash('alert-save', '1'); return redirect(route('admin_product_show')); } public function copy($id){ $model = Product::findOrFail($id); $product = $this->productRepo->copy($model); \Session()->flash('alert-success', 'Eintrag kopiert'); return redirect(route('admin_product_show')); } public function delete($id, $do = 'product', $did = null){ if($do === 'product'){ $model = Product::findOrFail($id); $model->delete(); \Session()->flash('alert-success', 'Eintrag gelöscht'); return redirect(route('admin_product_show')); } if($do === 'ingredient'){ $model = Product::findOrFail($id); $ProductIngredient = ProductIngredient::where('ingredient_id', $did)->where('product_id', $model->id)->first(); if($ProductIngredient){ $ProductIngredient->delete(); \Session()->flash('alert-success', 'Eintrag gelöscht'); return redirect(route('admin_product_edit', [$model->id])); } } } // Upload FILE ----------------------------------------------------------------------------------------------------------------------- public function imageUpload(){ $product_id = Request::get('product_id'); $product = Product::findOrFail($product_id); try { $image = \App\Services\Slim::getImages('images')[0]; if ( isset($image['output']['data']) ) { // Base64 of the image $data = $image['output']['data']; $file_ex = array( 'image/jpeg' => 'jpg', 'image/png' => 'png'); if (!isset($file_ex[$image['output']['type']])) { \Session()->flash('alert-danger', 'File is not jpg or png!'); return redirect(route('admin_product_edit', [$product->id])); } $ext = $file_ex[$image['output']['type']]; // Original file name $name = $image['output']['name']; $name = \App\Services\Slim::sanitizeFileName($name); $name = uniqid() . '_' . $name; $data = \Storage::disk('public')->put( 'images/product/'.$product->id.'/'.$name, $data ); ProductImage::create([ 'product_id' => $product->id, 'filename' => $name, 'original_name' => $image['output']['name'], 'ext' => $ext, 'mine' => $image['output']['type'], 'size' => $image['input']['size'] ]); \Session()->flash('alert-success', "Datei hochgeladen"); return redirect(route('admin_product_edit', [$product->id])); } \Session()->flash('alert-danger', "Datei leer"); return redirect(route('admin_product_edit', [$product->id])); } catch (Exception $e) { \Session()->flash('alert-danger', "Fehler".$e); return redirect(route('admin_product_edit', [$product->id])); } } public function imageDelete($image_id, $product_id){ $product = Product::findOrFail($product_id); $product_image = ProductImage::findOrFail($image_id); if($product_image->product_id == $product->id){ $file = 'images/product/'.$product->id.'/'.$product_image->filename; \Storage::disk('public')->delete($file); $product_image->delete(); \Session()->flash('alert-success', "Datei gelöscht"); return redirect(route('admin_product_edit', [$product->id])); } \Session()->flash('alert-danger', "Datei nicht gefunden"); return redirect(route('admin_product_edit', [$product->id])); } public function imageAttribute($product_id, $attr, $val = false){ if(is_numeric($val) && $val < 0){ $val = 0; } $product_image = ProductImage::findOrFail($product_id); $product_image->{$attr} = $val; $product_image->save(); \Session()->flash('alert-success', "Wert gespeichert"); return redirect()->back(); } }