You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

565 lines
23 KiB

<?php
namespace App\Http\Controllers\Admin;
use Carbon\Carbon;
use App\Models\Campaign;
use App\Models\Restaurant;
use App\Models\Translation;
use Illuminate\Support\Str;
use App\Models\ItemCampaign;
use Illuminate\Http\Request;
use App\CentralLogics\Helpers;
use App\Http\Controllers\Controller;
use Brian2694\Toastr\Facades\Toastr;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Facades\Validator;
class CampaignController extends Controller
{
function index($type)
{
return view('admin-views.campaign.'.$type.'.index');
}
function list($type)
{
if($type=='basic')
{
$campaigns=Campaign::latest()->paginate(config('default_pagination'));
}
else{
$campaigns=ItemCampaign::latest()->paginate(config('default_pagination'));
}
return view('admin-views.campaign.'.$type.'.list', compact('campaigns'));
}
public function storeBasic(Request $request)
{
$validator = Validator::make($request->all(), [
'title' => 'required|unique:campaigns|max:191',
'description'=>'max:1000',
'image' => 'required|max:2048',
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$campaign = new Campaign;
$campaign->title = $request->title[array_search('en', $request->lang)];
$campaign->description = $request->description[array_search('en', $request->lang)];
$campaign->image = Helpers::upload('campaign/', 'png', $request->file('image'));
$campaign->start_date = $request->start_date;
$campaign->end_date = $request->end_date;
$campaign->start_time = $request->start_time;
$campaign->end_time = $request->end_time;
$campaign->save();
$data = [];
foreach ($request->lang as $index => $key) {
if ($request->title[$index] && $key != 'en') {
array_push($data, array(
'translationable_type' => 'App\Models\Campaign',
'translationable_id' => $campaign->id,
'locale' => $key,
'key' => 'title',
'value' => $request->title[$index],
));
}
if ($request->description[$index] && $key != 'en') {
array_push($data, array(
'translationable_type' => 'App\Models\Campaign',
'translationable_id' => $campaign->id,
'locale' => $key,
'key' => 'description',
'value' => $request->description[$index],
));
}
}
Translation::insert($data);
return response()->json([], 200);
}
public function update(Request $request, Campaign $campaign)
{
$validator = Validator::make($request->all(),[
'title' => 'required|max:191',
'description' => 'max:1000',
'image' => 'nullable|max:2048',
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$campaign->title = $request->title[array_search('en', $request->lang)];
$campaign->description = $request->description[array_search('en', $request->lang)];
$campaign->image = $request->has('image') ? Helpers::update('campaign/', $campaign->image, 'png', $request->file('image')) : $campaign->image;;
$campaign->start_date = $request->start_date;
$campaign->end_date = $request->end_date;
$campaign->start_time = $request->start_time;
$campaign->end_time = $request->end_time;
$campaign->save();
foreach ($request->lang as $index => $key) {
if ($request->title[$index] && $key != 'en') {
Translation::updateOrInsert(
['translationable_type' => 'App\Models\Campaign',
'translationable_id' => $campaign->id,
'locale' => $key,
'key' => 'title'],
['value' => $request->title[$index]]
);
}
if ($request->description[$index] && $key != 'en') {
Translation::updateOrInsert(
['translationable_type' => 'App\Models\Campaign',
'translationable_id' => $campaign->id,
'locale' => $key,
'key' => 'description'],
['value' => $request->description[$index]]
);
}
}
return response()->json([], 200);
}
public function storeItem(Request $request)
{
$validator = Validator::make($request->all(), [
'title' => 'required|max:191|unique:item_campaigns',
'image' => 'required|max:2048',
'category_id' => 'required',
'price' => 'required|numeric|between:0.01,999999999999.99',
'restaurant_id' => 'required',
'start_time' => 'required',
'end_time' => 'required',
'start_date' => 'required',
'start_date' => 'required',
'veg' => 'required',
'description'=>'max:1000'
], [
'category_id.required' => translate('messages.select_category'),
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
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)]);
}
$campaign = new ItemCampaign;
$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,
]);
}
$campaign->category_ids = json_encode($category);
$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);
}
}
$campaign->choice_options = json_encode($choice_options);
$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($variations,$temp_variation);
}
}
$slug = Str::slug($request->title[array_search('en', $request->lang)]);
$campaign->slug = $campaign->slug? $campaign->slug :"{$slug}{$campaign->id}";
$campaign->admin_id = auth('admin')->id();
$campaign->title = $request->title[array_search('en', $request->lang)];
$campaign->description = $request->description[array_search('en', $request->lang)];
$campaign->image = Helpers::upload('campaign/', 'png', $request->file('image'));
$campaign->start_date = $request->start_date;
$campaign->end_date = $request->end_date;
$campaign->start_time = $request->start_time;
$campaign->end_time = $request->end_time;
$campaign->variations = json_encode($variations);
$campaign->price = $request->price;
$campaign->discount = $request->discount_type == 'amount' ? $request->discount : $request->discount;
$campaign->discount_type = $request->discount_type;
$campaign->attributes = $request->has('attribute_id') ? json_encode($request->attribute_id) : json_encode([]);
$campaign->add_ons = $request->has('addon_ids') ? json_encode($request->addon_ids) : json_encode([]);
$campaign->restaurant_id = $request->restaurant_id;
$campaign->veg = $request->veg;
$campaign->save();
$data = [];
foreach ($request->lang as $index => $key) {
if ($request->title[$index] && $key != 'en') {
array_push($data, array(
'translationable_type' => 'App\Models\ItemCampaign',
'translationable_id' => $p->id,
'locale' => $key,
'key' => 'title',
'value' => $request->title[$index],
));
}
if ($request->description[$index] && $key != 'en') {
array_push($data, array(
'translationable_type' => 'App\Models\ItemCampaign',
'translationable_id' => $p->id,
'locale' => $key,
'key' => 'description',
'value' => $request->description[$index],
));
}
}
Translation::insert($data);
return response()->json([], 200);
}
public function updateItem(ItemCampaign $campaign, Request $request)
{
$validator = Validator::make($request->all(), [
'title' => 'required|array',
'category_id' => 'required',
'price' => 'required|numeric|between:0.01,999999999999.99',
'restaurant_id' => 'required',
'veg' => 'required',
'image' => 'nullable|max:2048',
'description.*'=>'max:1000',
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
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)]);
}
$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,
]);
}
$campaign->category_ids = json_encode($category);
$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);
}
}
$campaign->choice_options = json_encode($choice_options);
$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($variations,$temp_variation);
}
}
$campaign->title = $request->title[array_search('en', $request->lang)];
$campaign->description = $request->description[array_search('en', $request->lang)];
$campaign->image = $request->has('image') ? Helpers::update('campaign/', $campaign->image, 'png', $request->file('image')) : $campaign->image;
$campaign->start_date = $request->start_date;
$campaign->end_date = $request->end_date;
$campaign->start_time = $request->start_time;
$campaign->end_time = $request->end_time;
$campaign->restaurant_id = $request->restaurant_id;
$campaign->variations = json_encode($variations);
$campaign->price = $request->price;
$campaign->discount = $request->discount_type == 'amount' ? $request->discount : $request->discount;
$campaign->discount_type = $request->discount_type;
$campaign->attributes = $request->has('attribute_id') ? json_encode($request->attribute_id) : json_encode([]);
$campaign->add_ons = $request->has('addon_ids') ? json_encode($request->addon_ids) : json_encode([]);
$campaign->veg = $request->veg;
$campaign->save();
foreach ($request->lang as $index => $key) {
if ($request->title[$index] && $key != 'en') {
Translation::updateOrInsert(
['translationable_type' => 'App\Models\ItemCampaign',
'translationable_id' => $campaign->id,
'locale' => $key,
'key' => 'title'],
['value' => $request->title[$index]]
);
}
if ($request->description[$index] && $key != 'en') {
Translation::updateOrInsert(
['translationable_type' => 'App\Models\ItemCampaign',
'translationable_id' => $campaign->id,
'locale' => $key,
'key' => 'description'],
['value' => $request->description[$index]]
);
}
}
return response()->json([], 200);
}
public function edit($type, $campaign)
{
if($type=='basic')
{
$campaign = Campaign::withoutGlobalScope('translate')->findOrFail($campaign);
}
else
{
$campaign = ItemCampaign::withoutGlobalScope('translate')->findOrFail($campaign);
}
return view('admin-views.campaign.'.$type.'.edit', compact('campaign'));
}
public function view(Request $request ,$type, $campaign)
{
if($type=='basic')
{
$campaign = Campaign::findOrFail($campaign);
$key = explode(' ', $request['search']);
$restaurants = $campaign->restaurants()
->when(isset($key) ,function ($q) use ($key) {
foreach ($key as $value) {
$q->where('name', 'like', "%{$value}%");
// ->orWhere('email', 'like', "%{$value}%");
}
})->paginate(config('default_pagination'));
$restaurant_ids = [];
foreach($campaign->restaurants as $restaurant)
{
$restaurant_ids[] = $restaurant->id;
}
return view('admin-views.campaign.basic.view', compact('campaign', 'restaurants', 'restaurant_ids'));
}
else
{
$campaign = ItemCampaign::findOrFail($campaign);
}
return view('admin-views.campaign.item.view', compact('campaign'));
}
public function status($type, $id, $status)
{
if($type=='item')
{
$campaign = ItemCampaign::findOrFail($id);
}
else{
$campaign = Campaign::findOrFail($id);
}
$campaign->status = $status;
$campaign->save();
Toastr::success(translate('messages.campaign_status_updated'));
return back();
}
public function delete(Campaign $campaign)
{
if (Storage::disk('public')->exists('campaign/' . $campaign->image)) {
Storage::disk('public')->delete('campaign/' . $campaign->image);
}
$campaign->translations()->delete();
$campaign->delete();
Toastr::success(translate('messages.campaign_deleted_successfully'));
return back();
}
public function delete_item(ItemCampaign $campaign)
{
if (Storage::disk('public')->exists('campaign/' . $campaign->image)) {
Storage::disk('public')->delete('campaign/' . $campaign->image);
}
$campaign->translations()->delete();
$campaign->delete();
Toastr::success(translate('messages.campaign_deleted_successfully'));
return back();
}
public function remove_restaurant(Campaign $campaign, $restaurant)
{
$campaign->restaurants()->detach($restaurant);
$campaign->save();
Toastr::success(translate('messages.restaurant_remove_from_campaign'));
return back();
}
public function addrestaurant(Request $request, Campaign $campaign)
{
$campaign->restaurants()->attach($request->restaurant_id,['campaign_status' => 'confirmed']);
$campaign->save();
Toastr::success(translate('messages.restaurant_added_to_campaign'));
return back();
}
public function restaurant_confirmation($campaign,$restaurant_id,$status)
{
$campaign = Campaign::findOrFail($campaign);
$campaign->restaurants()->updateExistingPivot($restaurant_id,['campaign_status' => $status]);
$campaign->save();
Toastr::success(translate('messages.restaurant_added_to_campaign'));
return back();
}
public function searchBasic(Request $request){
$key = explode(' ', $request['search']);
$campaigns=Campaign::where(function ($q) use ($key) {
foreach ($key as $value) {
$q->orWhere('title', 'like', "%{$value}%");
}
})->limit(50)->get();
return response()->json([
'view'=>view('admin-views.campaign.basic.partials._table',compact('campaigns'))->render(),
'count'=>$campaigns->count()
]);
}
public function searchItem(Request $request){
$key = explode(' ', $request['search']);
$campaigns=ItemCampaign::where(function ($q) use ($key) {
foreach ($key as $value) {
$q->orWhere('title', 'like', "%{$value}%");
}
})->limit(50)->get();
return response()->json([
'view'=>view('admin-views.campaign.item.partials._table',compact('campaigns'))->render()
]);
}
}