Viewing file: timetable.php (20.29 KB) -rwxr-xr-x Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php /** * timetable class * สำหรับจัดการตารางสอน * @author Sitthichai */
include("rg_controller.php"); class timetable extends Rg_controller {
var $condition = Array(); var $order = Array(); var $group = Array(); var $option = ''; var $sess_prsItId = ""; var $sess_prsUsId = ""; var $json_data = Array( 'error' => 1, 'html' => 'Ajax Error: Invalid Request', ); public function __construct() { parent::__construct(); $personId = $this->session->userdata('UsPsCode'); $this->sess_prsItId = 1; $this->sess_prsUsId = $personId; if(substr($personId, 0, 5)=='psout') { $this->sess_prsItId = 2; $this->sess_prsUsId = substr($personId, 5); } } /** * สำหรับบันทึกตารางสอน หรือจัดตารางสอน */ function arranged_schedule($mode){ if($mode=="teacher" or $mode=="default" or $mode=="view"){ $this->load->model($this->config->item("rg_folder").'mo_rg_termconfig','tmc'); $this->load->model($this->config->item("rg_folder").'mo_rg_term','tm'); $group_AcY = array('tmcAcY'=>'tmcAcY'); $rs_tmc= $this->tmc->get_options('',array('tmcAcY'=>'DESC'),$group_AcY); $this->contents['tmc'] = $rs_tmc; $this->contents['tm'] = $this->tm->get_options('',array('tmName'=>''),'','N');
$this->contents['mode'] = $mode; if($this->session->userdata('UsPsCode')){ $this->load->model($this->config->item("rg_folder").'mo_rg_person','prs'); $con_ps = array('prsUsId'=>$this->sess_prsUsId); $qu_ps= $this->prs->qryPrsJoinPPC($con_ps); $prsId = (isset($qu_ps) && $qu_ps!=NULL && $qu_ps->num_rows()>0) ? $qu_ps->row()->prsId : NULL; $this->contents['per'] = $prsId; } // หาวันทั้งหมด วัน $this->load->model($this->config->item("rg_folder").'mo_rg_day','dy'); $this->condition = ''; $this->group = ''; $this->option = ''; $this->order = array('dyId'=>''); $this->contents['dy'] = $this->dy->qryDy($this->condition,$this->order,$this->group,$this->option);
// หาคาบเรียน เวลาเริ่มต้นเรียน $this->load->model($this->config->item("rg_folder").'mo_rg_period','prd'); $this->condition = ''; $this->group = ''; $this->option = ''; $this->order = array('prdId'=>''); $this->contents['prdFr'] = $this->prd->get_options_frTime($this->condition,$this->order,$this->group,$this->option); $this->load->model($this->config->item("rg_folder").'mo_rg_room','room'); $rm = $this->room->get_Room(array('plIsRoom'=>'Y'),array('plRmNo'=>''),'',''); $this->contents['rm'] = $rm; if($this->session->flashdata('dt')){ $this->contents['dt'] = $this->session->flashdata('dt'); } /*if($this->session->userdata('dt')){ $this->contents['dt'] = $this->session->userdata('dt'); }*/
//$this->output($this->config->item("rg_folder")."v_ttArrangedSchedule",$this->session->flashdata('msg')); $this->output($this->config->item("rg_folder")."v_ttArrangedSchedule", $this->session->flashdata('msg')); } }
function opt_timetable_detail(){ //$rmId = $this->input->post('rmId'); }
function get_mep(){ $prdFrTime=2; $prdToTime=3; // หาคาบเรียน เวลาสิ้นสุดคาบเรียน $this->load->model($this->config->item("rg_folder").'mo_rg_period','prd'); $this->condition = array('1'=>'1'); $this->group = ''; $this->option = ''; $this->order = array('prdId'=>''); $this->prd->prdId = $prdFrTime;
$qu = $this->prd->get_options_toTime($this->condition,$this->order,$this->group,$this->option);
$attr = 'id="prdToTime" onChange="get_option();"'; echo form_dropdown('prdToTime',$qu,$prdToTime,$attr);
echo $this->db->last_query(); print_r($qu); //print_r($qu); }
function get_option(){ if ($this->input->server('REQUEST_METHOD') === 'POST') { $tmcAcY = $this->input->post('tmcAcY'); $tmId = $this->input->post('tmId'); $curId = $this->input->post('curId'); $syId = $this->input->post('syId'); $crsId = $this->input->post('crsId'); $coSection = $this->input->post('coSection'); $mepId = $this->input->post('mepId'); $sepId = $this->input->post('sepId'); $wdAcYWeekNo = $this->input->post('wdAcYWeekNo'); $numWeek = $this->input->post('numWeek'); $dyId = $this->input->post('dyId'); $prdFrTime = $this->input->post('prdFrTime'); $prdToTime = $this->input->post('prdToTime'); $prsId = $this->input->post('prsId'); $stId = $this->input->post('stId'); // $this->json_data['tt'] = "tmcAcY:$tmcAcY / tmId:$tmId";
// $this->load->model($this->config->item("rg_folder").'mo_rg_courseopen','co');
//หาสิทธิ์ if($curId=="NULL"){ $id = "0"; }else if(!$this->input->post('curId')){ $id = "0"; }else{ $id = $this->input->post('curId'); } $this->load->model($this->config->item("rg_folder").'mo_rg_person','prs'); $this->load->model($this->config->item("rg_folder").'mo_rg_personpermission','pp'); $prs_con = array('prsUsId'=>$this->sess_prsUsId,'prsItId'=>$this->sess_prsItId); $qu_prs = $this->prs->qryPrs($prs_con);
if ($qu_prs->num_rows() > 0) { $row_prs = $qu_prs->row(); $pp_con = array('ppPrsId'=>$row_prs->prsId,'ppAcY'=>$tmcAcY,'ppTmId'=>$tmId,'ppCurId'=>$id); $qu_pp = $this->pp->qryPp($pp_con); if ($qu_pp->num_rows() > 0) { $row = $qu_pp->row(); $this->json_data['pp'] = $row->ppTT; } else{ $this->json_data['pp'] = "N"; } }else{ $this->json_data['pp'] = "N"; }
/// ค้นหา หลักสูตร $this->load->model($this->config->item("rg_folder").'mo_rg_curriculum','cur'); $this->load->model($this->config->item("rg_folder").'mo_rg_courseopen','co'); $this->condition = array_merge($this->condition, array('coAcY'=>$tmcAcY,'coTmId'=>$tmId)); $this->group = array( 'curId'=>'curName' ); $this->option = '-- เลือกหลักสูตร --'; //$qu = $this->co->qry_optionCo($this->condition,$this->order,$this->group,$this->option); $con_cur = array('curStatus'=>'Y'); $qu = $this->cur->get_options($con_cur,$this->order,$this->group,$this->option); if(count($qu)==1){ $qu[''] = '-- ไม่พบหลักสูตรที่เปิดใน ภาคการศึกษานี้ --'; }else{ unset($qu['']); $qu['NULL'] = 'เรียนรวมหลายหลักสูตร'; ksort($qu); } $attr = 'id="curId" onChange="Sync(this.id);get_option();checkSubmit();timeTable();"'; $this->json_data['cur'] = form_dropdown('curId',$qu,$curId,$attr); //$tb_con = array('coAcY'=>$tmcAcY); $con_cur = array('curStatus'=>'Y'); $this->group = array( 'curId'=>'curName' ); $this->option = 'เรียนรวมหลายหลักสูตร'; $qu = $this->cur->get_options($con_cur,$this->order,$this->group,$this->option); if(count($qu)==1){ $qu[''] = '-- ไม่พบหลักสูตรที่เปิดใน ภาคการศึกษานี้ --'; }else{ unset($qu['']); $qu['NULL'] = '-- เรียนรวมหลักสูตร --'; ksort($qu); } $tbcurId = $this->input->post('tbcurId'); $attr = 'id="tbcurId" onChange="get_option();checkSubmit();timeTable();"'; //Sync(this.id); $this->json_data['tbcur'] = form_dropdown('tbcurId',$qu,$tbcurId,$attr); // ค้นหาชั้นปี if(!$this->input->post('curId')){ $curId = "NULL"; } $this->load->model($this->config->item("rg_folder").'mo_rg_studyyear','sy'); $this->condition = array_merge($this->condition, array('curId'=>$curId)); $this->order = array('syCode'=>''); $this->option = '-- เลือกชั้นปี --'; $qu = $this->sy->get_options2('',$this->order,'','N'); //echo $this->db->last_query(); if(count($qu)==1){ $qu[''] = '-- ไม่พบชั้นปี --'; } $attr = 'id="syId" onChange="Sync(this.id);get_option();checkSubmit();"'; $this->json_data['sy'] = form_dropdown('syId',$qu,$syId,$attr); if(!$this->input->post('tbcurId')){ $tbcurId = "NULL"; } //$tb_con = array('coAcY'=>$tmcAcY,'curId'=>$tbcurId); $this->order = array('syCode'=>''); $this->option = '-- เลือกชั้นปี --'; $qu = $this->sy->get_options2('',$this->order,'','N'); //echo $this->db->last_query(); if(count($qu)==1){ $qu[''] = '-- ไม่พบชั้นปี --'; } $tbsyId = $this->input->post('tbsyId'); $attr = 'id="tbsyId" onChange="checkSubmit();timeTable();"'; $this->json_data['tbsy'] = form_dropdown('tbsyId',$qu,$tbsyId,$attr); // ค้นหารายวิชา $this->condition = array_merge($this->condition, array('syId'=>$syId)); $this->group = array('crsId'=>'crsName'); $this->option = '-- เลือกรายวิชา --'; $qu = $this->co->qry_optionCo($this->condition,$this->order,$this->group,$this->option);
if(count($qu)==1){ $qu[''] = '-- ไม่พบรายวิชา --'; } $attr = 'id="crsId" onChange="get_option();checkSubmit();"'; $this->json_data['crs'] = form_dropdown('crsId',$qu,$crsId,$attr); // ค้นหากลุ่ม $this->condition = array_merge($this->condition, array('crsId'=>$crsId)); $this->order = array('coSection'=>''); $this->group = array('coSection'=>'coSection'); $this->option = ''; $qu = $this->co->qry_optionCo($this->condition,$this->order,$this->group,$this->option); if(count($qu)>1){ $qu['%'] = '-- ทุกกลุ่ม --'; ksort($qu); } if(count($qu)==0){ $qu[''] = '-- ไม่พบ --'; } $attr = 'id="coSection" onChange="get_option();checkSubmit();"'; $this->json_data['coSection'] = form_dropdown('coSection',$qu,$coSection,$attr);
// ค้นหา สถานที่ฝึกหลัก $this->load->model($this->config->item("rg_folder").'mo_rg_externalplace','etp'); $this->condition = ''; $this->group = array('mepId'=>'mepName'); $this->option = '-- เลือกสถานที่ฝึกหลัก --'; $this->order = ''; $qu = $this->etp->mep_optionsJoinMepSep($this->condition,$this->order,$this->group,$this->option); if(count($qu)>=1){ $attr = 'id="mepId" onChange="get_option();checkSubmit();"'; $this->json_data['mep'] = form_dropdown('mepId',$qu,$mepId,$attr).' : '; $attr = 'id="tbmepId" onChange="Sync(this.id);"'; $this->json_data['tbmep'] = form_dropdown('tbmepId',$qu,$mepId,$attr); }else{ $qu[''] = '-- ไม่พบสถานฝึกหลัก --'; $this->json_data['mep'] = form_dropdown('mepId',$qu,$mepId,$attr).' : '; $this->json_data['tbmep'] = form_dropdown('tbmepId',$qu,$mepId,$attr); }
if($mepId!=''){ $cond = array('mepId'=>$mepId); // ค้นหา สถานที่ฝึกย่อย $this->condition = $cond ; $this->group = array('sepId'=>'sepId'); $this->option = ''; $this->order = ''; $qu = $this->etp->sep_optionsJoinMepSep($this->condition,$this->order,$this->group,$this->option); /*if(count($qu)>1){ $qu['%'] = '--เลือกสถานที่ฝึกย่อย --'; ksort($qu); }*/ if(count($qu)>=1){ $attr = 'id="sepId" onChange="get_option();checkSubmit();"'; $this->json_data['sep'] = form_dropdown('sepId',$qu,$sepId,$attr); $attr = 'id="tbsepId" onChange="Sync(this.id);"'; $this->json_data['tbsep'] = form_dropdown('tbsepId',$qu,$sepId,$attr); }else{ $this->json_data['sep'] = ""; $this->json_data['tbsep'] = ""; } //$this->json_data['sep'] = $this->db->last_query(); }else{ $this->json_data['sep'] = ''; $this->json_data['tbsep'] = ''; } // ค้นหา สัปดาห์ $this->load->model($this->config->item("rg_folder").'mo_rg_weekdate','wd'); $this->condition = array('wdAcY'=>$tmcAcY); $this->group = ''; $this->option = ''; $this->order = '';//array('wdAcYWeekNo'=>''); $qu = $this->wd->opt_WeekNoFrToDate($this->condition,$this->order,$this->group,$this->option);
if(count($qu)==0){ $qu[0] = '-- ไม่พบหลักสูตรที่เปิดใน ปีศึกษานี้ --'; } $attr = 'id="wdAcYWeekNo" onChange="get_option();"'; $this->json_data['wd'] = form_dropdown('wdAcYWeekNo',$qu,(setValue('wdAcYWeekNo',$wdAcYWeekNo) == '')? $wdAcYWeekNo : setValue('wdAcYWeekNo',$wdAcYWeekNo),$attr); $attr = 'id="tbwdAcYWeekNo" onChange="Sync(this.id);"'; $this->json_data['tbwd'] = form_dropdown('tbwdAcYWeekNo',$qu,$wdAcYWeekNo,$attr); $attr = 'id="tbwdAcYWeekNo" onChange="timeTable();"'; $this->json_data['tbwd2'] = form_dropdown('tbwdAcYWeekNo',$qu,$wdAcYWeekNo,$attr); // gen จำนวนวัน $opt = Array(); $weekNum = 1; while($weekNum <= count($qu)-$wdAcYWeekNo+1) { $opt[$weekNum] = $weekNum; $weekNum++; } $attr = 'id="numWeek" onChange="get_option();"'; $this->json_data['numWeek'] = form_dropdown('numWeek',$opt,$numWeek,$attr);
// หาวันทั้งหมด วัน $this->load->model($this->config->item("rg_folder").'mo_rg_day','dy'); $this->condition = ''; $this->group = ''; $this->option = ''; $this->order = array('dyId'=>''); $qu = $this->dy->qryDy($this->condition,$this->order,$this->group,$this->option);
$attr = 'id="dyId" onChange="get_option();"'; $this->json_data['dy'] = form_dropdown('dyId',$qu,$dyId,$attr); // หาคาบเรียน เวลาสิ้นสุดคาบเรียน $this->load->model($this->config->item("rg_folder").'mo_rg_period','prd'); $this->condition = array('1'=>'1'); $this->group = ''; $this->option = ''; $this->order = array('prdId'=>''); $this->prd->prdId = $prdFrTime;
$qu = $this->prd->get_options_toTime($this->condition,$this->order,$this->group,$this->option); $attr = 'id="prdToTime" onChange="get_option();"'; $this->json_data['prdTo'] = form_dropdown('prdToTime',$qu,$prdToTime,$attr); // ค้นหาชื่ออาจารย์ผู้สอน $this->load->model($this->config->item("rg_folder").'mo_rg_person','prs'); $this->condition = array('prsPsId'=> 1); $this->group = ''; $this->option = ''; $this->order = array('fname'=>'','lname'=>'');
$qu = $this->prs->get_options($this->condition,$this->order,$this->group,$this->option); if(count($qu)>=2){ $attr = 'id="prsId" onChange="get_option();"'; $this->json_data['prs'] = form_dropdown('prsId',$qu,$prsId,$attr); $attr = 'id="tbprsId" onChange="Sync(this.id);getExam();"'; $this->json_data['tbprs'] = form_dropdown('tbprsId',$qu,$prsId,$attr); }else{ $this->json_data['tbprs'] = ""; $this->json_data['prs'] = ""; } // ค้นหาประเภทการสอน $this->load->model($this->config->item("rg_folder").'mo_rg_studytype','st'); $this->condition = ''; $this->group = ''; $this->option = ''; $this->order = array('stId'=>'');
$qu = $this->st->get_options($this->condition,$this->order,$this->group,$this->option); $attr = 'id="stId" onChange="get_option();checkSubmit();"'; if(count($qu)>=1){ $this->json_data['st'] = form_dropdown('stId',$qu,$stId,$attr); }else{ $this->json_data['st'] = ""; } /* $this->json_data['tt'] =$this->db->last_query();//form_dropdown('prdToTime',$qu); */ $this->json_data['error'] = 0; echo json_encode($this->json_data); //echo "tmcAcY : $tmcAcY || tmId : $tmId"; } }
// ##### start แสดงวิธีการสอน function tcm_popup() { $this->load->model($this->config->item("rg_folder").'mo_rg_teachingmethod','tcm'); $condition = ''; $group = ''; $order = array('tcmName'=>'');
$this->contents['qu'] = $this->tcm->qryTcm_2($condition,$order,$group); $this->output_detail($this->config->item("rg_folder")."v_checkboxTcm"); } // ##### end จบแสดงวิธีการสอน
// ##### start แสดงอาจารย์ผู้สอน function prs_popup() { $this->load->model($this->config->item("rg_folder").'mo_rg_person','prs'); $condition = array('prsPsId' => 1); $order = array('fName' => '', 'lName' => '' );
$this->contents['qu'] = $this->prs->qryPrsJoinPPC($condition, $order); $this->output_detail($this->config->item("rg_folder")."v_checkboxPrs");
} // ##### end จบแสดงอาจารย์ผู้สอน function search(){ $this->load->model($this->config->item("rg_folder").'m_rg_weekdate','wd'); $wd = $this->wd; $this->contents['opt_wd'] = $wd->get_options("",array('wdAcY'=>'wdAcY'),array('wdAcY'=>'wdAcY'), false); }
function showTimetable(){ $acY = 2554; $wdAcYWeekNo = 1; $this->load->model($this->config->item("rg_folder").'m_rg_Day','dy'); $dy = $this->dy; $this->load->model($this->config->item("rg_folder").'mo_rg_Period','prd'); $prd = $this->prd; $this->load->model($this->config->item("rg_folder").'mo_rg_timetable','tt'); $tt = $this->tt; $condition = array('1'=>'1'); $order = array('prdId'=>''); $qu_prd = $prd->qryPrd($condition,$order); $qu_dy = $dy->qryOrderId();
$show_table = array(); $show_table[0][0] = 'วัน\เวลา'; if($qu_prd->num_rows > 0 && $qu_dy->num_rows > 0) { foreach($qu_prd->result() as $prd_row){ $show_table[0][$prd_row->prdId] = $prd_row->prdId.'<br>'.substr($prd_row->prdFrTime, 0, 5).'-'.substr($prd_row->prdToTime, 0, 5); } foreach($qu_dy->result() as $dy_row){ $show_table[$dy_row->dyId][0] = $dy_row->dyName;
// foreach($qu_prd->result() as $prd_row){ // ค้นหา ตารางเรียนใน dy & prd
$show_table[$dy_row->dyId][$prd_row->prdId] = "[ $dy_row->dyId ][ $prd_row->prdId ]"; //$row->prdId.'<br>'.substr($prd_row->prdFrTime, 0, 5).'-'.substr($row->prdToTime, 0, 5); //--------------------------------------------------------- $condition = array( 'coAcY' =>$coAcY , 'wdAcYWeekNo'=>$wdAcYWeekNo , 'coCrsId'=>$coCrsId , 'ttDyId'=>$dy_row->dyId , ); // tt->searchBy($prd_row->prdFrTime) // } } } $this->contents['timetable'] = $show_table; $this->output($this->config->item("rg_folder")."v_showTimeTable"); } }
|