Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

eval(base64_decode('DQovKioNCiAqIENyZWF0ZWQgYnkgSW50ZWxsaUogSURFQS4NCiAqIFVzZXI6IG11bHRhem..

Decoded Output download


/**
 * Created by IntelliJ IDEA.
 * User: multazam
 * Date: 07/07/20
 * Time: 14:10
 */

class Cbtbanksoal extends CI_Controller {

	public function __construct(){
		parent::__construct();
		if (!$this->ion_auth->logged_in()){
			redirect('auth');
		}else if ( !$this->ion_auth->is_admin() && !$this->ion_auth->in_group('guru')){
			show_error('Hanya Administrator dan guru yang diberi hak untuk mengakses halaman ini, <a href="'.base_url('dashboard').'">Kembali ke menu awal</a>', 403, 'Akses Terlarang');
		}
		$this->load->library('upload');
		//$this->load->library('MY_Upload', 'my_upload');
		$this->load->library(['datatables', 'form_validation']);// Load Library Ignited-Datatables
		$this->form_validation->set_error_delimiters('','');

		$this->load->helper('my');// Load Library Ignited-Datatables
		$this->load->model('Master_model', 'master');
		$this->load->model('Dashboard_model', 'dashboard');
		$this->load->model('Cbt_model', 'cbt');
		$this->load->model('Log_model', 'logging');
		$this->load->model('Kelas_model', 'kelas');
		$this->load->model('Dropdown_model', 'dropdown');
	}

	public function output_json($data, $encode = true)
	{
		if($encode) $data = json_encode($data);
		$this->output->set_content_type('application/json')->set_output($data);
	}

	public function index() {
		$user = $this->ion_auth->user()->row();
		$setting = $this->dashboard->getSetting();
		$data = [
			'user' => $user,
			'judul'	=> 'Bank Soal',
			'subjudul'=> 'Soal',
			'setting'		=> $setting
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;
        $data['levels'] = $this->dropdown->getAllLevel($setting->jenjang);
        $data['mapels'] = $this->dropdown->getAllMapel();

        $type = $this->input->get('type');
		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);
			$data['gurus'] = $this->dropdown->getAllGuru();
            $data['kelas'] = $this->cbt->getKelas($tp->id_tp, $smt->id_smt);

            $data['filters'] = ['0'=>'Semua', '1'=>'Guru', '2'=>'Mapel', '3'=>'Level'];
            $data['id_filter'] = $type == null ? '' : $type;
            if ($type == '1') {
                $id_guru = $this->input->get('id');
                $data['id_guru'] = $id_guru;
                $data['banks'] = $this->cbt->getDataBank($id_guru);

                $data['id_mapel'] = '';
                $data['id_level'] = '';
            } elseif ($type == '2') {
                $id_mapel = $this->input->get('id');
                $data['id_mapel'] = $id_mapel;
                $data['banks'] = $this->cbt->getDataBank(null, $id_mapel);

                $data['id_guru'] = '';
                $data['id_level'] = '';
            } elseif ($type == '3') {
                $id_level = $this->input->get('id');
                $data['id_level'] = $id_level;
                $data['banks'] = $this->cbt->getDataBank(null, null, $id_level);

                $data['id_guru'] = '';
                $data['id_mapel'] = '';
            } else {
                $data['banks'] = $this->cbt->getDataBank();
                $data['id_guru'] = null;
                $data['id_mapel'] = null;
                $data['id_level'] = null;
            }

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/data');
			$this->load->view('_templates/dashboard/_footer');
		}else{
			$guru = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);
			$nguru[$guru->id_guru] = $guru->nama_guru;
			$data['guru'] = $guru;
            $data['gurus'] = $nguru;
            $data['kelas'] = $this->cbt->getKelas($tp->id_tp, $smt->id_smt);

            $data['filters'] = ['0'=>'Semua', '2'=>'Mapel', '3'=>'Level'];
            $data['id_filter'] = $type == null ? '' : $type;
            if ($type == '2') {
                $id_mapel = $this->input->get('id');
                $data['id_mapel'] = $id_mapel;
                $data['banks'] = $this->cbt->getDataBank($guru->id_guru, $id_mapel);

                $data['id_guru'] = '';
                $data['id_level'] = '';
            } elseif ($type == '3') {
                $id_level = $this->input->get('id');
                $data['id_level'] = $id_level;
                $data['banks'] = $this->cbt->getDataBank($guru->id_guru, null, $id_level);

                $data['id_guru'] = '';
                $data['id_mapel'] = '';
            } else {
                $data['id_guru'] = $guru->id_guru;
                $data['banks'] = $this->cbt->getDataBank($guru->id_guru);
                $data['id_mapel'] = '';
                $data['id_level'] = '';
            }

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/data');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function data($guru=null) {
		$this->output_json($this->cbt->getDataBank($guru), false);
	}

    public function dataTable($guru=null) {
        $this->output_json($this->cbt->getDataTableBank($guru), false);
    }

    public function getMapelGuru() {
        $id_guru = $this->input->get('id_guru', true);

        $tp = $this->master->getTahunActive();
        $smt = $this->master->getSemesterActive();
        $mapel_guru = $this->kelas->getGuruMapelKelas($id_guru, $tp->id_tp, $smt->id_smt);
        $mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

        $arrMapel = [];
        if ($mapel!=null){
            foreach ($mapel as $m) {
                $arrMapel[$m->id_mapel] = $m->nama_mapel;
            }
        }

        $this->output_json($arrMapel);
    }

	public function getKelasLevel() {
		$level = $this->input->get('level', true);
		$id_guru = $this->input->get('id_guru', true);
		$id_mapel = $this->input->get('mapel', true);

        $tp = $this->master->getTahunActive();
        $smt = $this->master->getSemesterActive();
		$mapel_guru = $this->kelas->getGuruMapelKelas($id_guru, $tp->id_tp, $smt->id_smt);
        $arrKelas = [];
        $arrMapel = [];
        $mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

        foreach ($mapel as $m) {
            $arrMapel[$m->id_mapel] = $m->nama_mapel;
            if ($id_mapel===$m->id_mapel){
                foreach ($m->kelas_mapel as $kls) {
                    array_push($arrKelas, $kls->kelas);
                }
            }
        }

		$this->output_json(['mapel'=> $arrMapel, 'kelas'=>$this->cbt->getKelasByLevel($level, $arrKelas)]);
	}

	public function addBank() {
		$user = $this->ion_auth->user()->row();
        $setting = $this->dashboard->getSetting();
		$data = [
			'user'      => $user,
			'judul'	    => 'Bank Soal',
			'subjudul'  => 'Buat Bank Soal',
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;

		$data['setting'] = $this->dashboard->getSetting();
		$data['bank'] = json_decode(json_encode($this->cbt->dummy($setting->jenjang)));
		$data['jenis'] = $this->cbt->getAllJenisUjian();
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);
			$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);
			$data['id_guru'] = '';
			$data['gurus'] = $this->dropdown->getAllGuru();
			$data['mapel'] = $this->dropdown->getAllMapel();

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/add');
			$this->load->view('_templates/dashboard/_footer');
		}else{
			$guru = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);
			$nguru[$guru->id_guru] = $guru->nama_guru;
            $data['gurus'] = $nguru;
			$data['guru'] = $guru;
			$data['id_guru'] = $guru->id_guru;

			$mapel_guru = $this->kelas->getGuruMapelKelas($guru->id_guru, $tp->id_tp, $smt->id_smt);
			$mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

			$arrMapel = [];
			$arrKelas = [];
			foreach ($mapel as $m) {
				$arrMapel[$m->id_mapel] = $m->nama_mapel;
				foreach ($m->kelas_mapel as $kls) {
					$arrKelas[$m->id_mapel][] = [
						'id_kelas'	=>	$kls->kelas,
						'nama_kelas'=>$this->dropdown->getNamaKelasById($tp->id_tp, $smt->id_smt, $kls->kelas)];
				}
			}

			$arrId = [];
			if (count($mapel) > 0) {
                foreach ($mapel[0]->kelas_mapel as $id_mapel) {
                    array_push($arrId, $id_mapel->kelas);
                }
            }

			$data['mapel_guru'] = $mapel_guru;
			$data['mapel'] = $arrMapel;
			$data['arrkelas'] = $arrKelas;
			$data['kelas'] = count($arrId) > 0 ? $this->dropdown->getAllKelasByArrayId($tp->id_tp, $smt->id_smt, $arrId) : [];

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/add');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function editBank() {
		$id_bank = $this->input->get('id_bank', true);
		$id_guru = $this->input->get('id_guru', true);
        $setting = $this->dashboard->getSetting();

		$user = $this->ion_auth->user()->row();
		$data = [
			'user'      => $user,
			'judul'	    => 'Edit Bank Soal',
			'subjudul'  => 'Edit Bank Soal'
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;
		$data['bulan'] = $this->dropdown->getBulan();

		$data['setting'] = $this->dashboard->getSetting();
		$data['jenis'] = $this->cbt->getAllJenisUjian();
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);
		$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);

		$data['bank'] = $this->cbt->getDataBankById($id_bank);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);
			$data['id_guru'] = $id_guru;
			$data['gurus'] = $this->dropdown->getAllGuru();

			$arrMapel = [];
			$mapel_guru = $this->kelas->getGuruMapelKelas($id_guru, $tp->id_tp, $smt->id_smt);
			$mapel = $mapel_guru->mapel_kelas != null ? json_decode(json_encode(unserialize($mapel_guru->mapel_kelas))) : [];
			foreach ($mapel as $m) {
				$arrMapel[$m->id_mapel] = $m->nama_mapel;
			}
			$data['mapel'] = $arrMapel;
			$data['mapel_guru'] = $mapel_guru;
			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/add');
			$this->load->view('_templates/dashboard/_footer');
		}else{
			$guru = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);
			$nguru[$guru->id_guru] = $guru->nama_guru;
			$mapel_guru = $this->kelas->getGuruMapelKelas($guru->id_guru, $tp->id_tp, $smt->id_smt);
			$mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

			$arrMapel = [];
			foreach ($mapel as $m) {
				$arrMapel[$m->id_mapel] = $m->nama_mapel;
			}

            $data['gurus'] = $nguru;
			$data['mapel_guru'] = $mapel_guru;
			$data['guru'] = $guru;
			$data['id_guru'] = $guru->id_guru;
			$data['mapel'] = $arrMapel;

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/add');
			//$this->load->view('members/guru/cbt/banksoal/add');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function saveBank() {
		if ($this->input->post()) {
            $tp = $this->master->getTahunActive();
            $smt = $this->master->getSemesterActive();

			$this->cbt->saveBankSoal($tp->id_tp, $smt->id_smt);
			$status = TRUE;
		} else {
			$status = FALSE;
		}
		$data['status'] = $status;

		$id = $this->input->post('id_bank', true);
		if (!$id) {
			$this->logging->saveLog(3, 'menambah bank soal');
		} else {
			$this->logging->saveLog(4, 'mengedit bank soal');
		}

		$this->output_json($data);
	}

	public function deleteBank() {
		$id = $this->input->get('id_bank', true);
		if ($this->cbt->cekJadwalBankSoal($id)>0) {
			$this->output_json(['status' => false, 'message' => 'Ada jadwal ujian yang menggunakan bank soal ini']);
		} else {
			if ($this->master->delete('cbt_soal', $id, 'bank_id')) {
                //if ($this->master->delete('cbt_soal_siswa', $id, 'id_bank')) {}
				if ($this->master->delete('cbt_bank_soal', $id, 'id_bank')) {
                    $this->logging->saveLog(5, 'menghapus bank soal');
                    $this->output_json(['status' => true, 'message' => 'berhasil' ]);
				}
			}
		}
	}

    public function detail($id) {
        $user = $this->ion_auth->user()->row();
        $data = [
            'user'      => $user,
            'judul'	    => 'Detail Soal',
            'subjudul'  => 'Detail Soal'
        ];
        $data['setting'] = $this->dashboard->getSetting();

        $tp = $this->master->getTahunActive();
        $smt = $this->master->getSemesterActive();

        $data['tp'] = $this->dashboard->getTahun();
        $data['tp_active'] = $tp;
        $data['smt'] = $this->dashboard->getSemester();
        $data['smt_active'] = $smt;
        $data['bank'] = $this->cbt->getDataBankById($id);
        $data['soals'] = $this->cbt->getAllSoalByBank($id);
        $data['kelas'] = $this->cbt->getKelas($tp->id_tp, $smt->id_smt);
        if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);

            $this->load->view('_templates/dashboard/_header', $data);
            $this->load->view('cbt/banksoal/detail');
            $this->load->view('_templates/dashboard/_footer');
        }else{
            $data['guru'] = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);

            $this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/detail');
            $this->load->view('members/guru/templates/footer');
        }
    }

    public function saveSelected() {
        $bank_id = $this->input->post('id_bank', true);
        $jenis = $this->input->post('jenis', true);
        $soal = count($this->input->post('soal', true));
        $unchek = json_decode($this->input->post('uncheck', true));
        $arrId = [];
        for ($i = 0; $i <= $soal; $i++) {
            $id = $this->input->post('soal['.$i.']', true);
            if ($id!=null) array_push($arrId, $id);
        }

        $updated = 0;
        foreach ($arrId as $id) {
            $this->db->set('tampilkan', 1);
            $this->db->where('id_soal', $id);
            $this->db->update('cbt_soal');
            $updated ++;
        }

        foreach ($unchek as $id) {
            $this->db->set('tampilkan', 0);
            $this->db->where('id_soal', $id);
            $this->db->update('cbt_soal');
        }

        sleep(1);
        $bank = $this->cbt->getDataBankById($bank_id);
        $soals = $this->cbt->getAllSoalByBank($bank_id);

        $total_soal_tampil = isset(array_count_values(array_column($soals, 'tampilkan'))['1']) ? array_count_values(array_column($soals, 'tampilkan'))['1'] : 0;
        $total_soal_seharusnya_tampil = $bank->tampil_pg + $bank->tampil_kompleks + $bank->tampil_jodohkan + $bank->tampil_isian + $bank->tampil_esai;
        $tampil_kurang = $total_soal_tampil < $total_soal_seharusnya_tampil;
        $status_soal = $tampil_kurang ? '0' : '1';

        $this->db->set('status_soal', $status_soal);
        $this->db->where('id_bank', $bank_id);
        $this->db->update('cbt_bank_soal');

        $data['check'] = $updated;
        $this->output_json($data);
    }

    public function copyBankSoal($id_bank) {
        $tp = $this->dashboard->getTahunActive();
        $smt = $this->dashboard->getSemesterActive();
        $bank = $this->cbt->getDataBankById($id_bank);
        $soals = $this->cbt->getAllSoalByBank($id_bank);

        $data = [
            'id_tp'             => $tp->id_tp,
            'id_smt'            =>$smt->id_smt,
            'bank_jenis_id'     => $bank->bank_jenis_id,
            'bank_kode'         =>$bank->bank_kode,
            'bank_level'        => $bank->bank_level,
            'bank_kelas'        => $bank->bank_kelas,
            'bank_mapel_id'     => $bank->bank_mapel_id,
            'bank_jurusan_id'   => $bank->bank_jurusan_id,
            'bank_guru_id'      => $bank->bank_guru_id,
            'bank_nama'         => $bank->bank_nama,
            'kkm'               => $bank->kkm,
            'deskripsi'         => $bank->deskripsi,
            'jml_soal'          => $bank->jml_soal,
            'tampil_pg'         => $bank->tampil_pg,
            'bobot_pg'          => $bank->bobot_pg,
            'jml_kompleks'      => $bank->jml_kompleks,
            'tampil_kompleks'   => $bank->tampil_kompleks,
            'bobot_kompleks'    => $bank->bobot_kompleks,
            'jml_jodohkan'      => $bank->jml_jodohkan,
            'tampil_jodohkan'   => $bank->tampil_jodohkan,
            'bobot_jodohkan'    => $bank->bobot_jodohkan,
            'jml_isian'         => $bank->jml_isian,
            'tampil_isian'      => $bank->tampil_isian,
            'bobot_isian'       => $bank->bobot_isian,
            'jml_esai'          => $bank->jml_esai,
            'tampil_esai'       => $bank->tampil_esai,
            'bobot_esai'        => $bank->bobot_esai,
            'opsi'              => $bank->opsi,
            'date'              => date('Y-m-d H:i:s'),
            'status'            => $bank->status,
            'soal_agama'        => $bank->soal_agama
        ];

        $result = $this->master->create('cbt_bank_soal', $data);
        $id = $this->db->insert_id();
        foreach ($soals as $soal) {
            unset($soal->id_soal);
            $soal->bank_id = $id;
            $soal->created_on = time();
            $soal->updated_on = time();
        }
        $this->db->insert_batch('cbt_soal', $soals);

        //$result['status'] = 'Materi berhasil dibuat';
        $this->logging->saveLog(3, 'membuat bank soal');

        $this->output_json($result);
    }

	public function buatsoal($id_bank) {
		//$id = $this->input->post('id_bank', true);
		$user = $this->ion_auth->user()->row();
		$data = [
			'user'      => $user,
			'judul'	    => 'Buat Soal',
			'subjudul'  => 'Buat Soal'
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;

		$setting = $this->dashboard->getSetting();
        $data['setting'] = $setting;

        $tab = $this->input->get('tab', true);
        $jenis = $tab == null ? "1" : $tab;
        $data['tab_active'] = $jenis;
        $bank = $this->cbt->getDataBankById($id_bank);

        $data['soal'] = null;//$this->cbt->getSoalByIdBank($id_bank, $jenis);
		$data['soal_ada'] = $this->cbt->cekSoalAda($id_bank, $jenis);
        $data['soal_belum_komplit'] = $this->cbt->cekSoalBelumKomplit($id_bank, $jenis, $setting->jenjang);

        //$total_pg = $bank->jml_soal;
        //$jml_soal_pg = $this->cbt->getTotalSoal($id_bank, 1);
        if ($jenis == "1") $data['jml_pg'] = $this->cbt->getNomorSoalTerbesar($id_bank, 1);
        elseif ($jenis == "2") $data['jml_pg2'] = $this->cbt->getNomorSoalTerbesar($id_bank, 2);
        elseif ($jenis == "3") $data['jml_jodohkan'] = $this->cbt->getNomorSoalTerbesar($id_bank, 3);
        elseif ($jenis == "4") $data['jml_isian'] = $this->cbt->getNomorSoalTerbesar($id_bank, 4);
        elseif ($jenis == "5") $data['jml_essai'] = $this->cbt->getNomorSoalTerbesar($id_bank, 5);
        //$data['jml_total'] = $this->cbt->getTotalSoal($id_bank);
        $data['bank'] = $bank;

        $data['soals'] = $this->cbt->getAllSoalByBank($id_bank, $jenis);
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);
		$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/soal');
			$this->load->view('_templates/dashboard/_footer');
		} else {
            $data['guru'] = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/soal');
			$this->load->view('members/guru/templates/footer');
		}
	}

    public function getSoalByNomor() {
        $bank_id = $this->input->get('bank_id', true);
        $nomor = $this->input->get('nomor', true);
        $jenis = $this->input->get('jenis', true);
        $soal = $this->cbt->getSoalByNomor($bank_id, $nomor, $jenis);
        $data = $soal;
        if ($data != null) {
            $data->file = unserialize($soal->file);
            if ($jenis == '2') {
                $t = @unserialize($soal->opsi_a);
                if ($t !== false) $data->opsi_a = $t;
                else ($data->opsi_a = false);

                $j = @unserialize($soal->jawaban);
                if ($j !== false) $data->jawaban = $j;
                else ($data->jawaban = false);
            } elseif ($jenis == '3') {
                $j = @unserialize($soal->jawaban);
                if ($j !== false) $data->jawaban = $j;
                else ($data->jawaban = false);
            }
        }
        $this->output_json($data);
    }

    public function tambahSoal(){
        $bank = $this->input->post('bank', true);
        $nomor = $this->input->post('nomor', true);
        $jenis = $this->input->post('jenis', true);

        $data = [
            'bank_id'		=> $bank,
            'nomor_soal'	=> $nomor,
            'jenis'			=> $jenis,
            'tampilkan'		=> 0,
            'created_on'	=> time(),
            'updated_on'	=> time()
        ];

        $insert = $this->db->insert('cbt_soal', $data);
        $this->output_json($insert);
    }

	public function importsoal($id) {
		$user = $this->ion_auth->user()->row();
        $setting = $this->dashboard->getSetting();
		$data = [
			'user'      => $user,
			'judul'	    => 'Import Bank Soal',
			'subjudul'  => 'Import Bank Soal'
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;

		$data['setting'] = $setting;
		$data['bank'] = $this->cbt->getDataBankById($id);
		$data['jenis'] = $this->cbt->getAllJenisUjian();
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);
		$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/import');
			$this->load->view('_templates/dashboard/_footer');
		}else{
            $data['guru'] = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/import');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function previewExcel() {
		$config['upload_path']		= './uploads/import/';
		$config['allowed_types']	= 'xls|xlsx|csv';
		$config['max_size']			= 2048;
		$config['encrypt_name']		= true;

		$this->load->library('upload', $config);

		if (!$this->upload->do_upload('upload_file')) {
			$error = $this->upload->display_errors();
			echo $error;
			die;
		} else {
			$file = $this->upload->data('full_path');
			$ext = $this->upload->data('file_ext');

			switch ($ext) {
				case '.xlsx':
					$reader = new \PhpOffice\PhpSpreadsheet\Reader\Xlsx();
					break;
				case '.xls':
					$reader = new \PhpOffice\PhpSpreadsheet\Reader\Xls();
					break;
				case '.csv':
					$reader = new \PhpOffice\PhpSpreadsheet\Reader\Csv();
					break;
				default:
					echo "unknown file ext";
					die;
			}

			$spreadsheet = $reader->load($file);
			$sheetData = $spreadsheet->getActiveSheet()->toArray();
			$data = [];
			for ($i = 1; $i < count($sheetData); $i++) {
				if ($sheetData[$i][0] != null) {
					$data[] = [
						'nama' => $sheetData[$i][1],
						'nip' => $sheetData[$i][2],
						'kode' => $sheetData[$i][3],
						'username' => $sheetData[$i][4],
						'password' => $sheetData[$i][5],
					];
					//$jurusan[] = $sheetData[$i][0];
				}
			}

			unlink($file);
			echo json_encode($data);
		}
	}

	public function previewWord($id_bank) {
		$config['upload_path']		= './uploads/import';
		$config['allowed_types']	= 'docx';
		$config['max_size']			= 2048;
		$config['encrypt_name']		= true;

		//$this->load->library('upload', $config);
		$this->upload->initialize($config);

		if (!$this->upload->do_upload('upload_file')) {
			$error = $this->upload->display_errors();
			echo $error;
			die;
		} else {
			$file = $this->upload->data('full_path');
			$phpWord = \PhpOffice\PhpWord\IOFactory::load($file);
			$htmlWriter = new \PhpOffice\PhpWord\Writer\HTML($phpWord);
			try {
				$htmlWriter->save('./uploads/temp/doc.html');
				//$htmlWriter->save("php://output");
			} catch (\PhpOffice\PhpWord\Exception\Exception $e) {
			}

			unlink($file);
			$text = file_get_contents('./uploads/temp/doc.html');

			$dom = new DOMDocument();
            $dom->preserveWhiteSpace = false;
            $dom->formatOutput = true;
			$dom->loadHTML($text);

			$images = $dom->getElementsByTagName('img');
			$numimg = 1;
			foreach ($images as $image) {
				$base64_image_string = $image->getAttribute('src');
				//echo $image->getAttribute('src') . "
";

				//usage:  if( substr( $img_src, 0, 5 ) === "data:" ) {  $filename=save_base64_image($base64_image_string, $output_file_without_extentnion, getcwd() . "/application/assets/pins/$user_id/"); }
				//data is like:    data:image/png;base64,asdfasdfasdf
				$splited = explode(',', substr( $base64_image_string , 5 ) , 2);
				$mime=$splited[0];
				$data=$splited[1];

				$mime_split_without_base64=explode(';', $mime,2);
				$mime_split=explode('/', $mime_split_without_base64[0],2);
				if(count($mime_split)==2)
				{
					$extension=$mime_split[1];
					if($extension=='jpeg')$extension='jpg';
					$output_file = 'img_'.$id_bank.$numimg.'.'.$extension;
				}
				file_put_contents( './uploads/bank_soal/' . $output_file, base64_decode($data) );
				$image->setAttribute('src', 'uploads/bank_soal/' . $output_file);
				$numimg ++;
				//return $output_file_with_extension;
			}

			$newhtml = $dom->saveHTML();
			/*
			$dom->loadHTML($newhtml);
			$data = [];
			$tables = $dom->getElementsByTagName('table');
            $arrJenis = ['1', '2', '3', '4', '5'];
            $UPPERCASE_LETTERS = range(chr(65),chr(90));
            $LOWERCASE_LETTERS = range(chr(97),chr(122));
            $NUMBERS_ZERO_THROUGH_NINE = range(chr(48),chr(57));


            for ($t=0;$t<$tables->count(); $t++) {
                $rows = $tables->item(0)->getElementsByTagName('tr');
                $nop = 1;
                for ($i = 1; $i < $rows->count(); $i++) {
                    $cols = $rows[$i]->getElementsByTagName('td');

                    $nomor = trim($cols->item(0)->nodeValue);
                    $nomor_kosong = (int)$nomor === 0;

                    $gambar = $cols->item(1)->getElementsByTagName('img');
                    $soal_gambar = $gambar->count() > 0;
                    $sSoal = trim($cols->item(1)->nodeValue);
                    $soal_kosong = !$soal_gambar && strlen($sSoal) < 3;

                    $jenis = trim($cols->item(2)->nodeValue);
                    $jenis_kosong = !in_array($jenis, $arrJenis);

                    $opsi = trim($cols->item(3)->nodeValue);
                    $opsi_kosong = !in_array($opsi, $UPPERCASE_LETTERS);

                    $jgambar = $cols->item(4)->getElementsByTagName('img');
                    $jwb_gambar = $gambar->count() > 0;
                    $jwbn = trim($cols->item(4)->nodeValue);
                    $jwbn_kosong = !$jwb_gambar && $jwbn === "";

                    $kunci = strtolower(trim($cols->item(5)->nodeValue));
                    $kunci_kosong = $kunci !== 'v';

                    $data[] = [
                        'nomor_soal' => $nop,
                        'soal'       => trim($this->innerXML($cols->item(1))),
                        'jenis'		 => trim($cols->item(2)->nodeValue),
                        'opsi'       => trim($cols->item(3)->nodeValue),
                        'jawaban'  => trim($cols->item(4)->nodeValue),//$dom->saveXML($cols->item(4), LIBXML_NOEMPTYTAG),
                        'kunci'    => $kunci,

                        'utf8_jenis' => mb_convert_encoding(trim($cols->item(2)->nodeValue), 'UTF-8', 'UTF-8'),
                        'soal_gambar' => $soal_gambar,
                        'soal_kosong' => $soal_kosong,
                        'opsi_kosong' => $opsi_kosong,
                        'kunci_kosong' => $kunci_kosong,
                        'jwbn_kosong' => $jwbn_kosong,
                    ];
                    $nop ++;
                }
            }
            /*
            $rows = $tables->item(0)->getElementsByTagName('tr');

            $nop = 1;
            for ($i = 1; $i < $rows->count(); $i++) {
                $cols = $rows[$i]->getElementsByTagName('td');
                $data[] = [
                    'jenis'		=> '1',
                    'nomor_soal'=> $nop,
                    'soal'       => trim($this->innerXML($cols->item(1))),
                    'jawaban_a'  => trim($this->innerXML($cols->item(2))),
                    'jawaban_b'  => trim($this->innerXML($cols->item(3))),
                    'jawaban_c'  => trim($this->innerXML($cols->item(4))),
                    'jawaban_d'  => trim($this->innerXML($cols->item(5))),
                    'jawaban_e'  => trim($this->innerXML($cols->item(6))),
                    'jawaban'  	 => trim($cols->item(7)->nodeValue)
                ];
                $nop ++;
            }

            if ($tables->item(1) !=null) {
                $rowsEssai = $tables->item(1)->getElementsByTagName('tr');
                $noe = 1;
                for ($j = 1; $j < $rowsEssai->count(); $j++) {
                    $cols = $rowsEssai[$j]->getElementsByTagName('td');
                    $data[] = [
                        'jenis'		=> '2',
                        'nomor_soal'=> $noe,
                        'soal'       => $this->innerXML($cols->item(1)),
                        'jawaban_a'  => '',
                        'jawaban_b'  => '',
                        'jawaban_c'  => '',
                        'jawaban_d'  => '',
                        'jawaban_e'  => '',
                        'jawaban'  => $this->innerXML($cols->item(2))
                    ];
                    $noe ++;
                }
            }
            //echo json_encode(array('pg' => $data));
            */
            $dataInsert = json_decode(json_encode($newhtml));
            //$json = json_decode(json_encode($data));
            $result['pg'] = $dataInsert;
            //$result['json'] = $json;
            $result['type'] = 'html';
		}

		/*
		// INSERT
        $bank = $this->cbt->getDataBankById($id_bank);
        $soal_ada = $this->cbt->cekSoalAda($id_bank);
        if (count($soal_ada) > 0) {
            $this->db->where('bank_id', $id_bank);
            $this->db->delete('cbt_soal');
        }

        $data = [];
        foreach ($dataInsert as $pg) {
            if ($pg->jenis == 1) {
                $tampilkan = $pg->nomor_soal > $bank->jml_soal ? 0 : 1;
            } else {
                $tampilkan = $pg->nomor_soal > $bank->jml_esai ? 0 : 1;
            }

            $data[] = [
                'bank_id'		=> $id_bank,
                'nomor_soal'	=> $pg->nomor_soal,
                'jenis'			=> $pg->jenis,
                'soal'			=> $pg->soal,
                'opsi_a'		=> $pg->jawaban_a,
                'opsi_b'		=> $pg->jawaban_b,
                'opsi_c'		=> $pg->jawaban_c,
                'opsi_d'		=> $pg->jawaban_d,
                'opsi_e'		=> $pg->jawaban_e,
                'jawaban'		=> $pg->jawaban,
                'tampilkan'		=> $tampilkan,
                'created_on'	=> time(),
                'updated_on'	=> time()
            ];
        }

        $save = $this->master->create('cbt_soal', $data, true);
        $this->logging->saveLog(3, 'mengimport bank soal');
        $result['data'] = $save;
		*/

        $this->output_json($result);
    }

    /**
     * @throws Exception
     */
    public function import(){
		$bank_id = $this->input->post('bank_id', true);
        $bank = $this->cbt->getDataBankById($bank_id);

        $input = $this->input->post('ganda');
        $str = preg_replace("",'',$input);
        $obj = json_decode($str);

        $json = json_decode( preg_replace('/[--]/', '', $input), true );
        $result['error'] = json_last_error_msg();

        $soal = json_decode(json_encode($json));
        $result['soal'] = $obj;
        /*
        $this->db->where('bank_id', $bank_id);
		if ($this->db->delete('cbt_soal', $bank_id)) {
			$data = [];
			foreach ($soal as $pg) {
			    if ($pg->jenis == 1) {
                    $tampilkan = $pg->nomor_soal > $bank->jml_soal ? 0 : 1;
                } else {
                    $tampilkan = $pg->nomor_soal > $bank->jml_esai ? 0 : 1;
                }

				$data[] = [
					'bank_id'		=> $bank_id,
					'nomor_soal'	=> $pg->nomor_soal,
					'jenis'			=> $pg->jenis,
					'soal'			=> $pg->soal,
					'opsi_a'		=> $pg->jawaban_a,
					'opsi_b'		=> $pg->jawaban_b,
					'opsi_c'		=> $pg->jawaban_c,
					'opsi_d'		=> $pg->jawaban_d,
					'opsi_e'		=> $pg->jawaban_e,
					'jawaban'		=> $pg->jawaban,
                    'tampilkan'		=> $tampilkan,
					'created_on'	=> time(),
					'updated_on'	=> time()
				];
			}

			$save = $this->master->create('cbt_soal', $data, true);
			$this->logging->saveLog(3, 'mengimport bank soal');
			$result['data'] = $save;
			//$this->output_json($save);
			//$this->output->set_content_type('application/json')->set_output($save);
		} else {
            $result['data'] = '0';
		}*/

        $this->output_json($result);
	}

	public function export($bank_id) {
        $bank = $this->cbt->getDataBankById($bank_id);

        $soal[] = json_decode(json_encode(['soal'=>'','opsi_a'=>'','opsi_b'=>'','opsi_c'=>'','opsi_d'=>'','opsi_e'=>'','jawaban'=>'']));
        $list = $this->cbt->getAllSoalByBank($bank_id, '1');
        $soals = array_merge($soal, $list);

        $ess[] = json_decode(json_encode(['soal'=>'','jawaban'=>'']));
        $listEss = $this->cbt->getAllSoalByBank($bank_id, '2');
        $essai = array_merge($ess, $listEss);

        $phpWord = new \PhpOffice\PhpWord\PhpWord();
        $section = $phpWord->addSection();
        $header = array('size' => 10, 'bold' => true);
        $arrHeader = ['', 'NO', 'SOAL', 'JAWABAN A', 'JAWABAN B', 'JAWABAN C', 'JAWABAN D', 'JAWABAN E', 'JAWABAN BENAR',];

        $cols = 8;
        $section->addText('I. PILIHAN GANDA', $header);

        $tableStyle = array('borderSize' => 6, 'borderColor' => '000000');
        $phpWord->addTableStyle('tab style', $tableStyle);
        $table = $section->addTable('tab style');

        for ($r = 1; $r <= count($soals); $r++) {
            $soal = $soals[$r-(1)];
            $arrVal = ['', '',
                isset($soal) ? $soal->soal : '',
                isset($soal) ? $soal->opsi_a : '',
                isset($soal) ? $soal->opsi_b : '',
                isset($soal) ? $soal->opsi_c : '',
                isset($soal) ? $soal->opsi_d : '',
                isset($soal) ? $soal->opsi_e : '',
                isset($soal) ? $soal->jawaban : '',
            ];

            $table->addRow();
            for ($c = 1; $c <= $cols; $c++) {
                $width = 4000;
                $align = array(
                    'align' => 'left',
                    'space' => array('before' => 50, 'after' => 50),
                    'indentation' => array('left' => 100, 'right' => 100));
                if ($c == 1) {
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 100, 'right' => 100));
                    $width = 500;
                } elseif ($c==2) {
                    $width = 8000;
                }

                $fontStyle = array('size' => 10, 'bold' => false);
                $no = $r-1;

                if ($r==1){
                    $no = "NO";
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 50, 'right' => 50));
                    $fontStyle = array('size' => 10, 'bold' => true);
                }

                if ($r == 1) {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $table->addCell($width)->addText($arrHeader[$c], $fontStyle, $align);
                    }
                } else {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $tagRemoved = strip_tags($arrVal[$c]);
                        $html = htmlspecialchars($tagRemoved);
                        $table->addCell($width)->addText($this->cleanString($html), $fontStyle, $align);
                        //$table->addCell($width)->addText(htmlspecialchars(strip_tags($arrVal[$c])), $fontStyle, $align);
                    }
                }
            }
        }

        $section->addPageBreak();
        $section->addText('II. ESSAI', $header);
        $arrHeader = ['', 'NO', 'SOAL', 'JAWABAN',];
        $cols = 3;
        $phpWord->addTableStyle('tab style', $tableStyle);
        $table = $section->addTable('tab style');

        for ($r = 1; $r <= count($essai); $r++) {
            $soal = $essai[$r-(1)];
            $arrVal = ['', '',
                isset($soal) ? $soal->soal : '',
                isset($soal) ? $soal->jawaban : '',
            ];

            $table->addRow();
            for ($c = 1; $c <= $cols; $c++) {
                $width = 4000;
                $align = array(
                    'align' => 'left',
                    'space' => array('before' => 50, 'after' => 50),
                    'indentation' => array('left' => 100, 'right' => 100));
                if ($c == 1) {
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 100, 'right' => 100));
                    $width = 500;
                } elseif ($c==2) {
                    $width = 8000;
                }

                $fontStyle = array('size' => 10, 'bold' => false);
                $no = $r-1;

                if ($r==1){
                    $no = "NO";
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 50, 'right' => 50));
                    $fontStyle = array('size' => 10, 'bold' => true);
                }

                if ($r == 1) {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $table->addCell($width)->addText($arrHeader[$c], $fontStyle, $align);
                    }
                } else {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $tagRemoved = strip_tags($arrVal[$c]);
                        $html = htmlspecialchars($tagRemoved);
                        $table->addCell($width)->addText($this->cleanString($html), $fontStyle, $align);
                    }
                }
            }
        }

        $objWriter = \PhpOffice\PhpWord\IOFactory::createWriter($phpWord, 'Word2007');
        header("Content-Disposition: attachment; filename=Soal ".$bank->nama_mapel.".docx");
        $objWriter->save('php://output');
    }

    public function getSoalSiswa($id_bank) {
        $soals = $this->cbt->getAllSoalByBank($id_bank);
        foreach ($soals as $soal) {
            $soal->file = unserialize($soal->file);
            if ($soal->jenis == '2') {
                $soal->jawaban = unserialize($soal->jawaban);
                $soal->opsi_a = unserialize($soal->opsi_a);
            } elseif ($soal->jenis == '3') {
                $soal->jawaban = unserialize($soal->jawaban);
            }
        }
        $data['soal'] = $soals;
        $this->output_json($data);
    }

	function innerXML($node) {
		$doc  = $node->ownerDocument;
		$frag = $doc->createDocumentFragment();
		foreach ($node->childNodes as $child) {
			$frag->appendChild($child->cloneNode(TRUE));
		}
		return $doc->saveXML($frag);
	}

	public function file_config() {
		$allowed_type 	= [
			"image/jpeg", "image/jpg", "image/png", "image/gif",
			"audio/mpeg", "audio/mpg", "audio/mpeg3", "audio/mp3", "audio/x-wav", "audio/wave", "audio/wav",
			"video/mp4", "application/octet-stream"
		];
		$config['upload_path']      = FCPATH.'uploads/bank_soal/';
		$config['allowed_types']    = 'jpeg|jpg|png|gif|mpeg|mpg|mpeg3|mp3|wav|wave|mp4';
		$config['encrypt_name']     = TRUE;

		return $this->load->library('upload', $config);
	}

	public function validasi($jenis) {
		$this->form_validation->set_rules('soal', 'Soal', 'required');
		if ($jenis==1) {
            $this->form_validation->set_rules('jawaban_pg', 'Kunci Jawaban', 'required');
        } elseif ($jenis==2) {
            $this->form_validation->set_rules('jawaban2_a', 'Kunci Jawaban', 'required');
            $this->form_validation->set_rules('jawaban_benar_pg2[]', 'Kunci Jawaban', 'required');
        } elseif ($jenis==3) {
            $this->form_validation->set_rules('jawaban_jodohkan', 'Kunci Jawaban', 'required');
        } elseif ($jenis==4) {
            $this->form_validation->set_rules('jawaban_isian', 'Kunci Jawaban', 'required');
		} else {
			$this->form_validation->set_rules('jawaban_essai', 'Kunci Jawaban', 'required');
		}
	}

	public function saveSoal() {
		$method = $this->input->post('method', true);
		$jenis = $this->input->post('jenis', true);

		$this->validasi($jenis);
		$this->file_config();

        $data = [
            'bank_id'       => $this->input->post('bank_id', true),
            'jenis'         => $jenis,
            'nomor_soal'    => $this->input->post('nomor_soal', true),
            'soal'          => $this->input->post('soal', false)
        ];

        if ($jenis==1) {
            $abjad = ['a', 'b', 'c', 'd', 'e'];
            foreach ($abjad as $abj) {
                $data['opsi_'.$abj] = $this->input->post('jawaban_'.$abj, false);
            }
            $data['jawaban'] = $this->input->post('jawaban_pg', true);
        } elseif ($jenis == 2) {
            $opsis = [];
            for ($i=97; $i<117; $i++) {
                $op = $this->input->post('jawaban2_'. chr($i), false);
                if ($op != null) {
                    //array_push($opsis, $op);
                    $opsis[chr($i)] = $op;
                }
            }
            $data['opsi_a'] = serialize($opsis);

            $jawabans = [];
            $jwb_pg2 = count($this->input->post('jawaban_benar_pg2', true));
            for ($i = 0; $i <= $jwb_pg2; $i++) {
                $jwb = $this->input->post('jawaban_benar_pg2['.$i.']', true);
                //if ($id!=null) array_push($arrId, $id);
                array_push($jawabans, $jwb);
            }
            $data['jawaban'] = serialize($jawabans);
        } elseif ($jenis == 3) {
            $jwb_jodohkan = [
                'model' => $this->input->post('model', true),
                'type' => $this->input->post('type', true),
                'jawaban' => json_decode($this->input->post('jawaban_jodohkan', true))
            ];
            $data['jawaban'] = serialize($jwb_jodohkan);
        } elseif ($jenis == 4) {
            $data['jawaban'] = $this->input->post('jawaban_isian', true);
		} else {
            $data['jawaban'] = $this->input->post('jawaban_essai', true);
		}

		if ($this->form_validation->run() === FALSE){
			$result['status'] = 'error';
		} else {
			if($method==='add'){
				$data['created_on'] = time();
				$data['updated_on'] = time();
				$this->master->create('cbt_soal', $data);
				$result['status'] = 'Soal berhasil dibuat';
				$this->logging->saveLog(3, 'membuat soal');
			} else if ($method==='edit'){
				$id_soal = $this->input->post('soal_id', true);
				$data['updated_on'] = time();
				$this->master->update('cbt_soal', $data, 'id_soal', $id_soal);
				$result['status'] = 'Soal berhasil diupdate';
				$this->logging->saveLog(4, 'mengedit soal');
			} else {
				$result['status'] = '400 Method not found';
			}
		}
		$this->output_json($result);
	}

    public function hapusSoal() {
        $id_soal = $this->input->post('soal_id', true);
        if ($this->db->delete('cbt_soal', 'id_soal='.$id_soal)){
            $result['status'] = 'Soal berhasil dihapus';
        } else {
            $result['status'] = '400 Method not found';
        }
        $this->output_json($result);
    }

    function uploadFile(){
        $id_soal = $this->input->get('id_soal', true);
        $soal = $this->cbt->getSoalById($id_soal);
        $files = $soal == null || $soal->file == null ? [] : unserialize($soal->file);

        if(isset($_FILES["file_uploads"]["name"])){
            $nama_file_asal = $_FILES["file_uploads"]["name"];
            $kode_file = $id_soal.'_'.time();

            $config['upload_path'] = './uploads/bank_soal/';
            $config['allowed_types'] = 'mpeg|mpg|mpeg3|mp3|wav|wave|mp4|avi';
            $config['file_name'] = $kode_file;

            //$config['encrypt_name'] = TRUE;
            //$config['max_size'] = '0';
            //$config['overwrite'] = FALSE;
            $this->upload->initialize($config);
            if(!$this->upload->do_upload('file_uploads')){
                $data['status'] = false;
                $src = '';
                $filename = '';
                $data['src'] = $this->upload->display_errors();
            }else{
                $file = $this->upload->data();
                /*
                $config['image_library']='gd2';
                $config['source_image']='./uploads/bank_soal/'.$file['file_name'];
                $config['create_thumb']= FALSE;
                $config['maintain_ratio']= TRUE;
                $config['quality']= '60%';
                $config['width']= 800;
                $config['height']= 800;
                $config['new_image']= './uploads/bank_soal/'.$file['file_name'];
                $this->load->library('image_lib', $config);
                $this->image_lib->resize();
                */

                //echo base_url().'uploads/bank_soal/'.$file['file_name'];
                $ext = pathinfo($file['file_name'], PATHINFO_EXTENSION);
                $src = 'uploads/bank_soal/'.$kode_file.'.'.$ext;
                $data['src'] = $src;
                //$filename = pathinfo($file['file_name'], PATHINFO_FILENAME);
                //$data['filename'] = $filename;
                $data['filename'] = $nama_file_asal;
                $data['status'] = true;

                $type = $_FILES['file_uploads']['type'];
                $data['type'] = $type;
                $data['size'] = $_FILES['file_uploads']['size'];
                $data['soal'] = $soal;

                $files[] = [
                    'file_name' => $nama_file_asal,
                    'alias' => $kode_file,
                    'src' => $src,
                    'type' => $type
                ];
                //array_push($files, ['files'=>$addFiles]);

                $this->db->set('file', serialize($files));
                $this->db->where('id_soal', $id_soal);
                $this->db->update('cbt_soal');
            }
        }

        $data['files'] = $files;
        $this->output_json($data);
    }
	//Upload image summernote
	function upload_image(){
		//$data['tag_id'] = $this->input->post('tag_id', true);
        $status = false;
        if(isset($_FILES["file"]["name"])){
			$config['upload_path'] = './uploads/bank_soal/';
			$config['allowed_types'] = 'jpg|jpeg|png|gif|mp3|ogg|wav|mp4|mpeg|webm';
            $config['file_name'] = 'file_'.date('YmdHis');
			$this->upload->initialize($config);
			if(!$this->upload->do_upload('file')){
				$this->upload->display_errors();
				$status = false;
			}else{
				$uploaded = $this->upload->data();
				//Compress Image
				//$config['image_library']='gd2';
				//$config['source_image']='./uploads/bank_soal/'.$data['file_name'];
				//$config['create_thumb']= FALSE;
				//$config['maintain_ratio']= TRUE;
				//$config['quality']= '60%';
				//$config['width']= 800;
				//$config['height']= 800;
				//$config['new_image']= './uploads/bank_soal/'.$data['file_name'];
				//$this->load->library('image_lib', $config);
				//$this->image_lib->resize();

				$data['filename'] =  'uploads/bank_soal/'.$uploaded['file_name'];
				$status = true;
			}
		}
		$data['status'] = $status;
		$this->output_json($data);
	}

	//Delete image summernote
    function deleteFile() {
        $src = $this->input->post('src');
        $file_name = str_replace(base_url(), '', $src);
        if (unlink($file_name)) {
            echo 'File Delete Successfully';
        }
    }

    function cleanString($text) {
        // 1) convert   => a o
        $text = preg_replace("/[]/u","a",$text);
        $text = preg_replace("/[]/u","A",$text);
        $text = preg_replace("/[]/u","I",$text);
        $text = preg_replace("/[]/u","i",$text);
        $text = preg_replace("/[]/u","e",$text);
        $text = preg_replace("/[]/u","E",$text);
        $text = preg_replace("/[]/u","o",$text);
        $text = preg_replace("/[]/u","O",$text);
        $text = preg_replace("/[]/u","u",$text);
        $text = preg_replace("/[]/u","U",$text);
        $text = preg_replace("/[]/u","'",$text);
        $text = preg_replace("/[]/u",'"',$text);
        $text = str_replace("","-",$text);
        $text = str_replace(" "," ",$text);
        $text = str_replace("","c",$text);
        $text = str_replace("","C",$text);
        $text = str_replace("","n",$text);
        $text = str_replace("","N",$text);

        //2) Translation CP1252. &ndash; => -
        $trans = get_html_translation_table(HTML_ENTITIES);
        $trans[chr(130)] = '&sbquo;';    // Single Low-9 Quotation Mark
        $trans[chr(131)] = '&fnof;';    // Latin Small Letter F With Hook
        $trans[chr(132)] = '&bdquo;';    // Double Low-9 Quotation Mark
        $trans[chr(133)] = '&hellip;';    // Horizontal Ellipsis
        $trans[chr(134)] = '&dagger;';    // Dagger
        $trans[chr(135)] = '&Dagger;';    // Double Dagger
        $trans[chr(136)] = '&circ;';    // Modifier Letter Circumflex Accent
        $trans[chr(137)] = '&permil;';    // Per Mille Sign
        $trans[chr(138)] = '&Scaron;';    // Latin Capital Letter S With Caron
        $trans[chr(139)] = '&lsaquo;';    // Single Left-Pointing Angle Quotation Mark
        $trans[chr(140)] = '&OElig;';    // Latin Capital Ligature OE
        $trans[chr(145)] = '&lsquo;';    // Left Single Quotation Mark
        $trans[chr(146)] = '&rsquo;';    // Right Single Quotation Mark
        $trans[chr(147)] = '&ldquo;';    // Left Double Quotation Mark
        $trans[chr(148)] = '&rdquo;';    // Right Double Quotation Mark
        $trans[chr(149)] = '&bull;';    // Bullet
        $trans[chr(150)] = '&ndash;';    // En Dash
        $trans[chr(151)] = '&mdash;';    // Em Dash
        $trans[chr(152)] = '&tilde;';    // Small Tilde
        $trans[chr(153)] = '&trade;';    // Trade Mark Sign
        $trans[chr(154)] = '&scaron;';    // Latin Small Letter S With Caron
        $trans[chr(155)] = '&rsaquo;';    // Single Right-Pointing Angle Quotation Mark
        $trans[chr(156)] = '&oelig;';    // Latin Small Ligature OE
        $trans[chr(159)] = '&Yuml;';    // Latin Capital Letter Y With Diaeresis
        $trans['euro'] = '&euro;';    // euro currency symbol
        ksort($trans);

        foreach ($trans as $k => $v) {
            $text = str_replace($v, $k, $text);
        }

        // 3) remove <p>, <br/> ...
        $text = strip_tags($text);

        // 4) &amp; => & &quot; => '
        $text = html_entity_decode($text);

        // 5) remove Windows-1252 symbols like "TradeMark", "Euro"...
        $text = preg_replace('/[^( -)]*/','', $text);

        $targets=array('
','
','
','	');
        $results=array(" "," "," ","");
        $text = str_replace($targets,$results,$text);

        //XML compatible
        /*
        $text = str_replace("&", "and", $text);
        $text = str_replace("<", ".", $text);
        $text = str_replace(">", ".", $text);
        $text = str_replace("\", "-", $text);
        $text = str_replace("/", "-", $text);
        */

        return ($text);
    }

    function cleanHTML($html) {
        $doc = new DOMDocument();
        /* Load the HTML */
        $doc->loadHTML($html,
            LIBXML_HTML_NOIMPLIED | # Make sure no extra BODY
            LIBXML_HTML_NODEFDTD |  # or DOCTYPE is created
            LIBXML_NOERROR |        # Suppress any errors
            LIBXML_NOWARNING        # or warnings about prefixes.
        );
        /* Immediately save the HTML and return it. */
        return $doc->saveHTML();
    }

    function addNamespaces($xml) {
        $root = '<w:wordDocument
        xmlns:w="http://schemas.microsoft.com/office/word/2003/wordml"
        xmlns:wx="http://schemas.microsoft.com/office/word/2003/auxHint"
        xmlns:o="urn:schemas-microsoft-com:office:office">';
        $root .= $xml;
        $root .= '</w:wordDocument>';
        return $root;
    }

    function doImport() {
        $bank_id = $this->input->post('id_bank', true);
        $string = $this->input->post('data', false);

        $json = json_decode($string);
        /*
        switch (json_last_error()) {
            case JSON_ERROR_NONE:
                echo ' - No errors';
                break;
            case JSON_ERROR_DEPTH:
                echo ' - Maximum stack depth exceeded';
                break;
            case JSON_ERROR_STATE_MISMATCH:
                echo ' - Underflow or the modes mismatch';
                break;
            case JSON_ERROR_CTRL_CHAR:
                echo ' - Unexpected control character found';
                break;
            case JSON_ERROR_SYNTAX:
                echo ' - Syntax error, malformed JSON';
                break;
            case JSON_ERROR_UTF8:
                echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
                break;
            default:
                echo ' - Unknown error';
                break;
        }
        */
        $datas = [];
        $jml = [];
        foreach ($json as $jenis=>$values) {
            $data_soal = [];
            foreach ($values as $val) {
                if (isset($val->NO)) {
                    $no = $val->NO;
                    if (isset($val->SOAL) && $val->SOAL != "") $data_soal[$no]['soal'] = $val->SOAL;

                    if ($jenis == "1") {
                        if (isset($val->OPSI)) {
                            $data_soal[$no]['opsi'][strtoupper($val->OPSI)] = $val->JAWABAN;
                            if (isset($val->KUNCI) && strtolower($val->KUNCI) == "v") {
                                $data_soal[$no]['kunci'][strtolower($val->KUNCI)] = strtoupper($val->OPSI);
                            }
                        }
                    } elseif ($jenis == "2") {
                        if (isset($val->OPSI)) {
                            $data_soal[$no]['opsi'][strtoupper($val->OPSI)] = $val->JAWABAN;
                            if (isset($val->KUNCI) && strtolower($val->KUNCI) == "v") {
                                $data_soal[$no]['kunci'][strtoupper($val->OPSI)] = strtolower($val->KUNCI);
                            }
                        }
                    } elseif ($jenis == "3") {
                        if (isset($val->KD_BARIS)) {
                            $data_soal[$no]['baris'][strtoupper($val->KD_BARIS)] = $val->BARIS;

                            if (isset($val->KUNCI)) {
                                $data_soal[$no]['kunci'][strtoupper($val->KD_KUNCI)] = strtoupper($val->KUNCI);
                            }
                        }

                        if (isset($val->KD_KOLOM)) {
                            $data_soal[$no]['kolom'][strtoupper($val->KD_KOLOM)] = $val->KOLOM;
                        }
                    } else {
                        if (isset($val->KUNCI)) $data_soal[$no]['kunci'] = $val->KUNCI;
                    }
                }
            }

            $datas[$jenis] = $data_soal;
        }

        $data_insert = [];
        foreach ($datas as $jenis=>$keys) {
            foreach ($keys as $no=>$v) {
                $isi_soal = isset($v['soal']) ? $v['soal'] : "";
                if ($isi_soal != "") {
                    $insert = [
                        'jenis' => $jenis,
                        'nomor_soal' => $no,
                        'soal' => $isi_soal,
                        'file' => serialize([]) ,
                    ];

                    if ($jenis == "1") {
                        $insert['opsi_a'] = isset($v['opsi']) && isset($v['opsi']['A']) ? $v['opsi']['A'] : '';
                        $insert['opsi_b'] = isset($v['opsi']) && isset($v['opsi']['B']) ? $v['opsi']['B'] : '';
                        $insert['opsi_c'] = isset($v['opsi']) && isset($v['opsi']['C']) ? $v['opsi']['C'] : '';
                        $insert['opsi_d'] = isset($v['opsi']) && isset($v['opsi']['D']) ? $v['opsi']['D'] : '';
                        $insert['opsi_e'] = isset($v['opsi']) && isset($v['opsi']['E']) ? $v['opsi']['E'] : '';
                        $insert['jawaban'] = isset($v['kunci']) && isset($v['kunci']['v']) ? $v['kunci']['v'] : '';
                    } elseif ($jenis == "2") {
                        $opsis = [];
                        $kuncis = [];
                        if (isset($v['opsi'])) {
                            foreach ($v['opsi'] as $opsi=>$jawaban) {
                                $opsis[strtolower($opsi)] = $jawaban;
                            }
                        }

                        if (isset($v['kunci'])) {
                            foreach ($v['kunci'] as $kunci=>$jawaban) {
                                if ($jawaban == "v") $kuncis[] = strtolower($kunci);
                            }
                        }
                        $insert['opsi_a'] = serialize($opsis);
                        $insert['jawaban'] = serialize($kuncis);

                    } elseif ($jenis == "3") {
                        $baris = [];
                        $kolom = [];

                        $header = [];
                        array_push($header, '#');

                        $arrKol = [];
                        foreach ($v['kolom'] as $kd_kol=>$kol) {
                            $kolom[$kd_kol] = $kol;
                            if ($kol != "") array_push($header, $kol);

                            foreach ($v['kunci'] as $kd_bar=>$kd_kol) {
                                if ($kd_kol != "") $arrKol[$kd_bar] = explode(',', $kd_kol);
                            }
                        }

                        array_push($baris, $header);
                        $jwbnBaris = [];
                        foreach ($v['baris'] as $kd_bar=>$bar) {
                            $jwbn = [];
                            if ($kd_bar != "") array_push($jwbn, $bar);

                            foreach ($kolom as $kk=>$val) {
                                if ($kd_bar != "" && $val != "") {
                                    $match = in_array($kk, $arrKol[$kd_bar]);
                                    array_push($jwbn, $match ? '1' : '0');
                                }
                            }
                            if (count($jwbn) > 0) array_push($baris, $jwbn);

                            if ($kd_bar != "") {
                                array_shift($jwbn);
                                $jwbnBaris[$kd_bar] = $jwbn;
                            }
                        }
                        $types = [];
                        foreach ($jwbnBaris as $brs=>$jml) {
                            $jmlType = array_count_values($jml);
                            if ($jmlType[1] > 1) array_push($types, 'checkbox');
                        }
                        $type = count($types) > 0 ? '1' : '2';

                        $jml_baris = count($baris);
                        $jml_kolom = count($baris[0]);

                        $jwb_jodohkan = [
                            'model' => $jml_baris == $jml_kolom ? '1' : '2',
                            'type' => $type,
                            'jawaban' => $baris
                        ];
                        $insert['jawaban'] = serialize($jwb_jodohkan);
                    } elseif ($jenis == "4") {
                        if (isset($v['kunci'])) $insert['jawaban'] = strip_tags($v['kunci']);
                    } else {
                        if (isset($v['kunci'])) $insert['jawaban'] = $v['kunci'];
                    }

                    $data_insert[] = $insert;
                }
            }
        }

        $inserted = [];
        foreach ($data_insert as $dins) {
            $inserted[] = [
                'bank_id' => $bank_id,
                'jenis' => $dins['jenis'],
                'nomor_soal' => $dins['nomor_soal'],
                'soal' => $dins['soal'],
                'deskripsi'=> '',
                'kesulitan'=> '8',
                'timer' => '0',
                'timer_menit' => '0',
                'file' => $dins['file'] ,
                'tampilkan' => '0',
                'created_on' => time(),
                'updated_on' => time(),
                'opsi_a' => isset($dins['opsi_a']) ? $dins['opsi_a'] : '',
                'opsi_b' => isset($dins['opsi_b']) ? $dins['opsi_b'] : '',
                'opsi_c' => isset($dins['opsi_c']) ? $dins['opsi_c'] : '',
                'opsi_d' => isset($dins['opsi_d']) ? $dins['opsi_d'] : '',
                'opsi_e' => isset($dins['opsi_e']) ? $dins['opsi_e'] : '',
                'jawaban' => $dins['jawaban']
            ];
        }

        $data['data_insert'] = $inserted;
        $data['total'] = count($inserted);
        if (count($inserted) > 0) {
            $this->db->where('bank_id', $bank_id);
            if ($this->db->delete('cbt_soal')) {
                $data['insert'] = $this->db->insert_batch('cbt_soal', $inserted);
            }
        } else {
            $data['insert'] = 0;
        }
        $this->output_json($data);
    }
}

