Compare commits

...

1 Commits

Author SHA1 Message Date
Zelda Ababil 3ab49230f3 nonprint 2024-03-05 12:43:24 +07:00
6 changed files with 381 additions and 62 deletions

View File

@ -31,9 +31,9 @@ class CreateRoutePermissionCommand extends Command
$routes = Route::getRoutes()->getRoutesByName(); $routes = Route::getRoutes()->getRoutesByName();
// dd($routes); // dd($routes);
foreach ($routes as $route) { foreach ($routes as $route) {
try {
if ($route->getName() != '' && count($route->getAction()['middleware']) >= 2) { if ($route->getName() != '' && count($route->getAction()['middleware']) >= 2) {
$permission = Permission::where('name', $route->getName())->first(); $permission = Permission::where('name', $route->getName())->first();
$data = $route->getName(); $data = $route->getName();
[$first_group] = explode('.', $data); [$first_group] = explode('.', $data);
$comment = $route->getComment(); $comment = $route->getComment();
@ -44,6 +44,11 @@ class CreateRoutePermissionCommand extends Command
permission::create(['name' => $data, 'group_name' => $first_group, 'desc' => $comment]); permission::create(['name' => $data, 'group_name' => $first_group, 'desc' => $comment]);
$this->info('Permission routes ' . $route->getName() . ' added successfully.'); $this->info('Permission routes ' . $route->getName() . ' added successfully.');
} }
} else {
$this->info('Permission routes ' . $route->getName() . ' not added.');
}
} catch (\Throwable $th) {
$this->info('Permission routes ' . $route->getName() . ' not added.');
} }
} }

View File

