Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sinkronisasi fasilitas PAUD dari Opensid #408

Open
wants to merge 13 commits into
base: dev
Choose a base branch
from
90 changes: 90 additions & 0 deletions app/Http/Controllers/Api/FasilitasPaudController.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
<?php

/*
* File ini bagian dari:
*
* OpenDK
*
* Aplikasi dan source code ini dirilis berdasarkan lisensi GPL V3
*
* Hak Cipta 2017 - 2022 Perkumpulan Desa Digital Terbuka (https://opendesa.id)
*
* Dengan ini diberikan izin, secara gratis, kepada siapa pun yang mendapatkan salinan
* dari perangkat lunak ini dan file dokumentasi terkait ("Aplikasi Ini"), untuk diperlakukan
* tanpa batasan, termasuk hak untuk menggunakan, menyalin, mengubah dan/atau mendistribusikan,
* asal tunduk pada syarat berikut:
*
* Pemberitahuan hak cipta di atas dan pemberitahuan izin ini harus disertakan dalam
* setiap salinan atau bagian penting Aplikasi Ini. Barang siapa yang menghapus atau menghilangkan
* pemberitahuan ini melanggar ketentuan lisensi Aplikasi Ini.
*
* PERANGKAT LUNAK INI DISEDIAKAN "SEBAGAIMANA ADANYA", TANPA JAMINAN APA PUN, BAIK TERSURAT MAUPUN
* TERSIRAT. PENULIS ATAU PEMEGANG HAK CIPTA SAMA SEKALI TIDAK BERTANGGUNG JAWAB ATAS KLAIM, KERUSAKAN ATAU
* KEWAJIBAN APAPUN ATAS PENGGUNAAN ATAU LAINNYA TERKAIT APLIKASI INI.
*
* @package OpenDK
* @author Tim Pengembang OpenDesa
* @copyright Hak Cipta 2017 - 2022 Perkumpulan Desa Digital Terbuka (https://opendesa.id)
* @license http://www.gnu.org/licenses/gpl.html GPL V3
* @link https://github.com/OpenSID/opendk
*/

namespace App\Http\Controllers\Api;

use App\Http\Controllers\Controller;
use App\Http\Requests\FasilitasPaudRequest;
use App\Imports\ImporFasilitasPaud;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Str;
use ZipArchive;