Did this file decode correctly?

Original Code

eval(base64_decode('
/**
 * Created by IntelliJ IDEA.
 * User: multazam
 * Date: 07/07/20
 * Time: 14:10
 */

class Cbtbanksoal extends CI_Controller {

	public function __construct(){
		parent::__construct();
		if (!$this->ion_auth->logged_in()){
			redirect('auth');
		}else if ( !$this->ion_auth->is_admin() && !$this->ion_auth->in_group('guru')){
			show_error('Hanya Administrator dan guru yang diberi hak untuk mengakses halaman ini, <a href="'.base_url('dashboard').'">Kembali ke menu awal</a>', 403, 'Akses Terlarang');
		}
		$this->load->library('upload');
		//$this->load->library('MY_Upload', 'my_upload');
		$this->load->library(['datatables', 'form_validation']);// Load Library Ignited-Datatables
		$this->form_validation->set_error_delimiters('','');

		$this->load->helper('my');// Load Library Ignited-Datatables
		$this->load->model('Master_model', 'master');
		$this->load->model('Dashboard_model', 'dashboard');
		$this->load->model('Cbt_model', 'cbt');
		$this->load->model('Log_model', 'logging');
		$this->load->model('Kelas_model', 'kelas');
		$this->load->model('Dropdown_model', 'dropdown');
	}

	public function output_json($data, $encode = true)
	{
		if($encode) $data = json_encode($data);
		$this->output->set_content_type('application/json')->set_output($data);
	}

	public function index() {
		$user = $this->ion_auth->user()->row();
		$setting = $this->dashboard->getSetting();
		$data = [
			'user' => $user,
			'judul'	=> 'Bank Soal',
			'subjudul'=> 'Soal',
			'setting'		=> $setting
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;
        $data['levels'] = $this->dropdown->getAllLevel($setting->jenjang);
        $data['mapels'] = $this->dropdown->getAllMapel();

        $type = $this->input->get('type');
		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);
			$data['gurus'] = $this->dropdown->getAllGuru();
            $data['kelas'] = $this->cbt->getKelas($tp->id_tp, $smt->id_smt);

            $data['filters'] = ['0'=>'Semua', '1'=>'Guru', '2'=>'Mapel', '3'=>'Level'];
            $data['id_filter'] = $type == null ? '' : $type;
            if ($type == '1') {
                $id_guru = $this->input->get('id');
                $data['id_guru'] = $id_guru;
                $data['banks'] = $this->cbt->getDataBank($id_guru);

                $data['id_mapel'] = '';
                $data['id_level'] = '';
            } elseif ($type == '2') {
                $id_mapel = $this->input->get('id');
                $data['id_mapel'] = $id_mapel;
                $data['banks'] = $this->cbt->getDataBank(null, $id_mapel);

                $data['id_guru'] = '';
                $data['id_level'] = '';
            } elseif ($type == '3') {
                $id_level = $this->input->get('id');
                $data['id_level'] = $id_level;
                $data['banks'] = $this->cbt->getDataBank(null, null, $id_level);

                $data['id_guru'] = '';
                $data['id_mapel'] = '';
            } else {
                $data['banks'] = $this->cbt->getDataBank();
                $data['id_guru'] = null;
                $data['id_mapel'] = null;
                $data['id_level'] = null;
            }

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/data');
			$this->load->view('_templates/dashboard/_footer');
		}else{
			$guru = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);
			$nguru[$guru->id_guru] = $guru->nama_guru;
			$data['guru'] = $guru;
            $data['gurus'] = $nguru;
            $data['kelas'] = $this->cbt->getKelas($tp->id_tp, $smt->id_smt);

            $data['filters'] = ['0'=>'Semua', '2'=>'Mapel', '3'=>'Level'];
            $data['id_filter'] = $type == null ? '' : $type;
            if ($type == '2') {
                $id_mapel = $this->input->get('id');
                $data['id_mapel'] = $id_mapel;
                $data['banks'] = $this->cbt->getDataBank($guru->id_guru, $id_mapel);

                $data['id_guru'] = '';
                $data['id_level'] = '';
            } elseif ($type == '3') {
                $id_level = $this->input->get('id');
                $data['id_level'] = $id_level;
                $data['banks'] = $this->cbt->getDataBank($guru->id_guru, null, $id_level);

                $data['id_guru'] = '';
                $data['id_mapel'] = '';
            } else {
                $data['id_guru'] = $guru->id_guru;
                $data['banks'] = $this->cbt->getDataBank($guru->id_guru);
                $data['id_mapel'] = '';
                $data['id_level'] = '';
            }

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/data');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function data($guru=null) {
		$this->output_json($this->cbt->getDataBank($guru), false);
	}

    public function dataTable($guru=null) {
        $this->output_json($this->cbt->getDataTableBank($guru), false);
    }

    public function getMapelGuru() {
        $id_guru = $this->input->get('id_guru', true);

        $tp = $this->master->getTahunActive();
        $smt = $this->master->getSemesterActive();
        $mapel_guru = $this->kelas->getGuruMapelKelas($id_guru, $tp->id_tp, $smt->id_smt);
        $mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

        $arrMapel = [];
        if ($mapel!=null){
            foreach ($mapel as $m) {
                $arrMapel[$m->id_mapel] = $m->nama_mapel;
            }
        }

        $this->output_json($arrMapel);
    }

	public function getKelasLevel() {
		$level = $this->input->get('level', true);
		$id_guru = $this->input->get('id_guru', true);
		$id_mapel = $this->input->get('mapel', true);

        $tp = $this->master->getTahunActive();
        $smt = $this->master->getSemesterActive();
		$mapel_guru = $this->kelas->getGuruMapelKelas($id_guru, $tp->id_tp, $smt->id_smt);
        $arrKelas = [];
        $arrMapel = [];
        $mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

        foreach ($mapel as $m) {
            $arrMapel[$m->id_mapel] = $m->nama_mapel;
            if ($id_mapel===$m->id_mapel){
                foreach ($m->kelas_mapel as $kls) {
                    array_push($arrKelas, $kls->kelas);
                }
            }
        }

		$this->output_json(['mapel'=> $arrMapel, 'kelas'=>$this->cbt->getKelasByLevel($level, $arrKelas)]);
	}

	public function addBank() {
		$user = $this->ion_auth->user()->row();
        $setting = $this->dashboard->getSetting();
		$data = [
			'user'      => $user,
			'judul'	    => 'Bank Soal',
			'subjudul'  => 'Buat Bank Soal',
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;

		$data['setting'] = $this->dashboard->getSetting();
		$data['bank'] = json_decode(json_encode($this->cbt->dummy($setting->jenjang)));
		$data['jenis'] = $this->cbt->getAllJenisUjian();
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);
			$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);
			$data['id_guru'] = '';
			$data['gurus'] = $this->dropdown->getAllGuru();
			$data['mapel'] = $this->dropdown->getAllMapel();

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/add');
			$this->load->view('_templates/dashboard/_footer');
		}else{
			$guru = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);
			$nguru[$guru->id_guru] = $guru->nama_guru;
            $data['gurus'] = $nguru;
			$data['guru'] = $guru;
			$data['id_guru'] = $guru->id_guru;

			$mapel_guru = $this->kelas->getGuruMapelKelas($guru->id_guru, $tp->id_tp, $smt->id_smt);
			$mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

			$arrMapel = [];
			$arrKelas = [];
			foreach ($mapel as $m) {
				$arrMapel[$m->id_mapel] = $m->nama_mapel;
				foreach ($m->kelas_mapel as $kls) {
					$arrKelas[$m->id_mapel][] = [
						'id_kelas'	=>	$kls->kelas,
						'nama_kelas'=>$this->dropdown->getNamaKelasById($tp->id_tp, $smt->id_smt, $kls->kelas)];
				}
			}

			$arrId = [];
			if (count($mapel) > 0) {
                foreach ($mapel[0]->kelas_mapel as $id_mapel) {
                    array_push($arrId, $id_mapel->kelas);
                }
            }

			$data['mapel_guru'] = $mapel_guru;
			$data['mapel'] = $arrMapel;
			$data['arrkelas'] = $arrKelas;
			$data['kelas'] = count($arrId) > 0 ? $this->dropdown->getAllKelasByArrayId($tp->id_tp, $smt->id_smt, $arrId) : [];

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/add');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function editBank() {
		$id_bank = $this->input->get('id_bank', true);
		$id_guru = $this->input->get('id_guru', true);
        $setting = $this->dashboard->getSetting();

		$user = $this->ion_auth->user()->row();
		$data = [
			'user'      => $user,
			'judul'	    => 'Edit Bank Soal',
			'subjudul'  => 'Edit Bank Soal'
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;
		$data['bulan'] = $this->dropdown->getBulan();

		$data['setting'] = $this->dashboard->getSetting();
		$data['jenis'] = $this->cbt->getAllJenisUjian();
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);
		$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);

		$data['bank'] = $this->cbt->getDataBankById($id_bank);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);
			$data['id_guru'] = $id_guru;
			$data['gurus'] = $this->dropdown->getAllGuru();

			$arrMapel = [];
			$mapel_guru = $this->kelas->getGuruMapelKelas($id_guru, $tp->id_tp, $smt->id_smt);
			$mapel = $mapel_guru->mapel_kelas != null ? json_decode(json_encode(unserialize($mapel_guru->mapel_kelas))) : [];
			foreach ($mapel as $m) {
				$arrMapel[$m->id_mapel] = $m->nama_mapel;
			}
			$data['mapel'] = $arrMapel;
			$data['mapel_guru'] = $mapel_guru;
			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/add');
			$this->load->view('_templates/dashboard/_footer');
		}else{
			$guru = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);
			$nguru[$guru->id_guru] = $guru->nama_guru;
			$mapel_guru = $this->kelas->getGuruMapelKelas($guru->id_guru, $tp->id_tp, $smt->id_smt);
			$mapel = json_decode(json_encode(unserialize($mapel_guru->mapel_kelas)));

			$arrMapel = [];
			foreach ($mapel as $m) {
				$arrMapel[$m->id_mapel] = $m->nama_mapel;
			}

            $data['gurus'] = $nguru;
			$data['mapel_guru'] = $mapel_guru;
			$data['guru'] = $guru;
			$data['id_guru'] = $guru->id_guru;
			$data['mapel'] = $arrMapel;

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/add');
			//$this->load->view('members/guru/cbt/banksoal/add');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function saveBank() {
		if ($this->input->post()) {
            $tp = $this->master->getTahunActive();
            $smt = $this->master->getSemesterActive();

			$this->cbt->saveBankSoal($tp->id_tp, $smt->id_smt);
			$status = TRUE;
		} else {
			$status = FALSE;
		}
		$data['status'] = $status;

		$id = $this->input->post('id_bank', true);
		if (!$id) {
			$this->logging->saveLog(3, 'menambah bank soal');
		} else {
			$this->logging->saveLog(4, 'mengedit bank soal');
		}

		$this->output_json($data);
	}

	public function deleteBank() {
		$id = $this->input->get('id_bank', true);
		if ($this->cbt->cekJadwalBankSoal($id)>0) {
			$this->output_json(['status' => false, 'message' => 'Ada jadwal ujian yang menggunakan bank soal ini']);
		} else {
			if ($this->master->delete('cbt_soal', $id, 'bank_id')) {
                //if ($this->master->delete('cbt_soal_siswa', $id, 'id_bank')) {}
				if ($this->master->delete('cbt_bank_soal', $id, 'id_bank')) {
                    $this->logging->saveLog(5, 'menghapus bank soal');
                    $this->output_json(['status' => true, 'message' => 'berhasil' ]);
				}
			}
		}
	}

    public function detail($id) {
        $user = $this->ion_auth->user()->row();
        $data = [
            'user'      => $user,
            'judul'	    => 'Detail Soal',
            'subjudul'  => 'Detail Soal'
        ];
        $data['setting'] = $this->dashboard->getSetting();

        $tp = $this->master->getTahunActive();
        $smt = $this->master->getSemesterActive();

        $data['tp'] = $this->dashboard->getTahun();
        $data['tp_active'] = $tp;
        $data['smt'] = $this->dashboard->getSemester();
        $data['smt_active'] = $smt;
        $data['bank'] = $this->cbt->getDataBankById($id);
        $data['soals'] = $this->cbt->getAllSoalByBank($id);
        $data['kelas'] = $this->cbt->getKelas($tp->id_tp, $smt->id_smt);
        if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);

            $this->load->view('_templates/dashboard/_header', $data);
            $this->load->view('cbt/banksoal/detail');
            $this->load->view('_templates/dashboard/_footer');
        }else{
            $data['guru'] = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);

            $this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/detail');
            $this->load->view('members/guru/templates/footer');
        }
    }

    public function saveSelected() {
        $bank_id = $this->input->post('id_bank', true);
        $jenis = $this->input->post('jenis', true);
        $soal = count($this->input->post('soal', true));
        $unchek = json_decode($this->input->post('uncheck', true));
        $arrId = [];
        for ($i = 0; $i <= $soal; $i++) {
            $id = $this->input->post('soal['.$i.']', true);
            if ($id!=null) array_push($arrId, $id);
        }

        $updated = 0;
        foreach ($arrId as $id) {
            $this->db->set('tampilkan', 1);
            $this->db->where('id_soal', $id);
            $this->db->update('cbt_soal');
            $updated ++;
        }

        foreach ($unchek as $id) {
            $this->db->set('tampilkan', 0);
            $this->db->where('id_soal', $id);
            $this->db->update('cbt_soal');
        }

        sleep(1);
        $bank = $this->cbt->getDataBankById($bank_id);
        $soals = $this->cbt->getAllSoalByBank($bank_id);

        $total_soal_tampil = isset(array_count_values(array_column($soals, 'tampilkan'))['1']) ? array_count_values(array_column($soals, 'tampilkan'))['1'] : 0;
        $total_soal_seharusnya_tampil = $bank->tampil_pg + $bank->tampil_kompleks + $bank->tampil_jodohkan + $bank->tampil_isian + $bank->tampil_esai;
        $tampil_kurang = $total_soal_tampil < $total_soal_seharusnya_tampil;
        $status_soal = $tampil_kurang ? '0' : '1';

        $this->db->set('status_soal', $status_soal);
        $this->db->where('id_bank', $bank_id);
        $this->db->update('cbt_bank_soal');

        $data['check'] = $updated;
        $this->output_json($data);
    }

    public function copyBankSoal($id_bank) {
        $tp = $this->dashboard->getTahunActive();
        $smt = $this->dashboard->getSemesterActive();
        $bank = $this->cbt->getDataBankById($id_bank);
        $soals = $this->cbt->getAllSoalByBank($id_bank);

        $data = [
            'id_tp'             => $tp->id_tp,
            'id_smt'            =>$smt->id_smt,
            'bank_jenis_id'     => $bank->bank_jenis_id,
            'bank_kode'         =>$bank->bank_kode,
            'bank_level'        => $bank->bank_level,
            'bank_kelas'        => $bank->bank_kelas,
            'bank_mapel_id'     => $bank->bank_mapel_id,
            'bank_jurusan_id'   => $bank->bank_jurusan_id,
            'bank_guru_id'      => $bank->bank_guru_id,
            'bank_nama'         => $bank->bank_nama,
            'kkm'               => $bank->kkm,
            'deskripsi'         => $bank->deskripsi,
            'jml_soal'          => $bank->jml_soal,
            'tampil_pg'         => $bank->tampil_pg,
            'bobot_pg'          => $bank->bobot_pg,
            'jml_kompleks'      => $bank->jml_kompleks,
            'tampil_kompleks'   => $bank->tampil_kompleks,
            'bobot_kompleks'    => $bank->bobot_kompleks,
            'jml_jodohkan'      => $bank->jml_jodohkan,
            'tampil_jodohkan'   => $bank->tampil_jodohkan,
            'bobot_jodohkan'    => $bank->bobot_jodohkan,
            'jml_isian'         => $bank->jml_isian,
            'tampil_isian'      => $bank->tampil_isian,
            'bobot_isian'       => $bank->bobot_isian,
            'jml_esai'          => $bank->jml_esai,
            'tampil_esai'       => $bank->tampil_esai,
            'bobot_esai'        => $bank->bobot_esai,
            'opsi'              => $bank->opsi,
            'date'              => date('Y-m-d H:i:s'),
            'status'            => $bank->status,
            'soal_agama'        => $bank->soal_agama
        ];

        $result = $this->master->create('cbt_bank_soal', $data);
        $id = $this->db->insert_id();
        foreach ($soals as $soal) {
            unset($soal->id_soal);
            $soal->bank_id = $id;
            $soal->created_on = time();
            $soal->updated_on = time();
        }
        $this->db->insert_batch('cbt_soal', $soals);

        //$result['status'] = 'Materi berhasil dibuat';
        $this->logging->saveLog(3, 'membuat bank soal');

        $this->output_json($result);
    }

	public function buatsoal($id_bank) {
		//$id = $this->input->post('id_bank', true);
		$user = $this->ion_auth->user()->row();
		$data = [
			'user'      => $user,
			'judul'	    => 'Buat Soal',
			'subjudul'  => 'Buat Soal'
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;

		$setting = $this->dashboard->getSetting();
        $data['setting'] = $setting;

        $tab = $this->input->get('tab', true);
        $jenis = $tab == null ? "1" : $tab;
        $data['tab_active'] = $jenis;
        $bank = $this->cbt->getDataBankById($id_bank);

        $data['soal'] = null;//$this->cbt->getSoalByIdBank($id_bank, $jenis);
		$data['soal_ada'] = $this->cbt->cekSoalAda($id_bank, $jenis);
        $data['soal_belum_komplit'] = $this->cbt->cekSoalBelumKomplit($id_bank, $jenis, $setting->jenjang);

        //$total_pg = $bank->jml_soal;
        //$jml_soal_pg = $this->cbt->getTotalSoal($id_bank, 1);
        if ($jenis == "1") $data['jml_pg'] = $this->cbt->getNomorSoalTerbesar($id_bank, 1);
        elseif ($jenis == "2") $data['jml_pg2'] = $this->cbt->getNomorSoalTerbesar($id_bank, 2);
        elseif ($jenis == "3") $data['jml_jodohkan'] = $this->cbt->getNomorSoalTerbesar($id_bank, 3);
        elseif ($jenis == "4") $data['jml_isian'] = $this->cbt->getNomorSoalTerbesar($id_bank, 4);
        elseif ($jenis == "5") $data['jml_essai'] = $this->cbt->getNomorSoalTerbesar($id_bank, 5);
        //$data['jml_total'] = $this->cbt->getTotalSoal($id_bank);
        $data['bank'] = $bank;

        $data['soals'] = $this->cbt->getAllSoalByBank($id_bank, $jenis);
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);
		$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/soal');
			$this->load->view('_templates/dashboard/_footer');
		} else {
            $data['guru'] = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/soal');
			$this->load->view('members/guru/templates/footer');
		}
	}

    public function getSoalByNomor() {
        $bank_id = $this->input->get('bank_id', true);
        $nomor = $this->input->get('nomor', true);
        $jenis = $this->input->get('jenis', true);
        $soal = $this->cbt->getSoalByNomor($bank_id, $nomor, $jenis);
        $data = $soal;
        if ($data != null) {
            $data->file = unserialize($soal->file);
            if ($jenis == '2') {
                $t = @unserialize($soal->opsi_a);
                if ($t !== false) $data->opsi_a = $t;
                else ($data->opsi_a = false);

                $j = @unserialize($soal->jawaban);
                if ($j !== false) $data->jawaban = $j;
                else ($data->jawaban = false);
            } elseif ($jenis == '3') {
                $j = @unserialize($soal->jawaban);
                if ($j !== false) $data->jawaban = $j;
                else ($data->jawaban = false);
            }
        }
        $this->output_json($data);
    }

    public function tambahSoal(){
        $bank = $this->input->post('bank', true);
        $nomor = $this->input->post('nomor', true);
        $jenis = $this->input->post('jenis', true);

        $data = [
            'bank_id'		=> $bank,
            'nomor_soal'	=> $nomor,
            'jenis'			=> $jenis,
            'tampilkan'		=> 0,
            'created_on'	=> time(),
            'updated_on'	=> time()
        ];

        $insert = $this->db->insert('cbt_soal', $data);
        $this->output_json($insert);
    }

	public function importsoal($id) {
		$user = $this->ion_auth->user()->row();
        $setting = $this->dashboard->getSetting();
		$data = [
			'user'      => $user,
			'judul'	    => 'Import Bank Soal',
			'subjudul'  => 'Import Bank Soal'
		];

		$tp = $this->master->getTahunActive();
		$smt = $this->master->getSemesterActive();

		$data['tp'] = $this->dashboard->getTahun();
		$data['tp_active'] = $tp;
		$data['smt'] = $this->dashboard->getSemester();
		$data['smt_active'] = $smt;

		$data['setting'] = $setting;
		$data['bank'] = $this->cbt->getDataBankById($id);
		$data['jenis'] = $this->cbt->getAllJenisUjian();
		$data['jurusan'] = $this->cbt->getAllJurusan();
		$data['level'] = $this->dropdown->getAllLevel($setting->jenjang);
		$data['kelas'] = $this->dropdown->getAllKelas($tp->id_tp, $smt->id_smt);

		if($this->ion_auth->is_admin()){
            $data['profile'] = $this->dashboard->getProfileAdmin($user->id);

			$this->load->view('_templates/dashboard/_header', $data);
			$this->load->view('cbt/banksoal/import');
			$this->load->view('_templates/dashboard/_footer');
		}else{
            $data['guru'] = $this->dashboard->getDataGuruByUserId($user->id, $tp->id_tp, $smt->id_smt);

			$this->load->view('members/guru/templates/header', $data);
            $this->load->view('cbt/banksoal/import');
			$this->load->view('members/guru/templates/footer');
		}
	}

	public function previewExcel() {
		$config['upload_path']		= './uploads/import/';
		$config['allowed_types']	= 'xls|xlsx|csv';
		$config['max_size']			= 2048;
		$config['encrypt_name']		= true;

		$this->load->library('upload', $config);

		if (!$this->upload->do_upload('upload_file')) {
			$error = $this->upload->display_errors();
			echo $error;
			die;
		} else {
			$file = $this->upload->data('full_path');
			$ext = $this->upload->data('file_ext');

			switch ($ext) {
				case '.xlsx':
					$reader = new \PhpOffice\PhpSpreadsheet\Reader\Xlsx();
					break;
				case '.xls':
					$reader = new \PhpOffice\PhpSpreadsheet\Reader\Xls();
					break;
				case '.csv':
					$reader = new \PhpOffice\PhpSpreadsheet\Reader\Csv();
					break;
				default:
					echo "unknown file ext";
					die;
			}

			$spreadsheet = $reader->load($file);
			$sheetData = $spreadsheet->getActiveSheet()->toArray();
			$data = [];
			for ($i = 1; $i < count($sheetData); $i++) {
				if ($sheetData[$i][0] != null) {
					$data[] = [
						'nama' => $sheetData[$i][1],
						'nip' => $sheetData[$i][2],
						'kode' => $sheetData[$i][3],
						'username' => $sheetData[$i][4],
						'password' => $sheetData[$i][5],
					];
					//$jurusan[] = $sheetData[$i][0];
				}
			}

			unlink($file);
			echo json_encode($data);
		}
	}

	public function previewWord($id_bank) {
		$config['upload_path']		= './uploads/import';
		$config['allowed_types']	= 'docx';
		$config['max_size']			= 2048;
		$config['encrypt_name']		= true;

		//$this->load->library('upload', $config);
		$this->upload->initialize($config);

		if (!$this->upload->do_upload('upload_file')) {
			$error = $this->upload->display_errors();
			echo $error;
			die;
		} else {
			$file = $this->upload->data('full_path');
			$phpWord = \PhpOffice\PhpWord\IOFactory::load($file);
			$htmlWriter = new \PhpOffice\PhpWord\Writer\HTML($phpWord);
			try {
				$htmlWriter->save('./uploads/temp/doc.html');
				//$htmlWriter->save("php://output");
			} catch (\PhpOffice\PhpWord\Exception\Exception $e) {
			}

			unlink($file);
			$text = file_get_contents('./uploads/temp/doc.html');

			$dom = new DOMDocument();
            $dom->preserveWhiteSpace = false;
            $dom->formatOutput = true;
			$dom->loadHTML($text);

			$images = $dom->getElementsByTagName('img');
			$numimg = 1;
			foreach ($images as $image) {
				$base64_image_string = $image->getAttribute('src');
				//echo $image->getAttribute('src') . "\n";

				//usage:  if( substr( $img_src, 0, 5 ) === "data:" ) {  $filename=save_base64_image($base64_image_string, $output_file_without_extentnion, getcwd() . "/application/assets/pins/$user_id/"); }
				//data is like:    data:image/png;base64,asdfasdfasdf
				$splited = explode(',', substr( $base64_image_string , 5 ) , 2);
				$mime=$splited[0];
				$data=$splited[1];

				$mime_split_without_base64=explode(';', $mime,2);
				$mime_split=explode('/', $mime_split_without_base64[0],2);
				if(count($mime_split)==2)
				{
					$extension=$mime_split[1];
					if($extension=='jpeg')$extension='jpg';
					$output_file = 'img_'.$id_bank.$numimg.'.'.$extension;
				}
				file_put_contents( './uploads/bank_soal/' . $output_file, base64_decode($data) );
				$image->setAttribute('src', 'uploads/bank_soal/' . $output_file);
				$numimg ++;
				//return $output_file_with_extension;
			}

			$newhtml = $dom->saveHTML();
			/*
			$dom->loadHTML($newhtml);
			$data = [];
			$tables = $dom->getElementsByTagName('table');
            $arrJenis = ['1', '2', '3', '4', '5'];
            $UPPERCASE_LETTERS = range(chr(65),chr(90));
            $LOWERCASE_LETTERS = range(chr(97),chr(122));
            $NUMBERS_ZERO_THROUGH_NINE = range(chr(48),chr(57));


            for ($t=0;$t<$tables->count(); $t++) {
                $rows = $tables->item(0)->getElementsByTagName('tr');
                $nop = 1;
                for ($i = 1; $i < $rows->count(); $i++) {
                    $cols = $rows[$i]->getElementsByTagName('td');

                    $nomor = trim($cols->item(0)->nodeValue);
                    $nomor_kosong = (int)$nomor === 0;

                    $gambar = $cols->item(1)->getElementsByTagName('img');
                    $soal_gambar = $gambar->count() > 0;
                    $sSoal = trim($cols->item(1)->nodeValue);
                    $soal_kosong = !$soal_gambar && strlen($sSoal) < 3;

                    $jenis = trim($cols->item(2)->nodeValue);
                    $jenis_kosong = !in_array($jenis, $arrJenis);

                    $opsi = trim($cols->item(3)->nodeValue);
                    $opsi_kosong = !in_array($opsi, $UPPERCASE_LETTERS);

                    $jgambar = $cols->item(4)->getElementsByTagName('img');
                    $jwb_gambar = $gambar->count() > 0;
                    $jwbn = trim($cols->item(4)->nodeValue);
                    $jwbn_kosong = !$jwb_gambar && $jwbn === " ";

                    $kunci = strtolower(trim($cols->item(5)->nodeValue));
                    $kunci_kosong = $kunci !== 'v';

                    $data[] = [
                        'nomor_soal' => $nop,
                        'soal'       => trim($this->innerXML($cols->item(1))),
                        'jenis'		 => trim($cols->item(2)->nodeValue),
                        'opsi'       => trim($cols->item(3)->nodeValue),
                        'jawaban'  => trim($cols->item(4)->nodeValue),//$dom->saveXML($cols->item(4), LIBXML_NOEMPTYTAG),
                        'kunci'    => $kunci,

                        'utf8_jenis' => mb_convert_encoding(trim($cols->item(2)->nodeValue), 'UTF-8', 'UTF-8'),
                        'soal_gambar' => $soal_gambar,
                        'soal_kosong' => $soal_kosong,
                        'opsi_kosong' => $opsi_kosong,
                        'kunci_kosong' => $kunci_kosong,
                        'jwbn_kosong' => $jwbn_kosong,
                    ];
                    $nop ++;
                }
            }
            /*
            $rows = $tables->item(0)->getElementsByTagName('tr');

            $nop = 1;
            for ($i = 1; $i < $rows->count(); $i++) {
                $cols = $rows[$i]->getElementsByTagName('td');
                $data[] = [
                    'jenis'		=> '1',
                    'nomor_soal'=> $nop,
                    'soal'       => trim($this->innerXML($cols->item(1))),
                    'jawaban_a'  => trim($this->innerXML($cols->item(2))),
                    'jawaban_b'  => trim($this->innerXML($cols->item(3))),
                    'jawaban_c'  => trim($this->innerXML($cols->item(4))),
                    'jawaban_d'  => trim($this->innerXML($cols->item(5))),
                    'jawaban_e'  => trim($this->innerXML($cols->item(6))),
                    'jawaban'  	 => trim($cols->item(7)->nodeValue)
                ];
                $nop ++;
            }

            if ($tables->item(1) !=null) {
                $rowsEssai = $tables->item(1)->getElementsByTagName('tr');
                $noe = 1;
                for ($j = 1; $j < $rowsEssai->count(); $j++) {
                    $cols = $rowsEssai[$j]->getElementsByTagName('td');
                    $data[] = [
                        'jenis'		=> '2',
                        'nomor_soal'=> $noe,
                        'soal'       => $this->innerXML($cols->item(1)),
                        'jawaban_a'  => '',
                        'jawaban_b'  => '',
                        'jawaban_c'  => '',
                        'jawaban_d'  => '',
                        'jawaban_e'  => '',
                        'jawaban'  => $this->innerXML($cols->item(2))
                    ];
                    $noe ++;
                }
            }
            //echo json_encode(array('pg' => $data));
            */
            $dataInsert = json_decode(json_encode($newhtml));
            //$json = json_decode(json_encode($data));
            $result['pg'] = $dataInsert;
            //$result['json'] = $json;
            $result['type'] = 'html';
		}

		/*
		// INSERT
        $bank = $this->cbt->getDataBankById($id_bank);
        $soal_ada = $this->cbt->cekSoalAda($id_bank);
        if (count($soal_ada) > 0) {
            $this->db->where('bank_id', $id_bank);
            $this->db->delete('cbt_soal');
        }

        $data = [];
        foreach ($dataInsert as $pg) {
            if ($pg->jenis == 1) {
                $tampilkan = $pg->nomor_soal > $bank->jml_soal ? 0 : 1;
            } else {
                $tampilkan = $pg->nomor_soal > $bank->jml_esai ? 0 : 1;
            }

            $data[] = [
                'bank_id'		=> $id_bank,
                'nomor_soal'	=> $pg->nomor_soal,
                'jenis'			=> $pg->jenis,
                'soal'			=> $pg->soal,
                'opsi_a'		=> $pg->jawaban_a,
                'opsi_b'		=> $pg->jawaban_b,
                'opsi_c'		=> $pg->jawaban_c,
                'opsi_d'		=> $pg->jawaban_d,
                'opsi_e'		=> $pg->jawaban_e,
                'jawaban'		=> $pg->jawaban,
                'tampilkan'		=> $tampilkan,
                'created_on'	=> time(),
                'updated_on'	=> time()
            ];
        }

        $save = $this->master->create('cbt_soal', $data, true);
        $this->logging->saveLog(3, 'mengimport bank soal');
        $result['data'] = $save;
		*/

        $this->output_json($result);
    }

    /**
     * @throws Exception
     */
    public function import(){
		$bank_id = $this->input->post('bank_id', true);
        $bank = $this->cbt->getDataBankById($bank_id);

        $input = $this->input->post('ganda');
        $str = preg_replace("\xEF\xBB\xBF",'',$input);
        $obj = json_decode($str);

        $json = json_decode( preg_replace('/[\x00-\x1F\x80-\xFF]/', '', $input), true );
        $result['error'] = json_last_error_msg();

        $soal = json_decode(json_encode($json));
        $result['soal'] = $obj;
        /*
        $this->db->where('bank_id', $bank_id);
		if ($this->db->delete('cbt_soal', $bank_id)) {
			$data = [];
			foreach ($soal as $pg) {
			    if ($pg->jenis == 1) {
                    $tampilkan = $pg->nomor_soal > $bank->jml_soal ? 0 : 1;
                } else {
                    $tampilkan = $pg->nomor_soal > $bank->jml_esai ? 0 : 1;
                }

				$data[] = [
					'bank_id'		=> $bank_id,
					'nomor_soal'	=> $pg->nomor_soal,
					'jenis'			=> $pg->jenis,
					'soal'			=> $pg->soal,
					'opsi_a'		=> $pg->jawaban_a,
					'opsi_b'		=> $pg->jawaban_b,
					'opsi_c'		=> $pg->jawaban_c,
					'opsi_d'		=> $pg->jawaban_d,
					'opsi_e'		=> $pg->jawaban_e,
					'jawaban'		=> $pg->jawaban,
                    'tampilkan'		=> $tampilkan,
					'created_on'	=> time(),
					'updated_on'	=> time()
				];
			}

			$save = $this->master->create('cbt_soal', $data, true);
			$this->logging->saveLog(3, 'mengimport bank soal');
			$result['data'] = $save;
			//$this->output_json($save);
			//$this->output->set_content_type('application/json')->set_output($save);
		} else {
            $result['data'] = '0';
		}*/

        $this->output_json($result);
	}

	public function export($bank_id) {
        $bank = $this->cbt->getDataBankById($bank_id);

        $soal[] = json_decode(json_encode(['soal'=>'','opsi_a'=>'','opsi_b'=>'','opsi_c'=>'','opsi_d'=>'','opsi_e'=>'','jawaban'=>'']));
        $list = $this->cbt->getAllSoalByBank($bank_id, '1');
        $soals = array_merge($soal, $list);

        $ess[] = json_decode(json_encode(['soal'=>'','jawaban'=>'']));
        $listEss = $this->cbt->getAllSoalByBank($bank_id, '2');
        $essai = array_merge($ess, $listEss);

        $phpWord = new \PhpOffice\PhpWord\PhpWord();
        $section = $phpWord->addSection();
        $header = array('size' => 10, 'bold' => true);
        $arrHeader = ['', 'NO', 'SOAL', 'JAWABAN A', 'JAWABAN B', 'JAWABAN C', 'JAWABAN D', 'JAWABAN E', 'JAWABAN BENAR',];

        $cols = 8;
        $section->addText('I. PILIHAN GANDA', $header);

        $tableStyle = array('borderSize' => 6, 'borderColor' => '000000');
        $phpWord->addTableStyle('tab style', $tableStyle);
        $table = $section->addTable('tab style');

        for ($r = 1; $r <= count($soals); $r++) {
            $soal = $soals[$r-(1)];
            $arrVal = ['', '',
                isset($soal) ? $soal->soal : '',
                isset($soal) ? $soal->opsi_a : '',
                isset($soal) ? $soal->opsi_b : '',
                isset($soal) ? $soal->opsi_c : '',
                isset($soal) ? $soal->opsi_d : '',
                isset($soal) ? $soal->opsi_e : '',
                isset($soal) ? $soal->jawaban : '',
            ];

            $table->addRow();
            for ($c = 1; $c <= $cols; $c++) {
                $width = 4000;
                $align = array(
                    'align' => 'left',
                    'space' => array('before' => 50, 'after' => 50),
                    'indentation' => array('left' => 100, 'right' => 100));
                if ($c == 1) {
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 100, 'right' => 100));
                    $width = 500;
                } elseif ($c==2) {
                    $width = 8000;
                }

                $fontStyle = array('size' => 10, 'bold' => false);
                $no = $r-1;

                if ($r==1){
                    $no = "NO";
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 50, 'right' => 50));
                    $fontStyle = array('size' => 10, 'bold' => true);
                }

                if ($r == 1) {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $table->addCell($width)->addText($arrHeader[$c], $fontStyle, $align);
                    }
                } else {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $tagRemoved = strip_tags($arrVal[$c]);
                        $html = htmlspecialchars($tagRemoved);
                        $table->addCell($width)->addText($this->cleanString($html), $fontStyle, $align);
                        //$table->addCell($width)->addText(htmlspecialchars(strip_tags($arrVal[$c])), $fontStyle, $align);
                    }
                }
            }
        }

        $section->addPageBreak();
        $section->addText('II. ESSAI', $header);
        $arrHeader = ['', 'NO', 'SOAL', 'JAWABAN',];
        $cols = 3;
        $phpWord->addTableStyle('tab style', $tableStyle);
        $table = $section->addTable('tab style');

        for ($r = 1; $r <= count($essai); $r++) {
            $soal = $essai[$r-(1)];
            $arrVal = ['', '',
                isset($soal) ? $soal->soal : '',
                isset($soal) ? $soal->jawaban : '',
            ];

            $table->addRow();
            for ($c = 1; $c <= $cols; $c++) {
                $width = 4000;
                $align = array(
                    'align' => 'left',
                    'space' => array('before' => 50, 'after' => 50),
                    'indentation' => array('left' => 100, 'right' => 100));
                if ($c == 1) {
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 100, 'right' => 100));
                    $width = 500;
                } elseif ($c==2) {
                    $width = 8000;
                }

                $fontStyle = array('size' => 10, 'bold' => false);
                $no = $r-1;

                if ($r==1){
                    $no = "NO";
                    $align = array(
                        'align' => 'center',
                        'space' => array('before' => 50, 'after' => 50),
                        'indentation' => array('left' => 50, 'right' => 50));
                    $fontStyle = array('size' => 10, 'bold' => true);
                }

                if ($r == 1) {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $table->addCell($width)->addText($arrHeader[$c], $fontStyle, $align);
                    }
                } else {
                    if ($c == 1 ) {
                        $table->addCell($width)->addText($no, $fontStyle, $align);
                    } else {
                        $tagRemoved = strip_tags($arrVal[$c]);
                        $html = htmlspecialchars($tagRemoved);
                        $table->addCell($width)->addText($this->cleanString($html), $fontStyle, $align);
                    }
                }
            }
        }

        $objWriter = \PhpOffice\PhpWord\IOFactory::createWriter($phpWord, 'Word2007');
        header("Content-Disposition: attachment; filename=Soal ".$bank->nama_mapel.".docx");
        $objWriter->save('php://output');
    }

    public function getSoalSiswa($id_bank) {
        $soals = $this->cbt->getAllSoalByBank($id_bank);
        foreach ($soals as $soal) {
            $soal->file = unserialize($soal->file);
            if ($soal->jenis == '2') {
                $soal->jawaban = unserialize($soal->jawaban);
                $soal->opsi_a = unserialize($soal->opsi_a);
            } elseif ($soal->jenis == '3') {
                $soal->jawaban = unserialize($soal->jawaban);
            }
        }
        $data['soal'] = $soals;
        $this->output_json($data);
    }

	function innerXML($node) {
		$doc  = $node->ownerDocument;
		$frag = $doc->createDocumentFragment();
		foreach ($node->childNodes as $child) {
			$frag->appendChild($child->cloneNode(TRUE));
		}
		return $doc->saveXML($frag);
	}

	public function file_config() {
		$allowed_type 	= [
			"image/jpeg", "image/jpg", "image/png", "image/gif",
			"audio/mpeg", "audio/mpg", "audio/mpeg3", "audio/mp3", "audio/x-wav", "audio/wave", "audio/wav",
			"video/mp4", "application/octet-stream"
		];
		$config['upload_path']      = FCPATH.'uploads/bank_soal/';
		$config['allowed_types']    = 'jpeg|jpg|png|gif|mpeg|mpg|mpeg3|mp3|wav|wave|mp4';
		$config['encrypt_name']     = TRUE;

		return $this->load->library('upload', $config);
	}

	public function validasi($jenis) {
		$this->form_validation->set_rules('soal', 'Soal', 'required');
		if ($jenis==1) {
            $this->form_validation->set_rules('jawaban_pg', 'Kunci Jawaban', 'required');
        } elseif ($jenis==2) {
            $this->form_validation->set_rules('jawaban2_a', 'Kunci Jawaban', 'required');
            $this->form_validation->set_rules('jawaban_benar_pg2[]', 'Kunci Jawaban', 'required');
        } elseif ($jenis==3) {
            $this->form_validation->set_rules('jawaban_jodohkan', 'Kunci Jawaban', 'required');
        } elseif ($jenis==4) {
            $this->form_validation->set_rules('jawaban_isian', 'Kunci Jawaban', 'required');
		} else {
			$this->form_validation->set_rules('jawaban_essai', 'Kunci Jawaban', 'required');
		}
	}

	public function saveSoal() {
		$method = $this->input->post('method', true);
		$jenis = $this->input->post('jenis', true);

		$this->validasi($jenis);
		$this->file_config();

        $data = [
            'bank_id'       => $this->input->post('bank_id', true),
            'jenis'         => $jenis,
            'nomor_soal'    => $this->input->post('nomor_soal', true),
            'soal'          => $this->input->post('soal', false)
        ];

        if ($jenis==1) {
            $abjad = ['a', 'b', 'c', 'd', 'e'];
            foreach ($abjad as $abj) {
                $data['opsi_'.$abj] = $this->input->post('jawaban_'.$abj, false);
            }
            $data['jawaban'] = $this->input->post('jawaban_pg', true);
        } elseif ($jenis == 2) {
            $opsis = [];
            for ($i=97; $i<117; $i++) {
                $op = $this->input->post('jawaban2_'. chr($i), false);
                if ($op != null) {
                    //array_push($opsis, $op);
                    $opsis[chr($i)] = $op;
                }
            }
            $data['opsi_a'] = serialize($opsis);

            $jawabans = [];
            $jwb_pg2 = count($this->input->post('jawaban_benar_pg2', true));
            for ($i = 0; $i <= $jwb_pg2; $i++) {
                $jwb = $this->input->post('jawaban_benar_pg2['.$i.']', true);
                //if ($id!=null) array_push($arrId, $id);
                array_push($jawabans, $jwb);
            }
            $data['jawaban'] = serialize($jawabans);
        } elseif ($jenis == 3) {
            $jwb_jodohkan = [
                'model' => $this->input->post('model', true),
                'type' => $this->input->post('type', true),
                'jawaban' => json_decode($this->input->post('jawaban_jodohkan', true))
            ];
            $data['jawaban'] = serialize($jwb_jodohkan);
        } elseif ($jenis == 4) {
            $data['jawaban'] = $this->input->post('jawaban_isian', true);
		} else {
            $data['jawaban'] = $this->input->post('jawaban_essai', true);
		}

		if ($this->form_validation->run() === FALSE){
			$result['status'] = 'error';
		} else {
			if($method==='add'){
				$data['created_on'] = time();
				$data['updated_on'] = time();
				$this->master->create('cbt_soal', $data);
				$result['status'] = 'Soal berhasil dibuat';
				$this->logging->saveLog(3, 'membuat soal');
			} else if ($method==='edit'){
				$id_soal = $this->input->post('soal_id', true);
				$data['updated_on'] = time();
				$this->master->update('cbt_soal', $data, 'id_soal', $id_soal);
				$result['status'] = 'Soal berhasil diupdate';
				$this->logging->saveLog(4, 'mengedit soal');
			} else {
				$result['status'] = '400 Method not found';
			}
		}
		$this->output_json($result);
	}

    public function hapusSoal() {
        $id_soal = $this->input->post('soal_id', true);
        if ($this->db->delete('cbt_soal', 'id_soal='.$id_soal)){
            $result['status'] = 'Soal berhasil dihapus';
        } else {
            $result['status'] = '400 Method not found';
        }
        $this->output_json($result);
    }

    function uploadFile(){
        $id_soal = $this->input->get('id_soal', true);
        $soal = $this->cbt->getSoalById($id_soal);
        $files = $soal == null || $soal->file == null ? [] : unserialize($soal->file);

        if(isset($_FILES["file_uploads"]["name"])){
            $nama_file_asal = $_FILES["file_uploads"]["name"];
            $kode_file = $id_soal.'_'.time();

            $config['upload_path'] = './uploads/bank_soal/';
            $config['allowed_types'] = 'mpeg|mpg|mpeg3|mp3|wav|wave|mp4|avi';
            $config['file_name'] = $kode_file;

            //$config['encrypt_name'] = TRUE;
            //$config['max_size'] = '0';
            //$config['overwrite'] = FALSE;
            $this->upload->initialize($config);
            if(!$this->upload->do_upload('file_uploads')){
                $data['status'] = false;
                $src = '';
                $filename = '';
                $data['src'] = $this->upload->display_errors();
            }else{
                $file = $this->upload->data();
                /*
                $config['image_library']='gd2';
                $config['source_image']='./uploads/bank_soal/'.$file['file_name'];
                $config['create_thumb']= FALSE;
                $config['maintain_ratio']= TRUE;
                $config['quality']= '60%';
                $config['width']= 800;
                $config['height']= 800;
                $config['new_image']= './uploads/bank_soal/'.$file['file_name'];
                $this->load->library('image_lib', $config);
                $this->image_lib->resize();
                */

                //echo base_url().'uploads/bank_soal/'.$file['file_name'];
                $ext = pathinfo($file['file_name'], PATHINFO_EXTENSION);
                $src = 'uploads/bank_soal/'.$kode_file.'.'.$ext;
                $data['src'] = $src;
                //$filename = pathinfo($file['file_name'], PATHINFO_FILENAME);
                //$data['filename'] = $filename;
                $data['filename'] = $nama_file_asal;
                $data['status'] = true;

                $type = $_FILES['file_uploads']['type'];
                $data['type'] = $type;
                $data['size'] = $_FILES['file_uploads']['size'];
                $data['soal'] = $soal;

                $files[] = [
                    'file_name' => $nama_file_asal,
                    'alias' => $kode_file,
                    'src' => $src,
                    'type' => $type
                ];
                //array_push($files, ['files'=>$addFiles]);

                $this->db->set('file', serialize($files));
                $this->db->where('id_soal', $id_soal);
                $this->db->update('cbt_soal');
            }
        }

        $data['files'] = $files;
        $this->output_json($data);
    }
	//Upload image summernote
	function upload_image(){
		//$data['tag_id'] = $this->input->post('tag_id', true);
        $status = false;
        if(isset($_FILES["file"]["name"])){
			$config['upload_path'] = './uploads/bank_soal/';
			$config['allowed_types'] = 'jpg|jpeg|png|gif|mp3|ogg|wav|mp4|mpeg|webm';
            $config['file_name'] = 'file_'.date('YmdHis');
			$this->upload->initialize($config);
			if(!$this->upload->do_upload('file')){
				$this->upload->display_errors();
				$status = false;
			}else{
				$uploaded = $this->upload->data();
				//Compress Image
				//$config['image_library']='gd2';
				//$config['source_image']='./uploads/bank_soal/'.$data['file_name'];
				//$config['create_thumb']= FALSE;
				//$config['maintain_ratio']= TRUE;
				//$config['quality']= '60%';
				//$config['width']= 800;
				//$config['height']= 800;
				//$config['new_image']= './uploads/bank_soal/'.$data['file_name'];
				//$this->load->library('image_lib', $config);
				//$this->image_lib->resize();

				$data['filename'] =  'uploads/bank_soal/'.$uploaded['file_name'];
				$status = true;
			}
		}
		$data['status'] = $status;
		$this->output_json($data);
	}

	//Delete image summernote
    function deleteFile() {
        $src = $this->input->post('src');
        $file_name = str_replace(base_url(), '', $src);
        if (unlink($file_name)) {
            echo 'File Delete Successfully';
        }
    }

    function cleanString($text) {
        // 1) convert á ô => a o
        $text = preg_replace("/[áàâãªä]/u","a",$text);
        $text = preg_replace("/[ÁÀÂÃÄ]/u","A",$text);
        $text = preg_replace("/[ÍÌÎÏ]/u","I",$text);
        $text = preg_replace("/[íìîï]/u","i",$text);
        $text = preg_replace("/[éèêë]/u","e",$text);
        $text = preg_replace("/[ÉÈÊË]/u","E",$text);
        $text = preg_replace("/[óòôõºö]/u","o",$text);
        $text = preg_replace("/[ÓÒÔÕÖ]/u","O",$text);
        $text = preg_replace("/[úùûü]/u","u",$text);
        $text = preg_replace("/[ÚÙÛÜ]/u","U",$text);
        $text = preg_replace("/[’‘‹›‚]/u","'",$text);
        $text = preg_replace("/[“”«»„]/u",'"',$text);
        $text = str_replace("–","-",$text);
        $text = str_replace(" "," ",$text);
        $text = str_replace("ç","c",$text);
        $text = str_replace("Ç","C",$text);
        $text = str_replace("ñ","n",$text);
        $text = str_replace("Ñ","N",$text);

        //2) Translation CP1252. &ndash; => -
        $trans = get_html_translation_table(HTML_ENTITIES);
        $trans[chr(130)] = '&sbquo;';    // Single Low-9 Quotation Mark
        $trans[chr(131)] = '&fnof;';    // Latin Small Letter F With Hook
        $trans[chr(132)] = '&bdquo;';    // Double Low-9 Quotation Mark
        $trans[chr(133)] = '&hellip;';    // Horizontal Ellipsis
        $trans[chr(134)] = '&dagger;';    // Dagger
        $trans[chr(135)] = '&Dagger;';    // Double Dagger
        $trans[chr(136)] = '&circ;';    // Modifier Letter Circumflex Accent
        $trans[chr(137)] = '&permil;';    // Per Mille Sign
        $trans[chr(138)] = '&Scaron;';    // Latin Capital Letter S With Caron
        $trans[chr(139)] = '&lsaquo;';    // Single Left-Pointing Angle Quotation Mark
        $trans[chr(140)] = '&OElig;';    // Latin Capital Ligature OE
        $trans[chr(145)] = '&lsquo;';    // Left Single Quotation Mark
        $trans[chr(146)] = '&rsquo;';    // Right Single Quotation Mark
        $trans[chr(147)] = '&ldquo;';    // Left Double Quotation Mark
        $trans[chr(148)] = '&rdquo;';    // Right Double Quotation Mark
        $trans[chr(149)] = '&bull;';    // Bullet
        $trans[chr(150)] = '&ndash;';    // En Dash
        $trans[chr(151)] = '&mdash;';    // Em Dash
        $trans[chr(152)] = '&tilde;';    // Small Tilde
        $trans[chr(153)] = '&trade;';    // Trade Mark Sign
        $trans[chr(154)] = '&scaron;';    // Latin Small Letter S With Caron
        $trans[chr(155)] = '&rsaquo;';    // Single Right-Pointing Angle Quotation Mark
        $trans[chr(156)] = '&oelig;';    // Latin Small Ligature OE
        $trans[chr(159)] = '&Yuml;';    // Latin Capital Letter Y With Diaeresis
        $trans['euro'] = '&euro;';    // euro currency symbol
        ksort($trans);

        foreach ($trans as $k => $v) {
            $text = str_replace($v, $k, $text);
        }

        // 3) remove <p>, <br/> ...
        $text = strip_tags($text);

        // 4) &amp; => & &quot; => '
        $text = html_entity_decode($text);

        // 5) remove Windows-1252 symbols like "TradeMark", "Euro"...
        $text = preg_replace('/[^(\x20-\x7F)]*/','', $text);

        $targets=array('\r\n','\n','\r','\t');
        $results=array(" "," "," ","");
        $text = str_replace($targets,$results,$text);

        //XML compatible
        /*
        $text = str_replace("&", "and", $text);
        $text = str_replace("<", ".", $text);
        $text = str_replace(">", ".", $text);
        $text = str_replace("\\", "-", $text);
        $text = str_replace("/", "-", $text);
        */

        return ($text);
    }

    function cleanHTML($html) {
        $doc = new DOMDocument();
        /* Load the HTML */
        $doc->loadHTML($html,
            LIBXML_HTML_NOIMPLIED | # Make sure no extra BODY
            LIBXML_HTML_NODEFDTD |  # or DOCTYPE is created
            LIBXML_NOERROR |        # Suppress any errors
            LIBXML_NOWARNING        # or warnings about prefixes.
        );
        /* Immediately save the HTML and return it. */
        return $doc->saveHTML();
    }

    function addNamespaces($xml) {
        $root = '<w:wordDocument
        xmlns:w="http://schemas.microsoft.com/office/word/2003/wordml"
        xmlns:wx="http://schemas.microsoft.com/office/word/2003/auxHint"
        xmlns:o="urn:schemas-microsoft-com:office:office">';
        $root .= $xml;
        $root .= '</w:wordDocument>';
        return $root;
    }

    function doImport() {
        $bank_id = $this->input->post('id_bank', true);
        $string = $this->input->post('data', false);

        $json = json_decode($string);
        /*
        switch (json_last_error()) {
            case JSON_ERROR_NONE:
                echo ' - No errors';
                break;
            case JSON_ERROR_DEPTH:
                echo ' - Maximum stack depth exceeded';
                break;
            case JSON_ERROR_STATE_MISMATCH:
                echo ' - Underflow or the modes mismatch';
                break;
            case JSON_ERROR_CTRL_CHAR:
                echo ' - Unexpected control character found';
                break;
            case JSON_ERROR_SYNTAX:
                echo ' - Syntax error, malformed JSON';
                break;
            case JSON_ERROR_UTF8:
                echo ' - Malformed UTF-8 characters, possibly incorrectly encoded';
                break;
            default:
                echo ' - Unknown error';
                break;
        }
        */
        $datas = [];
        $jml = [];
        foreach ($json as $jenis=>$values) {
            $data_soal = [];
            foreach ($values as $val) {
                if (isset($val->NO)) {
                    $no = $val->NO;
                    if (isset($val->SOAL) && $val->SOAL != "") $data_soal[$no]['soal'] = $val->SOAL;

                    if ($jenis == "1") {
                        if (isset($val->OPSI)) {
                            $data_soal[$no]['opsi'][strtoupper($val->OPSI)] = $val->JAWABAN;
                            if (isset($val->KUNCI) && strtolower($val->KUNCI) == "v") {
                                $data_soal[$no]['kunci'][strtolower($val->KUNCI)] = strtoupper($val->OPSI);
                            }
                        }
                    } elseif ($jenis == "2") {
                        if (isset($val->OPSI)) {
                            $data_soal[$no]['opsi'][strtoupper($val->OPSI)] = $val->JAWABAN;
                            if (isset($val->KUNCI) && strtolower($val->KUNCI) == "v") {
                                $data_soal[$no]['kunci'][strtoupper($val->OPSI)] = strtolower($val->KUNCI);
                            }
                        }
                    } elseif ($jenis == "3") {
                        if (isset($val->KD_BARIS)) {
                            $data_soal[$no]['baris'][strtoupper($val->KD_BARIS)] = $val->BARIS;

                            if (isset($val->KUNCI)) {
                                $data_soal[$no]['kunci'][strtoupper($val->KD_KUNCI)] = strtoupper($val->KUNCI);
                            }
                        }

                        if (isset($val->KD_KOLOM)) {
                            $data_soal[$no]['kolom'][strtoupper($val->KD_KOLOM)] = $val->KOLOM;
                        }
                    } else {
                        if (isset($val->KUNCI)) $data_soal[$no]['kunci'] = $val->KUNCI;
                    }
                }
            }

            $datas[$jenis] = $data_soal;
        }

        $data_insert = [];
        foreach ($datas as $jenis=>$keys) {
            foreach ($keys as $no=>$v) {
                $isi_soal = isset($v['soal']) ? $v['soal'] : "";
                if ($isi_soal != "") {
                    $insert = [
                        'jenis' => $jenis,
                        'nomor_soal' => $no,
                        'soal' => $isi_soal,
                        'file' => serialize([]) ,
                    ];

                    if ($jenis == "1") {
                        $insert['opsi_a'] = isset($v['opsi']) && isset($v['opsi']['A']) ? $v['opsi']['A'] : '';
                        $insert['opsi_b'] = isset($v['opsi']) && isset($v['opsi']['B']) ? $v['opsi']['B'] : '';
                        $insert['opsi_c'] = isset($v['opsi']) && isset($v['opsi']['C']) ? $v['opsi']['C'] : '';
                        $insert['opsi_d'] = isset($v['opsi']) && isset($v['opsi']['D']) ? $v['opsi']['D'] : '';
                        $insert['opsi_e'] = isset($v['opsi']) && isset($v['opsi']['E']) ? $v['opsi']['E'] : '';
                        $insert['jawaban'] = isset($v['kunci']) && isset($v['kunci']['v']) ? $v['kunci']['v'] : '';
                    } elseif ($jenis == "2") {
                        $opsis = [];
                        $kuncis = [];
                        if (isset($v['opsi'])) {
                            foreach ($v['opsi'] as $opsi=>$jawaban) {
                                $opsis[strtolower($opsi)] = $jawaban;
                            }
                        }

                        if (isset($v['kunci'])) {
                            foreach ($v['kunci'] as $kunci=>$jawaban) {
                                if ($jawaban == "v") $kuncis[] = strtolower($kunci);
                            }
                        }
                        $insert['opsi_a'] = serialize($opsis);
                        $insert['jawaban'] = serialize($kuncis);

                    } elseif ($jenis == "3") {
                        $baris = [];
                        $kolom = [];

                        $header = [];
                        array_push($header, '#');

                        $arrKol = [];
                        foreach ($v['kolom'] as $kd_kol=>$kol) {
                            $kolom[$kd_kol] = $kol;
                            if ($kol != "") array_push($header, $kol);

                            foreach ($v['kunci'] as $kd_bar=>$kd_kol) {
                                if ($kd_kol != "") $arrKol[$kd_bar] = explode(',', $kd_kol);
                            }
                        }

                        array_push($baris, $header);
                        $jwbnBaris = [];
                        foreach ($v['baris'] as $kd_bar=>$bar) {
                            $jwbn = [];
                            if ($kd_bar != "") array_push($jwbn, $bar);

                            foreach ($kolom as $kk=>$val) {
                                if ($kd_bar != "" && $val != "") {
                                    $match = in_array($kk, $arrKol[$kd_bar]);
                                    array_push($jwbn, $match ? '1' : '0');
                                }
                            }
                            if (count($jwbn) > 0) array_push($baris, $jwbn);

                            if ($kd_bar != "") {
                                array_shift($jwbn);
                                $jwbnBaris[$kd_bar] = $jwbn;
                            }
                        }
                        $types = [];
                        foreach ($jwbnBaris as $brs=>$jml) {
                            $jmlType = array_count_values($jml);
                            if ($jmlType[1] > 1) array_push($types, 'checkbox');
                        }
                        $type = count($types) > 0 ? '1' : '2';

                        $jml_baris = count($baris);
                        $jml_kolom = count($baris[0]);

                        $jwb_jodohkan = [
                            'model' => $jml_baris == $jml_kolom ? '1' : '2',
                            'type' => $type,
                            'jawaban' => $baris
                        ];
                        $insert['jawaban'] = serialize($jwb_jodohkan);
                    } elseif ($jenis == "4") {
                        if (isset($v['kunci'])) $insert['jawaban'] = strip_tags($v['kunci']);
                    } else {
                        if (isset($v['kunci'])) $insert['jawaban'] = $v['kunci'];
                    }

                    $data_insert[] = $insert;
                }
            }
        }

        $inserted = [];
        foreach ($data_insert as $dins) {
            $inserted[] = [
                'bank_id' => $bank_id,
                'jenis' => $dins['jenis'],
                'nomor_soal' => $dins['nomor_soal'],
                'soal' => $dins['soal'],
                'deskripsi'=> '',
                'kesulitan'=> '8',
                'timer' => '0',
                'timer_menit' => '0',
                'file' => $dins['file'] ,
                'tampilkan' => '0',
                'created_on' => time(),
                'updated_on' => time(),
                'opsi_a' => isset($dins['opsi_a']) ? $dins['opsi_a'] : '',
                'opsi_b' => isset($dins['opsi_b']) ? $dins['opsi_b'] : '',
                'opsi_c' => isset($dins['opsi_c']) ? $dins['opsi_c'] : '',
                'opsi_d' => isset($dins['opsi_d']) ? $dins['opsi_d'] : '',
                'opsi_e' => isset($dins['opsi_e']) ? $dins['opsi_e'] : '',
                'jawaban' => $dins['jawaban']
            ];
        }

        $data['data_insert'] = $inserted;
        $data['total'] = count($inserted);
        if (count($inserted) > 0) {
            $this->db->where('bank_id', $bank_id);
            if ($this->db->delete('cbt_soal')) {
                $data['insert'] = $this->db->insert_batch('cbt_soal', $inserted);
            }
        } else {
            $data['insert'] = 0;
        }
        $this->output_json($data);
    }
}'))

Function Calls

base64_decode 1

Variables

None

Stats

MD5 4a7f479cb06c4a64e21b8fff7bcb89d8
Eval Count 1
Decode Time 308 ms