信呼OA版本v2.3.8
This commit is contained in:
93
webmain/system/menu/menuAction.php
Normal file
93
webmain/system/menu/menuAction.php
Normal file
@@ -0,0 +1,93 @@
|
||||
<?php
|
||||
class menuClassAction extends Action
|
||||
{
|
||||
|
||||
public function dataAjax()
|
||||
{
|
||||
$this->rows = array();
|
||||
$type = $this->get('type');
|
||||
$loadci = (int)$this->get('loadci');
|
||||
$pid = (int)$this->get('pid','0');
|
||||
$where = '';
|
||||
//权限那来的
|
||||
if($type != ''){
|
||||
$where = 'and `status`=1 and `ispir`=1 and `type`=0';
|
||||
if($type=='view')$where = 'and `status`=1 and `type`=0';
|
||||
}else{
|
||||
$this->updatepirss();
|
||||
}
|
||||
if($pid>0){
|
||||
$where.=' and (`id`='.$pid.' or `pid`='.$pid.' or `pid` in(select `id` from `[Q]menu` where `pid`='.$pid.'))';
|
||||
}
|
||||
$this->alldata = $this->db->getall('select *,(select count(1)from `[Q]menu` where `pid`=a.id '.$where.')stotal from `[Q]menu` a where 1=1 '.$where.' order by `sort`');
|
||||
|
||||
$this->getmenu(0, 1, 1);
|
||||
|
||||
$pdata = array();
|
||||
if($loadci==1){
|
||||
foreach($this->alldata as $k=>$rs){
|
||||
if($rs['pid']=='0')$pdata[] = array('name'=>$rs['name'],'id'=>$rs['id']);
|
||||
}
|
||||
}
|
||||
|
||||
echo json_encode(array(
|
||||
'totalCount'=> 0,
|
||||
'pdata' => $pdata,
|
||||
'rows' => $this->rows
|
||||
));
|
||||
}
|
||||
|
||||
private function getmenu($pid, $oi, $zt)
|
||||
{
|
||||
$downid = '';
|
||||
foreach($this->alldata as $k=>$rs){
|
||||
if($pid==$rs['pid']){
|
||||
$downid.=','.$rs['id'].'';
|
||||
$rs['level'] = $oi;
|
||||
$zthui = $rs['status'];
|
||||
if($zt==0){
|
||||
$rs['ishui']=1;
|
||||
$zthui = 0;
|
||||
}
|
||||
//if($oi>1)$rs['trstyle']='display:none;';
|
||||
$this->rows[] = $rs;
|
||||
$len = count($this->rows)-1;
|
||||
$sidss = $this->getmenu($rs['id'], $oi+1, $zthui);
|
||||
//if($sidss)$this->rows[$len]['downallid'] = substr($sidss,1);
|
||||
}
|
||||
}
|
||||
return $downid;
|
||||
}
|
||||
|
||||
//下级需要验证,那上级也必须验证的
|
||||
private function updatepirss()
|
||||
{
|
||||
$rows = $this->db->getall('select `pid` from `[Q]menu` where `pid`>0 and `ispir`=1 group by `pid`');
|
||||
$sid = '0';
|
||||
foreach($rows as $k=>$rs)$sid.=','.$rs['pid'].'';
|
||||
if($sid!='')m('menu')->update('`ispir`=1', "`id` in($sid)");
|
||||
}
|
||||
|
||||
/**
|
||||
* 菜单管理获取菜单
|
||||
*/
|
||||
public function getdataAjax()
|
||||
{
|
||||
$pvalue = (int)$this->get('pvalue','0');
|
||||
$level = (int)$this->get('level','1');
|
||||
$rows = $this->db->getall('select *,(select count(1)from `[Q]menu` where `pid`=a.id )stotal from `[Q]menu` a where `pid`='.$pvalue.' order by `sort`');
|
||||
foreach($rows as $k=>$rs)$rows[$k]['level'] = $level;
|
||||
echo json_encode(array(
|
||||
'totalCount'=> 0,
|
||||
'rows' => $rows
|
||||
));
|
||||
}
|
||||
|
||||
public function delmenuAjax()
|
||||
{
|
||||
$id = (int)$this->post('id');
|
||||
if(m('menu')->rows('pid='.$id.'')>0)return returnerror('有下级菜单不能删除');
|
||||
m('menu')->delete($id);
|
||||
return returnsuccess();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user