temporary update

This commit is contained in:
Daeng Deni Mardaeni 2023-06-02 16:32:16 +07:00
parent ce1c7f4481
commit 0f8174143e
18 changed files with 1106 additions and 93 deletions

View File

@ -0,0 +1,105 @@
<?php
namespace Modules\Cetaklabel\DataTables;
use Illuminate\Database\Eloquent\Builder as QueryBuilder;
use Modules\Cetaklabel\Entities\Cardboard;
use Yajra\DataTables\EloquentDataTable;
use Yajra\DataTables\Html\Builder as HtmlBuilder;
use Yajra\DataTables\Html\Column;
use Yajra\DataTables\Services\DataTable;
class CardboardDataTable extends DataTable
{
/**
* Build the DataTable class.
*
* @param QueryBuilder $query Results from query() method.
*/
public function dataTable(QueryBuilder $query)
: EloquentDataTable
{
return (new EloquentDataTable($query))
->filter(function ($query) {
if (request()->has('search')) {
$search = request()->get('search');
$query->where('kode', 'like', "%" . $search['value'] . "%")
->orWhere('name', 'like', "%" . $search['value'] . "%");
}
})
->addIndexColumn()
->addColumn('directorat', function ($model) {
return $model->directorat->name;
})
->addColumn('sub_directorat', function ($model) {
return $model->subDirectorat->name;
})
->addColumn('status', function ($model) {
return $model->status == 1 ? 'Aktif' : 'Tidak Aktif';
})
->addColumn('action', 'cetaklabel::masters.cardboard._action')
->setRowId('id');
}
/**
* Get the query source of dataTable.
*/
public function query(Cardboard $model)
: QueryBuilder
{
return $model->newQuery();
}
/**
* Optional method if you want to use the html builder.
*/
public function html()
: HtmlBuilder
{
return $this->builder()
->setTableId('cardboard-table')
->columns($this->getColumns())
->minifiedAjax()
->stateSave(false)
->responsive()
->autoWidth(true)
->orderBy(1)
->parameters([
'scrollX' => true,
'drawCallback' => 'function() { KTMenu.createInstances(); }',
])
->addTableClass('align-middle table-row-dashed fs-6 gy-5');
}
/**
* Get the dataTable columns definition.
*/
public function getColumns()
: array
{
return [
Column::make('DT_RowIndex')->title('No')->orderable(false)->searchable(false),
Column::make('kode'),
Column::make('directorat'),
Column::make('sub_directorat'),
Column::make('name'),
Column::make('description'),
Column::make('sequence'),
Column::make('status'),
Column::computed('action')
->exportable(false)
->printable(false)
->width(60)
->addClass('text-center'),
];
}
/**
* Get the filename for export.
*/
protected function filename()
: string
{
return 'Cardboard_' . date('YmdHis');
}
}

View File

