| Server IP : 103.161.17.216 / Your IP : 216.73.216.1 Web Server : nginx/1.18.0 System : Linux tipsysaigoncharming 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 7.4.3-4ubuntu2.29 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /var/www/app.ansachsongkhoe.net/app/Http/Controllers/ |
Upload File : |
<?php
namespace App\Http\Controllers;
use App\TaxRate;
use App\GroupSubTax;
use Datatables;
use Illuminate\Http\Request;
class GroupTaxController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
if (request()->ajax()) {
$business_id = request()->session()->get('user.business_id');
$tax_rates = TaxRate::where('business_id', $business_id)
->where('is_tax_group', '1')
->with(['sub_taxes']);
return Datatables::of($tax_rates)
->addColumn(
'action',
'<button data-href="{{action(\'GroupTaxController@edit\', [$id])}}" class="btn btn-xs btn-primary btn-modal" data-container=".tax_group_modal"><i class="glyphicon glyphicon-edit"></i> @lang("messages.edit")</button>
<button data-href="{{action(\'GroupTaxController@destroy\', [$id])}}" class="btn btn-xs btn-danger delete_tax_group_button"><i class="glyphicon glyphicon-trash"></i> @lang("messages.delete")</button>'
)
->editColumn('amount', '{{@num_format($amount)}}')
->editColumn('sub_taxes', function ($row) {
$sub_taxes = [];
foreach ($row->sub_taxes as $sub_tax) {
$sub_taxes[] = $sub_tax->name;
}
return implode(' + ', $sub_taxes);
})
->removeColumn('id')
->rawColumns(['action'])
->make(true);
}
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
$business_id = request()->session()->get('user.business_id');
$taxes = TaxRate::where('business_id', $business_id)->where('is_tax_group', '0')->pluck('name', 'id');
return view('tax_group.create')
->with(compact('taxes'));
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
try {
$input['name'] = $request->input('name');
$input['business_id'] = $request->session()->get('user.business_id');
$input['created_by'] = $request->session()->get('user.id');
$sub_tax_ids = $request->input('taxes');
$sub_taxes = TaxRate::whereIn('id', $sub_tax_ids)->get();
$amount = 0;
foreach ($sub_taxes as $sub_tax) {
$amount += $sub_tax->amount ;
}
$input['amount'] = $amount;
$input['is_tax_group'] = 1;
$tax_rate = TaxRate::create($input);
$tax_rate->sub_taxes()->sync($sub_tax_ids);
$output = ['success' => true,
'msg' => __("tax_rate.tax_group_added_success")
];
} catch (\Exception $e) {
\Log::emergency("File:" . $e->getFile(). "Line:" . $e->getLine(). "Message:" . $e->getMessage());
$output = ['success' => false,
'msg' => __("messages.something_went_wrong")
];
}
return $output;
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id)
{
//
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
if (request()->ajax()) {
$business_id = request()->session()->get('user.business_id');
$tax_rate = TaxRate::where('business_id', $business_id)->with(['sub_taxes'])->find($id);
$taxes = TaxRate::where('business_id', $business_id)->where('is_tax_group', '0')->pluck('name', 'id');
$sub_taxes = [];
foreach ($tax_rate->sub_taxes as $sub_tax) {
$sub_taxes[] = $sub_tax->id;
}
return view('tax_group.edit')
->with(compact('taxes', 'sub_taxes', 'tax_rate'));
}
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id)
{
if (request()->ajax()) {
try {
$business_id = $request->session()->get('user.business_id');
$sub_tax_ids = $request->input('taxes');
$sub_taxes = TaxRate::whereIn('id', $sub_tax_ids)->get();
$amount = 0;
foreach ($sub_taxes as $sub_tax) {
$amount += $sub_tax->amount ;
}
$tax_rate = TaxRate::where('business_id', $business_id)->findOrFail($id);
$tax_rate->name = $request->input('name');
$tax_rate->amount = $amount;
$tax_rate->save();
$tax_rate->sub_taxes()->sync($sub_tax_ids);
$output = ['success' => true,
'msg' => __("tax_rate.tax_group_updated_success")
];
} catch (\Exception $e) {
\Log::emergency("File:" . $e->getFile(). "Line:" . $e->getLine(). "Message:" . $e->getMessage());
$output = ['success' => false,
'msg' => __("messages.something_went_wrong")
];
}
return $output;
}
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
if (request()->ajax()) {
try {
$business_id = request()->user()->business_id;
$tax_rate = TaxRate::where('business_id', $business_id)->findOrFail($id);
$tax_rate->delete();
$output = ['success' => true,
'msg' => __("tax_rate.deleted_success")
];
} catch (\Exception $e) {
\Log::emergency("File:" . $e->getFile(). "Line:" . $e->getLine(). "Message:" . $e->getMessage());
$output = ['success' => false,
'msg' => __("messages.something_went_wrong")
];
}
return $output;
}
}
}