Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64
Your IP : 3.137.177.116
Current Path : /var/www/oasis/src/ |
| Current File : /var/www/oasis/src/room_allotment_datewise_stph_new.php |
<?php
/*error_reporting(E_ALL);
ini_set('display_errors','on');*/
class room_allotment
{
function __construct($aobj_context)
{
session_start();
$this->aobj_context=$aobj_context;
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$this->user_id = $_SESSION['user_id'];
$this->funivcode = $_SESSION['FUNIVCODE'];
$this->collcode = $_SESSION['collcode'];
$this->log_name = $_SESSION['usr'];
}
function DisplayRoomAllotmentDetatilsDatewiseStphNew()
{
session_start();
$this->collcode=$_SESSION['collcode'];
$frm_date = ($this->aobj_context->mobj_data["frm_date"]);
$session = ($this->aobj_context->mobj_data["session"]);
$ra_from = ($this->aobj_context->mobj_data["ra_from"]);
$ra_to = ($this->aobj_context->mobj_data["ra_to"]);
$alternative = ($this->aobj_context->mobj_data["alternative"]);
$deggrp = ($this->aobj_context->mobj_data["deggrp"]);
$romm = ($this->aobj_context->mobj_data["romm"]);
$exmmonth = ($this->aobj_context->mobj_data["exmmonth"]);
$exmmonthy = explode('*',$exmmonth);
$year = $exmmonthy[0];
$examtype = $exmmonthy[1];
// var_dump($romm);
// die();
if($_SESSION['fexamseparate'] == 'T')
{
$candsum = "examcandsum";
$canddet = "examcanddet";
}else
{
$candsum = "candsum";
$canddet = "canddet";
}
$roomarray = [];
$roomalt = explode(",", $romm);
foreach($roomalt as $key => $val){
if($val == 'All'){
$data = "ALL";
}else{
$roomarr .= "'".$val."',";
}
}
$roomarray = substr_replace($roomarr ,"",-1);
if($data == 'ALL'){
$value = 'All';
}else{
$value = $roomarray;
}
if($value == 'All'){
$cond="";
}else{
$cond="and froomno in ($value)";
}
if($session== 'both')
{
$sectionvalue = "";
}
else
{
if($this->funivcode == '049'){
$sectionvalue = "and t.fsessiont like '{$session}'";
}else{
$sectionvalue = "and t.fsessiont like '{$session}%'";
}
}
$hall_no = '0';
/*
* Updating Qpcode to canddet so that no need to link subject later
* also update hallno to null for pirticular session and college
*/
$query1 = "SELECT COUNT(DISTINCT cd.FREGNO) AS reg_cnt
FROM $canddet cd INNER JOIN subject s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE=cd.FSUBCODE
INNER JOIN $candsum cs ON cd.fcollcode = cs.fcollcode and cd.FDEGREE=cs.FDEGREE
and cs.FREGNO=cd.FREGNO and cd.fcollcode = cs.fcollcode
inner join degree dd on cd.fdegree=dd.fdegree and dd.fexamno=cd.fexamno
inner join timetable t on s.fqpcode = t.fqpcode
and t.fyear = cd.fyear
and t.fexamtype = cd.fexamtype
WHERE t.fdate = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
AND IFNULL(cd.fpassmth,'') = ''
AND cd.fyear = '{$year}'
and cd.fexamtype = '{$examtype}'
AND cd.FPRESENT='P'
{$sectionvalue}
AND IFNULL(cs.FRECPTDATE,'0000-00-00')<>'0000-00-00'
and cs.fcntrcode = '{$this->collcode}'
and cs.fdegree in(select distinct fdegree from degree where fdeggrp = '{$deggrp}')
GROUP BY t.fdate";
$results1 = $this->aobj_context->mobj_db->GetRow($query1);
$reg_cnt = $results1['reg_cnt'];
$query1 = "select sum(fcapacity) as fcapacity from masroom where
fcollcode = '{$this->collcode}' $cond";
$results1 = $this->aobj_context->mobj_db->GetRow($query1);
$fcapacity = $results1['fcapacity'];
if($reg_cnt > $fcapacity)
{
$arr = "Insufficient Rooms for the allotment. Total Capacity : ".$fcapacity." Total Strength :".$reg_cnt;
echo $this->aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"failure");
return;
}
$query = "update $canddet cd, subject s, timetable t
set cd.fqpcode1 = t.fqpcode, FHALLNO = NULL,fslno = NULL
where cd.fdegree = s.fdegree and cd.fexamno = s.fexamno
and ifnull(cd.fpassmth,'') = '' and cd.fpresent = 'P'
and s.fqpcode = t.fqpcode
and cd.fyear = t.fyear and cd.fexamtype = t.fexamtype
and cd.fregno in (select fregno from $candsum where fcntrcode = '{$this->collcode}')
and cd.fsubcode = s.fsubcode and t.fsessiont like '{$session}%'
and cd.fdegree in(select distinct fdegree from degree where fdeggrp = '{$deggrp}')
AND cd.fyear = '{$year}'
and cd.fexamtype = '{$examtype}'
and t.fdate = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')";
$rst1 = $this->aobj_context->mobj_db->Execute($query);
$rows_affected = $this->aobj_context->mobj_db->affected_rows();
$query = "update masroom set fbalroomcnt = fcapacity where fcollcode = '{$this->collcode}'
$cond";
$rst1 = $this->aobj_context->mobj_db->Execute($query);
$cnd = "and ifnull(ab.fabstype,'') <> 'QpM'";
if($this->funivcode == '049' || $this->funivcode == '052' || $this->funivcode == '021' || $this->funivcode == '055' || $this->funivcode == '060' || $this->funivcode == '062')
$cnd = "";
$query = "SELECT COUNT(DISTINCT cd.FREGNO) AS reg_cnt,s.FQPCODE,t.fdate AS FDOE,s.fsubcode
FROM $canddet cd INNER JOIN subject s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE = cd.FSUBCODE and cd.fqpcode1 = s.fqpcode
INNER JOIN $candsum cs ON cs.FREGNO = cd.FREGNO AND cd.FDEGREE=cs.FDEGREE
inner join timetable t on s.fqpcode = t.fqpcode
and t.fyear = cd.fyear
and t.fexamtype = cd.fexamtype
left join absent ab on ab.fregno = cd.fregno
WHERE t.fdate = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
AND IFNULL(cd.fpassmth,'') = '' AND cd.FPRESENT='P' {$sectionvalue}
AND IFNULL(cs.FRECPTDATE,'0000-00-00')<>'0000-00-00'
and cs.fcntrcode = '{$this->collcode}'
AND cd.fyear = '{$year}'
and cd.fexamtype = '{$examtype}'
{$cnd}
and ifnull(s.fqpcode,'') <> ''
and cs.fdegree in(select distinct fdegree from degree where fdeggrp = '{$deggrp}')
GROUP BY s.FQPCODE ORDER BY reg_cnt DESC,s.fsession,s.FQPCODE";
$results = $this->aobj_context->mobj_db->GetAll($query);
$k = 1;
foreach($results as $ak=>$value)
{
$reg_cnt = $value['reg_cnt'];
$qpcode = $value['FQPCODE'];
$query2 ="SELECT * FROM masroom
WHERE fcollcode = '{$this->collcode}' $cond
and fcapacity > 0
order by froomno";
$restults = $this->aobj_context->mobj_db->GetAll($query2);
foreach($restults as $key => $value)
{
if($value['fbalroomcnt'] <= 0)
continue;
if($value['fmaxqpcnt'] == 0)
{
$value['fmaxqpcnt'] = 1;
}
$capacity = $value['fcapacity'];
$studperqp = round($value['fcapacity'] / $value['fmaxqpcnt']);
$balroomcnt = $value['fcapacity'] - $studperqp;
if($reg_cnt < $studperqp)
$studperqp = $reg_cnt;
if($value['fbalroomcnt'] <= $studperqp)
$studperqp = $value['fbalroomcnt'];
if($this->funivcode == '055')
$regorder = "ifnull(cd.fsorder,'01'),cd.fdegree,cd.fregno";
else
$regorder = "cd.fregno";
if($this->funivcode == '049')
{
if($session == 'N1' || $session == 'N2')
$regorder = "cd.fdegree,cd.fregno";
else
$regorder = "cd.fregno";
}
$query1 = "SET SESSION group_concat_max_len=10000000";
$res9 = $this->aobj_context->mobj_db->Execute($query1);
$query = "select group_concat(distinct concat(\"'\",cd.FREGNO,\"'\") order by $regorder) as fregno
from $canddet cd inner join $candsum cs on cd.fregno = cs.fregno
inner join subject s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE=cd.FSUBCODE
and s.fqpcode = cd.fqpcode1
inner join timetable t on s.fqpcode = t.fqpcode
and t.fyear = cd.fyear
and t.fexamtype = cd.fexamtype
left join absent ab on ab.fregno = cd.fregno
where cd.fqpcode1 = '{$qpcode}'
and cd.FPRESENT = 'P' and ifnull(cd.fpassmth,'') = ''
and ifnull(cd.FHALLNO,'') = ''
AND cd.fyear = '{$year}'
and cd.fexamtype = '{$examtype}'
{$cnd}
and cs.fcntrcode = '{$this->collcode}'
order by {$regorder}
limit {$studperqp}";
//var_dump($query);
$rst3 = $this->aobj_context->mobj_db->GetRow($query);
$regarr = explode(',',$rst3['fregno']);
$regnoin = array_slice($regarr,0,$studperqp);
$regnoin = implode(',',$regnoin);
$query = "update $canddet set FHALLNO = '{$value['froomno']}'
where fregno in ({$regnoin}) and fqpcode1 = '{$qpcode}'
and FPRESENT = 'P' and ifnull(fpassmth,'') = ''";
$rst1 = $this->aobj_context->mobj_db->Execute($query);
$rows_affected = $this->aobj_context->mobj_db->affected_rows();
if($rows_affected)
{
$query = "update masroom set fbalroomcnt = ({$value['fbalroomcnt']} - $rows_affected)
where froomno = '{$value['froomno']}'
and fcollcode = '{$this->collcode}'";
$rst1 = $this->aobj_context->mobj_db->Execute($query);
$insert = " insert into room_allotment(FCOLLCODE,FQPCODE,FHALLNO,FCAPACITY,FLOGNAME,FLOGDATE,FDOE,FSESSION,FORDER )
values ('{$this->collcode}','{$qpcode}' ,'{$value['froomno']}','{$rows_affected}','{$this->log_name}',now(),{date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')},'{$session}','{$k}')";
//$lobj_insert = $this->aobj_context->mobj_db->Execute($insert);
$insert = " insert into room_allotment(FCOLLCODE,FQPCODE,FHALLNO,FCAPACITY,FLOGNAME,FLOGDATE,FDOE,FSESSION,FORDER )
values ('{$this->collcode}','{$hall_arr[$k]->qpcode}' ,'{$hall_arr[$k]->hallno}','{$hall_arr[$k]->alloted}','{$this->log_name}',now(),'{$hall_arr[$k]->fdoe}','{$hall_arr[$k]->sestion}','{$k}')
ON DUPLICATE KEY UPDATE
FCOLLCODE = '{$this->collcode}',
FQPCODE = '{$hall_arr[$k]->qpcode}',
FHALLNO = '{$hall_arr[$k]->hallno}',
FCAPACITY = '{$hall_arr[$k]->alloted}',
FLOGNAME = '{$this->log_name}',
FLOGDATE = now(),
FDOE = '{$hall_arr[$k]->fdoe}',
FSESSION = '{$hall_arr[$k]->sestion}',
FORDER = '{$k}'";
$lobj_insert = $this->aobj_context->mobj_db->Execute($insert);
}
else
{
break;
}
}
$k++;
}
if($alternative == 'T')
{
}else
{
if($this->funivcode == '033')
{
$teacharry = [];
$query = "select distinct fteachcode from roominvig where fsession = '{$session}' and fdate = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')";
$res1 = $this->aobj_context->mobj_db->GetAll($query);
foreach($res1 as $val)
{
array_push($teacharry,$val['fteachcode']);
}
}
$query = "SELECT distinct cd.fhallno
FROM $canddet cd INNER JOIN subject s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE = cd.FSUBCODE and cd.fqpcode1 = s.fqpcode
INNER JOIN $candsum cs ON cs.FREGNO = cd.FREGNO
inner join timetable t on s.fqpcode = t.fqpcode
and t.fyear = cd.fyear
and t.fexamtype = cd.fexamtype
WHERE t.fdate = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
AND IFNULL(cd.fpassmth,'') = '' AND cd.FPRESENT='P' {$sectionvalue}
AND IFNULL(cs.FRECPTDATE,'0000-00-00')<>'0000-00-00'
AND cd.fyear = '{$year}'
and cd.fexamtype = '{$examtype}'
and cs.fcntrcode = '{$this->collcode}'
and ifnull(s.fqpcode,'') <> ''
and cd.fdegree in(select distinct fdegree from degree where fdeggrp = '{$deggrp}')
order by cd.fhallno";
//var_dump($query);
$results = $this->aobj_context->mobj_db->GetAll($query);
$roomprifxarry = ["A","B","C","D",'E',"F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","AA","AB",
"AC","AD",'AE',"AF","AG","AH","AI","AJ","AK","AL","AM","AN","AO","AP","AQ","AR","AS","AT","AU","AV","AW","AX","AY","AZ"];
$x = 0;
foreach($results as $value)
{
$qrypre = "select fprefix,fcapacity from masroom where fcollcode = '{$this->collcode}'
and froomno = '{$value['fhallno']}'";
$resqrypre = $this->aobj_context->mobj_db->GetRow($qrypre);
$teacode = $teacharry[$x];
$roomprifix = $resqrypre['fprefix'];
$fcapacity = ($resqrypre['fcapacity']/2);
$lprix = 3;
if($x >25)
$lprix =2;
if($this->funivcode == '033' || $this->funivcode == '052' || $this->funivcode == '060' || $this->funivcode == '062')
{
$query1 = "SET SESSION group_concat_max_len=10000000";
$res9 = $this->aobj_context->mobj_db->Execute($query1);
$query = "SELECT distinct m.froomname,s.fqpcode,cd.fdegree,cd.fqpcode1,cd.fcollcode,cd.fexamno, count(distinct cd.fregno) as cnt,
group_concat(distinct cd.fregno order by {$regorder}) as reg
FROM $canddet cd INNER JOIN subject s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE = cd.FSUBCODE and cd.fqpcode1 = s.fqpcode
INNER JOIN $candsum cs ON cs.FREGNO = cd.FREGNO
inner join timetable t on s.fqpcode = t.fqpcode
and t.fyear = cd.fyear
and t.fexamtype = cd.fexamtype
INNER join masroom m on cs.fcntrcode = m.fcollcode and cd.FHALLNO = m.froomno
WHERE t.fdate = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
AND IFNULL(cd.fpassmth,'') = '' AND cd.FPRESENT='P' {$sectionvalue}
AND IFNULL(cs.FRECPTDATE,'0000-00-00')<>'0000-00-00'
and cs.fcntrcode = '{$this->collcode}'
AND cd.fyear = '{$year}'
and cd.fexamtype = '{$examtype}'
and ifnull(s.fqpcode,'') <> ''
and cd.fhallno = '{$value['fhallno']}'
and cd.fdegree in(select distinct fdegree from degree where fdeggrp = '{$deggrp}')
group by fqpcode
order by cnt desc,cd.fhallno";
//var_dump($query);
$res = $this->aobj_context->mobj_db->GetAll($query);
$a =1;
$b =2;
$d = 1;
$i =1;
$r = 1;
$y =1;
$x = 1;
foreach($res as $val)
{
$fdegree = $val['fdegree'];
$fqpcode1 = $val['fqpcode1'];
$fexamno = $val['fexamno'];
$reg = $val['reg'];
$froomname = $val['froomname'];
$regdet = explode(",",$reg);
foreach($regdet as $ereg)
{
$regno = $ereg;
if($this->funivcode == '052')
{
if($x <= $fcapacity)
{
$slno = 'A'.$x;
}
else
{
$slno = 'B'.$y;
$y++;
}
$update = "update $canddet set fslno = '{$slno}'
where fqpcode1 = '{$fqpcode1}'
and fexamno = '{$fexamno}'
and fregno = '{$regno}'";
$res1 = $this->aobj_context->mobj_db->Execute($update);
$x++;
}else if($this->funivcode == '060')
{
$slno = $froomname.'-S'.str_pad($x, '2', "0",STR_PAD_LEFT);
$update = "update $canddet set fslno = '{$slno}'
where fqpcode1 = '{$fqpcode1}'
and fexamno = '{$fexamno}'
and fregno = '{$regno}'";
$res1 = $this->aobj_context->mobj_db->Execute($update);
$x++;
}
else
{
if($this->funivcode == '062')
{
$slno = str_pad($d, $lprix, "0",STR_PAD_LEFT);
}else
{
if(( $i == 1 && $r <= $fcapacity ))
$slno = $roomprifix.str_pad($a, $lprix, "0",STR_PAD_LEFT);
else
$slno = $roomprifix.str_pad($b, $lprix, "0",STR_PAD_LEFT);
}
$update = "update $canddet set fslno = '{$slno}'
where fqpcode1 = '{$fqpcode1}'
and fexamno = '{$fexamno}'
and fregno = '{$regno}'";
$res1 = $this->aobj_context->mobj_db->Execute($update);
if($i==1 && $r <= $fcapacity)
$a = $a+2;
else
$b = $b+2;
$r++;
$d++;
}
}
$i++;
}
//die();
}
else
{
if($this->funivcode == '055')
{
$query = "update $canddet x, (select right(concat('000',@a:=@a+1),3) as fslno, fregno, fqpcode1, fhallno
from (select cd.fdegree, cd.fcollcode,
cd.fregno,cd.fqpcode1, cd.fhallno from $canddet cd, subject s, $candsum cs
where s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE = cd.FSUBCODE
and cd.fqpcode1 = s.fqpcode and cs.FREGNO = cd.FREGNO AND cd.FDEGREE=cs.FDEGREE
and cd.fcollcode = cs.fcollcode
and s.fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
AND IFNULL(cd.fpassmth,'') = '' AND cd.FPRESENT='P' {$sectionvalue}
AND IFNULL(cs.FRECPTDATE,'0000-00-00')<>'0000-00-00' and cd.fhallno = '{$value['fhallno']}'
and cs.fcntrcode = '{$this->collcode}'
and ifnull(s.fqpcode,'') <> ''
order by cd.fqpcode1,RAND(),fregno) b, (SELECT @a:= '000') AS a) y
set x.fslno = y.fslno
where x.fqpcode1 = y.fqpcode1
and x.fhallno = y.fhallno
and x.fregno = y.fregno";
}else
{
$query = "update $canddet x, (select right(concat('000',@a:=@a+1),3) as fslno, fregno, fqpcode1, fhallno
from (select cd.fdegree, cd.fcollcode,
cd.fregno,cd.fqpcode1, cd.fhallno from $canddet cd, subject s, $candsum cs
where s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE = cd.FSUBCODE
and cd.fqpcode1 = s.fqpcode and cs.FREGNO = cd.FREGNO
and cd.fcollcode = cs.fcollcode
and s.fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
AND IFNULL(cd.fpassmth,'') = '' AND cd.FPRESENT='P' {$sectionvalue}
AND IFNULL(cs.FRECPTDATE,'0000-00-00')<>'0000-00-00' and cd.fhallno = '{$value['fhallno']}'
and cs.fcntrcode = '{$this->collcode}'
and ifnull(s.fqpcode,'') <> ''
order by cd.fqpcode1,fregno) b, (SELECT @a:= '000') AS a) y
set x.fslno = y.fslno
where x.fqpcode1 = y.fqpcode1
and x.fhallno = y.fhallno
and x.fregno = y.fregno";
}
$lobj_insert = $this->aobj_context->mobj_db->Execute($query);
}
//$query = "";
//var_dump($query); and cd.fregno in(select distinct fregno from student where fcollcode = '{$this->collcode}' order by fregno)
$x++;
}
$query = "delete from anscapt where fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d') and fcntrcode = '{$this->collcode}'
and ifnull(fansbookno,'') = ''";
$lobj_update = $this->aobj_context->mobj_db->Execute($query);
$query = "insert ignore into anscapt(fregno, fdegree, fqpcode, fpresent, fyear, fexamtype, fdoe, fsession, fcntrcode, froomno)
select a.fregno, a.fdegree, s.fqpcode, a.fpresent, a.fyear, a.fexamtype, s.fdoe, s.fsession, b.fcntrcode,
a.fhallno from $canddet a inner join $candsum b on a.fcollcode = b.fcollcode
and a.fregno = b.fregno inner join subject s on a.fdegree = s.fdegree and a.fexamno = s.fexamno
and a.fsubcode = s.fsubcode
and INSTR(b.fhtenable,a.fexamno) >0
where ifnull(b.frecptdate,'') <> '' and ifnull(a.fpresent,'') = 'P' and ifnull(fpassmth,'') = ''
and fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
and b.fcntrcode = '{$this->collcode}'";
$lobj_update = $this->aobj_context->mobj_db->Execute($query);
$insert = " insert ignore into room_allotment(FCOLLCODE,FQPCODE,FHALLNO,FCAPACITY,FLOGNAME,FLOGDATE,FDOE,FSESSION )
select b.fcntrcode, s.fqpcode,a.fhallno, '26','-',now(),s.fdoe, s.fsession
from $canddet a inner join $candsum b on a.fcollcode = b.fcollcode
and a.fregno = b.fregno inner join subject s on a.fdegree = s.fdegree and a.fexamno = s.fexamno
and a.fsubcode = s.fsubcode
and INSTR(b.fhtenable,a.fexamno) >0
where ifnull(b.frecptdate,'') <> '' and ifnull(a.fpresent,'') = 'P' and ifnull(fpassmth,'') = ''
and fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
and b.fcntrcode = '{$this->collcode}'";
$lobj_insert = $this->aobj_context->mobj_db->Execute($insert);
}
echo $this->aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success");
}
function SaveRoomAllotmentDatewise()
{
ini_set('memory_limit','900M');
ini_set('max_execution_time',0);
include_once($this->aobj_context->main_src."/src/json.php");
$json = new Services_JSON();
$hall_arr = stripslashes($this->aobj_context->mobj_data["hall_arr"]);
$mobj_jsondata = $json->decode($hall_arr);
$hall_arr = get_object_vars($mobj_jsondata);
$i = 0;
$oldqp = '';
$newqp = '';
$j = 0;
$mpcnd = "and ifnull(ab.fabstype,'') <> 'QpM'";
if($this->funivcode == '027' || $this->funivcode == '052')
$mpcnd = "";
for($k=1;$k<=count($hall_arr);$k++)
{
$newqp = $hall_arr[$k]->qpcode;
if($newqp != $oldqp)
{
$i = 0;
$query1 = "SET SESSION group_concat_max_len=100000";
$results1 = $this->aobj_context->mobj_db->Execute($query1);
$query = "SELECT group_concat(distinct concat(\"'\",cd.FREGNO,\"'\") order by cd.fregno) as fregno,cd.FEXAMNO,cd.FDEGREE,cd.FSUBCODE
FROM canddet cd INNER JOIN subject s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FSUBCODE=cd.FSUBCODE
INNER JOIN candsum cs ON cs.FCOLLCODE = cd.FCOLLCODE and cs.fdegree = cd.fdegree and cs.FREGNO=cd.FREGNO
left join attshort a on a.fdegree = cd.fdegree and cd.fexamno = a.fexamno and a.fregno = cd.fregno and left(a.fsubcode,4) = cd.fsubcode
and a.fyear = cd.fyear
and a.fexamtype = cd.fexamtype
left join absent ab on ab.fregno = cd.fregno
WHERE cs.FCNTRCODE='{$this->collcode}' AND TRIM(s.FQPCODE)='{$hall_arr[$k]->qpcode}'
AND FPRESENT='P' AND IFNULL(cd.fpassmth,'') = ''
and ifnull(a.fregno,'') = ''
{$mpcnd}
AND IFNULL(cs.FRECPTDATE,'0000-00-00')<>'0000-00-00'
group by s.fqpcode
ORDER BY cd.FREGNO";
$results = $this->aobj_context->mobj_db->GetRow($query);
}
if($hall_arr[$j]->remaing > 0)
{
$hall_arr[$k]->capacity = $hall_arr[$j]->remaing;
}
$insert = " insert into room_allotment(FCOLLCODE,FQPCODE,FHALLNO,FCAPACITY,FLOGNAME,FLOGDATE,FDOE,FSESSION,FORDER )
values ('{$this->collcode}','{$hall_arr[$k]->qpcode}' ,'{$hall_arr[$k]->hallno}','{$hall_arr[$k]->alloted}','{$this->log_name}',now(),'{$hall_arr[$k]->fdoe}','{$hall_arr[$k]->sestion}','{$k}')";
$lobj_insert = $this->aobj_context->mobj_db->Execute($insert);
$fregno = explode(',',$results['fregno']);
$FSUBCODE = $results['FSUBCODE'];
$regnoin = array_slice($fregno,$i,$hall_arr[$k]->capacity);
$regnoin = implode(',',$regnoin);
$update = "update $canddet,candsum,subject
set canddet.FHALLNO='{$hall_arr[$k]->hallno}'
where
canddet.FCOLLCODE = candsum.FCOLLCODE
and canddet.FDEGREE = candsum.FDEGREE
and canddet.FREGNO = candsum.FREGNO
and canddet.fdegree = subject.fdegree
and canddet.fexamno = subject.fexamno
and canddet.fsubcode = subject.fsubcode
and candsum.FCNTRCODE = '{$this->collcode}'
and subject.fqpcode = '{$hall_arr[$k]->qpcode}'
and canddet.fregno in({$regnoin})";
$lobj_update = $this->aobj_context->mobj_db->Execute($update);
$i = $i+$hall_arr[$k]->capacity;
$oldqp = $hall_arr[$k]->qpcode;
$j++;
}
if($lobj_update)
{
$data="Update Successfully.";
echo $this->aobj_context->mobj_output->ToJSONEnvelope($data,0,"success");
}
else
{
$data="Failed";
echo $this->aobj_context->mobj_output->ToJSONEnvelope($data,-1,"failure");
}
}
}
function DisplayRoomAllotmentDetatilsDatewiseStphNew($aobj_context)
{
$class_obj=new room_allotment($aobj_context);
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$class_obj->DisplayRoomAllotmentDetatilsDatewiseStphNew();
}
function SaveRoomAllotmentDatewise($aobj_context)
{
$class_obj=new room_allotment($aobj_context);
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$class_obj->SaveRoomAllotmentDatewise();
}
function getRoomdetailsNew($aobj_context)
{
session_start();
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$collcode = $_SESSION['collcode'];
$query = "select funivcode from control";
$results = $aobj_context->mobj_db->GetRow($query);
$funivcode = $results['funivcode'];
$query = "select froomno as id, concat(froomname,' - ',fcapacity) as value from masroom
where ifnull(fdeleted,'') <>'T' and fcapacity > 0
and fcollcode = '{$collcode}' order by froomno ";
$rst1 = $aobj_context->mobj_db->getAll($query); //forder,
$query = "SELECT DISTINCT dg.fdeggrp as id, dg.fdescpn as value
FROM deggrp dg
INNER JOIN degree d ON d.fdeggrp = dg.fdeggrp and d.fexamno ='A'
INNER JOIN colldeg c ON c.fdegree = d.fdegree and ifnull(c.fdeleted,'') <> 'T'
WHERE c.fcollcode='{$collcode}'";
$rst2 = $aobj_context->mobj_db->getAll($query);
if($funivcode == '012' || $funivcode == '052')
{
$query3 = "select distinct FREASONCD as id,concat(r.FDESCPN,' (',r.FREASONCD,')') as value
from reason r
order by r.FREASONCD";
}else
{
$cnd = "inner join colldeg cd on s.fdegree = cd.fdegree and ifnull(cd.fdeleted,'') <> 'T'
where cd.fcollcode = '{$collcode}'";
if($funivcode == '042'){
$cnd = "";
}
$query3 = "select distinct s.fsession as id,concat(r.FDESCPN,' (',s.fsession,')') as value
from subject s inner join reason r on s.fsession = r.FREASONCD
{$cnd}
order by s.fsession";
}
$rst3 = $aobj_context->mobj_db->getAll($query3);
$rst['room'] = $rst1;
$rst['deggrp'] = $rst2;
$rst['session'] = $rst3;
echo $aobj_context->mobj_output->ToJSONEnvelope($rst,0,"success");
}
function getExamMonthDeggp($aobj_context)
{
session_start();
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$collcode = $_SESSION['collcode'];
$doe = stripslashes($aobj_context->mobj_data["doe"]);
$query = "select funivcode from control";
$results = $aobj_context->mobj_db->GetRow($query);
$funivcode = $results['funivcode'];
$query = "select froomno as id, concat(froomname,' - ',fcapacity) as value from masroom
where ifnull(fdeleted,'') <>'T' and fcapacity > 0
and fcollcode = '{$collcode}' order by froomno ";
$rst1 = $aobj_context->mobj_db->getAll($query);
$query = "SELECT DISTINCT dg.fdeggrp as id, dg.fdescpn as value
FROM deggrp dg
INNER JOIN degree d ON d.fdeggrp = dg.fdeggrp
INNER JOIN subject s on s.fdegree = d.fdegree and d.fexamno = s.fexamno
INNER JOIN timetable t on s.fqpcode = t.fqpcode
INNER JOIN colldeg c ON c.fdegree = d.fdegree and ifnull(c.fdeleted,'') <> 'T'
WHERE t.fdate = date_format(STR_TO_DATE('{$doe}', '%d/%m/%Y'),'%Y-%m-%d')";
$rst2 = $aobj_context->mobj_db->getAll($query);
$query = "SELECT distinct concat(t.fdeggrp,' - ',d.fexamdate) as value,
concat(d.fyear,'*',d.fexamtype) as id
FROM degexam d INNER JOIN candsum c
ON d.fdegree = c.fdegree and d.fyear = c.fyear
and d.fexamtype = c.fexamtype
INNER JOIN subject s on s.fdegree = c.fdegree
INNER JOIN timetable t on s.fqpcode = t.fqpcode
and t.fyear = c.fyear
and t.fexamtype = c.fexamtype
WHERE c.fcntrcode = '{$collcode}'
and t.fdate = date_format(STR_TO_DATE('{$doe}', '%d/%m/%Y'),'%Y-%m-%d')
GROUP BY d.fyear,d.fexamtype,t.fdeggrp";
$result1 = $aobj_context->mobj_db->GetAll($query);
if($funivcode == '012' || $funivcode == '052' || $funivcode == '062')
{
$query3 = "select distinct FREASONCD as id,concat(r.FDESCPN,' (',r.FREASONCD,')') as value
from reason r
order by r.FREASONCD";
}else
{
$cnd = "inner join colldeg cd on s.fdegree = cd.fdegree and ifnull(cd.fdeleted,'') <> 'T'
where cd.fcollcode = '{$collcode}'";
if($funivcode == '042')
{
$cnd = "";
}
$query3 = "select distinct s.fsession as id,concat(r.FDESCPN,' (',s.fsession,')') as value
from subject s inner join reason r on s.fsession = r.FREASONCD
{$cnd}
order by s.fsession";
}
$rst3 = $aobj_context->mobj_db->getAll($query3);
$rst['room'] = $rst1;
$rst['deggrp'] = $rst2;
$rst['session'] = $rst3;
$rst['exmmonth'] = $result1;
echo $aobj_context->mobj_output->ToJSONEnvelope($rst,0,"success");
}
function getRoomdetailsreortNew($aobj_context)
{
session_start();
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$collcode = $_SESSION['collcode'];
$query = "select funivcode from control";
$results = $aobj_context->mobj_db->GetRow($query);
$funivcode = $results['funivcode'];
$query = "select froomno as id, concat(froomname,' - ',fcapacity) as value from masroom
where ifnull(fdeleted,'') <>'T' and fcapacity > 0
and fcollcode = '{$collcode}' order by froomno ";
$rst1 = $aobj_context->mobj_db->getAll($query); //forder,
$query = "SELECT DISTINCT dg.fdeggrp as id, dg.fdescpn as value
FROM deggrp dg
INNER JOIN degree d ON d.fdeggrp = dg.fdeggrp and d.fexamno ='A'
INNER JOIN colldeg c ON c.fdegree = d.fdegree and ifnull(c.fdeleted,'') <> 'T'
WHERE c.fcollcode='{$collcode}'";
$rst2 = $aobj_context->mobj_db->getAll($query);
if($funivcode == '012' || $funivcode == '052' || $funivcode == '062')
{
$query3 = "select distinct FREASONCD as id,concat(r.FDESCPN,' (',r.FREASONCD,')') as value
from reason r
order by r.FREASONCD";
}else
{
$cnd = "inner join colldeg cd on s.fdegree = cd.fdegree and ifnull(cd.fdeleted,'') <> 'T'
where cd.fcollcode = '{$collcode}'";
if($funivcode == '042'){
$cnd = "";
}
$query3 = "select distinct s.fsession as id,concat(r.FDESCPN,' (',s.fsession,')') as value
from subject s inner join reason r on s.fsession = r.FREASONCD
{$cnd}
order by s.fsession";
}
$rst3 = $aobj_context->mobj_db->getAll($query3);
$query = "SELECT distinct d.fexamdate as value ,
concat(d.fyear,'*',d.fexamtype) as id
FROM degexam d INNER JOIN candsum c
ON d.fdegree = c.fdegree and d.fyear = c.fyear
and d.fexamtype = c.fexamtype
WHERE c.fcntrcode = '{$collcode}'
GROUP BY d.fyear,d.fexamtype";
$result1 = $aobj_context->mobj_db->GetAll($query);
$rst['room'] = $rst1;
$rst['deggrp'] = $rst2;
$rst['session'] = $rst3;
$rst['exmmonth'] = $result1;
echo $aobj_context->mobj_output->ToJSONEnvelope($rst,0,"success");
}
?>
|