sekolah_adiwiyata/app/Helpers/custom.php

765 lines
27 KiB
PHP

<?php
use App\Models\Master\MasterMenu;
use App\Models\Master\MasterAccessMenu;
use App\Models\Kuesioner;
use App\Models\Master\FormKriteria;
use App\Models\Penilaian;
if (!function_exists('hitungSkor')) {
/**
* @param $val
*
* @return string
*/
function hitungSkor($key,$val,$lainnya = [])
{
$skor = 0;
$countLainnya = 0;
if(@$lainnya){
$countLainnya = count(array_filter($lainnya, function ($value) {
return !is_null($value);
}));
}
if($key == 'rencana_gerakan_pblhs'){
if($val == "Sesuai dengan Laporan EDS dan hasil IPMLH."){
$skor = 3;
}elseif($val == "Sesuai dengan Laporan EDS atau hasil IPMLH."){
$skor = 2;
}elseif($val == "Tidak sesuai dengan Laporan EDS dan hasil IPMLH."){
$skor = 1;
}else{
$skor = 0;
}
}elseif($key == 'pihak_terlibat_pblhs'){
$array3 = ["Kepala Sekolah", "Dewan pendidik", "Komite sekolah", "Peserta Didik", "Masyarakat"];
$array2 = ["Kepala Sekolah", "Dewan pendidik", "Komite sekolah", "Peserta Didik"];
$array1 = ["Kepala Sekolah", "Dewan pendidik", "Komite sekolah"];
if (!array_diff($array3, $val) && !array_diff($val, $array3)) {
$skor = 3;
} elseif (!array_diff($array2, $val) && !array_diff($val, $array2)) {
$skor = 2;
} elseif (!array_diff($array1, $val) && !array_diff($val, $array1)) {
$skor = 1;
} else {
$skor = 0;
}
}elseif($key == 'dokumen_ktsp'){
$array3 = ["Visi", "Misi", "Tujuan", "Program pengembangan diri"];
$array2 = ["Visi", "Misi", "Tujuan"];
$array22 = ["Visi", "Misi", "Program pengembangan diri"];
$array1 = ["Visi", "Misi","Tujuan", "Program pengembangan diri tidak memuat"];
if (!array_diff($array3, $val) && !array_diff($val, $array3)) {
$skor = 3;
} elseif ((!array_diff($array2, $val) && !array_diff($val, $array2)) || (!array_diff($array22, $val) && !array_diff($val, $array22))) {
$skor = 2;
} elseif (!array_diff($array1, $val) && !array_diff($val, $array1)) {
$skor = 1;
} else {
$skor = 0;
}
}elseif($key == 'aspek_prlh'){
if(count($val) >= 5){
$skor = 5;
}elseif(count($val) == 4){
$skor = 4;
}elseif(count($val) == 3){
$skor = 3;
}elseif(count($val) == 2){
$skor = 2;
}elseif(count($val) == 1){
$skor = 1;
}else{
$skor = 0;
}
}elseif($key == 'jumlah_rpp'){
if($val > 80){
$skor = 5;
}elseif(($val > 60) && ($val < 80)){
$skor = 4;
}elseif(($val > 40) && ($val < 60)){
$skor = 3;
}elseif(($val > 20) && ($val < 40)){
$skor = 2;
}elseif($val <= 20){
$skor = 1;
}else{
$skor = 0;
}
}elseif($key == 'unsur_warga_partisipasi'){
if(count($val) <= 4){
$skor = 1;
}elseif((count($val) >= 4) && ($countLainnya == 1)){
$skor = 2;
}elseif((count($val) >= 4) && ($countLainnya == 2)){
$skor = 3;
}elseif((count($val) >= 4) && ($countLainnya == 3)){
$skor = 4;
}elseif((count($val) >= 4) && ($countLainnya >= 4)){
$skor = 5;
}else{
$skor = 0;
}
}elseif($key == 'upaya_pemeliharaan'){
if(count($val) >= 7){
$skor = 5;
}elseif(count($val) == 6){
$skor = 4;
}elseif(count($val) == 5){
$skor = 3;
}elseif(count($val) == 4){
$skor = 2;
}elseif(count($val) <= 3){
$skor = 1;
}
}elseif($key == 'pelihara_kebersihan'){
$array3 = ["Sekolah bersih", "Sanitasi berfungsi", "Drainase berfungsi"];
$array2 = ["Sekolah bersih", "Sanitasi berfungsi"];
$array22 = ["Sekolah bersih", "Drainase berfungsi"];
if(!empty($val) && !is_array($val)){
$val = array($val);
}
if (!array_diff($array3, $val) && !array_diff($val, $array3)) {
$skor = 3;
} elseif ((!array_diff($array2, $val) && !array_diff($val, $array2)) || (!array_diff($array22, $val) && !array_diff($val, $array22))) {
$skor = 2;
} else {
$skor = 1;
}
}elseif($key == 'upaya_pengurangan_timbulan'){
if(count($val) >= 7){
$skor = 5;
}elseif(count($val) == 6){
$skor = 4;
}elseif(count($val) == 5){
$skor = 3;
}elseif(count($val) == 4){
$skor = 2;
}elseif(count($val) <= 3){
$skor = 1;
}
}elseif($key == 'upaya_daur_ulang_sampah'){
if(count($val) >= 3){
$skor = 3;
}elseif(count($val) == 2){
$skor = 2;
}elseif(count($val) == 1){
$skor = 1;
}
}elseif($key == 'pihak_terlibat_pemindahan_sampah'){
$array3 = ["Peserta didik", "Kader Adiwiyata", "Petugas kebersihan"];
$array2 = ["Peserta didik", "Kader Adiwiyata"];
$array1 = ["Petugas kebersihan"];
if(!empty($val) && !is_array($val)){
$val = array($val);
}
if (!array_diff($array3, $val) && !array_diff($val, $array3)) {
$skor = 3;
} elseif ((!array_diff($array2, $val) && !array_diff($val, $array2))) {
$skor = 2;
}elseif ((!array_diff($array1, $val) && !array_diff($val, $array1))) {
$skor = 1;
}
}elseif($key == 'kegiatan_penghijauan'){
$array3 = ["Penanaman", "Pemeliharaan", "Pembibitan"];
$array2 = ["Penanaman", "Pemeliharaan"];
$array1 = ["Penanaman"];
if(!empty($val) && !is_array($val)){
$val = array($val);
}
if (!array_diff($array3, $val) && !array_diff($val, $array3)) {
$skor = 3;
} elseif ((!array_diff($array2, $val) && !array_diff($val, $array2))) {
$skor = 2;
}elseif ((!array_diff($array1, $val) && !array_diff($val, $array1))) {
$skor = 1;
}
}elseif($key == 'warga_sekolah'){
if(count($val) >= 5){
$skor = 5;
}elseif(count($val) == 4){
$skor = 4;
}elseif(count($val) == 3){
$skor = 3;
}elseif(count($val) == 2){
$skor = 2;
}elseif(count($val) <= 1){
$skor = 1;
}
}elseif($key == 'upaya_konservasi_air'){
if(count($val) >= 7){
$skor = 5;
}elseif(count($val) == 6){
$skor = 4;
}elseif(count($val) == 5){
$skor = 3;
}elseif(count($val) == 4){
$skor = 2;
}elseif(count($val) <= 3){
$skor = 1;
}
}elseif($key == 'upaya_konservasi_energi'){
if(count($val) >= 7){
$skor = 5;
}elseif(count($val) == 6){
$skor = 4;
}elseif(count($val) == 5){
$skor = 3;
}elseif(count($val) == 4){
$skor = 2;
}elseif(count($val) <= 3){
$skor = 1;
}
}elseif($key == 'jumlah_karya_inovatif'){
if($val >= 5){
$skor = 3;
}elseif(($val >= 3) || ($val <= 4)){
$skor = 2;
}elseif(($val >= 1) || ($val <= 2)){
$skor = 1;
}
}elseif($key == 'aksi_penerapan_prlh'){
if(count($val) >= 4){
$skor = 5;
}elseif(count($val) == 3){
$skor = 4;
}elseif(count($val) == 2){
$skor = 3;
}elseif(count($val) == 1){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'pemilahan_sampah'){
if($val == 'Sampah terpilah dan terkelola dengan baik'){
$skor = 3;
}elseif($val == 'Sampah terpilah namun tidak terkelola dengan baik'){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'jejaring_kerja'){
if(count($val) >= 5){
$skor = 5;
}elseif(count($val) == 4){
$skor = 4;
}elseif(count($val) == 3){
$skor = 3;
}elseif(count($val) == 2){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'kegiatan_kampanye'){
if(count($val) >= 5){
$skor = 5;
}elseif(count($val) == 4){
$skor = 4;
}elseif(count($val) == 3){
$skor = 3;
}elseif(count($val) == 2){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'media'){
if($val >= 5){
$skor = 3;
}elseif(($val >= 3) || ($val <= 4)){
$skor = 2;
}elseif(($val >= 1) || ($val <= 2)){
$skor = 1;
}
}elseif($key == 'jumlah_kader'){
if($val > 20){
$skor = 5;
}elseif(($val > 15) || ($val <= 20)){
$skor = 4;
}elseif(($val > 10) || ($val <= 15)){
$skor = 3;
}elseif(($val > 5) || ($val <= 10)){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'kegiatan_kader_adiwiyata'){
if(count($val) >= 5){
$skor = 5;
}elseif(count($val) == 4){
$skor = 4;
}elseif(count($val) == 3){
$skor = 3;
}elseif(count($val) == 2){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'frekuensi_pelaksanaan'){
if($val == '3 kali dalam 1 tahun'){
$skor = 3;
}elseif($val == '2 kali dalam 1 tahun'){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'rencana_kegiatan_pblhs'){
if($val > 80){
$skor = 5;
}elseif(($val > 60) || ($val <= 80)){
$skor = 4;
}elseif(($val > 40) || ($val <= 60)){
$skor = 3;
}elseif(($val > 20) || ($val <= 40)){
$skor = 2;
}else{
$skor = 1;
}
}elseif($key == 'unsur_pemantauan_evaluasi'){
$array3 = ["Kepala sekolah", "Dewan Pendidik", "Komite sekolah","Peserta Didik","Masyarakat"];
$array2 = ["Kepala sekolah", "Dewan Pendidik", "Komite sekolah","Peserta Didik"];
$array1 = ["Kepala sekolah", "Dewan Pendidik", "Komite sekolah"];
if(!empty($val) && !is_array($val)){
$val = array($val);
}
if (!array_diff($array3, $val) && !array_diff($val, $array3)) {
$skor = 3;
} elseif ((!array_diff($array2, $val) && !array_diff($val, $array2))) {
$skor = 2;
}elseif ((!array_diff($array1, $val) && !array_diff($val, $array1))) {
$skor = 1;
}
}
//
return $skor;
}
}
if (!function_exists('formKriteria')) {
/**
* @param $val
*
* @return string
*/
function formKriteria($page_number)
{
$kriteria = FormKriteria::where('page_number',$page_number)->get();
$html = '';
foreach($kriteria as $keyKriteria => $data){
$penilaian = Penilaian::where('key',$data->key)->first();
$html .= '<div class="card mb-2 removeFormKriteria">';
$html .= '<div class="card-body">';
$html .= '<h6><b>'.$data->judul.'</b></h6>';
//QUESTION
if($data->type == 'textarea'){
$html .= '<div class="form-group m-2">';
$html .= '<textarea class="form-control is-required" name="input_'.$data->key.'"></textarea>';
$html .= '</div>';
}elseif($data->type == 'freetext'){
$html .= '<div class="form-group m-2">';
$html .= '<input type="text" class="form-control is-required" name="input_'.$data->key.'">';
$html .= '</div>';
}elseif($data->type == 'checkbox'){
$option = json_decode($data->option);
foreach($option as $keyOption => $dataOption){
$key = 'number_'.$keyKriteria.'_'.$keyOption;
$html .= '<div class="custom-control custom-checkbox m-2">';
$html .= '<input type="checkbox" class="custom-control-input is-required" id="'.$key.'" value="'.$dataOption.'" name="input_'.$data->key.'[]">';
$html .= '<label class="custom-control-label" for="'.$key.'">'.$dataOption.'</label>';
$html .= '</div>';
}
}elseif($data->type == 'radio_button'){
$option = json_decode($data->option);
foreach($option as $keyOption => $dataOption){
$key = 'number_'.$keyKriteria.'_'.$keyOption;
$html .= '<div class="custom-control custom-radio m-2">';
$html .= '<input type="radio" class="custom-control-input is-required" id="'.$key.'" value="'.$dataOption.'" name="input_'.$data->key.'">';
$html .= '<label class="custom-control-label" for="'.$key.'">'.$dataOption.'</label>';
$html .= '</div>';
}
}elseif($data->type == 'number'){
$html .= '<div class="form-group m-2">';
$html .= '<input type="text" class="form-control is-required numberInput" name="input_'.$data->key.'">';
$html .= '</div>';
}
$html .= '</div>';
$html .= '</div>';
if($data->active_lainnya == 1){
$html .= '<div class="card mb-2 removeFormKriteria">';
$html .= '<div class="card-body">';
$html .= '<h6><b>'.$data->judul_lainnya.'</b></h6>';
for($i = 1; $i <= $data->number_answer_lainnya; $i++){
$html .= '<div class="form-group m-2">';
$html .= '<input type="text" class="form-control" placeholder="Jawaban" name="input_lainnya[]">';
$html .= '</div>';
}
$html .= '</div>';
$html .= '</div>';
}
}
$html .= '<div class="card mb-2 removeFormKriteria">';
$html .= '<input type="hidden" name="key" value="'.encode_id($page_number).'">';
$html .= '<div class="card-body">';
$html .= '<h6><b>Link Google Drive (folder/File penyimpanan bukti)</b></h6>';
$html .= '<div class="form-group">';
$html .= '<input type="text" class="form-control" name="input_link_grdive" placeholder="Link Google Drive (folder penyimpanan bukti)">';
$html .= '<small><i>Contoh link : https://example.com</i></small>';
$html .= '</div>';
$html .= '</div>';
$html .= '</div>';
return $html;
}
}
if (!function_exists('levelAdiwiyata')) {
/**
* @param $val
*
* @return string
*/
function levelAdiwiyata($npsn)
{
$kuesioner = Kuesioner::where('npsn',$npsn)->where('tahun',date('Y'))->first();
$data = null;
if(@$kuesioner){
$data = $kuesioner;
}else{
$kuesioner = Kuesioner::where('npsn',$npsn)->where('tahun',(date('Y')-1))->first();
$data = $kuesioner;
}
$level = '';
if(@$data->level == 0){
if((@$data->level == 0) && (@$data->tim_adiwiyata == 2) && (@$data->info_pblhs == 2) ){
$level = '2';
}elseif((@$data->level == 0) && (@$data->tim_adiwiyata == 2)){
$level = '1';
}else{
$level = '0';
}
}elseif(@$data->level == 1){
$level = '3';
}elseif(@$data->level == 2){
$level = '4';
}else{
$level = '0';
}
return $level;
}
}
if (!function_exists('taskLabel')) {
/**
* @param $val
*
* @return string
*/
function taskLabel($val)
{
if ($val == 'store') {
$task = 'save';
} elseif ($val == 'save_permission') {
$task = 'save group access';
} elseif ($val == 'destroy') {
$task = 'delete';
} elseif ($val == 'batch') {
$task = 'delete';
} else {
$task = $val;
}
return $task;
}
}
if (!function_exists('logActivity')) {
/**
* @param $request
* @param $note
*/
function logActivity($request, $note)
{
$repository = app(\App\Models\Log::class);
$data = [
'module' => $request->route()->getAction('prefix'),
'task' => taskLabel($request->route()->getActionMethod()),
'user_id' => session('uid'),
'ipaddress' => $request->getClientIp(),
'useragent' => $request->header('User-Agent'),
'note' => $note,
'created_at' => \Carbon\Carbon::now()
];
if (session('superuser') == false)
$repository->create($data);
}
}
if (!function_exists('trimId')) {
/**
* @param $val
* @return array
*/
function trimId($val)
{
$string = explode('+', $val);
return $string;
}
}
if (!function_exists('dateTime')) {
/**
* make secure id
*
* @param string|null $val
*
* @return string
*/
function dateTime($date)
{
return date('d-m-Y H:i:s',strtotime(@$date));
}
}
if (!function_exists('encode_id')) {
/**
* make secure id
*
* @param string|null $val
*
* @return string
*/
function encode_id(?string $val = ''): string
{
$params = ['val' => $val];
return rtrim(base64_encode(serialize($params)), "=");
}
}
if (!function_exists('decode_id')) {
/**
* @param string|null $val
* ${STATIC}
*
* @return mixed|null
* @author alex.gz <amqit.consultant@gmail.com>
* @created 02/12/2023 4:28
*
*/
function decode_id(?string $val = ''): mixed
{
$secure = unserialize(base64_decode($val));
return $secure ? $secure['val'] : null;
}
}
if (!function_exists('permission')) {
/**
* @param $access
* @param $key
* @param string $method
* @param bool $view
*
* @return mixed
*/
function permission($access, $key, string $method = 'menu', bool $view = false): mixed
{
if (@session('group_id') != 1) {
if ($method == 'module') {
if (is_array($access)) {
$model = MasterAccessMenu::where('module', 'LIKE', "{$key}%")->where('ms_group_id', session('group_id'))->first();
$query = count(array_intersect((array)$access, (array)$model->access));
} else {
$query = MasterAccessMenu::where($access, true)->where('module', 'LIKE', $key.'%')->where('ms_group_id', session('group_id'))->count();
}
} else {
$query = MasterAccessMenu::where($access, true)->where('ms_menu_id', $key)->where('ms_group_id', session('group_id'))->count();
}
if ($query > 0) {
return true;
} else {
return false;
}
} else {
return true;
}
}
}
if (!function_exists('activeMenuClass')) {
/**
* Helper to grab the application version.
*
* @return mixed
*/
function activeMenuClass($route){
// dd(request()->route()->getName());
// if(request()->route()->getName() == $route){
// return true;
// }else{
// return false;
// }
if (\Str::is($route, request()->route()->getName())) {
return true;
} else {
return false;
}
}
}
if (!function_exists('renderMenu')) {
/**
* Loops through a folder and requires all PHP files
* Searches sub-directories as well.
*
* @param $folder
*/
function renderMenu()
{
$parent = MasterMenu::where('status',true)->where('menu_type','sidebar')->where('parent_id',0)->orderBy('ordering','ASC')->get();
$html = '';
foreach ($parent as $p1) {
// echo $p1->MsMenuId.'<br>';
$child2 = MasterMenu::where('status',true)->where('menu_type','sidebar')->where('parent_id',$p1->MsMenuId)->get();
$access1 = permission('is_read', $p1->MsMenuId, 'menu', true);
$ch1 = count($child2) > 0 ? '' : '';
$link1 = count($child2) > 0 ? '' : 'menu-link';
$active = activeMenuClass($p1->module) ? 'active' : '';
// dd($p1->route);
if ($access1) {
$active1 = $active ? ' active ' . null : null;
$html .= '<li class="' . $ch1 . $active1 . '"><a class="' . $link1 . '" href="' . url($p1->url) . '"><i class="' . $p1->menu_icons . '"></i> <span class="nav-link-text" data-i18n="nav.application_intel">' . @$p1->title.'</span>';
if (count($child2) > 0) {
$html .= '</a>';
$html .= '<ul class="menu-subs">';
foreach ($child2 as $p2) {
$child3 = MasterMenu::where('status',true)->where('menu_type','sidebar')->where('parent_id',$p2->MsMenuId)->get();
$access2 = permission('is_read', $p2->MsMenuId, 'menu', true);
$ch2 = count($child3) > 0 ? '' : '';
$link2 = count($child3) > 0 ? '' : 'menu-link';
if ($access2) {
$active2 = activeMenuClass($p2->module) ? 'active' : '';
$html .= '<li class="' . $ch2 . '"><a class="' . $link2 . $active2 . '" href="' . url($p2->url) . '"> <i class="' . $p2->menu_icons . '"></i> <span class="nav-link-text" data-i18n="nav.application_intel">' . @$p2->title.'<span>';
if (count($child3) > 0) {
$html .= '</a>';
$html .= '<ul>';
foreach ($child3 as $p3) {
$child4 = MasterMenu::where('status',true)->where('menu_type','sidebar')->where('parent_id',$p3->MsMenuId)->get();
$access3 = permission('is_read', $p3->MsMenuId, 'menu', true);
$ch3 = count($child4) > 0 ? '' : '';
$link3 = count($child4) > 0 ? '' : 'menu-link';
if ($access3) {
$active2 = activeMenuClass($p3->module) ? 'active' : '';
// $active3 = $active ? ' ' . null : null;
$html .= '<li class="' . $ch3 . '"><a class="' . $link3 . $active3 . '" href="' . url($p3->url) . '"> <span class="nav-link-text" data-i18n="nav.application_intel">' . @$p3->title.'</span>';
if (count($child4) > 0) {
$html .= '</a>';
$html .= '<ul class="menu-subs">';
foreach ($child4 as $p4) {
$html .= '<li class=" ' . null . '"><a class="menu-link" href="' . url($p4->url) . '"> <span class="nav-link-text" data-i18n="nav.application_intel">' . @$p4->title.'<span>';
}
$html .= '</ul>';
} else {
$html .= '</a>';
}
$html .= '</li>';
}
}
$html .= '</ul>';
} else {
$html .= '</a>';
}
$html .= '</li>';
}
}
$html .= '</ul>';
} else {
$html .= '</a>';
}
$html .= '</li>';
}
}
return $html;
}
}
if (!function_exists('include_route_files')) {
/**
* Loops through a folder and requires all PHP files
* Searches sub-directories as well.
*
* @param $folder
*/
function include_route_files($folder)
{
include_files_in_folder($folder);
}
}
if (!function_exists('include_files_in_folder')) {
/**
* Loops through a folder and requires all PHP files
* Searches sub-directories as well.
*
* @param $folder
*/
function include_files_in_folder($folder)
{
try {
$rdi = new RecursiveDirectoryIterator($folder);
$it = new RecursiveIteratorIterator($rdi);
while ($it->valid()) {
if (!$it->isDot() && $it->isFile() && $it->isReadable() && $it->current()->getExtension() === 'php') {
require $it->key();
}
$it->next();
}
} catch (Exception $e) {
echo $e->getMessage();
}
}
}