@ -9,6 +9,7 @@ use App\Models\RekeningCoa;
use Carbon\Carbon; use Carbon\Carbon;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Session;
class PenjualanController extends Controller class PenjualanController extends Controller
{ {
@ -26,7 +27,7 @@ class PenjualanController extends Controller
$filter_tanggal_2 = $request->filter_tanggal_2; $filter_tanggal_2 = $request->filter_tanggal_2;
$akun_coa = $request->akun_coa; $akun_coa = $request->akun_coa;
if ($request->akun_coa == null) { if ($request->akun_coa == null) {
$data = Pesanan::with(['detailPesanan', 'user', 'rekening_coa']) $data = Pesanan::with(['detailPesanan', 'user'])
->when($filter_tanggal_1, function ($query) use ($filter_tanggal_1) { ->when($filter_tanggal_1, function ($query) use ($filter_tanggal_1) {
return $query->whereDate('tanggal_pesanan', '>=', $filter_tanggal_1); return $query->whereDate('tanggal_pesanan', '>=', $filter_tanggal_1);
}) })
@ -76,7 +77,7 @@ class PenjualanController extends Controller
return 'Rp ' . number_format($data->grand_total, 0, ',', '.'); return 'Rp ' . number_format($data->grand_total, 0, ',', '.');
}) })
->addColumn('jenis_pembayarannya', function ($data) { ->addColumn('jenis_pembayarannya', function ($data) {
return $data->jenis_pembayaran == 1 ? 'Tunai' : 'Non-Tunai' . ' (' . $data->rekening_coa->keterangan_coa . ')'; return $data->jenis_pembayaran == 1 ? 'Tunai' : ($data->jenis_pembayaran == null ? 'Tunai' : 'Non-Tunai' . ' (' . ($data->rekening_coa?->keterangan_coa ?? '') . ')');
}) })
->addColumn('ubah', function ($data) { ->addColumn('ubah', function ($data) {
return '<div class="btn-group"> return '<div class="btn-group">
@ -103,6 +104,7 @@ class PenjualanController extends Controller
public function laporan(Request $request) public function laporan(Request $request)
{ {
try {
$mpdf = new \Mpdf\Mpdf([ $mpdf = new \Mpdf\Mpdf([
'mode' => 'utf-8', 'mode' => 'utf-8',
'format' => 'A4', 'format' => 'A4',
@ -116,7 +118,6 @@ class PenjualanController extends Controller
]); ]);
$mpdf->AddPage(); $mpdf->AddPage();
$mpdf->setFooter('{PAGENO}'); $mpdf->setFooter('{PAGENO}');
$filter_tanggal_1 = $request->filter_tanggal_1; $filter_tanggal_1 = $request->filter_tanggal_1;
$filter_tanggal_2 = $request->filter_tanggal_2; $filter_tanggal_2 = $request->filter_tanggal_2;
if ($request->jenis_coa == null) { if ($request->jenis_coa == null) {
@ -131,16 +132,33 @@ class PenjualanController extends Controller
->get(); ->get();
} }
$html = view('pages.admin.penjualan.laporan', [ $alldata = [
'data' => $data, 'data' => $data,
'filter_tanggal_1' => $filter_tanggal_1, 'filter_tanggal_1' => $filter_tanggal_1,
'filter_tanggal_2' => $filter_tanggal_2, 'filter_tanggal_2' => $filter_tanggal_2,
'keterangan_coa' => $keterangan_coa 'keterangan_coa' => $keterangan_coa
]); ];
$html = view('pages.admin.penjualan.laporan', $alldata);
// $html->render();
// $mpdf->WriteHTML($html);
// $mpdf->chunkLoadView('<html-separator/>', 'pages.admin.penjualan.laporan', $alldata);
// return $mpdf->stream('document.pdf');
$chunks = explode("chunk", (string)$html);
foreach ($chunks as $key => $val) {
// $mpdf->WriteHTML($val);
}
$mpdf->writeHTML($html); $mpdf->writeHTML($html);
$mpdf->Output('Laporan_Penjualan.pdf', 'I'); $mpdf->Output('Laporan_Penjualan.pdf', 'I');
return response()->header('Content-Type', 'application/pdf'); return response()->header('Content-Type', 'application/pdf');
} catch (\Throwable $th) {
Session::flash('errors', 'Gagal membuat laporan, coba lagi dengan rentang tanggal yang lebih pendek');
return redirect()->back();
//throw $th;
}
} }
public function cancel(Request $request) public function cancel(Request $request)

View File

@ -0,0 +1,180 @@
<?php
namespace App\Http\Controllers\Admins\PerangkatPrinter;
use App\Helpers\ResponseFormatter;
use App\Http\Controllers\Controller;
use App\Models\PerangkatPrinter;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Validator;
use Mpdf\Tag\Q;
class PerangkatPrinterController extends Controller
{
public function index()
{
return view('pages.admin.perangkat_printer.index');
}
public function getDataPrinter()
{
$data = PerangkatPrinter::get();
return datatables()->of($data)
->addColumn('status_printer', function ($data) {
if ($data->status == '1') {
return '<span class="badge badge-success">Aktif</span>';
} else {
return '<span class="badge badge-danger">Tidak Aktif</span>';
}
})
->addColumn('action', function ($data) {
return '
<button class="btn btn-sm btn-warning btn-edit-printer" data-printer=' . $data . '><i class="fas fa-edit"></i></button>
<button class="btn btn-sm btn-danger btn-hapus-printer" data-printer=' . $data . '><i class="fas fa-trash"></i></button>
';
})
->rawColumns(['action' => 'action', 'status_printer' => 'status_printer'])
->addIndexColumn()
->make(true);
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request)
{
// validation
$validator = Validator::make($request->all(), [
'printer_nama' => 'required',
'printer_mm' => 'required',
'printer_for' => 'required',
], [
'printer_nama.required' => 'Nama tidak boleh kosong!',
'printer_mm.required' => 'Ukuran kertas printer tidak boleh kosong!',
'printer_for.required' => 'Printer digunakan untuk tidak boleh kosong!',
]);
// check validation
if ($validator->fails()) {
return ResponseFormatter::error($validator->errors()->first());
}
try {
DB::beginTransaction();
if ($request->printer_status != 'on' || $request->printer_status == null) {
$status = '0';
} else {
$status = '1';
}
// create new account
$printer = PerangkatPrinter::create([
'nama_printer' => $request->printer_nama,
'printer_connection' => $request->printer_connection,
'ip_address' => $request->ip_address,
'printer_mm' => $request->printer_mm,
'printer_for' => $request->printer_for,
'status' => $status,
]);
DB::commit();
return ResponseFormatter::success($printer, "Printer berhasil ditambahkan");
} catch (\Throwable $th) {
DB::rollBack();
return ResponseFormatter::error($th->getMessage());
}
}
/**
* Display the specified resource.
*/
public function show(string $id)
{
//
}
/**
* Show the form for editing the specified resource.
*/
public function edit(string $id)
{
// get data from printer
$printer = PerangkatPrinter::findOrFail($id);
return ResponseFormatter::success([
'printer' => $printer
]);
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, string $id)
{
// validation
$validator = Validator::make($request->all(), [
'printer_nama_edit' => 'required',
'printer_mm_edit' => 'required',
'printer_for_edit' => 'required',
], [
'printer_nama_edit.required' => 'Nama tidak boleh kosong!',
'printer_mm_edit.required' => 'Ukuran kertas printer tidak boleh kosong!',
'printer_for_edit.required' => 'Printer digunakan untuk tidak boleh kosong!'
]);
// check validation
if ($validator->fails()) {
return ResponseFormatter::error($validator->errors()->first());
}
try {
DB::beginTransaction();
if ($request->printer_status_edit != 'on' || $request->printer_status_edit == null) {
$status = '0';
} else {
$status = '1';
}
// create new account
$printer = PerangkatPrinter::findOrFail($id);
$printer->update([
'nama_printer' => $request->printer_nama_edit,
'printer_connection' => $request->printer_connection,
'ip_address' => $request->ip_address,
'printer_mm' => $request->printer_mm_edit,
'printer_for' => $request->printer_for_edit,
'status' => $status,
]);
DB::commit();
return ResponseFormatter::success($printer, "Printer berhasil diubah");
} catch (\Throwable $th) {
DB::rollBack();
return ResponseFormatter::error($th->getMessage());
}
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
// get data from printer
$printer = PerangkatPrinter::findOrFail($id);
// check printer
if (!$printer) {
return ResponseFormatter::error("Data printer tidak ditemukan!");
}
// delete printer
$printer->delete();
return ResponseFormatter::success(null, "Printer berhasil dihapus!");
}
}

View File

@ -16,11 +16,12 @@ class Menu extends Controller
public function index() public function index()
{ {
$kategori_produks = KategoriProduk::get(); $kategori_produks = KategoriProduk::get();
$kelompok_kategoris = KelompokKategori::get();
return view('pages.Menu.index', compact('kategori_produks')); return view('pages.Menu.index', compact('kategori_produks', 'kelompok_kategoris'));
} }
public function kelompokKategori($id) { public function kelompokKategori($id)
{
$kelompok_kategoris = KelompokKategori::where('kategori_produk_id', $id)->get(); $kelompok_kategoris = KelompokKategori::where('kategori_produk_id', $id)->get();
if (empty($kelompok_kategoris[0])) { if (empty($kelompok_kategoris[0])) {
@ -28,13 +29,23 @@ class Menu extends Controller
} else { } else {
return $kelompok_kategoris; return $kelompok_kategoris;
} }
} }
public function getDataMenu() public function getDataMenu(Request $request)
{ {
// $data = Produk::with(['kategori_produk'])->get(); // $data = Produk::with(['kategori_produk'])->get();
$data = KelompokKategoriPivot::with(['kelompokKategori', 'produk'])->get(); $data = KelompokKategoriPivot::with(['kelompokKategori', 'produk'])->get();
$kelompok_kategori_id = $request->kelompok_produk;
if ($kelompok_kategori_id == null || $kelompok_kategori_id == 0) {
$data = KelompokKategoriPivot::with(['kelompokKategori', 'produk'])->get();
} else {
$data = KelompokKategoriPivot::with(['kelompokKategori', 'produk'])
->where('kelompok_kategori_id', $kelompok_kategori_id)
->get();
}
$nomor = 1; $nomor = 1;
return $datatables = datatables() return $datatables = datatables()
@ -69,7 +80,8 @@ class Menu extends Controller
} }
// Tambah Menu // Tambah Menu
public function store(Request $request) { public function store(Request $request)
{
// validation // validation
$rules = array( $rules = array(
'kategori_produk' => 'required', 'kategori_produk' => 'required',
@ -80,6 +92,11 @@ class Menu extends Controller
'tersedia' => 'required', 'tersedia' => 'required',
'deskripsi_produk' => 'required', 'deskripsi_produk' => 'required',
); );
if ($request->kelompok_produk == 9) {
$rules = array(
'promodatetime' => 'required',
);
}
$validator = Validator::make($request->all(), $rules); $validator = Validator::make($request->all(), $rules);
// check validation // check validation
@ -87,6 +104,22 @@ class Menu extends Controller
// If validation fails, return with errors // If validation fails, return with errors
return response()->json(['errors' => $validator->errors()], 422); return response()->json(['errors' => $validator->errors()], 422);
} else { } else {
if ($request->kelompok_produk == 9) {
// date promo 02/27/2024 12:00 AM - 03/30/2024 11:00 PM
$tanggal_array = explode(" - ", $request->promodatetime);
$tanggal_awal_string = $tanggal_array[0];
$tanggal_akhir_string = $tanggal_array[1];
// Konversi string tanggal menjadi objek Carbon
$tanggal_awal = Carbon::createFromFormat('m/d/Y h:i A', $tanggal_awal_string);
$tanggal_akhir = Carbon::createFromFormat('m/d/Y h:i A', $tanggal_akhir_string);
// Mendapatkan tanggal dan waktu awal serta akhir
$tgl_start_promo = $tanggal_awal->toDateTimeString();
$tgl_end_promo = $tanggal_akhir->toDateTimeString();
}
// create product // create product
$produk = Produk::create([ $produk = Produk::create([
'kategori_produk_id' => $request->kategori_produk, 'kategori_produk_id' => $request->kategori_produk,
@ -95,6 +128,9 @@ class Menu extends Controller
'harga_produk' => $request->harga_produk, 'harga_produk' => $request->harga_produk,
'tersedia' => $request->tersedia, 'tersedia' => $request->tersedia,
'deskripsi_produk' => $request->deskripsi_produk, 'deskripsi_produk' => $request->deskripsi_produk,
'stok_promo' => $request->stok_promo,
'tgl_start_promo' => $tgl_start_promo,
'tgl_end_promo' => $tgl_end_promo,
'created_at' => Carbon::now() 'created_at' => Carbon::now()
]); ]);
@ -109,13 +145,15 @@ class Menu extends Controller
} }
} }
public function show($id) { public function show($id)
{
$data = KelompokKategoriPivot::with(['kelompokKategori', 'produk'])->findOrFail($id); $data = KelompokKategoriPivot::with(['kelompokKategori', 'produk'])->findOrFail($id);
return response()->json($data); return response()->json($data);
} }
// Ubah Menu // Ubah Menu
public function update(Request $request, $id) { public function update(Request $request, $id)
{
// validation // validation
$rules = array( $rules = array(
'kategori_produk' => 'required', 'kategori_produk' => 'required',
@ -126,6 +164,11 @@ class Menu extends Controller
'tersedia' => 'required', 'tersedia' => 'required',
'deskripsi_produk' => 'required', 'deskripsi_produk' => 'required',
); );
if ($request->kelompok_produk == 9) {
$rules = array(
'promodatetime' => 'required',
);
}
$validator = Validator::make($request->all(), $rules); $validator = Validator::make($request->all(), $rules);
// check validation // check validation
@ -133,6 +176,22 @@ class Menu extends Controller
// If validation fails, return with errors // If validation fails, return with errors
return response()->json(['errors' => $validator->errors()], 422); return response()->json(['errors' => $validator->errors()], 422);
} else { } else {
if ($request->kelompok_produk == 9) {
// date promo 02/27/2024 12:00 AM - 03/30/2024 11:00 PM
$tanggal_array = explode(" - ", $request->promodatetime);
$tanggal_awal_string = $tanggal_array[0];
$tanggal_akhir_string = $tanggal_array[1];
// Konversi string tanggal menjadi objek Carbon
$tanggal_awal = Carbon::createFromFormat('m/d/Y h:i A', $tanggal_awal_string);
$tanggal_akhir = Carbon::createFromFormat('m/d/Y h:i A', $tanggal_akhir_string);
// Mendapatkan tanggal dan waktu awal serta akhir
$tgl_start_promo = $tanggal_awal->toDateTimeString();
$tgl_end_promo = $tanggal_akhir->toDateTimeString();
}
$pivot = KelompokKategoriPivot::findOrFail($id); $pivot = KelompokKategoriPivot::findOrFail($id);
$produk = Produk::find($pivot->produk_id); $produk = Produk::find($pivot->produk_id);
@ -149,6 +208,9 @@ class Menu extends Controller
'harga_produk' => $request->harga_produk, 'harga_produk' => $request->harga_produk,
'tersedia' => $request->tersedia, 'tersedia' => $request->tersedia,
'deskripsi_produk' => $request->deskripsi_produk, 'deskripsi_produk' => $request->deskripsi_produk,
'stok_promo' => $request->stok_promo,
'tgl_start_promo' => $tgl_start_promo,
'tgl_end_promo' => $tgl_end_promo,
]); ]);
// Return a success response // Return a success response

View File

@ -0,0 +1,16 @@
<?php
namespace App\Models;
use App\Traits\Blameable;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class PerangkatPrinter extends Model
{
use HasFactory, Blameable, SoftDeletes;
protected $table = 'perangkat_printers';
protected $fillable = ['nama_printer', 'ip_address', 'printer_connection', 'printer_mm', 'printer_for', 'status'];
}

View File

@ -0,0 +1,38 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('perangkat_printers', function (Blueprint $table) {
$table->id();
$table->string("nama_printer")->nullable();
$table->enum("printer_mm", ["80", "58"])->default("80")->comment("0=80, 1=58");
$table->enum("printer_connection", ["wireless", "wired"])->default("wired")->comment("0=wireless, 1=wired/usb");
$table->string("ip_address")->nullable();
$table->enum("printer_for", ["kasir", "dapur"])->default("kasir")->comment("0=kasir, 1=dapur");
$table->enum("status", [1, 0])->default(0)->comment("0=nonaktif, 1=aktif");
$table->unsignedBigInteger("updated_by")->nullable();
$table->unsignedBigInteger("created_by")->nullable();
$table->unsignedBigInteger("deleted_by")->nullable();
$table->softDeletes();
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('perangkat_printers');
}
};