Actualizacuion de Rama Kquiroz
This commit is contained in:
@@ -4,19 +4,20 @@ namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Models\Product;
|
||||
use App\Models\ProductStock;
|
||||
use App\Models\Category;
|
||||
use App\Models\ProductTax;
|
||||
use App\Models\ProductTranslation;
|
||||
use App\Models\Upload;
|
||||
use Artisan;
|
||||
|
||||
use App\Services\ProductService;
|
||||
use App\Services\ProductStockService;
|
||||
use App\Services\ProductTaxService;
|
||||
use Auth;
|
||||
|
||||
class DigitalProductController extends Controller
|
||||
{
|
||||
public function __construct()
|
||||
{
|
||||
|
||||
// Staff Permission Check
|
||||
$this->middleware(['permission:show_digital_products'])->only('index');
|
||||
$this->middleware(['permission:add_digital_product'])->only('create');
|
||||
@@ -33,13 +34,15 @@ class DigitalProductController extends Controller
|
||||
public function index(Request $request)
|
||||
{
|
||||
$sort_search = null;
|
||||
$products = Product::orderBy('created_at', 'desc');
|
||||
$products = Product::query();
|
||||
$products->where('added_by', 'admin');
|
||||
if ($request->has('search')) {
|
||||
$sort_search = $request->search;
|
||||
$products = $products->where('name', 'like', '%' . $sort_search . '%');
|
||||
}
|
||||
$products = $products->where('digital', 1)->paginate(10);
|
||||
return view('backend.product.digital_products.index', compact('products', 'sort_search'));
|
||||
$products = $products->where('digital', 1)->orderBy('created_at', 'desc')->paginate(10);
|
||||
$type = 'Admin';
|
||||
return view('backend.product.digital_products.index', compact('products', 'sort_search', 'type'));
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -64,66 +67,36 @@ class DigitalProductController extends Controller
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
$product = new Product;
|
||||
$product->name = $request->name;
|
||||
$product->added_by = 'admin';
|
||||
$product->user_id = Auth::user()->id;
|
||||
$product->category_id = $request->category_id;
|
||||
$product->digital = 1;
|
||||
$product->photos = $request->photos;
|
||||
$product->thumbnail_img = $request->thumbnail_img;
|
||||
// Product Store
|
||||
$product = (new ProductService)->store($request->except([
|
||||
'_token', 'tax_id', 'tax', 'tax_type'
|
||||
]));
|
||||
|
||||
$tags = array();
|
||||
if ($request->tags[0] != null) {
|
||||
foreach (json_decode($request->tags[0]) as $key => $tag) {
|
||||
array_push($tags, $tag->value);
|
||||
}
|
||||
$request->merge(['product_id' => $product->id, 'current_stock' => 0]);
|
||||
|
||||
//Product Stock
|
||||
(new ProductStockService)->store($request->only([
|
||||
'unit_price', 'current_stock', 'product_id'
|
||||
]), $product);
|
||||
|
||||
//VAT & Tax
|
||||
if ($request->tax_id) {
|
||||
(new ProductTaxService)->store($request->only([
|
||||
'tax_id', 'tax', 'tax_type', 'product_id'
|
||||
]));
|
||||
}
|
||||
$product->tags = implode(',', $tags);
|
||||
|
||||
$product->description = $request->description;
|
||||
$product->unit_price = $request->unit_price;
|
||||
$product->purchase_price = $request->purchase_price;
|
||||
$product->discount = $request->discount;
|
||||
$product->discount_type = $request->discount_type;
|
||||
// Product Translations
|
||||
$request->merge(['lang' => env('DEFAULT_LANGUAGE')]);
|
||||
ProductTranslation::create($request->only([
|
||||
'lang', 'name', 'unit', 'description', 'product_id'
|
||||
]));
|
||||
|
||||
$product->meta_title = $request->meta_title;
|
||||
$product->meta_description = $request->meta_description;
|
||||
$product->meta_img = $request->meta_img;
|
||||
flash(translate('Product has been inserted successfully'))->success();
|
||||
|
||||
$product->file_name = $request->file;
|
||||
|
||||
$product->slug = preg_replace('/[^A-Za-z0-9\-]/', '', str_replace(' ', '-', $request->name)) . '-' . rand(10000, 99999);
|
||||
|
||||
if ($product->save()) {
|
||||
$request->merge(['product_id' => $product->id]);
|
||||
//VAT & Tax
|
||||
if ($request->tax_id) {
|
||||
(new ProductTaxService)->store($request->only([
|
||||
'tax_id', 'tax', 'tax_type', 'product_id'
|
||||
]));
|
||||
}
|
||||
|
||||
$product_stock = new ProductStock;
|
||||
$product_stock->product_id = $product->id;
|
||||
$product_stock->variant = '';
|
||||
$product_stock->price = $request->unit_price;
|
||||
$product_stock->sku = '';
|
||||
$product_stock->qty = 0;
|
||||
$product_stock->save();
|
||||
|
||||
// Product Translations
|
||||
$product_translation = ProductTranslation::firstOrNew(['lang' => env('DEFAULT_LANGUAGE'), 'product_id' => $product->id]);
|
||||
$product_translation->name = $request->name;
|
||||
$product_translation->description = $request->description;
|
||||
$product_translation->save();
|
||||
|
||||
flash(translate('Digital Product has been inserted successfully'))->success();
|
||||
return redirect()->route('digitalproducts.index');
|
||||
} else {
|
||||
flash(translate('Something went wrong'))->error();
|
||||
return back();
|
||||
}
|
||||
Artisan::call('view:clear');
|
||||
Artisan::call('cache:clear');
|
||||
return redirect()->route('digitalproducts.index');
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -164,71 +137,42 @@ class DigitalProductController extends Controller
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
$product = Product::findOrFail($id);
|
||||
if ($request->lang == env("DEFAULT_LANGUAGE")) {
|
||||
$product->name = $request->name;
|
||||
$product->description = $request->description;
|
||||
}
|
||||
|
||||
$product->category_id = $request->category_id;
|
||||
$product->digital = 1;
|
||||
$product->photos = $request->photos;
|
||||
$product->thumbnail_img = $request->thumbnail_img;
|
||||
//Product Update
|
||||
$product = (new ProductService)->update($request->except([
|
||||
'_token', 'tax_id', 'tax', 'tax_type'
|
||||
]), $product);
|
||||
|
||||
$tags = array();
|
||||
if ($request->tags[0] != null) {
|
||||
foreach (json_decode($request->tags[0]) as $key => $tag) {
|
||||
array_push($tags, $tag->value);
|
||||
}
|
||||
}
|
||||
$product->tags = implode(',', $tags);
|
||||
|
||||
$product->unit_price = $request->unit_price;
|
||||
$product->purchase_price = $request->purchase_price;
|
||||
$product->discount = $request->discount;
|
||||
$product->discount_type = $request->discount_type;
|
||||
|
||||
$product->meta_title = $request->meta_title;
|
||||
$product->meta_description = $request->meta_description;
|
||||
$product->meta_img = $request->meta_img;
|
||||
$product->slug = strtolower($request->slug);
|
||||
|
||||
$product->file_name = $request->file;
|
||||
|
||||
// Delete From Product Stock
|
||||
//Product Stock
|
||||
foreach ($product->stocks as $key => $stock) {
|
||||
$stock->delete();
|
||||
}
|
||||
|
||||
if ($product->save()) {
|
||||
$request->merge(['product_id' => $product->id]);
|
||||
//VAT & Tax
|
||||
if ($request->tax_id) {
|
||||
ProductTax::where('product_id', $product->id)->delete();
|
||||
(new ProductTaxService)->store($request->only([
|
||||
'tax_id', 'tax', 'tax_type', 'product_id'
|
||||
]));
|
||||
}
|
||||
// Insert Into Product Stock
|
||||
$product_stock = new ProductStock;
|
||||
$product_stock->product_id = $product->id;
|
||||
$product_stock->variant = '';
|
||||
$product_stock->price = $request->unit_price;
|
||||
$product_stock->sku = '';
|
||||
$product_stock->qty = 0;
|
||||
$product_stock->save();
|
||||
$request->merge(['product_id' => $product->id,'current_stock' => 0]);
|
||||
|
||||
// Product Translations
|
||||
$product_translation = ProductTranslation::firstOrNew(['lang' => $request->lang, 'product_id' => $product->id]);
|
||||
$product_translation->name = $request->name;
|
||||
$product_translation->description = $request->description;
|
||||
$product_translation->save();
|
||||
(new ProductStockService)->store($request->only([
|
||||
'unit_price', 'current_stock', 'product_id'
|
||||
]), $product);
|
||||
|
||||
flash(translate('Digital Product has been updated successfully'))->success();
|
||||
return back();
|
||||
} else {
|
||||
flash(translate('Something went wrong'))->error();
|
||||
return back();
|
||||
//VAT & Tax
|
||||
if ($request->tax_id) {
|
||||
ProductTax::where('product_id', $product->id)->delete();
|
||||
(new ProductTaxService)->store($request->only([
|
||||
'tax_id', 'tax', 'tax_type', 'product_id'
|
||||
]));
|
||||
}
|
||||
|
||||
// Product Translations
|
||||
ProductTranslation::updateOrCreate(
|
||||
$request->only(['lang', 'product_id']),
|
||||
$request->only(['name', 'description'])
|
||||
);
|
||||
|
||||
flash(translate('Product has been updated successfully'))->success();
|
||||
|
||||
Artisan::call('view:clear');
|
||||
Artisan::call('cache:clear');
|
||||
return back();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -239,15 +183,16 @@ class DigitalProductController extends Controller
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
$product = Product::findOrFail($id);
|
||||
|
||||
$product->product_translations()->delete();
|
||||
$product->stocks()->delete();
|
||||
|
||||
Product::destroy($id);
|
||||
|
||||
flash(translate('Product has been deleted successfully'))->success();
|
||||
return redirect()->route('digitalproducts.index');
|
||||
$product_destroy = (new ProductService)->destroy($id);
|
||||
|
||||
if ($product_destroy) {
|
||||
flash(translate('Product has been deleted successfully'))->success();
|
||||
Artisan::call('view:clear');
|
||||
Artisan::call('cache:clear');
|
||||
} else {
|
||||
flash(translate('Something went wrong'))->error();
|
||||
}
|
||||
return back();
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user