staff=$staff->getUserByIdList($_COOKIE["staff"]);
return "/";
}
}
Doo::loadCore ( 'uri/DooUriRouter' );
$router = new DooUriRouter ();
$routeRs = $router->execute ( Doo::app ()->route, Doo::conf ()->SUBFOLDER );
if($routeRs['1']!="login"){
header ( 'Content-Type:text/html;charset=utf-8' );
@header ( "Location: /login" );
}
}
public function myList(){
$checkadmin = $this->checkisadmin();
if($checkadmin){
$data['cansee'] = 1;
}
Doo::loadModel('holidayday');
Doo::loadModel('holiday');
Doo::loadModel('holidaystaff');
$hday = new HDay();
$holiday = new Holiday();
$hstaff = new HStaff();
$thisyear = date('Y',time());
// $thisyear = date('Y',1546358400);
$num = intval($thisyear)-2017;
$html = '';
$yearnum = isset($this->params['yearnum']) && is_numeric($this->params['yearnum']) ? $this->params['yearnum'] : '';
for($i = $num; $i >= 0; $i--){
if($yearnum == (2017+$i)){
$html .= '';
}else{
$html .= '';
}
}
$data['option'] = $html;
$yeartime = isset($this->params['yearnum']) && is_numeric($this->params['yearnum']) ? $this->getYearMonthTime($this->params['yearnum']) : $this->getYearMonthTime($thisyear);
//记录事,病,旷,加,值,补,调的信息
$holidaymsg = array('1'=> array(), '2' => array(), '3' => array(), '4' => array(), '5' => array(), '10' => array(), '11' => array());
foreach(array(1,2,3,4,5,10,11) as $k => $v){
$all = 0;
for($i = 0; $i < 12; $i++){
if($v == 11){
$typeholiday = $holiday->find(array('where' => 'status=1 and type='.$v.' and uid='.$this->staff[0]['sid'].' and addtime between '.$yeartime[$i]['starttime'].' and '.$yeartime[$i]['endtime'],'asArray' => TRUE));
$holidaymsg[$v][$i+1] = 0;
if(!empty($typeholiday)){
foreach($typeholiday as $tk => $tv){
$holidaymsg[$v][$i+1] += floatval($tv['daynum']);
$all += floatval($tv['daynum']);
}
}
$holidaymsg[$v][$i+1] = $holidaymsg[$v][$i+1] != 0 ? $holidaymsg[$v][$i+1] : '';
}else{
$typeholiday = $hday->find(array('where' => 'type='.$v.' and uid='.$this->staff[0]['sid'].' and UNIX_TIMESTAMP(daytime) between '.$yeartime[$i]['starttime'].' and '.$yeartime[$i]['endtime'],'asArray' => TRUE));
$holidaymsg[$v][$i+1] = 0;
if(!empty($typeholiday)){
foreach($typeholiday as $tk => $tv){
$holidaymsg[$v][$i+1] += floatval($tv['daymsg']);
$all += floatval($tv['daymsg']);
}
}
$holidaymsg[$v][$i+1] = $holidaymsg[$v][$i+1] != 0 ? $holidaymsg[$v][$i+1] : '';
}
}
$holidaymsg[$v]['all'] = $all != 0 ? $all : '';
}
$hstaffmsg = $hstaff->getOne(array('where' => 'uid='.$this->staff[0]['sid'], 'asArray' => TRUE));
$data['yearnum'] = floatval($hstaffmsg['yearnum']);
$data['overtimetnum'] = floatval($holidaymsg[4]['all'])+floatval($holidaymsg[5]['all']);
$data['addnum'] = floatval($hstaffmsg['addnum']);
$data['hunjianum'] = floatval($hstaffmsg['hunjianum']);
$data['chanjianum'] = floatval($hstaffmsg['chanjianum']);
$data['sangjianum'] = floatval($hstaffmsg['sangjianum']);
$data['gongjianum'] = floatval($hstaffmsg['gongjianum']);
$data['yearround'] = $this->getYearRoundtime($hstaffmsg['hadyear'],$this->staff[0]['hiredate']);
// var_dump($holidaymsg);
// exit;
$data['holidaymsg'] = $holidaymsg;
$data ['memu'] = 'holiday';
$data ['holidaymenu'] = 'mylist';
$data ['staff'] = $this->staff;
$data['noindexjs'] = 'noindexjs';
$this->render ( "/holiday-myList", $data );
}
public function holidayBorad(){
$checkadmin = $this->checkisadmin();
if($checkadmin){
$data['cansee'] = 1;
}
Doo::loadModel('holiday');
Doo::loadModel('holidayday');
Doo::loadModel('holidaystaff');
Doo::loadModel('holidaytype');
$thismonth = $this->getMonthTime(date('Y-m-d',time()));
$data['countmonth'] = date("Y年m月",time());
$holiday = new Holiday();
$hday = new HDay();
$hstaff = new HStaff();
$type = new HType();
$holidaycount =array();
foreach(array(1,2,3,4,5) as $k => $v){
$typeholiday = $hday->find(array('where' => 'type='.$v.' and uid='.$this->staff[0]['sid'].' and UNIX_TIMESTAMP(daytime) between '.$thismonth['start'].' and '.$thismonth['end'],'asArray' => TRUE));
$holidaycount[$k] = 0;
if(!empty($typeholiday)){
foreach($typeholiday as $tk => $tv){
$holidaycount[$k] += floatval($tv['daymsg']);
}
}
}
$hstaffmsg = $hstaff->getOne(array('where' => 'uid='.$this->staff[0]['sid'], 'asArray' => TRUE));
$holidaycount[5] = floatval($hstaffmsg['yearnum']);
$holidaycount[6] = floatval($hstaffmsg['addnum']);
$data['holidaycount'] = $holidaycount;
$holidaymsg = $holiday->find(array('where' => 'uid='.$this->staff[0]['sid'], 'limit' => 10, 'desc' => 'approvetime', 'desc' => 'id', 'asArray' => TRUE));
if(!empty($holidaymsg)){
foreach($holidaymsg as $k => $v){
$holidaymsg[$k]['typename'] = $type->getTypeNamebyid($v['type']);
$holidaymsg[$k]['daynum'] = floatval($v['daynum']);
$holidaymsg[$k]['approvetime'] = !empty($v['approvetime']) ? date('Y-m-d H:i:s',$v['approvetime']) : '';
$msg = '';
if(in_array($v['type'],array(1,2,3,4,5,10,11,12))){
$dayjson = json_decode($v['dayjson']);
if($v['type'] != 11){
$holidaydays = $this->geyDayMsg($dayjson->holiday);
foreach($holidaydays as $hk => $hv){
$msg .= $hv['daytime'].' '.$hv['daymsg'].',';
}
$msg = substr($msg,0,strlen($msg)-1);
}else{
$msg .= '休假时间:';
$holidaydays = $this->geyDayMsg($dayjson->holiday);
foreach($holidaydays as $hk => $hv){
$msg .= $hv['daytime'].' '.$hv['daymsg'].',';
}
$msg = substr($msg,0,strlen($msg)-1);
$msg .= '
加班时间:';
$overtimedays = $this->geyDayMsg($dayjson->overtime);
foreach($overtimedays as $ok => $ov){
$msg .= $ov['daytime'].' '.$ov['daymsg'].',';
}
$msg = substr($msg,0,strlen($msg)-1);
}
}elseif(in_array($v['type'],array(6,7,8,9))){
$msg .= $v['starttime']. ' 至 '.$v['endtime'];
}elseif(in_array($v['type'],array(13,14,15,16,17,18,19))){
$msg .= date('Y-m-d H:i:s',$v['addtime']);
}
$holidaymsg[$k]['daymsg'] = $msg;
}
$data['holidaylist'] = $holidaymsg;
}
$data ['memu'] = 'holiday';
$data ['holidaymenu'] = 'borad';
$data ['staff'] = $this->staff;
$data['noindexjs'] = 'noindexjs';
$this->render ( "/holiday-borad", $data );
}
public function allList(){
$checkadmin = $this->checkisadmin();
if($checkadmin){
$data['cansee'] = 1;
}
Doo::loadModel('holiday');
Doo::loadModel('holidaytype');
$holiday = new Holiday();
$type = new HType();
if(isset($this->params['type'])){
if($this->params['type'] == 4 ){//加班、值班
$sql = ' and (type=4 or type=5)';
}elseif($this->params['type'] == 6){//其他,管理员操作
$sql = ' and type in(3,6,7,8,9,13,14,15,16,17,18,19)';
}else{
$sql = ' and type='.$this->params['type'];
}
$pagemsg = '/type/'.$this->params['type'];
$data['thistype'] = $this->params['type'];
}else{
$sql = '';
$pagemsg = '';
$data['thistype'] = '';
}
Doo::loadHelper('DooPager');
$totalArchive = $holiday->count(array('where' => 'uid='.$this->staff[0]['sid'].$sql, 'asArray' => TRUE));
$pager = new DooPager(Doo::conf()->APP_URL . "holidayallList".$pagemsg."/page", $totalArchive, 10, 10);
if (isset($this->params['pindex']))
$pager->paginate(intval($this->params['pindex']));
else
$pager->paginate(1);
if ($pager->limit != ' -10,10')
$holidaymsg = $holiday->find(array('where' => 'uid='.$this->staff[0]['sid'].$sql, 'limit' => $pager->limit, 'desc' => 'id', 'asArray' => TRUE));
if(isset($holidaymsg) && !empty($holidaymsg)){
foreach($holidaymsg as $k => $v){
$holidaymsg[$k]['typename'] = $type->getTypeNamebyid($v['type']);
$holidaymsg[$k]['daynum'] = floatval($v['daynum']);
$holidaymsg[$k]['approvetime'] = !empty($v['approvetime']) ? date('Y-m-d H:i:s',$v['approvetime']) : '';
$msg = '';
if(in_array($v['type'],array(1,2,3,4,5,10,11,12))){
$dayjson = json_decode($v['dayjson']);
if($v['type'] != 11){
$holidaydays = $this->geyDayMsg($dayjson->holiday);
foreach($holidaydays as $hk => $hv){
$msg .= $hv['daytime'].' '.$hv['daymsg'].',';
}
$msg = substr($msg,0,strlen($msg)-1);
}else{
$msg .= '休假时间:';
$holidaydays = $this->geyDayMsg($dayjson->holiday);
foreach($holidaydays as $hk => $hv){
$msg .= $hv['daytime'].' '.$hv['daymsg'].',';
}
$msg = substr($msg,0,strlen($msg)-1);
$msg .= '
加班时间:';
$overtimedays = $this->geyDayMsg($dayjson->overtime);
foreach($overtimedays as $ok => $ov){
$msg .= $ov['daytime'].' '.$ov['daymsg'].',';
}
$msg = substr($msg,0,strlen($msg)-1);
}
}elseif(in_array($v['type'],array(6,7,8,9))){
$msg .= $v['starttime']. ' 至 '.$v['endtime'];
}elseif(in_array($v['type'],array(13,14,15,16,17,18,19))){
$msg .= date('Y-m-d H:i:s',$v['addtime']);
}
$holidaymsg[$k]['daymsg'] = $msg;
}
$data['holidaylist'] = $holidaymsg;
}
$data['pager'] = $pager->output;
$data ['memu'] = 'holiday';
$data ['holidaymenu'] = 'borad';
$data ['staff'] = $this->staff;
$data['noindexjs'] = 'noindexjs';
$this->render ( "/holiday-allList", $data );
}
public function holidayClose(){
$checkadmin = $this->checkisadmin();
if(!$checkadmin){
exit('非假期管理员无法访问此页面');
}
$data['cansee'] = 1;
//获取办事处列表
Doo::loadModel('staff');
Doo::loadModel('holidaystaff');
Doo::loadModel('holidayday');
Doo::loadModel('holiday');
$staff = new staff();
$hstaff = new HStaff();
$hday = new HDay();
$holiday = new Holiday();
$sql = 'SELECT `CLD_L_category`.cid,`CLD_L_category`.title,count(`CLD_staff`.sid) as count FROM `CLD_L_category` left join `CLD_staff` on `CLD_L_category`.cid=`CLD_staff`.cid where `CLD_staff`.nature=1 group by `CLD_staff`.cid HAVING count(`CLD_staff`.sid)>0 order by count(`CLD_staff`.sid) desc';
$query = Doo::db ()->query ( $sql );
$result = $query->fetchAll ();
$data['category'] = $result;
$thisyear = date('Y',time());
// $thisyear = date('Y',1546358400);
$data['thismonth'] = intval(date('m',time()));
$num = intval($thisyear)-2017;
$html = '';
$yearnum = isset($this->params['year']) && is_numeric($this->params['year']) ? $this->params['year'] : '';
for($i = $num; $i >= 0; $i--){
if($yearnum == (2017+$i)){
$html .= '';
}else{
$html .= '';
}
}
$data['option'] = $html;
if(isset($this->params['year']) && isset($this->params['month'])){
$month = intval($this->params['month']) < 10 ? '0'.$this->params['month'] : $this->params['month'];
$date = $this->params['year'].'-'.$month.'-01';
$thismonth = $this->getMonthTime($date);
$data['thismonth'] = $this->params['month'];
}else{
$thismonth = $this->getMonthTime(date('Y-m-d',time()));
}
foreach($result as $k => $v){
$stafflist[$k]['categoryname'] = $v['title'];
$stafflist[$k]['count'] = $v['count'];
$cidstafflist = $staff->find(array('where' => 'cid='.$v['cid'].' and nature=1', 'asArray' => TRUE));
foreach($cidstafflist as $ck => $cv) {
foreach (array(1, 2, 3) as $tk => $tv) {
$typeholiday = $hday->find(array('where' => 'type=' . $tv . ' and uid=' . $cv['sid'] . ' and UNIX_TIMESTAMP(daytime) between ' . $thismonth['start'] . ' and ' . $thismonth['end'], 'asArray' => TRUE));
$cidstafflist[$ck][$tv] = 0;
if (!empty($typeholiday)) {
foreach ($typeholiday as $thk => $thv) {
$cidstafflist[$ck][$tv] += floatval($thv['daymsg']);
}
}
$cidstafflist[$ck][$tv] = $cidstafflist[$ck][$tv] != 0 ? $cidstafflist[$ck][$tv] : '';
}
$cidstafflist[$ck]['first'] = $ck == 0 ? 1 : ''; // 是否第一个
}
$stafflist[$k]['cidstafflist'] = $cidstafflist;
}
$data['stafflist'] = $stafflist;
$zongbu = $staff->find(array('where' => 'cid=12 and nature=1', 'asArray' => TRUE));
$data['zongbu'] = $zongbu;
$data ['memu'] = 'holiday';
$data ['holidaymenu'] = 'close';
$data ['staff'] = $this->staff;
$data['noindexjs'] = 'noindexjs';
$this->render ( "/holiday-close", $data );
}
public function holidayClose2(){
$checkadmin = $this->checkisadmin();
if(!$checkadmin){
exit('非假期管理员无法访问此页面');
}
$data['cansee'] = 1;
//获取办事处列表
Doo::loadModel('staff');
Doo::loadModel('holidaystaff');
Doo::loadModel('holidayday');
Doo::loadModel('holiday');
$staff = new staff();
$hstaff = new HStaff();
$hday = new HDay();
$holiday = new Holiday();
$sql = 'SELECT `CLD_L_category`.cid,`CLD_L_category`.title,count(`CLD_staff`.sid) as count FROM `CLD_L_category` left join `CLD_staff` on `CLD_L_category`.cid=`CLD_staff`.cid where `CLD_staff`.nature=2 group by `CLD_staff`.cid HAVING count(`CLD_staff`.sid)>0 order by count(`CLD_staff`.sid) desc';
$query = Doo::db ()->query ( $sql );
$result = $query->fetchAll ();
$data['category'] = $result;
$thisyear = date('Y',time());
// $thisyear = date('Y',1546358400);
$data['thismonth'] = intval(date('m',time()));
$num = intval($thisyear)-2017;
$html = '';
$yearnum = isset($this->params['year']) && is_numeric($this->params['year']) ? $this->params['year'] : '';
for($i = $num; $i >= 0; $i--){
if($yearnum == (2017+$i)){
$html .= '';
}else{
$html .= '';
}
}
$data['option'] = $html;
if(isset($this->params['year']) && isset($this->params['month'])){
$month = intval($this->params['month']) < 10 ? '0'.$this->params['month'] : $this->params['month'];
$date = $this->params['year'].'-'.$month.'-01';
$thismonth = $this->getMonthTime($date);
$data['thismonth'] = $this->params['month'];
}else{
$thismonth = $this->getMonthTime(date('Y-m-d',time()));
}
$stafflist = array();
foreach($result as $k => $v){
$stafflist[$k]['categoryname'] = $v['title'];
$stafflist[$k]['count'] = $v['count'];
$cidstafflist = $staff->find(array('where' => 'cid='.$v['cid'].' and nature=2', 'asArray' => TRUE));
foreach($cidstafflist as $ck => $cv) {
foreach (array(1, 2, 3, 14) as $tk => $tv) {
if($tv == 14){
$typeholiday = $holiday->getOne(array('where' => 'status=3 and type='.$tv.' and uid='.$cv['sid'].' and starttime="'.$thismonth['start'].'" and endtime="'.$thismonth['end'].'"', 'desc' => 'id', 'asArray' => TRUE));
$cidstafflist[$ck][$tv] = $typeholiday['daynum'] != 0 ? floatval($typeholiday['daynum']) : '';
}else{
$typeholiday = $hday->find(array('where' => 'type=' . $tv . ' and uid=' . $cv['sid'] . ' and UNIX_TIMESTAMP(daytime) between ' . $thismonth['start'] . ' and ' . $thismonth['end'], 'asArray' => TRUE));
$cidstafflist[$ck][$tv] = 0;
if (!empty($typeholiday)) {
foreach ($typeholiday as $thk => $thv) {
$cidstafflist[$ck][$tv] += floatval($thv['daymsg']);
}
}
$cidstafflist[$ck][$tv] = $cidstafflist[$ck][$tv] != 0 ? $cidstafflist[$ck][$tv] : '';
}
}
$cidstafflist[$ck]['first'] = $ck == 0 ? 1 : ''; // 是否第一个
}
$stafflist[$k]['cidstafflist'] = $cidstafflist;
}
$data['stafflist'] = $stafflist;
$data['internstafflist'] = $staff->find(array('where' => 'nature=2', 'asArray' => TRUE));
$data ['memu'] = 'holiday';
$data ['holidaymenu'] = 'close';
$data ['staff'] = $this->staff;
$data['noindexjs'] = 'noindexjs';
$this->render ( "/holiday-close2", $data );
}
public function addHoliday2(){
if(isset($_POST['uid']) && is_numeric($_POST['uid']) && isset($_POST['type']) && is_numeric($_POST['type'])){
Doo::loadModel('holiday');
$holiday = new Holiday();
if(in_array($_POST['type'],array(1,2,3))){
$day = $_POST['day'];
$dayjson = array('holiday' => [$day.'_1']);
$holiday->uid = $_POST['uid'];
$holiday->type = $_POST['type'];
$holiday->dayjson = json_encode($dayjson);
$holiday->daynum = 1.0;
$holiday->status = 3;
$holiday->addtime = time();
$holiday->approvetime = time();
$holiday->description = $_POST['description'];
$id = $holiday->insert();
Doo::loadModel('holidayday');
$hday = new HDay();
$hday->hid = $id;
$hday->uid = $_POST['uid'];
$hday->type = $_POST['type'];
$hday->daytime = $day;
$hday->daymsg = 1.0;
$hday->insert();
if(isset($_POST['close2'])){
return '/holidayclose2';
}else{
return '/holidayclose';
}
}elseif($_POST['type'] == 14){
$thismonth = $this->getMonthTime(date('Y-m-d',time()));
$holiday->uid = $_POST['uid'];
$holiday->type = $_POST['type'];
$holiday->starttime = $thismonth['start'];
$holiday->endtime = $thismonth['end'];
$holiday->daynum = $_POST['daynum'];
$holiday->status = 3;
$holiday->addtime = time();
$holiday->approvetime = time();
$holiday->description = $_POST['description'];
$holiday->insert();
return '/holidayclose2';
}
}
exit('添加事病假、旷工出错');
}
public function holidayOvertime(){
$checkadmin = $this->checkisadmin();
if(!$checkadmin){
exit('非假期管理员无法访问此页面');
}
$data['cansee'] = 1;
//获取办事处列表
Doo::loadModel('staff');
Doo::loadModel('holidaystaff');
Doo::loadModel('holidayday');
Doo::loadModel('holiday');
$staff = new staff();
$hstaff = new HStaff();
$hday = new HDay();
$holiday = new Holiday();
$sql = 'SELECT `CLD_L_category`.cid,`CLD_L_category`.title,count(`CLD_staff`.sid) as count FROM `CLD_L_category` left join `CLD_staff` on `CLD_L_category`.cid=`CLD_staff`.cid group by `CLD_staff`.cid HAVING count(`CLD_staff`.sid)>0 order by count(`CLD_staff`.sid) desc';
$query = Doo::db ()->query ( $sql );
$result = $query->fetchAll ();
$data['category'] = $result;
$thisyear = date('Y',time());
// $thisyear = date('Y',1546358400);
$data['thismonth'] = intval(date('m',time()));
$num = intval($thisyear)-2017;
$html = '';
$yearnum = isset($this->params['year']) && is_numeric($this->params['year']) ? $this->params['year'] : '';
for($i = $num; $i >= 0; $i--){
if($yearnum == (2017+$i)){
$html .= '';
}else{
$html .= '';
}
}
$data['option'] = $html;
if(isset($this->params['year']) && isset($this->params['month'])){
$month = intval($this->params['month']) < 10 ? '0'.$this->params['month'] : $this->params['month'];
$date = $this->params['year'].'-'.$month.'-01';
$thismonth = $this->getMonthTime($date);
$data['thismonth'] = $this->params['month'];
}else{
$thismonth = $this->getMonthTime(date('Y-m-d',time()));
}
$stafflist = array();
if(isset($this->params['cid']) && is_numeric($this->params['cid'])){
$data['thiscid'] = $this->params['cid'];
foreach($result as $k => $v){
if($this->params['cid'] == $v['cid']){
$stafflist[0]['categoryname'] = $v['title'];
$stafflist[0]['count'] = $v['count'];
$cidstafflist = $staff->getStaffByCid($v['cid']);
foreach($cidstafflist as $ck => $cv){
$hstaffmsg = $hstaff->getOne(array('where' => 'uid='.$cv['sid'], 'asArray' => TRUE));
$cidstafflist[$ck]['addnum'] = $hstaffmsg['addnum'] != 0.0 ? floatval($hstaffmsg['addnum']) : '';
foreach(array(4,5,10,11) as $tk => $tv){
if($tv == 11){
$typeholiday = $holiday->find(array('where' => 'status=1 and type='.$tv.' and uid='.$cv['sid'].' and addtime between '.$thismonth['start'].' and '.$thismonth['end'],'asArray' => TRUE));
$cidstafflist[$ck][$tv] = 0;
if(!empty($typeholiday)){
foreach($typeholiday as $thk => $thv){
$cidstafflist[$ck][$tv] += floatval($thv['daynum']);
}
}
$cidstafflist[$ck][$tv] = $cidstafflist[$ck][$tv] != 0 ? $cidstafflist[$ck][$tv] : '';
}else{
$typeholiday = $hday->find(array('where' => 'type='.$tv.' and uid='.$cv['sid'].' and UNIX_TIMESTAMP(daytime) between '.$thismonth['start'].' and '.$thismonth['end'],'asArray' => TRUE));
$cidstafflist[$ck][$tv] = 0;
if(!empty($typeholiday)){
foreach($typeholiday as $thk => $thv){
$cidstafflist[$ck][$tv] += floatval($thv['daymsg']);
}
}
$cidstafflist[$ck][$tv] = $cidstafflist[$ck][$tv] != 0 ? $cidstafflist[$ck][$tv] : '';
}
}
$cidstafflist[$ck]['countnum'] = floatval($cidstafflist[$ck][4])+floatval($cidstafflist[$ck][5]) != 0 ? floatval($cidstafflist[$ck][4]) + floatval($cidstafflist[$ck][5]) : '';
$cidstafflist[$ck]['first'] = $ck == 0 ? 1 : ''; // 是否第一个
}
$stafflist[0]['cidstafflist'] = $cidstafflist;
break;
}
}
}else{
foreach($result as $k => $v){
$stafflist[$k]['categoryname'] = $v['title'];
$stafflist[$k]['count'] = $v['count'];
$cidstafflist = $staff->getStaffByCid($v['cid']);
foreach($cidstafflist as $ck => $cv) {
$hstaffmsg = $hstaff->getOne(array('where' => 'uid=' . $cv['sid'], 'asArray' => TRUE));
$cidstafflist[$ck]['addnum'] = $hstaffmsg['addnum'] != 0.0 ? floatval($hstaffmsg['addnum']) : '';
foreach (array(4, 5, 10, 11) as $tk => $tv) {
if ($tv == 11) {
$typeholiday = $holiday->find(array('where' => 'status=1 and type=' . $tv . ' and uid=' . $cv['sid'] . ' and addtime between ' . $thismonth['start'] . ' and ' . $thismonth['end'], 'asArray' => TRUE));
$cidstafflist[$ck][$tv] = 0;
if (!empty($typeholiday)) {
foreach ($typeholiday as $thk => $thv) {
$cidstafflist[$ck][$tv] += floatval($thv['daynum']);
}
}
$cidstafflist[$ck][$tv] = $cidstafflist[$ck][$tv] != 0 ? $cidstafflist[$ck][$tv] : '';
} else {
$typeholiday = $hday->find(array('where' => 'type=' . $tv . ' and uid=' . $cv['sid'] . ' and UNIX_TIMESTAMP(daytime) between ' . $thismonth['start'] . ' and ' . $thismonth['end'], 'asArray' => TRUE));
$cidstafflist[$ck][$tv] = 0;
if (!empty($typeholiday)) {
foreach ($typeholiday as $thk => $thv) {
$cidstafflist[$ck][$tv] += floatval($thv['daymsg']);
}
}
$cidstafflist[$ck][$tv] = $cidstafflist[$ck][$tv] != 0 ? $cidstafflist[$ck][$tv] : '';
}
}
$cidstafflist[$ck]['countnum'] = floatval($cidstafflist[$ck][4])+floatval($cidstafflist[$ck][5]) != 0 ? floatval($cidstafflist[$ck][4]) + floatval($cidstafflist[$ck][5]) : '';
$cidstafflist[$ck]['first'] = $ck == 0 ? 1 : ''; // 是否第一个
}
$stafflist[$k]['cidstafflist'] = $cidstafflist;
}
}
$data['stafflist'] = $stafflist;
$zongbu = $staff->getStaffByCid(12);
$data['zongbu'] = $zongbu;
$data ['memu'] = 'holiday';
$data ['holidaymenu'] = 'overtime';
$data ['staff'] = $this->staff;
$data['noindexjs'] = 'noindexjs';
$this->render ( "/holiday-overtime", $data );
}
public function addHoliday(){
if(isset($_POST['uid']) && is_numeric($_POST['uid']) && isset($_POST['type']) && is_numeric($_POST['type'])){
Doo::loadModel('holidaystaff');
Doo::loadModel('holiday');
$holiday = new Holiday();
$hstaff = new HStaff();
$hstaffmsg = $hstaff->getOne(array('where' => 'uid='.$_POST['uid'], 'asArray' => TRUE));
if($_POST['type'] == 4 || $_POST['type'] == 5){
$day = $_POST['day'];
$hstaff->uid = $_POST['uid'];
$hstaff->addnum = floatval($hstaffmsg['addnum'])+1;
$result = $hstaff->update();
if($result){
$dayjson = array('holiday' => [$day.'_1']);
$holiday->uid = $_POST['uid'];
$holiday->type = $_POST['type'];
$holiday->dayjson = json_encode($dayjson);
$holiday->daynum = 1.0;
$holiday->status = 3;
$holiday->addtime = time();
$holiday->approvetime = time();
$holiday->description = $_POST['description'];
$id = $holiday->insert();
Doo::loadModel('holidayday');
$hday = new HDay();
$hday->hid = $id;
$hday->uid = $_POST['uid'];
$hday->type = $_POST['type'];
$hday->daytime = $day;
$hday->daymsg = 1.0;
$hday->insert();
return '/holidayovertime';
}else{
exit('添加到holidaystaff出错');
}
}elseif($_POST['type'] == 13){
$daynum = $_POST['tixian'];
if($daynum > $hstaffmsg['addnum']){
exit('提现天数超过存假天数了');
}else{
$hstaff->uid = $_POST['uid'];
$hstaff->addnum = $hstaffmsg['addnum']-$daynum;
$result = $hstaff->update();
if($result){
$holiday->uid = $_POST['uid'];
$holiday->type = 13;
$holiday->daynum = $daynum;
$holiday->status = 3;
$holiday->addtime = time();
$holiday->approvetime = time();
$holiday->description = $_POST['description'];
$holiday->insert();
return '/holidayovertime';
}else{
exit('添加到holidaystaff出错');
}
}
}
}
exit('添加加值班或提现出错');
}
public function holidayVacation(){
$checkadmin = $this->checkisadmin();
if(!$checkadmin){
exit('非假期管理员无法访问此页面');
}
$data['cansee'] = 1;
//获取办事处列表
Doo::loadModel('staff');
Doo::loadModel('holidaystaff');
$staff = new staff();
$hstaff = new HStaff();
$sql = 'SELECT `CLD_L_category`.cid,`CLD_L_category`.title,count(`CLD_staff`.sid) as count FROM `CLD_L_category` left join `CLD_staff` on `CLD_L_category`.cid=`CLD_staff`.cid group by `CLD_staff`.cid HAVING count(`CLD_staff`.sid)>0 order by count(`CLD_staff`.sid) desc';
$query = Doo::db ()->query ( $sql );
$result = $query->fetchAll ();
$data['category'] = $result;
$stafflist = array();
if(isset($this->params['cid']) && is_numeric($this->params['cid'])){
$data['thiscid'] = $this->params['cid'];
foreach($result as $k => $v){
if($this->params['cid'] == $v['cid']){
$stafflist[0]['categoryname'] = $v['title'];
$stafflist[0]['count'] = $v['count'];
$cidstafflist = $staff->getStaffByCid($v['cid']);
foreach($cidstafflist as $ck => $cv){
$hstaffmsg = $hstaff->getOne(array('where' => 'uid='.$cv['sid'], 'asArray' => TRUE));
$cidstafflist[$ck]['yearnum'] = $cv['nature'] == 1 ? ($hstaffmsg['yearnum'] != 0.0 ? floatval($hstaffmsg['yearnum']) : '') : '';
$cidstafflist[$ck]['addnum'] = $hstaffmsg['addnum'] != 0.0 ? floatval($hstaffmsg['addnum']) : '';
$cidstafflist[$ck]['hunjianum'] = $hstaffmsg['hunjianum'] != 0.0 ? floatval($hstaffmsg['hunjianum']) : '';
$cidstafflist[$ck]['chanjianum'] = $hstaffmsg['chanjianum'] != 0.0 ? floatval($hstaffmsg['chanjianum']) : '';
$cidstafflist[$ck]['sangjianum'] = $hstaffmsg['sangjianum'] != 0.0 ? floatval($hstaffmsg['sangjianum']) : '';
$cidstafflist[$ck]['gongjianum'] = $hstaffmsg['gongjianum'] != 0.0 ? floatval($hstaffmsg['gongjianum']) : '';
$cidstafflist[$ck]['yearround'] = $cv['nature'] == 1 ? $this->getYearRoundtime($hstaffmsg['hadyear'],$cv['hiredate']) : '';
$cidstafflist[$ck]['first'] = $ck == 0 ? 1 : ''; // 是否第一个
}
$stafflist[0]['cidstafflist'] = $cidstafflist;
break;
}
}
}else{
foreach($result as $k => $v){
$stafflist[$k]['categoryname'] = $v['title'];
$stafflist[$k]['count'] = $v['count'];
$cidstafflist = $staff->getStaffByCid($v['cid']);
foreach($cidstafflist as $ck => $cv){
$hstaffmsg = $hstaff->getOne(array('where' => 'uid='.$cv['sid'], 'asArray' => TRUE));
$cidstafflist[$ck]['yearnum'] = $cv['nature'] == 1 ? ($hstaffmsg['yearnum'] != 0.0 ? floatval($hstaffmsg['yearnum']) : '') : '';
$cidstafflist[$ck]['addnum'] = $hstaffmsg['addnum'] != 0.0 ? floatval($hstaffmsg['addnum']) : '';
$cidstafflist[$ck]['hunjianum'] = $hstaffmsg['hunjianum'] != 0.0 ? floatval($hstaffmsg['hunjianum']) : '';
$cidstafflist[$ck]['chanjianum'] = $hstaffmsg['chanjianum'] != 0.0 ? floatval($hstaffmsg['chanjianum']) : '';
$cidstafflist[$ck]['sangjianum'] = $hstaffmsg['sangjianum'] != 0.0 ? floatval($hstaffmsg['sangjianum']) : '';
$cidstafflist[$ck]['gongjianum'] = $hstaffmsg['gongjianum'] != 0.0 ? floatval($hstaffmsg['gongjianum']) : '';
$cidstafflist[$ck]['yearround'] = $cv['nature'] == 1 ? $this->getYearRoundtime($hstaffmsg['hadyear'],$cv['hiredate']) : '';
$cidstafflist[$ck]['first'] = $ck == 0 ? 1 : ''; // 是否第一个
}
$stafflist[$k]['cidstafflist'] = $cidstafflist;
}
}
$zongbu = $staff->getStaffByCid(12);
$data['zongbu'] = $zongbu;
$hstaff2 = new HStaff();
$hstaffmsg2 = $hstaff2->getOne(array('select' => 'yearnum', 'where' => 'uid='.$zongbu[0]['sid'], 'asArray' => TRUE));
$data['thisnum'] = floatval($hstaffmsg2['yearnum']);
$data['stafflist'] = $stafflist;
$data ['memu'] = 'holiday';
$data ['holidaymenu'] = 'vacation';
$data ['staff'] = $this->staff;
$data['noindexjs'] = 'noindexjs';
$this->render ( "/holiday-vacation", $data );
}
public function setStaffHoliday(){
if(isset($_POST['uid']) && is_numeric($_POST['uid']) && isset($_POST['typeholiday']) && isset($_POST['addnum'])){
Doo::loadModel('holidaystaff');
$hstaff = new HStaff();
$hstaffmsg = $hstaff->getOne(array('where' => 'uid='.$_POST['uid'], 'asArray' => TRUE));
$hstaff->uid = $_POST['uid'];
$type = '';
switch($_POST['typeholiday']){
case 'yearnum':
$hstaff->yearnum = $hstaffmsg['yearnum']+$_POST['addnum'];
$type = 15;
break;
case 'hunjianum':
$hstaff->hunjianum = $hstaffmsg['hunjianum']+$_POST['addnum'];
$type = 16;
break;
case 'chanjianum':
$hstaff->chanjianum = $hstaffmsg['chanjianum']+$_POST['addnum'];
$type = 17;
break;
case 'sangjianum':
$hstaff->sangjianum = $hstaffmsg['sangjianum']+$_POST['addnum'];
$type = 18;
break;
case 'gongjianum':
$hstaff->gongjianum = $hstaffmsg['gongjianum']+$_POST['addnum'];
$type = 19;
break;
}
$hstaff->update();
Doo::loadModel('holiday');
$holiday = new Holiday();
$holiday->uid = $_POST['uid'];
$holiday->type = $type;
$holiday->daynum = $_POST['addnum'];
$holiday->status = 3;
$holiday->addtime = time();
$holiday->approvetime = time();
$holiday->description = $_POST['description'];
$holiday->insert();
return '/holidayvacation';
}else{
exit('增加出错');
}
}
public function getStaffCategory(){
if(isset($_POST['cid']) && is_numeric($_POST['cid'])){
Doo::loadModel('staff');
$staff = new staff();
$stafflist = $staff->getStaffByCid($_POST['cid']);
Doo::loadModel('holidaystaff');
$hstaff = new HStaff();
$hstaffmsg = $hstaff->getOne(array('select' => 'yearnum', 'where' => 'uid='.$stafflist[0]['sid'], 'asArray' => TRUE));
exit(json_encode(array('code' => 200, 'stafflist' => $stafflist, 'thisnum' => floatval($hstaffmsg['yearnum']))));
}
exit(json_encode(array('code' => 400)));
}
public function getHolidayStaff(){
if(isset($_POST['uid']) && is_numeric($_POST['uid']) && isset($_POST['type'])){
Doo::loadModel('holidaystaff');
$hstaff = new HStaff();
$staffmsg = $hstaff->getOne(array('select' => $_POST['type'], 'where' => 'uid='.$_POST['uid'], 'asArray' => TRUE));
exit(json_encode(array('code' => 200, 'thisnum' => floatval($staffmsg[$_POST['type']]))));
}
exit(json_encode(array('code' => 400)));
}
private function geyDayMsg($dayjson){
$holidayday = array();
foreach($dayjson as $dk => $dv){
$oneday = explode('_',$dv);
if($oneday[1] != 0){
$holidayday[$dk]['daytime'] = $oneday[0];
$holidayday[$dk]['daymsg'] = $oneday[1] == 1 ? '' : ($oneday[1] == 2 ? '上午' : '下午');
}
}
return $holidayday;
}
//获取某日期的月初月末时间戳
private function getMonthTime($time){
$starttime = strtotime(date('Y-m-01',strtotime($time)));
$endtime = strtotime("+1 months", strtotime(date('Y-m-01',strtotime($time))))-1;
return array('start' => $starttime, 'end' => $endtime);
}
//获取本年的每个月的时间戳
private function getYearMonthTime($thisyear){
$monthdata = array();
for($i = 0; $i < 12; $i++){
$j = $i+1;
$j = $j < 10 ? '0'.$j : $j;
$nowmonth = $thisyear.'-'.$j.'-01';
$monthdata[$i]['starttime'] = strtotime($nowmonth);
$monthdata[$i]['endtime'] = strtotime("+1 months", strtotime($nowmonth))-1;
}
return $monthdata;
}
//获取本年当事人的年假周期
private function getYearRoundtime($hadyear,$hiredate){
$month = date('m', strtotime($hiredate));
$date = date('d', strtotime($hiredate));
$monthday = intval($month).'月'.intval($date).'日';
$year = date('Y',time());
//每隔4年加一天
if(date('Y',(strtotime($hiredate)+(86400*365*$hadyear)+intval($hadyear/4)*86400)) < $year){
$lastyear = intval($year)-1;
return intval($lastyear).'年'.$monthday.'~'.intval($year).'年'.$monthday;
}else{
$nextyear = intval($year)+1;
return intval($year).'年'.$monthday.'~'.intval($nextyear).'年'.$monthday;
}
}
private function checkisadmin(){
Doo::loadModel('holidayadmin');
$admin = new HAdmin();
$adminmsg = $admin->getOne(array('where' => 'uid='.$this->staff[0]['sid'], 'asArray' => TRUE));
if(!empty($adminmsg)){
return TRUE;
}else{
return FALSE;
}
}
}
?>