| Current Path : /home/users/unlimited/www/admin.priyotama.com/app/Http/Controllers/Vendor/ |
| Current File : /home/users/unlimited/www/admin.priyotama.com/app/Http/Controllers/Vendor/ItemController.php |
<?php
namespace App\Http\Controllers\Vendor;
use Carbon\Carbon;
use App\Models\Tag;
use App\Models\Item;
use App\Models\Brand;
use App\Models\Review;
use App\Models\Allergy;
use App\Models\Category;
use App\Models\Nutrition;
use App\Scopes\StoreScope;
use App\Models\GenericName;
use App\Models\TempProduct;
use Illuminate\Support\Str;
use Illuminate\Http\Request;
use App\Models\FlashSaleItem;
use App\CentralLogics\Helpers;
use App\Models\CommonCondition;
use Illuminate\Validation\Rule;
use Illuminate\Support\Facades\DB;
use App\CentralLogics\ProductLogic;
use App\Models\PharmacyItemDetails;
use App\Http\Controllers\Controller;
use App\Models\EcommerceItemDetails;
use Brian2694\Toastr\Facades\Toastr;
use Rap2hpoutre\FastExcel\FastExcel;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Facades\Validator;
class ItemController extends Controller
{
public function index()
{
if (!Helpers::get_store_data()->item_section && Helpers::get_store_data()->store_business_model == 'commission') {
Toastr::warning(translate('messages.permission_denied'));
return back();
} elseif (!Helpers::get_store_data()->item_section && in_array(Helpers::get_store_data()->store_business_model, ['subscription', 'unsubscribed'])) {
Toastr::warning(translate('You_have_reached_the_maximum_limit_of_item_uploads_allowed_in_your_subscription_package'));
return back();
}
$categories = Category::where(['position' => 0])->module(Helpers::get_store_data()->module_id)->get();
$conditions = CommonCondition::get(['id', 'name']);
$brands = Brand::active()->where(function ($query) {
$query->where('module_id', Helpers::get_store_data()->module_id)->orWhere('module_id', null);
})->get();
$module_data = config('module.' . Helpers::get_store_data()->module->module_type);
$taxData = Helpers::getTaxSystemType();
$productWiseTax = $taxData['productWiseTax'];
$taxVats = $taxData['taxVats'];
return view('vendor-views.product.index', compact('categories', 'module_data', 'conditions', 'brands', 'productWiseTax', 'taxVats'));
}
public function store(Request $request)
{
if (!Helpers::get_store_data()->item_section) {
return response()->json([
'errors' => [
['code' => 'unauthorized', 'message' => translate('messages.permission_denied')]
]
]);
}
$validator = Validator::make($request->all(), [
'name' => 'array',
'name.0' => 'required',
'name.*' => 'max:191',
'category_id' => 'required',
'image' => [
Rule::requiredIf(function () use ($request) {
return (Helpers::get_store_data()->module->module_type != 'food' && $request?->product_gellary == null);
})
],
'price' => 'required|numeric|between:.01,999999999999.99',
'description.*' => 'max:1000',
'description.0' => 'required',
'discount' => 'required|numeric|min:0',
], [
'name.0.required' => translate('messages.item_default_name_required'),
'description.0.required' => translate('messages.item_default_description_required'),
'category_id.required' => translate('messages.category_required'),
'description.*.max' => translate('messages.description_length_warning'),
]);
if ($request['discount_type'] == 'percent') {
$dis = ($request['price'] / 100) * $request['discount'];
} else {
$dis = $request['discount'];
}
if ($request['price'] <= $dis) {
$validator->getMessageBag()->add('unit_price', translate('messages.discount_can_not_be_more_than_or_equal'));
}
if ($request['price'] <= $dis || $validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$store = Helpers::get_store_data();
if ($store->store_business_model == 'subscription') {
$store_sub = $store?->store_sub;
if (isset($store_sub)) {
if ($store_sub->max_product != "unlimited" && $store_sub->max_product > 0) {
$total_item = Item::where('store_id', $store->id)->count() + 1;
if ($total_item >= $store_sub->max_product) {
$store->item_section = 0;
$store->save();
}
}
} else {
return response()->json([
'errors' => [
['code' => 'unauthorized', 'message' => translate('messages.you_are_not_subscribed_to_any_package')]
]
]);
}
} elseif ($store->store_business_model == 'unsubscribed') {
return response()->json([
'errors' => [
['code' => 'unauthorized', 'message' => translate('messages.you_are_not_subscribed_to_any_package')]
]
]);
}
$tag_ids = [];
if ($request->tags != null) {
$tags = explode(",", $request->tags);
}
if (isset($tags)) {
foreach ($tags as $key => $value) {
$tag = Tag::firstOrNew(
['tag' => $value]
);
$tag->save();
array_push($tag_ids, $tag->id);
}
}
$nutrition_ids = [];
if ($request->nutritions != null) {
$nutritions = $request->nutritions;
}
if (isset($nutritions)) {
foreach ($nutritions as $key => $value) {
$nutrition = Nutrition::firstOrNew(
['nutrition' => $value]
);
$nutrition->save();
array_push($nutrition_ids, $nutrition->id);
}
}
$allergy_ids = [];
if ($request->allergies != null) {
$allergies = $request->allergies;
}
if (isset($allergies)) {
foreach ($allergies as $key => $value) {
$allergy = Allergy::firstOrNew(
['allergy' => $value]
);
$allergy->save();
array_push($allergy_ids, $allergy->id);
}
}
$generic_ids = [];
if ($request->generic_name != null) {
$generic_name = GenericName::firstOrNew(
['generic_name' => $request->generic_name]
);
$generic_name->save();
array_push($generic_ids, $generic_name->id);
}
$images = [];
if ($request->item_id && $request?->product_gellary == 1) {
$item_data = Item::withoutGlobalScope(StoreScope::class)->select(['image', 'images'])->findOrfail($request->item_id);
if (!$request->has('image')) {
$oldDisk = 'public';
if ($item_data->storage && count($item_data->storage) > 0) {
foreach ($item_data->storage as $value) {
if ($value['key'] == 'image') {
$oldDisk = $value['value'];
}
}
}
$oldPath = "product/{$item_data->image}";
$newFileNamethumb = Carbon::now()->toDateString() . "-" . uniqid() . ".png";
$newPath = "product/{$newFileNamethumb}";
$dir = 'product/';
$newDisk = Helpers::getDisk();
try {
if (Storage::disk($oldDisk)->exists($oldPath)) {
if (!Storage::disk($newDisk)->exists($dir)) {
Storage::disk($newDisk)->makeDirectory($dir);
}
$fileContents = Storage::disk($oldDisk)->get($oldPath);
Storage::disk($newDisk)->put($newPath, $fileContents);
}
} catch (\Exception $e) {
}
}
foreach ($item_data->images as $key => $value) {
if (!in_array(is_array($value) ? $value['img'] : $value, explode(",", $request->removedImageKeys))) {
$value = is_array($value) ? $value : ['img' => $value, 'storage' => 'public'];
$oldDisk = $value['storage'];
$oldPath = "product/{$value['img']}";
$newFileName = Carbon::now()->toDateString() . "-" . uniqid() . ".png";
$newPath = "product/{$newFileName}";
$dir = 'product/';
$newDisk = Helpers::getDisk();
try {
if (Storage::disk($oldDisk)->exists($oldPath)) {
if (!Storage::disk($newDisk)->exists($dir)) {
Storage::disk($newDisk)->makeDirectory($dir);
}
$fileContents = Storage::disk($oldDisk)->get($oldPath);
Storage::disk($newDisk)->put($newPath, $fileContents);
}
} catch (\Exception $e) {
}
$images[] = ['img' => $newFileName, 'storage' => Helpers::getDisk()];
}
}
}
$food = new Item;
$food->name = $request->name[array_search('default', $request->lang)];
$category = [];
if ($request->category_id != null) {
array_push($category, [
'id' => $request->category_id,
'position' => 1,
]);
}
if ($request->sub_category_id != null) {
array_push($category, [
'id' => $request->sub_category_id,
'position' => 2,
]);
}
if ($request->sub_sub_category_id != null) {
array_push($category, [
'id' => $request->sub_sub_category_id,
'position' => 3,
]);
}
$food->category_id = $request->sub_category_id ? $request->sub_category_id : $request->category_id;
$food->category_ids = json_encode($category);
$food->description = $request->description[array_search('default', $request->lang)];
$food->unit_id = $request?->unit;
$choice_options = [];
if ($request->has('choice')) {
foreach ($request->choice_no as $key => $no) {
$str = 'choice_options_' . $no;
if ($request[$str][0] == null) {
$validator->getMessageBag()->add('name', translate('messages.attribute_choice_option_value_can_not_be_null'));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$item['name'] = 'choice_' . $no;
$item['title'] = $request->choice[$key];
$item['options'] = explode(',', implode('|', preg_replace('/\s+/', ' ', $request[$str])));
array_push($choice_options, $item);
}
}
$food->choice_options = json_encode($choice_options);
$variations = [];
$options = [];
if ($request->has('choice_no')) {
foreach ($request->choice_no as $key => $no) {
$name = 'choice_options_' . $no;
$my_str = implode('|', $request[$name]);
array_push($options, explode(',', $my_str));
}
}
//Generates the combinations of customer choice options
$combinations = Helpers::combinations($options);
if (count($combinations[0]) > 0) {
foreach ($combinations as $key => $combination) {
$str = '';
foreach ($combination as $k => $item) {
if ($k > 0) {
$str .= '-' . str_replace(' ', '', $item);
} else {
$str .= str_replace(' ', '', $item);
}
}
$item = [];
$item['type'] = $str;
$item['price'] = abs($request['price_' . str_replace('.', '_', $str)]);
if ($request->discount_type == 'amount' && $item['price'] < $request->discount) {
$validator->getMessageBag()->add('unit_price', translate("Variation price must be greater than discount amount"));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$item['stock'] = abs($request['stock_' . str_replace('.', '_', $str)]);
array_push($variations, $item);
}
}
if (!empty($request->file('item_images'))) {
foreach ($request->item_images as $img) {
$image_name = Helpers::upload('product/', 'png', $img);
$images[] = ['img' => $image_name, 'storage' => Helpers::getDisk()];
}
}
// food variation
$food_variations = [];
if (isset($request->options)) {
foreach (array_values($request->options) as $key => $option) {
$temp_variation['name'] = $option['name'];
$temp_variation['type'] = $option['type'];
$temp_variation['min'] = $option['min'] ?? 0;
$temp_variation['max'] = $option['max'] ?? 0;
$temp_variation['required'] = $option['required'] ?? 'off';
if ($option['min'] > 0 && $option['min'] > $option['max']) {
$validator->getMessageBag()->add('name', translate('messages.minimum_value_can_not_be_greater_then_maximum_value'));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
if (!isset($option['values'])) {
$validator->getMessageBag()->add('name', translate('messages.please_add_options_for') . $option['name']);
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
if ($option['max'] > count($option['values'])) {
$validator->getMessageBag()->add('name', translate('messages.please_add_more_options_or_change_the_max_value_for') . $option['name']);
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$temp_value = [];
foreach (array_values($option['values']) as $value) {
if (isset($value['label'])) {
$temp_option['label'] = $value['label'];
}
$temp_option['optionPrice'] = $value['optionPrice'];
array_push($temp_value, $temp_option);
}
$temp_variation['values'] = $temp_value;
array_push($food_variations, $temp_variation);
}
}
$food->food_variations = json_encode($food_variations);
$food->variations = json_encode($variations);
$food->price = $request->price;
$food->veg = $request->veg ?? 0;
$food->image = $request->has('image') ? Helpers::upload('product/', 'png', $request->file('image')) : $newFileNamethumb ?? null;
$food->available_time_starts = $request->available_time_starts ?? '00:00:00';
$food->available_time_ends = $request->available_time_ends ?? '23:59:59';
$food->discount = $request->discount_type == 'amount' ? $request->discount : $request->discount;
$food->discount_type = $request->discount_type;
$food->maximum_cart_quantity = $request->maximum_cart_quantity;
$food->attributes = $request->has('attribute_id') ? json_encode($request->attribute_id) : json_encode([]);
$food->add_ons = $request->has('addon_ids') ? json_encode($request->addon_ids) : json_encode([]);
$food->store_id = Helpers::get_store_id();
$food->module_id = Helpers::get_store_data()->module_id;
$food->images = $images;
$food->stock = $request->current_stock ?? 0;
$module_type = Helpers::get_store_data()->module->module_type;
if ($module_type == 'grocery') {
$food->organic = $request->organic ?? 0;
}
$food->is_halal = $request->is_halal ?? 0;
$food->save();
$food->tags()->sync($tag_ids);
$food->nutritions()->sync($nutrition_ids);
$food->allergies()->sync($allergy_ids);
if ($module_type == 'pharmacy') {
$food->generic()->sync($generic_ids);
$item_details = new PharmacyItemDetails();
$item_details->item_id = $food->id;
$item_details->common_condition_id = $request->condition_id;
$item_details->is_basic = $request->basic ?? 0;
$item_details->is_prescription_required = $request->is_prescription_required ?? 0;
$item_details->save();
}
if ($module_type == 'ecommerce') {
$item_details = new EcommerceItemDetails();
$item_details->item_id = $food->id;
$item_details->brand_id = $request->brand_id;
$item_details->save();
}
if (addon_published_status('TaxModule')) {
$SystemTaxVat = \Modules\TaxModule\Entities\SystemTaxSetup::where('is_active', 1)->where('is_default', 1)->first();
if ($SystemTaxVat?->tax_type == 'product_wise') {
foreach ($request['tax_ids'] ?? [] as $tax_id) {
\Modules\TaxModule\Entities\Taxable::create(
[
'taxable_type' => Item::class,
'taxable_id' => $food->id,
'system_tax_setup_id' => $SystemTaxVat->id,
'tax_id' => $tax_id
],
);
}
}
}
Helpers::add_or_update_translations(request: $request, key_data: 'name', name_field: 'name', model_name: 'Item', data_id: $food->id, data_value: $food->name);
Helpers::add_or_update_translations(request: $request, key_data: 'description', name_field: 'description', model_name: 'Item', data_id: $food->id, data_value: $food->description);
$product_approval_datas = \App\Models\BusinessSetting::where('key', 'product_approval_datas')->first()?->value ?? '';
$product_approval_datas = json_decode($product_approval_datas, true);
if (Helpers::get_mail_status('product_approval') && data_get($product_approval_datas, 'Add_new_product', null) == 1) {
$this->store_temp_data(data: $food, request: $request, tag_ids: $tag_ids, nutrition_ids: $nutrition_ids, allergy_ids: $allergy_ids, generic_ids: $generic_ids, taxIds: $request['tax_ids']);
$food->is_approved = 0;
$food->save();
return response()->json(['product_approval' => translate('messages.The_product_will_be_published_once_it_receives_approval_from_the_admin.')], 200);
}
return response()->json(['success' => translate('messages.product_added_successfully')], 200);
}
public function view($id)
{
$taxData = Helpers::getTaxSystemType();
$productWiseTax = $taxData['productWiseTax'];
$product = Item::with($productWiseTax ? ['taxVats.tax'] : [])->findOrFail($id);
$reviews = Review::where(['item_id' => $id])->latest()->paginate(config('default_pagination'));
return view('vendor-views.product.view', compact('product', 'reviews','productWiseTax'));
}
public function edit(Request $request, $id)
{
if (!Helpers::get_store_data()->item_section && Helpers::get_store_data()->product_uploaad_check == 'commission') {
Toastr::warning(translate('messages.permission_denied'));
return back();
}
$temp_product = false;
if ($request->temp_product) {
$product = TempProduct::withoutGlobalScope('translate')->findOrFail($id);
$temp_product = true;
} else {
$product = Item::withoutGlobalScope('translate');
if (isset($request->product_gellary) && $request->product_gellary == 1) {
$product->withoutGlobalScope(StoreScope::class)->where('is_approved', 1);
}
$product = $product->findOrFail($id);
}
$product_category = json_decode($product->category_ids);
$categories = Category::where(['parent_id' => 0])->module(Helpers::get_store_data()->module_id)->get();
$module_data = config('module.' . Helpers::get_store_data()->module->module_type);
$conditions = CommonCondition::get(['id', 'name']);
$brands = Brand::active()->where(function ($query) {
$query->where('module_id', Helpers::get_store_data()->module_id)->orWhere('module_id', null);
})->get();
$taxData = Helpers::getTaxSystemType();
$productWiseTax = $taxData['productWiseTax'];
$taxVats = $taxData['taxVats'];
$taxVatIds = $productWiseTax ? $product->taxVats()->pluck('tax_id')->toArray(): [];
return view('vendor-views.product.edit', compact('product', 'product_category', 'categories', 'module_data', 'temp_product', 'conditions', 'brands', 'productWiseTax', 'taxVats', 'taxVatIds'));
}
public function status(Request $request)
{
if (!Helpers::get_store_data()->item_section && Helpers::get_store_data()->product_uploaad_check == 'commission') {
Toastr::warning(translate('messages.permission_denied'));
return back();
}
if (Helpers::get_store_data()->product_uploaad_check !== null && !in_array(Helpers::get_store_data()->product_uploaad_check, ['unlimited', 'commission']) && Helpers::get_store_data()->product_uploaad_check >= 0 && $request->status == 1) {
Toastr::warning(translate('Your_current_package_doesnot_allow_to_activate_more_then_allocated_items_in_your_package'));
return back();
}
$product = Item::find($request->id);
$product->status = $request->status;
$product->save();
Toastr::success('Item status updated!');
return back();
}
public function recommended(Request $request)
{
if (!Helpers::get_store_data()->item_section) {
Toastr::warning(translate('messages.permission_denied'));
return back();
}
$product = Item::find($request->id);
$product->recommended = $request->status;
$product->save();
Toastr::success(translate('Item recommendation updated!'));
return back();
}
public function update(Request $request, $id)
{
if (!Helpers::get_store_data()->item_section && Helpers::get_store_data()->product_uploaad_check == 'commission') {
return response()->json([
'errors' => [
['code' => 'unauthorized', 'message' => translate('messages.permission_denied')]
]
]);
}
$validator = Validator::make($request->all(), [
'name' => 'array',
'name.0' => 'required',
'name.*' => 'max:191',
'category_id' => 'required',
'price' => 'required|numeric|between:0.01,999999999999.99',
'description.*' => 'max:1000',
'description.0' => 'required',
'discount' => 'required|numeric|min:0',
], [
'name.0.required' => translate('messages.item_default_name_required'),
'description.0.required' => translate('messages.item_default_description_required'),
'category_id.required' => translate('messages.category_required'),
'description.*.max' => translate('messages.description_length_warning'),
]);
if ($request['discount_type'] == 'percent') {
$dis = ($request['price'] / 100) * $request['discount'];
} else {
$dis = $request['discount'];
}
if ($request['price'] <= $dis) {
$validator->getMessageBag()->add('unit_price', translate('messages.discount_can_not_be_more_than_or_equal'));
}
if ($request['price'] <= $dis || $validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$tag_ids = [];
if ($request->tags != null) {
$tags = explode(",", $request->tags);
}
if (isset($tags)) {
foreach ($tags as $key => $value) {
$tag = Tag::firstOrNew(
['tag' => $value]
);
$tag->save();
array_push($tag_ids, $tag->id);
}
}
$nutrition_ids = [];
if ($request->nutritions != null) {
$nutritions = $request->nutritions;
}
if (isset($nutritions)) {
foreach ($nutritions as $key => $value) {
$nutrition = Nutrition::firstOrNew(
['nutrition' => $value]
);
$nutrition->save();
array_push($nutrition_ids, $nutrition->id);
}
}
$allergy_ids = [];
if ($request->allergies != null) {
$allergies = $request->allergies;
}
if (isset($allergies)) {
foreach ($allergies as $key => $value) {
$allergy = Allergy::firstOrNew(
['allergy' => $value]
);
$allergy->save();
array_push($allergy_ids, $allergy->id);
}
}
$generic_ids = [];
if ($request->generic_name != null) {
$generic_name = GenericName::firstOrNew(
['generic_name' => $request->generic_name]
);
$generic_name->save();
array_push($generic_ids, $generic_name->id);
}
$p = Item::find($id);
$p->name = $request->name[array_search('default', $request->lang)];
$p->unit_id = $request?->unit;
$category = [];
if ($request->category_id != null) {
array_push($category, [
'id' => $request->category_id,
'position' => 1,
]);
}
if ($request->sub_category_id != null) {
array_push($category, [
'id' => $request->sub_category_id,
'position' => 2,
]);
}
if ($request->sub_sub_category_id != null) {
array_push($category, [
'id' => $request->sub_sub_category_id,
'position' => 3,
]);
}
$p->category_id = $request->sub_category_id ? $request->sub_category_id : $request->category_id;
$p->category_ids = json_encode($category);
$p->description = $request->description[array_search('default', $request->lang)];
$choice_options = [];
if ($request->has('choice')) {
foreach ($request->choice_no as $key => $no) {
$str = 'choice_options_' . $no;
if ($request[$str][0] == null) {
$validator->getMessageBag()->add('name', translate('messages.attribute_choice_option_value_can_not_be_null'));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$item['name'] = 'choice_' . $no;
$item['title'] = $request->choice[$key];
$item['options'] = explode(',', implode('|', preg_replace('/\s+/', ' ', $request[$str])));
array_push($choice_options, $item);
}
}
$p->choice_options = json_encode($choice_options);
$variations = [];
$options = [];
if ($request->has('choice_no')) {
foreach ($request->choice_no as $key => $no) {
$name = 'choice_options_' . $no;
$my_str = implode('|', $request[$name]);
array_push($options, explode(',', $my_str));
}
}
//Generates the combinations of customer choice options
$combinations = Helpers::combinations($options);
if (count($combinations[0]) > 0) {
foreach ($combinations as $key => $combination) {
$str = '';
foreach ($combination as $k => $item) {
if ($k > 0) {
$str .= '-' . str_replace(' ', '', $item);
} else {
$str .= str_replace(' ', '', $item);
}
}
$item = [];
$item['type'] = $str;
$item['price'] = abs($request['price_' . str_replace('.', '_', $str)]);
if ($request->discount_type == 'amount' && $item['price'] < $request->discount) {
$validator->getMessageBag()->add('unit_price', translate("Variation price must be greater than discount amount"));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$item['stock'] = abs($request['stock_' . str_replace('.', '_', $str)]);
array_push($variations, $item);
}
}
//combinations end
$food_variations = [];
if (isset($request->options)) {
foreach (array_values($request->options) as $key => $option) {
$temp_variation['name'] = $option['name'];
$temp_variation['type'] = $option['type'];
$temp_variation['min'] = $option['min'] ?? 0;
$temp_variation['max'] = $option['max'] ?? 0;
if ($option['min'] > 0 && $option['min'] > $option['max']) {
$validator->getMessageBag()->add('name', translate('messages.minimum_value_can_not_be_greater_then_maximum_value'));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
if (!isset($option['values'])) {
$validator->getMessageBag()->add('name', translate('messages.please_add_options_for') . $option['name']);
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
if ($option['max'] > count($option['values'])) {
$validator->getMessageBag()->add('name', translate('messages.please_add_more_options_or_change_the_max_value_for') . $option['name']);
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$temp_variation['required'] = $option['required'] ?? 'off';
$temp_value = [];
foreach (array_values($option['values']) as $value) {
if (isset($value['label'])) {
$temp_option['label'] = $value['label'];
}
$temp_option['optionPrice'] = $value['optionPrice'];
array_push($temp_value, $temp_option);
}
$temp_variation['values'] = $temp_value;
array_push($food_variations, $temp_variation);
}
}
$variation_changed = false;
if ((($p->food_variations != null && $food_variations != '[]') && strcmp($p->food_variations, json_encode($food_variations)) !== 0) || (
($p->variations != null && $variations != '[]') && strcmp($p->variations, json_encode($variations)) !== 0)) {
$variation_changed = true;
}
$old_price = $p->price;
$slug = Str::slug($request->name[array_search('default', $request->lang)]);
$p->slug = $p->slug ? $p->slug : "{$slug}-{$p->id}";
$p->food_variations = json_encode($food_variations);
$p->variations = json_encode($variations);
$p->price = $request->price;
$p->veg = $request->veg ?? 0;
$p->available_time_starts = $request->available_time_starts ?? '00:00:00';
$p->available_time_ends = $request->available_time_ends ?? '23:59:59';
$p->discount = $request->discount_type == 'amount' ? $request->discount : $request->discount;
$p->discount_type = $request->discount_type;
$p->maximum_cart_quantity = $request->maximum_cart_quantity;
$p->attributes = $request->has('attribute_id') ? json_encode($request->attribute_id) : json_encode([]);
$p->add_ons = $request->has('addon_ids') ? json_encode($request->addon_ids) : json_encode([]);
$p->stock = $request->current_stock ?? 0;
$p->organic = $request->organic ?? 0;
$p->is_halal = $request->is_halal ?? 0;
$product_approval_datas = \App\Models\BusinessSetting::where('key', 'product_approval_datas')->first()?->value ?? '';
$product_approval_datas = json_decode($product_approval_datas, true);
if (Helpers::get_mail_status('product_approval') && ((data_get($product_approval_datas, 'Update_anything_in_product_details', null) == 1) || (data_get($product_approval_datas, 'Update_product_price', null) == 1 && $old_price != $request->price) || (data_get($product_approval_datas, 'Update_product_variation', null) == 1 && $variation_changed))) {
$this->store_temp_data(data: $p, request: $request, tag_ids: $tag_ids, nutrition_ids: $nutrition_ids, allergy_ids: $allergy_ids, generic_ids: $generic_ids, update: true, taxIds: $request['tax_ids']);
return response()->json(['product_approval' => translate('your_product_added_for_approval')], 200);
} else {
$p->image = $request->has('image') ? Helpers::update('product/', $p->image, 'png', $request->file('image')) : $p->image;
$images = $p['images'];
foreach ($p->images as $key => $value) {
if (in_array(is_array($value) ? $value['img'] : $value, explode(",", $request->removedImageKeys))) {
$value = is_array($value) ? $value : ['img' => $value, 'storage' => 'public'];
Helpers::check_and_delete('product/', $value['img']);
unset($images[$key]);
}
}
$images = array_values($images);
if ($request->has('item_images')) {
foreach ($request->item_images as $img) {
$image = Helpers::upload('product/', 'png', $img);
array_push($images, ['img' => $image, 'storage' => Helpers::getDisk()]);
}
}
$p->images = $images;
}
if ($p->module->module_type == 'pharmacy') {
DB::table('pharmacy_item_details')
->updateOrInsert(
['item_id' => $p->id],
[
'common_condition_id' => $request->condition_id,
'is_basic' => $request->basic ?? 0,
'is_prescription_required' => $request->is_prescription_required ?? 0,
]
);
}
if ($p->module->module_type == 'ecommerce') {
DB::table('ecommerce_item_details')
->updateOrInsert(
['item_id' => $p->id],
[
'brand_id' => $request->brand_id,
]
);
}
if (addon_published_status('TaxModule')) {
$taxVatIds = $p->taxVats()->pluck('tax_id')->toArray() ?? [];
$newTaxVatIds = array_map('intval', $request['tax_ids'] ?? []);
sort($newTaxVatIds);
sort($taxVatIds);
if ($newTaxVatIds != $taxVatIds) {
$p->taxVats()->delete();
$SystemTaxVat = \Modules\TaxModule\Entities\SystemTaxSetup::where('is_active', 1)->where('is_default', 1)->first();
if ($SystemTaxVat?->tax_type == 'product_wise') {
foreach ($request['tax_ids'] ?? [] as $tax_id) {
\Modules\TaxModule\Entities\Taxable::create(
[
'taxable_type' => Item::class,
'taxable_id' => $p->id,
'system_tax_setup_id' => $SystemTaxVat->id,
'tax_id' => $tax_id
],
);
}
}
}
}
$p->save();
$p->tags()->sync($tag_ids);
$p->nutritions()->sync($nutrition_ids);
$p->allergies()->sync($allergy_ids);
$p->generic()->sync($generic_ids);
Helpers::add_or_update_translations(request: $request, key_data: 'name', name_field: 'name', model_name: 'Item', data_id: $p->id, data_value: $p->name);
Helpers::add_or_update_translations(request: $request, key_data: 'description', name_field: 'description', model_name: 'Item', data_id: $p->id, data_value: $p->description);
return response()->json(['success' => translate('messages.product_updated_successfully')], 200);
}
public function delete(Request $request)
{
if (!Helpers::get_store_data()->item_section) {
Toastr::warning(translate('messages.permission_denied'));
return back();
}
if ($request?->temp_product) {
$product = TempProduct::find($request->id);
} else {
$product = Item::find($request->id);
$product?->temp_product?->translations()?->delete();
$product?->temp_product()?->delete();
$product?->carts()?->delete();
}
if ($product->image) {
Helpers::check_and_delete('product/', $product['image']);
}
foreach ($product->images as $value) {
$value = is_array($value) ? $value : ['img' => $value, 'storage' => 'public'];
Helpers::check_and_delete('product/', $value['img']);
}
$product->translations()->delete();
$product?->taxVats()->delete();
$product->delete();
Toastr::success('Item removed!');
return back();
}
public function variant_combination(Request $request)
{
$options = [];
$price = $request->price;
$product_name = $request->name;
if ($request->has('choice_no')) {
foreach ($request->choice_no as $key => $no) {
$name = 'choice_options_' . $no;
$my_str = implode('', $request[$name]);
array_push($options, explode(',', $my_str));
}
}
$result = [[]];
foreach ($options as $property => $property_values) {
$tmp = [];
foreach ($result as $result_item) {
foreach ($property_values as $property_value) {
$tmp[] = array_merge($result_item, [$property => $property_value]);
}
}
$result = $tmp;
}
$data = [];
foreach ($result as $combination) {
$str = '';
foreach ($combination as $key => $item) {
if ($key > 0) {
$str .= '-' . str_replace(' ', '', $item);
} else {
$str .= str_replace(' ', '', $item);
}
}
$price_field = 'price_' . $str;
$stock_field = 'stock_' . $str;
$item_price = $request->input($price_field);
$item_stock = $request->input($stock_field);
$data[] = [
'name' => $str,
'price' => $item_price ?? $price,
'stock' => $item_stock ?? 1
];
}
$combinations = $result;
$stock = (bool)$request->stock;
return response()->json([
'view' => view('vendor-views.product.partials._variant-combinations', compact('combinations', 'price', 'product_name', 'stock', 'data'))->render(),
'length' => count($combinations),
]);
}
public function get_categories(Request $request)
{
$cat = Category::where(['parent_id' => $request->parent_id])->get();
$res = '<option value="' . 0 . '" disabled selected>---Select---</option>';
foreach ($cat as $row) {
if ($row->id == $request->sub_category) {
$res .= '<option value="' . $row->id . '" selected >' . $row->name . '</option>';
} else {
$res .= '<option value="' . $row->id . '">' . $row->name . '</option>';
}
}
return response()->json([
'options' => $res,
]);
}
public function list(Request $request)
{
$category_id = $request->query('category_id', 'all');
$type = $request->query('type', 'all');
$sub_category_id = $request->query('sub_category_id', 'all');
$key = explode(' ', $request['search']);
$items = Item::when(is_numeric($category_id), function ($query) use ($category_id) {
return $query->whereHas('category', function ($q) use ($category_id) {
return $q->whereId($category_id)->orWhere('parent_id', $category_id);
});
})
->when(is_numeric($sub_category_id), function ($query) use ($sub_category_id) {
return $query->where('category_id', $sub_category_id);
})
->where('is_approved', 1)
->when(isset($key), function ($q) use ($key) {
$q->where(function ($q) use ($key) {
foreach ($key as $value) {
$q->where('name', 'like', "%{$value}%");
}
});
})
->type($type)->latest()->paginate(config('default_pagination'));
$sub_categories = $category_id != 'all' ? Category::where('parent_id', $category_id)->get(['id', 'name']) : [];
$taxData = Helpers::getTaxSystemType();
$productWiseTax = $taxData['productWiseTax'];
$category = $category_id != 'all' ? Category::findOrFail($category_id) : null;
return view('vendor-views.product.list', compact('items', 'category', 'type', 'sub_categories','productWiseTax'));
}
public function search(Request $request)
{
$view = 'vendor-views.product.partials._table';
$key = explode(' ', $request['search']);
$settings_access = Helpers::get_mail_status('access_all_products');
$items = Item::where(function ($q) use ($key) {
foreach ($key as $value) {
$q->where('name', 'like', "%{$value}%");
}
})
->module(Helpers::get_store_data()->module_id)
->where('is_approved', 1);
if (isset($request->product_gallery) && $request->product_gallery == 1 && $settings_access == 1) {
$items = $items->withoutGlobalScope(StoreScope::class)->limit(12)->get();
$view = 'vendor-views.product.partials._gallery';
} elseif (isset($request->product_gallery) && $request->product_gallery == 1 && $settings_access == 0) {
$items = $items->limit(12)->get();
$view = 'vendor-views.product.partials._gallery';
} else {
$items = $items->latest()->limit(50)->get();
}
return response()->json([
'view' => view($view, compact('items'))->render(),
'count' => $items->count()
]);
}
public function remove_image(Request $request)
{
if ($request?->temp_product) {
$item = TempProduct::find($request['id']);
} else {
$item = Item::find($request['id']);
}
$array = [];
if (count($item['images']) < 2) {
Toastr::warning('You cannot delete all images!');
return back();
}
Helpers::check_and_delete('product/', $request['name']);
foreach ($item['images'] as $image) {
if (is_array($image)) {
if ($image['img'] != $request['name']) {
array_push($array, $image);
}
} else {
if ($image != $request['name']) {
array_push($array, $image);
}
}
}
if ($request?->temp_product) {
TempProduct::where('id', $request['id'])->update([
'images' => json_encode($array),
]);
} else {
Item::where('id', $request['id'])->update([
'images' => json_encode($array),
]);
}
Toastr::success('Item image removed successfully!');
return back();
}
public function bulk_import_index()
{
$module_type = Helpers::get_store_data()->module->module_type;
return view('vendor-views.product.bulk-import', compact('module_type'));
}
public function bulk_import_data(Request $request)
{
$request->validate([
'products_file' => 'required|max:2048'
]);
$module_id = Helpers::get_store_data()->module->id;
$module_type = Helpers::get_store_data()->module->module_type;
if (!Helpers::get_store_data()->item_section) {
Toastr::warning(translate('messages.permission_denied'));
return back();
}
try {
$collections = (new FastExcel)->import($request->file('products_file'));
} catch (\Exception $exception) {
Toastr::error(translate('messages.you_have_uploaded_a_wrong_format_file'));
return back();
}
$item_id = Item::withoutGlobalScopes()->orderby('id', 'desc')->select('id')->first()?->id;
$product_approval_datas = \App\Models\BusinessSetting::where('key', 'product_approval_datas')->first()?->value ?? '';
$product_approval_datas = json_decode($product_approval_datas, true);
$product_approval_active = Helpers::get_mail_status('product_approval');
$message = translate('messages.Products_imported_successfully');
if ($request->button == 'import') {
$data = [];
$temp_data = [];
try {
foreach ($collections as $key => $collection) {
if ($collection['Id'] === "" || $collection['Name'] === "" || $collection['CategoryId'] === "" || $collection['SubCategoryId'] === "" || $collection['Price'] === "" || $collection['Discount'] === "" || $collection['DiscountType'] === "") {
Toastr::error(translate('messages.please_fill_all_required_fields'));
return back();
}
if (isset($collection['Price']) && ($collection['Price'] < 0)) {
Toastr::error(translate('messages.Price_must_be_greater_then_0') . ' ' . $collection['Id']);
return back();
}
if (isset($collection['Discount']) && ($collection['Discount'] < 0)) {
Toastr::error(translate('messages.Discount_must_be_greater_then_0') . ' ' . $collection['Id']);
return back();
}
if (data_get($collection, 'Image') != "" && strlen(data_get($collection, 'Image')) > 30) {
Toastr::error(translate('messages.Image_name_must_be_in_30_char._on_id') . ' ' . $collection['Id']);
return back();
}
try {
$t1 = Carbon::parse($collection['AvailableTimeStarts']);
$t2 = Carbon::parse($collection['AvailableTimeEnds']);
if ($t1->gt($t2)) {
Toastr::error(translate('messages.AvailableTimeEnds_must_be_greater_then_AvailableTimeStarts_on_id') . ' ' . $collection['Id']);
return back();
}
} catch (\Exception $e) {
info(["line___{$e->getLine()}", $e->getMessage()]);
Toastr::error(translate('messages.Invalid_AvailableTimeEnds_or_AvailableTimeStarts_on_id') . ' ' . $collection['Id']);
return back();
}
array_push($data, [
'id' => $item_id + $key + 1,
'name' => $collection['Name'],
'description' => $collection['Description'],
'image' => $collection['Image'],
'images' => $collection['Images'] ?? json_encode([]),
'category_id' => $collection['SubCategoryId'] ? $collection['SubCategoryId'] : $collection['CategoryId'],
'category_ids' => json_encode([['id' => $collection['CategoryId'], 'position' => 0], ['id' => $collection['SubCategoryId'], 'position' => 1]]),
'unit_id' => is_int($collection['UnitId']) ? $collection['UnitId'] : null,
'stock' => is_numeric($collection['Stock']) ? abs($collection['Stock']) : 0,
'price' => $collection['Price'],
'discount' => $collection['Discount'],
'discount_type' => $collection['DiscountType'],
'available_time_starts' => $collection['AvailableTimeStarts'] ?? '00:00:00',
'available_time_ends' => $collection['AvailableTimeEnds'] ?? '23:59:59',
'variations' => $module_type == 'food' ? json_encode([]) : $collection['Variations'] ?? json_encode([]),
'food_variations' => $module_type == 'food' ? $collection['Variations'] ?? json_encode([]) : json_encode([]),
'add_ons' => $collection['AddOns'] ? ($collection['AddOns'] == "" ? json_encode([]) : $collection['AddOns']) : json_encode([]),
'attributes' => $collection['Attributes'] ? ($collection['Attributes'] == "" ? json_encode([]) : $collection['Attributes']) : json_encode([]),
'store_id' => Helpers::get_store_id(),
'module_id' => Helpers::get_store_data()->module_id,
'choice_options' => $module_type == 'food' ? json_encode([]) : $collection['ChoiceOptions'] ?? json_encode([]),
'status' => $collection['Status'] == 'active' ? 1 : 0,
'veg' => $collection['Veg'] == 'yes' ? 1 : 0,
'recommended' => $collection['Recommended'] == 'yes' ? 1 : 0,
'created_at' => now(),
'updated_at' => now()
]);
if ($product_approval_active && data_get($product_approval_datas, 'Add_new_product', null) == 1) {
// $this->store_temp_data($food, $request,$tag_ids);
$data[$key]['is_approved'] = 0;
$slug = Str::slug($data[$key]['name']) . '_' . $data[$key]['store_id'];
array_push($temp_data, [
// 'id' => $item_id + $key +1,
'name' => $data[$key]['name'],
'description' => $data[$key]['description'],
'image' => $data[$key]['image'],
'images' => $data[$key]['images'],
'category_id' => $data[$key]['category_id'],
'category_ids' => $data[$key]['category_ids'],
'store_id' => $data[$key]['store_id'],
'module_id' => $data[$key]['module_id'],
'unit_id' => $data[$key]['unit_id'],
'item_id' => $data[$key]['id'],
'slug' => $slug,
'tag_ids' => json_encode([]),
'nutrition_ids' => json_encode([]),
'allergy_ids' => json_encode([]),
'generic_ids' => json_encode([]),
'choice_options' => $data[$key]['choice_options'],
'food_variations' => $data[$key]['food_variations'],
'variations' => $data[$key]['variations'],
'add_ons' => $data[$key]['add_ons'],
'attributes' => $data[$key]['attributes'],
'price' => $data[$key]['price'],
'discount' => $data[$key]['discount'],
'discount_type' => $data[$key]['discount_type'],
'available_time_starts' => $data[$key]['available_time_starts'],
'available_time_ends' => $data[$key]['available_time_ends'],
'veg' => $data[$key]['veg'],
'stock' => $data[$key]['stock'],
'status' => $data[$key]['status'],
'recommended' => $data[$key]['recommended'],
'created_at' => now(),
'updated_at' => now()
]);
}
}
} catch (\Exception $e) {
info(["line___{$e->getLine()}", $e->getMessage()]);
Toastr::error($e->getMessage());
return back();
}
try {
DB::beginTransaction();
$total_item = count($data);
$store = Helpers::get_store_data();
if ($store->store_business_model == 'subscription') {
$store_sub = $store?->store_sub;
if (isset($store_sub)) {
if ($store_sub->max_product != "unlimited" && $store_sub->max_product > 0 && $store_sub->max_product >= $total_item) {
$store_sub->decrement('max_product', $total_item);
if ($store_sub->max_product <= 0) {
$store->update(['item_section' => 0]);
} else {
Toastr::error(translate('messages.you_have_reached_the_maximum_limit_of_item'));
return back();
}
}
if ($store_sub->max_product != "unlimited" && $store_sub->max_product > 0) {
$total_all_items = Item::where('store_id', $store->id)->count();
$available_item_uploads = $total_all_items + $total_item;
if ($available_item_uploads > $store_sub->max_product) {
Toastr::error(translate('messages.you_have_reached_the_maximum_limit_of_item'));
return back();
}
}
} else {
return response()->json([
'errors' => [
['code' => 'unauthorized', 'message' => translate('messages.you_are_not_subscribed_to_any_package')]
]
]);
}
}
$chunkSize = 100;
$chunk_items = array_chunk($data, $chunkSize);
foreach ($chunk_items as $key => $chunk_item) {
// DB::table('items')->insert($chunk_item);
foreach ($chunk_item as $item) {
$insertedId = DB::table('items')->insertGetId($item);
Helpers::updateStorageTable(get_class(new Item), $insertedId, $item['image']);
}
}
if (count($temp_data) > 0) {
$message = translate('messages.Products_are_added_for_the_admin_approval');
$chunk_temp_items = array_chunk($temp_data, $chunkSize);
foreach ($chunk_temp_items as $key => $chunk_item) {
// DB::table('temp_products')->insert($chunk_item);
foreach ($chunk_item as $item) {
$insertedId = DB::table('temp_products')->insertGetId($item);
Helpers::updateStorageTable(get_class(new TempProduct), $insertedId, $item['image']);
}
}
}
DB::commit();
} catch (\Exception $e) {
DB::rollBack();
info(["line___{$e->getLine()}", $e->getMessage()]);
Toastr::error($e->getMessage());
return back();
}
Toastr::success(count($data) . ' ' . $message);
return back();
}
$data = [];
$temp_data = [];
try {
foreach ($collections as $key => $collection) {
if ($collection['Id'] === "" || $collection['Name'] === "" || $collection['CategoryId'] === "" || $collection['SubCategoryId'] === "" || $collection['Price'] === "" || $collection['Discount'] === "" || $collection['DiscountType'] === "") {
Toastr::error(translate('messages.please_fill_all_required_fields'));
return back();
}
if (isset($collection['Price']) && ($collection['Price'] < 0)) {
Toastr::error(translate('messages.Price_must_be_greater_then_0') . ' ' . $collection['Id']);
return back();
}
if (isset($collection['Discount']) && ($collection['Discount'] < 0)) {
Toastr::error(translate('messages.Discount_must_be_greater_then_0') . ' ' . $collection['Id']);
return back();
}
if (isset($collection['Discount']) && ($collection['Discount'] > 100)) {
Toastr::error(translate('messages.Discount_must_be_less_then_100') . ' ' . $collection['Id']);
return back();
}
if (data_get($collection, 'Image') != "" && strlen(data_get($collection, 'Image')) > 30) {
Toastr::error(translate('messages.Image_name_must_be_in_30_char._on_id') . ' ' . $collection['Id']);
return back();
}
try {
$t1 = Carbon::parse($collection['AvailableTimeStarts']);
$t2 = Carbon::parse($collection['AvailableTimeEnds']);
if ($t1->gt($t2)) {
Toastr::error(translate('messages.AvailableTimeEnds_must_be_greater_then_AvailableTimeStarts_on_id') . ' ' . $collection['Id']);
return back();
}
} catch (\Exception $e) {
info(["line___{$e->getLine()}", $e->getMessage()]);
Toastr::error(translate('messages.Invalid_AvailableTimeEnds_or_AvailableTimeStarts_on_id') . ' ' . $collection['Id']);
return back();
}
array_push($data, [
'id' => $collection['Id'],
'name' => $collection['Name'],
'description' => $collection['Description'],
'image' => $collection['Image'],
'images' => $collection['Images'] ?? json_encode([]),
'category_id' => $collection['SubCategoryId'] ? $collection['SubCategoryId'] : $collection['CategoryId'],
'category_ids' => json_encode([['id' => $collection['CategoryId'], 'position' => 0], ['id' => $collection['SubCategoryId'], 'position' => 1]]),
'unit_id' => is_int($collection['UnitId']) ? $collection['UnitId'] : null,
'stock' => is_numeric($collection['Stock']) ? abs($collection['Stock']) : 0,
'price' => $collection['Price'],
'discount' => $collection['Discount'],
'discount_type' => $collection['DiscountType'],
'available_time_starts' => $collection['AvailableTimeStarts'] ?? '00:00:00',
'available_time_ends' => $collection['AvailableTimeEnds'] ?? '23:59:59',
'variations' => $module_type == 'food' ? json_encode([]) : $collection['Variations'] ?? json_encode([]),
'food_variations' => $module_type == 'food' ? $collection['Variations'] ?? json_encode([]) : json_encode([]),
'add_ons' => $collection['AddOns'] ? ($collection['AddOns'] == "" ? json_encode([]) : $collection['AddOns']) : json_encode([]),
'attributes' => $collection['Attributes'] ? ($collection['Attributes'] == "" ? json_encode([]) : $collection['Attributes']) : json_encode([]),
'store_id' => Helpers::get_store_id(),
'module_id' => Helpers::get_store_data()->module_id,
'status' => $collection['Status'] == 'active' ? 1 : 0,
'veg' => $collection['Veg'] == 'yes' ? 1 : 0,
'recommended' => $collection['Recommended'] == 'yes' ? 1 : 0,
'updated_at' => now(),
'choice_options' => $module_type == 'food' ? json_encode([]) : $collection['ChoiceOptions'] ?? json_encode([]),
]);
if ($product_approval_active && ((data_get($product_approval_datas, 'Update_anything_in_product_details', null) == 1) || (data_get($product_approval_datas, 'Update_product_price', null) == 1) || (data_get($product_approval_datas, 'Update_product_variation', null) == 1))) {
array_push($temp_data, [
// 'id' => $item_id + $key +1,
'name' => $data[$key]['name'],
'description' => $data[$key]['description'],
'image' => $data[$key]['image'],
'images' => $data[$key]['images'],
'category_id' => $data[$key]['category_id'],
'category_ids' => $data[$key]['category_ids'],
'unit_id' => $data[$key]['unit_id'],
'price' => $data[$key]['price'],
'discount' => $data[$key]['discount'],
'stock' => $data[$key]['stock'],
'discount_type' => $data[$key]['discount_type'],
'available_time_starts' => $data[$key]['available_time_starts'],
'available_time_ends' => $data[$key]['available_time_ends'],
'variations' => $data[$key]['variations'],
'food_variations' => $data[$key]['food_variations'],
'add_ons' => $data[$key]['add_ons'],
'store_id' => $data[$key]['store_id'],
'attributes' => $data[$key]['attributes'],
'veg' => $data[$key]['veg'],
'status' => $data[$key]['status'],
'recommended' => $data[$key]['recommended'],
'module_id' => $data[$key]['module_id'],
'item_id' => $data[$key]['id'],
// 'slug' => null,
'tag_ids' => json_encode([]),
'nutrition_ids' => json_encode([]),
'allergy_ids' => json_encode([]),
'generic_ids' => json_encode([]),
'choice_options' => $data[$key]['choice_options'],
'updated_at' => now()
]);
}
}
$id = $collections->pluck('Id')->toArray();
if (Item::whereIn('id', $id)->doesntExist()) {
Toastr::error(translate('messages.Item_doesnt_exist_at_the_database'));
return back();
}
} catch (\Exception $e) {
info(["line___{$e->getLine()}", $e->getMessage()]);
Toastr::error($e->getMessage());
return back();
}
try {
DB::beginTransaction();
$chunkSize = 100;
if (count($temp_data) > 0) {
$message = translate('messages.Products_are_added_for_the_admin_approval');
$chunk_items = array_chunk($temp_data, $chunkSize);
foreach ($chunk_items as $key => $chunk_item) {
// DB::table('temp_products')->upsert($chunk_item,['item_id','module_id'],['name','description','image','images','category_id','category_ids','unit_id','stock','price','discount','discount_type','available_time_starts','available_time_ends','variations','food_variations','add_ons','attributes','store_id','status','veg','recommended' ,'tag_ids','choice_options']);
foreach ($chunk_item as $item) {
if (isset($item['id']) && DB::table('temp_products')->where('id', $item['id'])->exists()) {
DB::table('temp_products')->where('id', $item['id'])->update($item);
Helpers::updateStorageTable(get_class(new TempProduct), $item['id'], $item['image']);
} else {
$insertedId = DB::table('temp_products')->insertGetId($item);
Helpers::updateStorageTable(get_class(new TempProduct), $insertedId, $item['image']);
}
}
}
} else {
$chunk_items = array_chunk($data, $chunkSize);
foreach ($chunk_items as $key => $chunk_item) {
// DB::table('items')->upsert($chunk_item,['id','module_id'],['name','description','image','images','category_id','category_ids','unit_id','stock','price','discount','discount_type','available_time_starts','available_time_ends','variations','food_variations','add_ons','attributes','store_id','status','veg','recommended', 'updated_at','choice_options']);
foreach ($chunk_item as $item) {
if (isset($item['id']) && DB::table('items')->where('id', $item['id'])->exists()) {
DB::table('items')->where('id', $item['id'])->update($item);
Helpers::updateStorageTable(get_class(new Item), $item['id'], $item['image']);
} else {
$insertedId = DB::table('items')->insertGetId($item);
Helpers::updateStorageTable(get_class(new Item), $insertedId, $item['image']);
}
}
}
}
DB::commit();
} catch (\Exception $e) {
DB::rollBack();
info(["line___{$e->getLine()}", $e->getMessage()]);
Toastr::error($e->getMessage());
return back();
}
Toastr::success(count($data) . ' ' . $message);
return back();
}
public function bulk_export_index()
{
return view('vendor-views.product.bulk-export');
}
public function bulk_export_data(Request $request)
{
if (!Helpers::get_store_data()->item_section) {
Toastr::warning(translate('messages.permission_denied'));
return back();
}
$request->validate([
'type' => 'required',
'start_id' => 'required_if:type,id_wise',
'end_id' => 'required_if:type,id_wise',
'from_date' => 'required_if:type,date_wise',
'to_date' => 'required_if:type,date_wise'
]);
$products = Item::when($request['type'] == 'date_wise', function ($query) use ($request) {
$query->whereBetween('created_at', [$request['from_date'] . ' 00:00:00', $request['to_date'] . ' 23:59:59']);
})
->when($request['type'] == 'id_wise', function ($query) use ($request) {
$query->whereBetween('id', [$request['start_id'], $request['end_id']]);
})
->where('store_id', Helpers::get_store_id())
->get();
return (new FastExcel(ProductLogic::format_export_items(Helpers::Export_generator($products), Helpers::get_store_data()->module->module_type)))->download('Items.xlsx');
}
public function stock_limit_list(Request $request)
{
$category_id = $request->query('category_id', 'all');
$type = $request->query('type', 'all');
$items = Item::when(is_numeric($category_id), function ($query) use ($category_id) {
return $query->whereHas('category', function ($q) use ($category_id) {
return $q->whereId($category_id)->orWhere('parent_id', $category_id);
});
})
->type($type);
if (Helpers::get_store_data()->storeConfig?->minimum_stock_for_warning > 0) {
$items = $items->where('stock', '<=', Helpers::get_store_data()->storeConfig->minimum_stock_for_warning);
} else {
$items = $items->where('stock', 0);
}
$items = $items->orderby('stock')
->latest()->paginate(config('default_pagination'));
$category = $category_id != 'all' ? Category::findOrFail($category_id) : null;
return view('vendor-views.product.stock_limit_list', compact('items', 'category', 'type'));
}
public function get_variations(Request $request)
{
$product = Item::find($request['id']);
return response()->json([
'view' => view('vendor-views.product.partials._get_stock_data', compact('product'))->render()
]);
}
public function get_stock(Request $request)
{
$product = Item::withoutGlobalScope(StoreScope::class)->find($request['id']);
return response()->json([
'view' => view('vendor-views.product.partials._get_stock_data', compact('product'))->render()
]);
}
public function stock_update(Request $request)
{
$variations = [];
$stock_count = $request['current_stock'];
if ($request->has('type')) {
foreach ($request['type'] as $key => $str) {
$item = [];
$item['type'] = $str;
$item['price'] = abs($request['price_' . $key . '_' . str_replace('.', '_', $str)]);
$item['stock'] = abs($request['stock_' . $key . '_' . str_replace('.', '_', $str)]);
array_push($variations, $item);
}
}
$product = Item::find($request['product_id']);
$product->stock = $stock_count ?? 0;
$product->variations = json_encode($variations);
$product->save();
Toastr::success(translate("messages.Stock_updated_successfully"));
return back();
}
public function food_variation_generator(Request $request)
{
$validator = Validator::make($request->all(), [
'options' => 'required',
]);
$food_variations = [];
if (isset($request->options)) {
foreach (array_values($request->options) as $key => $option) {
$temp_variation['name'] = $option['name'];
$temp_variation['type'] = $option['type'];
$temp_variation['min'] = $option['min'] ?? 0;
$temp_variation['max'] = $option['max'] ?? 0;
$temp_variation['required'] = $option['required'] ?? 'off';
if ($option['min'] > 0 && $option['min'] > $option['max']) {
$validator->getMessageBag()->add('name', translate('messages.minimum_value_can_not_be_greater_then_maximum_value'));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
if (!isset($option['values'])) {
$validator->getMessageBag()->add('name', translate('messages.please_add_options_for') . $option['name']);
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
if ($option['max'] > count($option['values'])) {
$validator->getMessageBag()->add('name', translate('messages.please_add_more_options_or_change_the_max_value_for') . $option['name']);
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$temp_value = [];
foreach (array_values($option['values']) as $value) {
if (isset($value['label'])) {
$temp_option['label'] = $value['label'];
}
$temp_option['optionPrice'] = $value['optionPrice'];
array_push($temp_value, $temp_option);
}
$temp_variation['values'] = $temp_value;
array_push($food_variations, $temp_variation);
}
}
return response()->json([
'variation' => json_encode($food_variations)
]);
}
public function variation_generator(Request $request)
{
$validator = Validator::make($request->all(), [
'choice' => 'required',
]);
$choice_options = [];
if ($request->has('choice')) {
foreach ($request->choice_no as $key => $no) {
$str = 'choice_options_' . $no;
if ($request[$str][0] == null) {
$validator->getMessageBag()->add('name', translate('messages.attribute_choice_option_value_can_not_be_null'));
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$temp['name'] = 'choice_' . $no;
$temp['title'] = $request->choice[$key];
$temp['options'] = explode(',', implode('|', preg_replace('/\s+/', ' ', $request[$str])));
array_push($choice_options, $temp);
}
}
$variations = [];
$options = [];
if ($request->has('choice_no')) {
foreach ($request->choice_no as $key => $no) {
$name = 'choice_options_' . $no;
$my_str = implode('|', $request[$name]);
array_push($options, explode(',', $my_str));
}
}
//Generates the combinations of customer choice options
$combinations = Helpers::combinations($options);
if (count($combinations[0]) > 0) {
foreach ($combinations as $key => $combination) {
$str = '';
foreach ($combination as $k => $temp) {
if ($k > 0) {
$str .= '-' . str_replace(' ', '', $temp);
} else {
$str .= str_replace(' ', '', $temp);
}
}
$temp = [];
$temp['type'] = $str;
$temp['price'] = abs($request['price_' . str_replace('.', '_', $str)]);
$temp['stock'] = abs($request['stock_' . str_replace('.', '_', $str)]);
array_push($variations, $temp);
}
}
//combinations end
return response()->json([
'choice_options' => json_encode($choice_options),
'variation' => json_encode($variations),
'attributes' => $request->has('attribute_id') ? json_encode($request->attribute_id) : json_encode([])
]);
}
public function pending_item_list(Request $request)
{
abort_if(Helpers::get_mail_status('product_approval') != 1, 404);
$key = explode(' ', $request['search']);
$sub_category_id = $request->query('sub_category_id', 'all');
$category_id = $request->query('category_id', 'all');
$type = $request->query('type', 'all');
$items = TempProduct::when(is_numeric($category_id), function ($query) use ($category_id) {
return $query->whereHas('category', function ($q) use ($category_id) {
return $q->whereId($category_id)->orWhere('parent_id', $category_id);
});
})
->where('store_id', Helpers::get_store_id())
->when(isset($key), function ($q) use ($key) {
$q->where(function ($q) use ($key) {
foreach ($key as $value) {
$q->where('name', 'like', "%{$value}%");
}
});
})
->when(is_numeric($sub_category_id), function ($query) use ($sub_category_id) {
return $query->where('category_id', $sub_category_id);
})
->type($type)->latest()->paginate(config('default_pagination'));
$sub_categories = $category_id != 'all' ? Category::where('parent_id', $category_id)->get(['id', 'name']) : [];
$category = $category_id != 'all' ? Category::findOrFail($category_id) : null;
return view('vendor-views.product.pending_list', compact('items', 'category', 'type', 'sub_categories'));
}
public function requested_item_view($id)
{
$product = TempProduct::withoutGlobalScope('translate')->with(['translations', 'store', 'unit'])->findOrFail($id);
return view('vendor-views.product.requested_product_view', compact('product'));
}
public function store_temp_data($data, $request, $tag_ids, $nutrition_ids, $allergy_ids, $generic_ids, $update = null, $taxIds = null)
{
$temp_item = TempProduct::firstOrNew(
['item_id' => $data->id]
);
$old_img = $temp_item->image ?? null;
$temp_item->name = $request->name[array_search('default', $request->lang)];
$temp_item->description = $request->description[array_search('default', $request->lang)];
$temp_item->store_id = $data->store_id;
$temp_item->module_id = $data->module_id;
$temp_item->unit_id = $data->unit_id;
$temp_item->item_id = $data->id;
$temp_item->category_id = $data->category_id;
$temp_item->category_ids = $data->category_ids;
$temp_item->slug = $data->slug;
$temp_item->choice_options = $data->choice_options;
$temp_item->food_variations = $data->food_variations;
$temp_item->variations = $data->variations;
$temp_item->add_ons = $data->add_ons;
$temp_item->attributes = $data->attributes;
$temp_item->price = $data->price;
$temp_item->discount = $data->discount;
$temp_item->discount_type = $data->discount_type;
$temp_item->tag_ids = json_encode($tag_ids);
$temp_item->nutrition_ids = json_encode($nutrition_ids);
$temp_item->allergy_ids = json_encode($allergy_ids);
$temp_item->generic_ids = json_encode($generic_ids);
$temp_item->available_time_starts = $data->available_time_starts;
$temp_item->available_time_ends = $data->available_time_ends;
$temp_item->maximum_cart_quantity = $data->maximum_cart_quantity;
$temp_item->veg = $data->veg ?? 0;
$temp_item->organic = $data->organic ?? 0;
$temp_item->is_halal = $request->is_halal ?? 0;
$temp_item->basic = $data->basic ?? 0;
$temp_item->common_condition_id = $data->common_condition_id;
$temp_item->brand_id = $request->brand_id ?? 0;
$temp_item->stock = $data->stock ?? 0;
$module_type = Helpers::get_store_data()->module->module_type;
if ($module_type == 'pharmacy') {
$temp_item->common_condition_id = $request->condition_id ?? 0;
$temp_item->basic = $request->basic ?? 0;
}
if ($module_type == 'ecommerce') {
$temp_item->brand_id = $request->brand_id ?? 0;
}
if ($request->has('image')) {
if ($old_img) {
$temp_image_name = Helpers::update('product/', $old_img, 'png', $request->file('image'));
} else {
$temp_image_name = Helpers::upload('product/', 'png', $request->file('image'));
}
$temp_item->image = $temp_image_name;
} else {
$oldDisk = 'public';
if ($data->storage && count($data->storage) > 0) {
foreach ($data->storage as $value) {
if ($value['key'] == 'image') {
$oldDisk = $value['value'];
}
}
}
$oldPath = "product/{$data->image}";
$newFileName = Carbon::now()->toDateString() . "-" . uniqid() . ".png";
$newPath = "product/{$newFileName}";
$dir = 'product/';
$newDisk = Helpers::getDisk();
if (Storage::disk($oldDisk)->exists($oldPath)) {
if (!Storage::disk($newDisk)->exists($dir)) {
Storage::disk($newDisk)->makeDirectory($dir);
}
$fileContents = Storage::disk($oldDisk)->get($oldPath);
Storage::disk($newDisk)->put($newPath, $fileContents);
}
$temp_item->image = $newFileName;
}
$images = $request?->temp_product == 1 ? $temp_item->images ?? [] : $data->images ?? [];
if ($request->removedImageKeys) {
foreach ($images as $key => $value) {
if (in_array(is_array($value) ? $value['img'] : $value, explode(",", $request->removedImageKeys))) {
unset($images[$key]);
}
}
$images = array_values($images);
}
foreach ($images as $k => $value) {
$value = is_array($value) ? $value : ['img' => $value, 'storage' => 'public'];
$oldDisk = $value['storage'];
$oldPath = "product/{$value['img']}";
$newFileName = Carbon::now()->toDateString() . "-" . uniqid() . ".png";
$newPath = "product/{$newFileName}";
$dir = 'product/';
$newDisk = Helpers::getDisk();
try {
if (Storage::disk($oldDisk)->exists($oldPath)) {
if (!Storage::disk($newDisk)->exists($dir)) {
Storage::disk($newDisk)->makeDirectory($dir);
}
$fileContents = Storage::disk($oldDisk)->get($oldPath);
Storage::disk($newDisk)->put($newPath, $fileContents);
unset($images[$k]);
}
} catch (\Exception $e) {
}
$images[] = ['img' => $newFileName, 'storage' => Helpers::getDisk()];
}
$images = array_values($images);
if ($update) {
if ($request->has('item_images')) {
foreach ($request->item_images as $img) {
$image = Helpers::upload('product/', 'png', $img);
array_push($images, ['img' => $image, 'storage' => Helpers::getDisk()]);
}
}
}
$temp_item->images = $images;
if ($update) {
$temp_item->is_rejected = 0;
}
$temp_item->save();
if ($module_type == 'pharmacy') {
DB::table('pharmacy_item_details')
->updateOrInsert(
['temp_product_id' => $temp_item->id],
[
'common_condition_id' => $request->condition_id,
'is_basic' => $request->basic ?? 0,
'is_prescription_required' => $request->is_prescription_required ?? 0,
'item_id' => null
]
);
}
if ($module_type == 'ecommerce') {
DB::table('ecommerce_item_details')
->updateOrInsert(
['temp_product_id' => $temp_item->id],
[
'brand_id' => $request->brand_id,
'item_id' => null
]
);
}
if (addon_published_status('TaxModule')) {
$SystemTaxVat = \Modules\TaxModule\Entities\SystemTaxSetup::where('is_active', 1)->where('is_default', 1)->first();
if ($SystemTaxVat?->tax_type == 'product_wise') {
foreach ($taxIds ?? [] as $tax_id) {
\Modules\TaxModule\Entities\Taxable::create(
[
'taxable_type' => TempProduct::class,
'taxable_id' => $temp_item->id,
'system_tax_setup_id' => $SystemTaxVat->id,
'tax_id' => $tax_id
],
);
}
}
}
Helpers::add_or_update_translations(request: $request, key_data: 'name', name_field: 'name', model_name: 'TempProduct', data_id: $temp_item->id, data_value: $temp_item->name);
Helpers::add_or_update_translations(request: $request, key_data: 'description', name_field: 'description', model_name: 'TempProduct', data_id: $temp_item->id, data_value: $temp_item->description);
return true;
}
public function product_gallery(Request $request)
{
$key = explode(' ', $request['search']);
$category_id = $request->query('category_id', 'all');
$type = $request->query('type', 'all');
$settings = Helpers::get_mail_status('product_gallery');
$settings_access = Helpers::get_mail_status('access_all_products');
$items = Item::when($settings_access == 1, function ($q) {
$q->withoutGlobalScope(StoreScope::class);
})
->where('is_approved', 1)
->when(is_numeric($category_id), function ($query) use ($category_id) {
return $query->whereHas('category', function ($q) use ($category_id) {
return $q->whereId($category_id)->orWhere('parent_id', $category_id);
});
})
->when($request['search'], function ($query) use ($key) {
return $query->where(function ($q) use ($key) {
foreach ($key as $value) {
$q->where('name', 'like', "%{$value}%");
}
});
})
->type($type)
->inRandomOrder()
->module(Helpers::get_store_data()->module_id)
->limit(12)
->get();
$category = $category_id != 'all' ? Category::findOrFail($category_id) : null;
return view('vendor-views.product.product_gallery', compact('items', 'category', 'type'));
}
public function flash_sale(Request $request)
{
$key = explode(' ', $request['search']);
$items = FlashSaleItem::with('flashSale')
->wherehas('item', function ($q) {
$q->where('store_id', Helpers::get_store_id());
})
->when(isset($key), function ($q) use ($key) {
$q->whereHas('item', function ($q) use ($key) {
$q->where(function ($q) use ($key) {
foreach ($key as $value) {
$q->orWhere('name', 'like', "%{$value}%");
}
});
});
})
->paginate(config('default_pagination'));
return view('vendor-views.product.flash_sale.list', compact('items'));
}
}