class FasilitasPaudController extends Controller
{
/**
* Create a new AuthController instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth:api');
}

public function store(FasilitasPaudRequest $request)
{
try {
// Upload file zip temporary.
$file = $request->file('file');
$file->storeAs('temp', $name = $file->getClientOriginalName());

// Temporary path file
$path = storage_path("app/temp/{$name}");
$extract = storage_path('app/public/fasilitas_paud/');

// Ekstrak file
$zip = new ZipArchive();
$zip->open($path);
$zip->extractTo($extract);
$zip->close();

(new ImporFasilitasPaud())
->queue($extract . $csvName = Str::replaceLast('zip', 'csv', $name));
} catch (\Exception $e) {
report($e);
return response()->json([
'status' => 'danger',
"message" => $e->getMessage(),
]);
}

// Hapus folder temp ketika sudah selesai
Storage::deleteDirectory('temp');
// Hapus file excell temp ketika sudah selesai
Storage::disk('public')->delete('fasilitas_paud' . $csvName);

return response()->json([
"message" => "Data Bantuan Sedang di Sinkronkan",
"status" => "success"
]);
}
}
51 changes: 2 additions & 49 deletions app/Http/Controllers/Data/FasilitasPaudController.php
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,6 @@ public function getDataFasilitasPAUD()
{
return DataTables::of(FasilitasPAUD::with(['desa'])->get())
->addColumn('aksi', function ($row) {
$data['edit_url'] = route('data.fasilitas-paud.edit', $row->id);
$data['delete_url'] = route('data.fasilitas-paud.destroy', $row->id);

return view('forms.aksi', $data);
Expand All @@ -73,10 +72,8 @@ public function import()
{
$page_title = 'Import';
$page_description = 'Import Data Fasilitas PAUD';
$years_list = years_list();
$months_list = months_list();

return view('data.fasilitas_paud.import', compact('page_title', 'page_description', 'years_list', 'months_list'));
return view('data.fasilitas_paud.import', compact('page_title', 'page_description'));
}

/**
Expand All @@ -87,14 +84,11 @@ public function import()
public function do_import(Request $request)
{
$this->validate($request, [
'desa_id' => 'required|unique:das_fasilitas_paud,desa_id',
'file' => 'required|file|mimes:xls,xlsx,csv|max:5120',
'tahun' => 'required|unique:das_fasilitas_paud',
'semester' => 'required|unique:das_fasilitas_paud',
]);

try {
(new ImporFasilitasPaud($request->only(['desa_id', 'semester', 'tahun'])))
(new ImporFasilitasPaud())
->queue($request->file('file'));
} catch (\Exception $e) {
report($e);
Expand All @@ -104,47 +98,6 @@ public function do_import(Request $request)
return redirect()->route('data.fasilitas-paud.index')->with('success', 'Import data sukses.');
}

/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return Response
*/
public function edit($id)
{
$fasilitas = FasilitasPAUD::with(['desa'])->findOrFail($id);
$page_title = 'Fasilitas PAUD';
$page_description = 'Ubah Fasilitas PAUD : Desa ' . $fasilitas->desa->nama;

return view('data.fasilitas_paud.edit', compact('page_title', 'page_description', 'fasilitas'));
}

/**
* Update the specified resource in storage.
*
* @param int $id
* @return Response
*/
public function update(Request $request, $id)
{
request()->validate([
'jumlaah_paud' => 'required',
'jumlah_guru_paud' => 'required',
'jumlah_siswa_paud' => 'required',
'semester' => 'required',
'tahun' => 'required',
]);

try {
FasilitasPAUD::findOrFail($id)->update($request->all());
} catch (\Exception $e) {
report($e);
return back()->withInput()->with('error', 'Data gagal diubah!');
}

return redirect()->route('data.fasilitas-paud.index')->with('success', 'Data berhasil diubah!');
}

/**
* Remove the specified resource from storage.
*
Expand Down
61 changes: 61 additions & 0 deletions app/Http/Requests/FasilitasPaudRequest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
<?php

/*
* File ini bagian dari:
*
* OpenDK
*
* Aplikasi dan source code ini dirilis berdasarkan lisensi GPL V3
*
* Hak Cipta 2017 - 2022 Perkumpulan Desa Digital Terbuka (https://opendesa.id)
*
* Dengan ini diberikan izin, secara gratis, kepada siapa pun yang mendapatkan salinan
* dari perangkat lunak ini dan file dokumentasi terkait ("Aplikasi Ini"), untuk diperlakukan
* tanpa batasan, termasuk hak untuk menggunakan, menyalin, mengubah dan/atau mendistribusikan,
* asal tunduk pada syarat berikut:
*
* Pemberitahuan hak cipta di atas dan pemberitahuan izin ini harus disertakan dalam
* setiap salinan atau bagian penting Aplikasi Ini. Barang siapa yang menghapus atau menghilangkan
* pemberitahuan ini melanggar ketentuan lisensi Aplikasi Ini.
*
* PERANGKAT LUNAK INI DISEDIAKAN "SEBAGAIMANA ADANYA", TANPA JAMINAN APA PUN, BAIK TERSURAT MAUPUN
* TERSIRAT. PENULIS ATAU PEMEGANG HAK CIPTA SAMA SEKALI TIDAK BERTANGGUNG JAWAB ATAS KLAIM, KERUSAKAN ATAU
* KEWAJIBAN APAPUN ATAS PENGGUNAAN ATAU LAINNYA TERKAIT APLIKASI INI.
*
* @package OpenDK
* @author Tim Pengembang OpenDesa
* @copyright Hak Cipta 2017 - 2022 Perkumpulan Desa Digital Terbuka (https://opendesa.id)
* @license http://www.gnu.org/licenses/gpl.html GPL V3
* @link https://github.com/OpenSID/opendk
*/

namespace App\Http\Requests;

use App\Rules\CekDesa;
use Illuminate\Foundation\Http\FormRequest;

class FasilitasPaudRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}

/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
'file' => 'file|mimes:zip|max:5120',
"desa_id" => ['required', 'string', new CekDesa()],
];
}
}
43 changes: 22 additions & 21 deletions app/Imports/ImporFasilitasPaud.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,23 +33,16 @@

use App\Models\FasilitasPAUD;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Support\Collection;
use Maatwebsite\Excel\Concerns\Importable;
use Maatwebsite\Excel\Concerns\ToModel;
use Maatwebsite\Excel\Concerns\ToCollection;
use Maatwebsite\Excel\Concerns\WithChunkReading;
use Maatwebsite\Excel\Concerns\WithHeadingRow;

class ImporFasilitasPaud implements ToModel, WithHeadingRow, WithChunkReading, ShouldQueue
class ImporFasilitasPaud implements ToCollection, WithHeadingRow, WithChunkReading, ShouldQueue
{
use Importable;

/** @var array $request */
protected $request;

public function __construct(array $request)
{
$this->request = $request;
}

/**
* {@inheritdoc}
*/
Expand All @@ -59,17 +52,25 @@ public function chunkSize(): int
}

/**
* {@inheritdoc}
*/
public function model(array $row)
* @param Collection $collection
*/
public function collection(Collection $collection)
{
return new FasilitasPAUD([
'desa_id' => $this->request['desa_id'],
'jumlah_paud' => $row['jumlah_paud_ra'],
'jumlah_guru_paud' => $row['jumlah_guru_paud_ra'],
'jumlah_siswa_paud' => $row['jumlah_siswa_paud_ra'],
'semester' => $this->request['semester'],
'tahun' => $this->request['tahun'],
]);
foreach ($collection as $value) {
$insert = [
'desa_id' => $value['desa_id'],
'jumlah_paud' => $value['jumlah_paud'],
'jumlah_guru_paud' => $value['jumlah_guru_paud'],
'jumlah_siswa_paud' => $value['jumlah_siswa_paud'],
'semester' => $value['semester'],
'tahun' => $value['tahun'],
];

FasilitasPAUD::updateOrCreate([
'desa_id' => $insert['desa_id'],
'semester' => $insert['semester'],
'tahun' => $insert['tahun'],
], $insert);
}
}
}
Loading