@ -0,0 +1,44 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Modules\Cetaklabel\Entities\Directorat;
use Modules\Cetaklabel\Entities\SubDirectorat;
return new class extends Migration {
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('cardboards', function (Blueprint $table) {
$table->id();
$table->foreignIdFor(Directorat::class)->constrained('directorats')->onDelete('cascade');
$table->foreignIdFor(SubDirectorat::class)->constrained('sub_directorats')->onDelete('cascade');
$table->string('kode', 15);
$table->string('name');
$table->string('description')->nullable();
$table->integer('sequence')->nullable();
$table->string('status');
$table->timestamps();
$table->softDeletes();
$table->unsignedBigInteger('created_by')->nullable();
$table->unsignedBigInteger('updated_by')->nullable();
$table->unsignedBigInteger('deleted_by')->nullable();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::disableForeignKeyConstraints();
Schema::dropIfExists('cardboards');
}
};

View File

@ -0,0 +1,39 @@
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
return new class extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('odners', function (Blueprint $table){
$table->id();
$table->string('kode', 15);
$table->string('name');
$table->string('description')->nullable();
$table->timestamps();
$table->softDeletes();
$table->unsignedBigInteger('created_by')->nullable();
$table->unsignedBigInteger('updated_by')->nullable();
$table->unsignedBigInteger('deleted_by')->nullable();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::disableForeignKeyConstraints();
Schema::dropIfExists('odners');
}
};

View File

@ -0,0 +1,39 @@
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
return new class extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('cardboard_odners',function (Blueprint $table){
$table->id();
$table->foreignId('cardboard_id')->constrained('cardboards')->onDelete('cascade');
$table->foreignId('odner_id')->constrained('odners')->onDelete('cascade');
$table->timestamps();
$table->softDeletes();
$table->unsignedBigInteger('created_by')->nullable();
$table->unsignedBigInteger('updated_by')->nullable();
$table->unsignedBigInteger('deleted_by')->nullable();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::disableForeignKeyConstraints();
Schema::dropIfExists('cardboard_odners');
}
};

View File

@ -0,0 +1,38 @@
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
return new class extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('odner_documents', function (Blueprint $table){
$table->id();
$table->foreignId('odner_id')->constrained('odners')->onDelete('cascade');
//$table->foreignId('document_id')->constrained('documents')->onDelete('cascade');
$table->timestamps();
$table->softDeletes();
$table->unsignedBigInteger('created_by')->nullable();
$table->unsignedBigInteger('updated_by')->nullable();
$table->unsignedBigInteger('deleted_by')->nullable();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::disableForeignKeyConstraints();
Schema::dropIfExists('odner_documents');
}
};

View File

@ -0,0 +1,39 @@
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
use Modules\Cetaklabel\Entities\Directorat;
use Modules\Cetaklabel\Entities\SubDirectorat;
return new class extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::disableForeignKeyConstraints();
Schema::table('users', function (Blueprint $table) {
$table->foreignIdFor(Directorat::class)->constrained('directorats')->onDelete('cascade')->nullable()->after('id');
$table->foreignIdFor(SubDirectorat::class)->constrained('sub_directorats')->onDelete('cascade')->nullable()->after('directorat_id');
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::disableForeignKeyConstraints();
Schema::table('users', function (Blueprint $table) {
$table->dropForeignIdFor(Directorat::class,'directorat_id');
$table->dropForeignIdFor(SubDirectorat::class,'sub_directorat_id');
$table->dropColumn(['directorat_id','sub_directorat_id']);
});
}
};

View File

@ -0,0 +1,40 @@
<?php
namespace Modules\Usermanager\Database\factories;
use Illuminate\Database\Eloquent\Factories\Factory;
use Illuminate\Support\Str;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\Modules\Usermanager\Entities\User>
*/
class UserFactory extends Factory
{
/**
* Define the model's default state.
*
* @return array<string, mixed>
*/
public function definition()
{
return [
'name' => fake()->name(),
'email' => fake()->unique()->safeEmail(),
'email_verified_at' => now(),
'password' => '$2y$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', // password
'remember_token' => Str::random(10),
];
}
/**
* Indicate that the model's email address should be unverified.
*
* @return static
*/
public function unverified()
{
return $this->state(fn(array $attributes) => [
'email_verified_at' => null,
]);
}
}

26
Entities/Cardboard.php Normal file
View File

@ -0,0 +1,26 @@
<?php
namespace Modules\Cetaklabel\Entities;
class Cardboard extends BaseModel
{
protected $fillable = [
'id',
'directorat_id',
'sub_directorat_id',
'kode',
'name',
'sequence',
'description',
];
public function directorat()
{
return $this->belongsTo(Directorat::class);
}
public function sub_directorat()
{
return $this->belongsTo(SubDirectorat::class);
}
}

View File

@ -3,35 +3,36 @@
namespace Modules\Cetaklabel\Http\Controllers\Api;
use App\Http\Controllers\ApiController;
use App\Http\Middleware\ExecutionTimeMiddleware;
use Exception;
use Illuminate\Http\Request;
use Modules\Cetaklabel\Entities\Directorat;
use Modules\Cetaklabel\Http\Requests\Directorat\StoreDirectoratRequest;
use Modules\Cetaklabel\Http\Requests\Directorat\UpdateDirectoratRequest;
use Modules\Cetaklabel\Http\Requests\Directorat\StoreCardboardRequest;
use Modules\Cetaklabel\Http\Requests\Directorat\UpdateCardboardRequest;
use Symfony\Component\HttpFoundation\JsonResponse;
class DirectoratController extends ApiController
{
public function index()
: JsonResponse
public function index(): JsonResponse
{
$directorats = Directorat::all();
$generated_at = microtime(true);
$directorats = Directorat::all();
$execution_time = (microtime(true) - $generated_at);
return $this->sendResponse($directorats, 'Directorats retrieved successfully.');
}
public function show($directorat)
: JsonResponse
public function show($directorat): JsonResponse
{
$directorat = Directorat::find($directorat);
if (is_null($directorat)) {
return $this->sendError('Directorat not found.');
return $this->sendError('Directorat not found . ');
}
return $this->sendResponse($directorat, 'Directorat retrieved successfully.');
return $this->sendResponse($directorat, 'Directorat retrieved successfully . ');
}
public function store(StoreDirectoratRequest $request)
: JsonResponse
public function store(StoreCardboardRequest $request): JsonResponse
{
// Validate the request...
$validated = $request->validated();
@ -41,17 +42,16 @@
try {
$data = Directorat::create($validated);
return $this->sendResponse($data, 'Directorat created successfully.');
return $this->sendResponse($data, 'Directorat created successfully . ');
} catch (Exception $e) {
return $this->sendError($e->getMessage(), $e->getCode());
}
}
return $this->sendError('Directorat created failed.', 400);
return $this->sendError('Directorat created failed . ', 400);
}
public function update(UpdateDirectoratRequest $request, Directorat $directorat)
: JsonResponse
public function update(UpdateCardboardRequest $request, Directorat $directorat): JsonResponse
{
// Validate the request...
$validated = $request->validated();
@ -61,27 +61,26 @@
try {
$data = $directorat->update($validated);
return $this->sendResponse($data, 'Directorat updated successfully.');
return $this->sendResponse($data, 'Directorat updated successfully . ');
} catch (Exception $e) {
return $this->sendError($e->getMessage(), $e->getCode());
}
}
return $this->sendError('Directorat created failed.', 400);
return $this->sendError('Directorat created failed . ', 400);
}
public function destroy($id)
: JsonResponse
public function destroy($id): JsonResponse
{
$directorat = Directorat::find($id);
if (is_null($directorat)) {
return $this->sendError('Directorat not found.');
return $this->sendError('Directorat not found . ');
}
try {
$directorat->delete();
return $this->sendResponse($directorat, 'Directorat deleted successfully.');
return $this->sendResponse($directorat, 'Directorat deleted successfully . ');
} catch (Exception $e) {
return $this->sendError($e->getMessage(), $e->getCode());
}

View File

@ -0,0 +1,158 @@
<?php
namespace Modules\Cetaklabel\Http\Controllers;
use Illuminate\Contracts\Support\Renderable;
use Illuminate\Http\Request;
use Illuminate\Routing\Controller;
use Illuminate\Support\Facades\Auth;
use Modules\Cetaklabel\DataTables\CardboardDataTable;
use Modules\Cetaklabel\Entities\Cardboard;
use Modules\Cetaklabel\Http\Requests\Cardboard\StoreCardboardRequest;
use Modules\Cetaklabel\Http\Requests\Cardboard\UpdateCardboardRequest;
class CardboardController extends Controller
{
public $user;
public function __construct()
{
$this->middleware(function ($request, $next) {
$this->user = Auth::guard('web')->user();
return $next($request);
});
}
/**
* Display a listing of the resource.
* @return Renderable
*/
public function index(CardboardDataTable $dataTable)
{
if(is_null($this->user) || !$this->user->can('cardboard.read')){
abort(403, 'Sorry !! You are Unauthorized to view any Cardbaords data !');
}
return $dataTable->render('cetaklabel::masters.cardboard.index');
}
/**
* Show the form for creating a new resource.
* @return Renderable
*/
public function create()
{
if (is_null($this->user) || !$this->user->can('cardboard.create')) {
abort(403, 'Sorry !! You are Unauthorized to create any Cardboard data !');
}
abort(404);
}
/**
* Store a newly created resource in storage.
* @param Request $request
* @return Renderable
*/
public function store(StoreCardboardRequest $request)
{
if(is_null($this->user) || !$this->user->can('cardboard.create')){
abort(403, 'Sorry !! You are Unauthorized to create any Cardboard data !');
}
// Validate the request...
$validated = $request->validated();
// Store the Cardboard...
if ($validated) {
try {
Cardboard::create($validated);
echo json_encode(['status' => 'success', 'message' => 'Cardboard created successfully.']);
} catch (Exception $e) {
echo json_encode(['status' => 'error', 'message' => 'Cardboard created failed.']);
}
return;
}
echo json_encode(['status' => 'error', 'message' => 'Cardboard created failed.']);
}
/**
* Show the specified resource.
* @param int $id
* @return Renderable
*/
public function show($id)
{
if (is_null($this->user) || !$this->user->can('masters.read')) {
abort(403, 'Sorry !! You are Unauthorized to view any master data !');
}
abort(404);
}
/**
* Show the form for editing the specified resource.
* @param int $id
* @return Renderable
*/
public function edit($id)
{
if (is_null($this->user) || !$this->user->can('cardboard.update')) {
abort(403, 'Sorry !! You are Unauthorized to update any cardboard data !');
}
$data = Cardboard::find($id);
echo json_encode($data);
}
/**
* Update the specified resource in storage.
* @param Request $request
* @param int $id
* @return Renderable
*/
public function update(UpdateCardboardRequest $request, Cardboard $cardboard)
{
if (is_null($this->user) || !$this->user->can('cardboard.update')) {
abort(403, 'Sorry !! You are Unauthorized to update any cardboard data !');
}
// Validate the request...
$validated = $request->validated();
// Update the Cardboard...
if ($validated) {
try {
$cardboard->update($validated);
echo json_encode(['status' => 'success', 'message' => 'Cardboard updated successfully.']);
} catch (Exception $e) {
echo json_encode(['status' => 'error', 'message' => 'Cardboard updated failed.']);
}
return;
}
echo json_encode(['status' => 'error', 'message' => 'Cardboard updated failed.']);
}
/**
* Remove the specified resource from storage.
* @param int $id
* @return Renderable
*/
public function destroy($id)
{
if (is_null($this->user) || !$this->user->can('cardboard.delete')) {
abort(403, 'Sorry !! You are Unauthorized to delete any cardboard data !');
}
try {
Cardboard::find($id)->delete();
echo json_encode(['status' => 'success', 'message' => 'Cardboard deleted successfully.']);
} catch (Exception $e) {
echo json_encode(['status' => 'error', 'message' => 'Cardboard deleted failed.']);
}
}
}

View File

@ -9,27 +9,14 @@
use Haruncpi\LaravelIdGenerator\IdGenerator;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\View;
use Modules\Cetaklabel\DataTables\DocumentDataTable;
use Modules\Cetaklabel\Entities\Directorat;
use Modules\Cetaklabel\Entities\Document;
use Modules\Cetaklabel\Entities\DocumentDetail;
use Modules\Cetaklabel\Entities\DocumentType;
use Modules\Cetaklabel\Entities\Job;
use Modules\Cetaklabel\Entities\SpecialCode;
use Modules\Cetaklabel\Entities\SubDirectorat;
use Modules\Cetaklabel\Entities\SubJob;
use Modules\Cetaklabel\Entities\SubSubJob;
use Modules\Cetaklabel\Http\Requests\Document\StoreDocumentRequest;
use Modules\Cetaklabel\Http\Requests\Document\UpdateDocumentRequest;
use Response;
// Reference the Dompdf namespace
use Dompdf\Dompdf;
// Reference the Options namespace
use Dompdf\Options;
// Reference the Font Metrics namespace
use Dompdf\FontMetrics;
class DocumentController extends Controller
{
@ -74,8 +61,9 @@
if ($validated) {
try {
$document = Document::where(['kode_odner' => $validated['kode_odner'],
'sequence_odner' => $validated['sequence_odner']
$document = Document::where([
'kode_odner' => $validated['kode_odner'],
'sequence_odner' => $validated['sequence_odner']
])->first();
if ($document) {
@ -144,6 +132,31 @@
return false;
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request)
{
if (is_null($this->user) || !$this->user->hasRole('otorisator')) {
abort(403, 'Sorry !! You are Unauthorized to update any master data !');
}
try {
$data = [
'status' => $request->keterangan == "" ? '1' : '3',
'keterangan' => $request->keterangan ?? null,
'approved_at' => date('Y-m-d H:i:s'),
'approved_by' => $this->user->id
];
$documents = DocumentDetail::find($request->id);
$documents->update($data);
echo json_encode(['status' => 'success', 'message' => 'Document updated successfully.']);
} catch (Exception $e) {
echo json_encode(['status' => 'error', 'message' => 'Document updated failed.']);
}
}
/**
* Show the form for creating a new resource.
*/
@ -156,8 +169,8 @@
$directorat = Directorat::all();
$special_code = SpecialCode::all();
$document_type = DocumentType::all();
$setting = Setting::all();
return view('cetaklabel::app.document.create', compact('directorat', 'special_code', 'document_type','setting'));
$setting = Setting::all();
return view('cetaklabel::app.document.create', compact('directorat', 'special_code', 'document_type', 'setting'));
}
/**
@ -177,47 +190,22 @@
*/
public function edit($id)
{
if (is_null($this->user) || !$this->user->hasRole('otorisator')){
if (is_null($this->user) || !$this->user->hasRole('otorisator')) {
abort(403, 'Sorry !! You are Unauthorized to update any master data !');
}
$document = DocumentDetail::with('document')->find($id);
$document = DocumentDetail::with('document')->find($id);
if ($document->status != '0') {
abort(403, 'Sorry !! This Document has been authorized !');
}
$document = DocumentDetail::with('document')->find($id);
$document = DocumentDetail::with('document')->find($id);
return view('cetaklabel::app.document.edit', compact('document'));
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request)
{
if (is_null($this->user) || !$this->user->hasRole('otorisator')) {
abort(403, 'Sorry !! You are Unauthorized to update any master data !');
}
try {
$data = [
'status' => $request->keterangan =="" ? '1' : '3',
'keterangan' => $request->keterangan ?? null,
'approved_at' => date('Y-m-d H:i:s'),
'approved_by' => $this->user->id
];
$documents = DocumentDetail::find($request->id);
$documents->update($data);
echo json_encode(['status' => 'success', 'message' => 'Document updated successfully.']);
} catch (Exception $e) {
echo json_encode(['status' => 'error', 'message' => 'Document updated failed.']);
}
}
/**
* Remove the specified resource from storage.
*/
@ -229,19 +217,22 @@
// Delete Detail Document First...
$document_details = DocumentDetail::find($request->document);
if($document_details->status == 1){
$document_details->update(['status' => '6','keterangan' => $request->keterangan]);
if ($document_details->status == 1) {
$document_details->update(['status' => '6', 'keterangan' => $request->keterangan]);
echo json_encode(['status' => 'success', 'message' => 'Document menunggu Approval untuk di Hapus.']);
return;
}
if($document_details->status == 6){
if ($document_details->status == 6) {
$document_details->update(['status' => '7']);
echo json_encode(['status' => 'success', 'message' => 'Document menunggu Approval Tingkat 2 untuk di Hapus.']);
echo json_encode([
'status' => 'success',
'message' => 'Document menunggu Approval Tingkat 2 untuk di Hapus.'
]);
return;
}
if($document_details->status == 7){
if ($document_details->status == 7) {
$document_details->update(['status' => '8']);
$document_details->delete();
@ -257,19 +248,19 @@
}
$document = DocumentDetail::find($request->id);
if($document->status == 1){
if ($document->status == 1) {
$document->update(['status' => '4']);
echo json_encode(['status' => 'success', 'message' => 'Document menunggu Approval untuk di Cetak.']);
return;
}
if($document->status == 4){
if ($document->status == 4) {
$document->update(['status' => '5']);
echo json_encode(['status' => 'success', 'message' => 'Approval Berhasil.']);
return;
}
if($document->status == 5){
if ($document->status == 5) {
$document->update(['status' => '1']);
$document->save();
$filepath = public_path($document->file);
@ -282,14 +273,17 @@
public function aktif(Request $request)
{
$document = DocumentDetail::find($request->id);
if($document->aktif == 1 && $document->status != 9){
$document->update(['status' => '9','keterangan' => $request->keterangan]);
echo json_encode(['status' => 'success', 'message' => 'Document menunggu Approval untuk di Nonaktifkan.']);
if ($document->aktif == 1 && $document->status != 9) {
$document->update(['status' => '9', 'keterangan' => $request->keterangan]);
echo json_encode([
'status' => 'success',
'message' => 'Document menunggu Approval untuk di Nonaktifkan.'
]);
return;
}
if($document->aktif == 1 && $document->status == 9){
$document->update(['aktif' => '0','status' => '1']);
if ($document->aktif == 1 && $document->status == 9) {
$document->update(['aktif' => '0', 'status' => '1']);
echo json_encode(['status' => 'success', 'message' => 'Document Berhasil di Nonaktifkan.']);
return;
}
@ -302,8 +296,9 @@
}
$document_detail = DocumentDetail::with(['document'])->find($request->id);
$document = Document::with(['document_details'])->where(['kode_dus' => $document_detail->document->kode_dus,
'sequence_dus' => $document_detail->document->sequence_dus
$document = Document::with(['document_details'])->where([
'kode_dus' => $document_detail->document->kode_dus,
'sequence_dus' => $document_detail->document->sequence_dus
])->first();
$start = DocumentDetail::where('document_id', $document_detail->document_id)->orderBy('tanggal_dokumen', 'asc')->first()->tanggal_dokumen;
@ -315,11 +310,7 @@
$last = Carbon::create($last);
$last = $last->isoFormat('DD MMMM Y');
activity()
->performedOn($document)
->causedBy(Auth::user())
->withProperties($document)
->log('Cetak Label Dus');
activity()->performedOn($document)->causedBy(Auth::user())->withProperties($document)->log('Cetak Label Dus');
return view('cetaklabel::app.document.label', compact('document_detail', 'start', 'last', 'document'));
@ -333,8 +324,9 @@
}
$document_detail = DocumentDetail::with(['document'])->find($request->id);
$document = Document::with(['document_details'])->where(['kode_odner' => $document_detail->document->kode_odner,
'sequence_odner' => $document_detail->document->sequence_odner
$document = Document::with(['document_details'])->where([
'kode_odner' => $document_detail->document->kode_odner,
'sequence_odner' => $document_detail->document->sequence_odner
])->first();
$start = DocumentDetail::where('document_id', $document_detail->document_id)->orderBy('tanggal_dokumen', 'asc')->first()->tanggal_dokumen;
@ -346,11 +338,7 @@
$last = Carbon::create($last);
$last = $last->isoFormat('DD MMMM Y');
activity()
->performedOn($document)
->causedBy(Auth::user())
->withProperties($document)
->log('Cetak Label Odner');
activity()->performedOn($document)->causedBy(Auth::user())->withProperties($document)->log('Cetak Label Odner');
return view('cetaklabel::app.document.odner', compact('document_detail', 'start', 'last', 'document'));
}

View File

@ -0,0 +1,76 @@
<?php
namespace Modules\Cetaklabel\Http\Requests\Cardboard;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Http\Exceptions\HttpResponseException;
use Illuminate\Validation\ValidationException;
use Illuminate\Validation\Validator;
use Symfony\Component\HttpFoundation\JsonResponse;
class StoreCardboardRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*/
public function authorize(): bool
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array<string, \Illuminate\Contracts\Validation\Rule|array|string>
*/
public function rules(): array
{
return [
'kode' => 'required|string|max:15|min:2|unique:cardboards,kode',
'name' => 'required|string|max:50',
'description' => 'nullable|string|max:255',
'sequence' => 'nullable|integer|max:5',
'status' => 'nullable|string|max:1'
];
}
/**
* Configure the validator instance.
*/
public function withValidator(Validator $validator): void
{
$validator->after(function (Validator $validator) {
if ($validator->errors()->any()) {
$errors = json_decode($validator->errors()->toJson(), true);
foreach ($errors as $key => $value) {
flash($value[0]);
}
return redirect()->route('cardboard.index')->with('error', 'Cardboard created failed . ');
}
});
}
protected function failedValidation(Validator|\Illuminate\Contracts\Validation\Validator $validator): JsonResponse
{
$errors = (new ValidationException($validator))->errors();
throw new HttpResponseException(response()->json([
'success' => false,
'errors' => $errors,
'messages' => 'Cardboard created failed . '
], JsonResponse::HTTP_UNPROCESSABLE_ENTITY));
}
protected function prepareForValidation(): void
{
$directorat_id = Auth()->user()->directorat_id ?? null;
$sub_directorat_id = Auth()->user()->sub_directorat_id ?? null;
$this->merge([
'directorat_id' => $directorat_id,
'sub_directorat_id' => $sub_directorat_id
]);
}
}

View File

@ -0,0 +1,64 @@
<?php
namespace Modules\Cetaklabel\Http\Requests\Cardboard;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Http\Exceptions\HttpResponseException;
use Illuminate\Http\JsonResponse;
use Illuminate\Validation\ValidationException;
use Illuminate\Validation\Validator;
class UpdateCardboardRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*/
public function authorize(): bool
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array<string, \Illuminate\Contracts\Validation\Rule|array|string>
*/
public function rules(): array
{
return [
'kode' => 'required|string|max:15|min:2|unique:cardboards,kode,' . $this->cardboard->id,
'name' => 'required|string|max:50',
'description' => 'nullable|string|max:255',
'sequence' => 'nullable|integer|max:5',
'status' => 'nullable|string|max:1'
];
}
/**
* Configure the validator instance.
*/
public function withValidator(Validator $validator): void
{
$validator->after(function (Validator $validator) {
if ($validator->errors()->any()) {
$error = json_decode($validator->errors()->toJson(), true);
foreach ($error as $key => $value) {
flash($value[0]);
}
return redirect()->route('cardboard.index')->with('error', 'Cardboard updated failed.');
}
});
}
protected function failedValidation(Validator|\Illuminate\Contracts\Validation\Validator $validator): JsonResponse
{
$errors = (new ValidationException($validator))->errors();
throw new HttpResponseException(response()->json([
'success' => false,
'errors' => $errors,
'messages' => 'Cardboard updated failed.'
], JsonResponse::HTTP_UNPROCESSABLE_ENTITY));
}
}

View File

@ -0,0 +1,13 @@
@php
$route = explode('.', Route::currentRouteName());
@endphp
<div class="d-flex flex-row flex-center">
<a href="{{ route($route[0].'.edit',['cardboard' => $model->id]) }}"
class="kt_edit_form btn btn-icon btn-bg-light btn-active-light-primary btn-sm me-1">
{!! getIcon("pencil", "fs-1 text-info","duotune") !!}
</a>
{!! Form::open(['method' => 'DELETE','route' => [$route[0].'.destroy', $model->id],'class'=>'']) !!}
{{ Form::button(getIcon("trash", "fs-1 text-danger","duotune"), ['type' => 'submit', 'class' => 'delete btn btn-icon btn-bg-light btn-active-light-danger btn-sm'] ) }}
{!! Form::close() !!}
</div>

View File

@ -0,0 +1,94 @@
@php
$route = explode('.', Route::currentRouteName());
@endphp
<!--begin::Modal - New Target-->
<div class="modal fade" id="kt_modal_cardboard" tabindex="-1" aria-hidden="true">
<!--begin::Modal dialog-->
<div class="modal-dialog modal-dialog-centered mw-650px">
<!--begin::Modal content-->
<div class="modal-content rounded">
<!--begin::Modal header-->
<div class="modal-header pb-0 border-0 justify-content-end">
<!--begin::Close-->
<div class="btn btn-sm btn-icon btn-active-color-primary" data-bs-dismiss="modal">{!! getIcon('cross', 'fs-1') !!}</div>
<!--end::Close-->
</div>
<!--begin::Modal header-->
<!--begin::Modal body-->
<div class="modal-body scroll-y px-10 px-lg-15 pt-0 pb-15">
<!--begin:Form-->
<form class="form_{{$route[0]}}" method="POST" action="{{ route($route[0].'.store') }}">
@csrf
<!--begin::Heading-->
<div class="mb-13 text-center">
<!--begin::Title-->
<h1 class="mb-3 text-capitalize" id="title_form">{{ str_replace('-',' ',$route[0]) }}</h1>
<!--end::Title-->
</div>
<!--end::Heading-->
<!--begin::Input group-->
<div class="d-flex flex-column mb-8 fv-row">
<!--begin::Label-->
<label class="d-flex align-items-center fs-6 fw-semibold mb-2">
<span class="required">Kode</span>
<span class="ms-1" data-bs-toggle="tooltip" title="Specify a target name for future usage and reference"></span>
</label>
<!--end::Label-->
<input type="hidden" id="cardboard_id" name="id"/>
<input type="number" id="cardboard_kode" minlength="2" maxlength="15" pattern="[0-9]{2,15}" class="form-control form-control-solid" placeholder="Enter Kode Cardboard" name="kode"/>
</div>
<!--end::Input group-->
<!--begin::Input group-->
<div class="d-flex flex-column mb-8 fv-row">
<!--begin::Label-->
<label class="d-flex align-items-center fs-6 fw-semibold mb-2">
<span class="required">Sequence</span>
<span class="ms-1" data-bs-toggle="tooltip" title="Specify a target name for future usage and reference"></span>
</label>
<!--end::Label-->
<input type="number" id="cardboard_sequence" minlength="1" maxlength="1" min="1" max="5" pattern="[0-9]{1,1}" class="form-control form-control-solid" placeholder="Enter Sequence Cardboard" name="sequence"/>
</div>
<!--end::Input group-->
<!--begin::Input group-->
<div class="d-flex flex-column mb-8 fv-row">
<!--begin::Label-->
<label class="d-flex align-items-center fs-6 fw-semibold mb-2">
<span class="required">Name</span>
<span class="ms-1" data-bs-toggle="tooltip" title="Specify a target name for future usage and reference"></span>
</label>
<!--end::Label-->
<input type="text" id="cardboard_name" maxlength="50" class="form-control form-control-solid" placeholder="Enter Cardboard Name" name="name"/>
</div>
<!--end::Input group-->
<!--begin::Input group-->
<div class="d-flex flex-column mb-8 fv-row">
<!--begin::Label-->
<label class="d-flex align-items-center fs-6 fw-semibold mb-2">
<span class="required">Description</span>
<span class="ms-1" data-bs-toggle="tooltip" title="Specify a target name for future usage and reference"></span>
</label>
<!--end::Label-->
<textarea rows="3" id="cardboard_description" maxlength="50" class="form-control form-control-solid" placeholder="Enter Cardboard Description" name="description"></textarea>
</div>
<!--end::Input group-->
<!--begin::Actions-->
<div class="text-center">
<button type="reset" data-bs-dismiss="modal" class="btn btn-light me-3">Cancel</button>
<button type="submit" class="btn btn-primary">Submit</button>
</div>
<!--end::Actions-->
</form>
<!--end:Form-->
</div>
<!--end::Modal body-->
</div>
<!--end::Modal content-->
</div>
<!--end::Modal dialog-->
</div>
<!--end::Modal - New Target-->

View File

@ -0,0 +1,117 @@
<!--begin::Table-->
{{ $dataTable->table() }}
<!--end::Table-->
{{-- Inject Scripts --}}
@section('scripts')
{{ $dataTable->scripts() }}
@endsection
@push('customscript')
@php
$route = explode('.', Route::currentRouteName());
@endphp
<script>
$("#searchbox").on("keyup search input paste cut", function () {
LaravelDataTables["{{$route[0]}}-table"].search(this.value).draw();
});
$(function () {
const documentTitle = '{{ ucfirst($route[0]) }} Report';
var buttons = new $.fn.dataTable.Buttons(LaravelDataTables["{{$route[0]}}-table"], {
buttons: [
{
extend: 'copyHtml5',
title: documentTitle
},
{
extend: 'excelHtml5',
title: documentTitle
},
{
extend: 'csvHtml5',
title: documentTitle
},
{
extend: 'pdfHtml5',
title: documentTitle
},
{
extend: 'print',
title: documentTitle
}
]
}).container().appendTo($('#kt_datatable_example_buttons'));
// Hook dropdown menu click event to datatable export buttons
const exportButtons = document.querySelectorAll('#kt_datatable_example_export_menu [data-kt-export]');
exportButtons.forEach(exportButton => {
exportButton.addEventListener('click', e => {
e.preventDefault();
console.log(e.target.getAttribute('data-kt-export'));
// Get clicked export value
const exportValue = e.target.getAttribute('data-kt-export');
const target = document.querySelector('.dt-buttons .buttons-' + exportValue);
// Trigger click event on hidden datatable export buttons
target.click();
});
});
LaravelDataTables["{{$route[0]}}-table"].on('click', '.kt_edit_form', function (event) {
event.preventDefault();
$.ajax({
url: $(this).attr('href'),
type: 'GET',
dataType: 'json',
success: function (response) {
$('#title_form').text('Edit {{ ucfirst(str_replace('-',' ',$route[0])) }}');
$('#{{$route[0]}}_id').val(response.id);
$('#{{$route[0]}}_name').val(response.name);
$('#{{$route[0]}}_kode').val(response.kode);
$('#{{$route[0]}}_sequence').val(response.sequence);
$('#{{$route[0]}}_description').val(response.description);
$('.form_{{$route[0]}}').attr('action', '{{ URL::to('/'.$route[0].'/') }}/' + response.id).append('<input type="hidden" name="_method" value="PUT">');
$('#kt_modal_{{$route[0]}}').modal('show');
}
})
})
LaravelDataTables["{{$route[0]}}-table"].on('click', '.delete', function (event) {
var form = $(this).closest("form");
event.preventDefault();
Swal.fire({
title: 'Are you sure?',
text: "You won't be able to revert this!",
icon: 'warning',
showCancelButton: true,
confirmButtonColor: '#3085d6',
cancelButtonColor: '#d33',
confirmButtonText: 'Yes, delete it!'
}).then((result) => {
if (result.isConfirmed) {
$.ajax({
type: "POST",
url: form.attr('action'),
data: form.serialize(), // serializes the form's elements.
success: function (data) {
toastr.success('{{ucfirst($route[0])}} has been deleted.', 'Success!', {timeOut: 5000});
LaravelDataTables["{{$route[0]}}-table"].ajax.reload();
}
});
}
})
})
})
</script>
@endpush
@section('styles')
<style>
.dataTables_filter {
display: none;
}
</style>
@endsection

View File

@ -0,0 +1,131 @@
<x-default-layout>
<!--begin::Card-->
<div class="card card-xxl-stretch mb-5 mb-xl-8">
<!--begin::Card body-->
<div class="card-header border-0 pt-5">
<div class="card-title align-items-start flex-column">
<div class="d-flex align-items-center position-relative my-1">
<!--begin::Svg Icon | path: icons/duotune/general/gen021.svg-->
<span class="svg-icon svg-icon-1 position-absolute ms-6">
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none">
<rect opacity="0.5" x="17.0365" y="15.1223" width="8.15546" height="2" rx="1"
transform="rotate(45 17.0365 15.1223)" fill="currentColor"></rect>
<path
d="M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z"
fill="currentColor"></path>
</svg>
</span>
<!--end::Svg Icon-->
<input type="text" id="searchbox"
class="form-control form-control-solid border border-gray-300 w-250px ps-15"
placeholder="Search Cardboard">
</div>
<!--begin::Export buttons-->
<div id="kt_datatable_example_1_export" class="d-none"></div>
<!--end::Export buttons-->
</div>
<div class="card-toolbar">
<!--begin::Export dropdown-->
<button type="button" class="btn btn-light-primary" data-kt-menu-trigger="click"
data-kt-menu-placement="bottom-end">
<i class="ki-duotone ki-exit-down fs-2"><span class="path1"></span><span class="path2"></span></i>
Export Report
</button>
<!--begin::Menu-->
<div id="kt_datatable_example_export_menu"
class="menu menu-sub menu-sub-dropdown menu-column menu-rounded menu-gray-600 menu-state-bg-light-primary fw-semibold fs-7 w-200px py-4"
data-kt-menu="true">
<!--begin::Menu item-->
<div class="menu-item px-3">
<a href="#" class="menu-link px-3" data-kt-export="copy">
Copy to clipboard
</a>
</div>
<!--end::Menu item-->
<!--begin::Menu item-->
<div class="menu-item px-3">
<a href="#" class="menu-link px-3" data-kt-export="excel">
Export as Excel
</a>
</div>
<!--end::Menu item-->
<!--begin::Menu item-->
<div class="menu-item px-3">
<a href="#" class="menu-link px-3" data-kt-export="csv">
Export as CSV
</a>
</div>
<!--end::Menu item-->
<!--begin::Menu item-->
<div class="menu-item px-3">
<a href="#" class="menu-link px-3" data-kt-export="pdf">
Export as PDF
</a>
</div>
<!--end::Menu item-->
<!--begin::Menu item-->
<div class="menu-item px-3">
<a href="#" class="menu-link px-3" data-kt-export="print">
Print
</a>
</div>
<!--end::Menu item-->
</div>
<!--begin::Hide default export buttons-->
<div id="kt_datatable_example_buttons" class="d-none"></div>
<!--end::Hide default export buttons-->
</div>
</div>
<div class="card-body pt-6">
@include('cetaklabel::masters.cardboard._table')
@include('cetaklabel::masters.cardboard._form')
</div>
<!--end::Card body-->
</div>
<!--end::Card-->
@push('customscript')
<script>
$(function () {
$(".form_cardboard").submit(function (e) {
e.preventDefault(); // avoid to execute the actual submit of the form.
var form = $(this);
var actionUrl = form.attr('action');
$.ajax({
type: "POST",
url: actionUrl,
data: form.serialize(), // serializes the form's elements.
success: function (data) {
var _data = JSON.parse(data);
toastr.success(_data.message);
form[0].reset();
LaravelDataTables["cardboard-table"].ajax.reload();
$('#kt_modal_cardboard').modal('hide');
},
error: function (data, textStatus, errorThrown) {
var errors = data.responseJSON.errors;
$.each(errors, function (key, value) {
toastr.error(value);
});
}
});
});
$('#kt_modal_cardboard').on('hidden.bs.modal', function (e) {
$(".form_cardboard")[0].reset();
$(".form_cardboard").attr('action', "{{ route('cardboard.store') }}");
$(".form_cardboard").find('input[name="_method"]').remove();
$("#title_form").html("Create Cardboard");
})
});
</script>
@endpush
</x-default-layout>

View File

@ -11,6 +11,7 @@
|
*/
use Modules\Cetaklabel\Http\Controllers\CardboardController;
use Modules\Cetaklabel\Http\Controllers\DirectoratController;
use Modules\Cetaklabel\Http\Controllers\DocumentController;
use Modules\Cetaklabel\Http\Controllers\DocumentTypeController;
@ -32,6 +33,8 @@
Route::resource('special-code', SpecialCodeController::class);
Route::resource('document-type', DocumentTypeController::class);
Route::resource('cardboard', CardboardController::class);
Route::resource('document', DocumentController::class);
Route::get('document-download/{id}', [DocumentController::class, 'download'])->name('document.download');
Route::get('document-label/{id}', [DocumentController::class, 'label'])->name('document.label');