| 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\InvoiceScheme;
use App\InvoiceLayout;
use Illuminate\Http\Request;
use Datatables;
class InvoiceSchemeController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
if (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
$business_id = request()->session()->get('user.business_id');
if (request()->ajax()) {
$schemes = InvoiceScheme::where('business_id', $business_id)
->select(['id', 'name', 'scheme_type', 'prefix', 'start_number', 'invoice_count', 'total_digits', 'is_default']);
return Datatables::of($schemes)
->addColumn(
'action',
'<button type="button" data-href="{{action(\'InvoiceSchemeController@edit\', [$id])}}" class="btn btn-xs btn-primary btn-modal" data-container=".invoice_edit_modal"><i class="glyphicon glyphicon-edit"></i> @lang("messages.edit")</button>
<button type="button" data-href="{{action(\'InvoiceSchemeController@destroy\', [$id])}}" class="btn btn-xs btn-danger delete_invoice_button" @if($is_default) disabled @endif><i class="glyphicon glyphicon-trash"></i> @lang("messages.delete")</button>
@if($is_default)
<button type="button" class="btn btn-xs btn-success" disabled><i class="fa fa-check-square-o" aria-hidden="true"></i> @lang("barcode.default")</button>
@else
<button class="btn btn-xs btn-info set_default_invoice" data-href="{{action(\'InvoiceSchemeController@setDefault\', [$id])}}">@lang("barcode.set_as_default")</button>
@endif
'
)
->editColumn('prefix', function ($row) {
if ($row->scheme_type == 'year') {
return $row->prefix.date('Y') . config('constants.invoice_scheme_separator');
} else {
return $row->prefix;
}
})
->editColumn('name', function ($row) {
if ($row->is_default == 1) {
return $row->name . ' <span class="label label-success">' . __("barcode.default") .'</span>' ;
} else {
return $row->name ;
}
})
->removeColumn('id')
->removeColumn('is_default')
->removeColumn('scheme_type')
->rawColumns([5,0])
->make(false);
}
$invoice_layouts = InvoiceLayout::where('business_id', $business_id)
->with(['locations'])
->get();
return view('invoice_scheme.index')
->with(compact('invoice_layouts'));
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
if (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
return view('invoice_scheme.create');
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
if (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
try {
$input = $request->only(['name', 'scheme_type', 'prefix', 'start_number', 'total_digits']);
$business_id = $request->session()->get('user.business_id');
$input['business_id'] = $business_id;
if (!empty($request->input('is_default'))) {
//get_default
$default = InvoiceScheme::where('business_id', $business_id)
->where('is_default', 1)
->update(['is_default' => 0 ]);
$input['is_default'] = 1;
}
InvoiceScheme::create($input);
$output = ['success' => true,
'msg' => __("invoice.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)
{
if (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
//
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
if (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
$business_id = request()->session()->get('user.business_id');
$invoice = InvoiceScheme::where('business_id', $business_id)->find($id);
return view('invoice_scheme.edit')
->with(compact('invoice'));
}
/**
* 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 (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
try {
$input = $request->only(['name', 'scheme_type', 'prefix', 'start_number', 'total_digits']);
$invoice = InvoiceScheme::where('id', $id)->update($input);
$output = ['success' => true,
'msg' => __('invoice.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 (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
if (request()->ajax()) {
try {
$invoice = InvoiceScheme::find($id);
if ($invoice->is_default != 1) {
$invoice->delete();
$output = ['success' => true,
'msg' => __("invoice.deleted_success")
];
} else {
$output = ['success' => false,
'msg' => __("messages.something_went_wrong")
];
}
} catch (\Exception $e) {
\Log::emergency("File:" . $e->getFile(). "Line:" . $e->getLine(). "Message:" . $e->getMessage());
$output = ['success' => false,
'msg' => __("messages.something_went_wrong")
];
}
return $output;
}
}
/**
* Sets invoice scheme setting as default
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function setDefault($id)
{
if (!auth()->user()->can('invoice_settings.access')) {
abort(403, 'Unauthorized action.');
}
if (request()->ajax()) {
try {
//get_default
$business_id = request()->session()->get('user.business_id');
$default = InvoiceScheme::where('business_id', $business_id)
->where('is_default', 1)
->update(['is_default' => 0 ]);
$invoice = InvoiceScheme::find($id);
$invoice->is_default = 1;
$invoice->save();
$output = ['success' => true,
'msg' => __("barcode.default_set_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;
}
}
}