本文整理匯總了PHP中tree_to_list函數的典型用法代碼示例。如果您正苦於以下問題:PHP tree_to_list函數的具體用法?PHP tree_to_list怎麽用?PHP tree_to_list使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了tree_to_list函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: fetchList
public function fetchList()
{
$menuList = $this->order('sort')->select();
$tree = list_to_tree($menuList);
$list = tree_to_list($tree);
return $list;
}
示例2: node
public function node()
{
$node_model = M("Node");
if (!empty($_POST['eq_pid'])) {
$eq_pid = $_POST['eq_pid'];
} else {
$eq_pid = $node_model->where('pid=0')->order('sort asc')->getField('id');
}
//dump($node_model -> select());
$node_list = $node_model->order('sort asc')->select();
$node_list = tree_to_list(list_to_tree($node_list, $eq_pid));
$node_list = rotate($node_list);
//dump($node_list);
$node_list = implode(",", $node_list['id']) . ",{$eq_pid}";
$where['id'] = array('in', $node_list);
$menu = $node_model->field('id,pid,name,url')->where($where)->order('sort asc')->select();
$tree = list_to_tree($menu);
$this->assign('eq_pid', $eq_pid);
$list = tree_to_list($tree);
$this->assign('node_list', $list);
//$this->assign('menu',sub_tree_menu($list));
$role = M("Role")->order('sort asc')->select();
$this->assign('list', $role);
$list = $node_model->where('pid=0')->order('sort asc')->getField('id,name');
$this->assign('groupList', $list);
$this->display();
}
示例3: index
public function index()
{
$widget['date'] = true;
$this->assign("widget", $widget);
$this->assign('user_id', get_user_id());
$auth = $this->config['auth'];
$this->assign('auth', $auth);
if ($auth['admin']) {
$node = D("Dept");
$dept_id = get_dept_id();
$dept_name = get_dept_name();
$menu = array();
$dept_menu = $node->field('id,pid,name')->where("is_del=0")->order('sort asc')->select();
$dept_tree = list_to_tree($dept_menu, $dept_id);
$count = count($dept_tree);
if (empty($count)) {
/*獲取部門列表*/
$html = '';
$html = $html . "<option value='{$dept_id}'>{$dept_name}</option>";
$this->assign('dept_list', $html);
/*獲取人員列表*/
$where['dept_id'] = array('eq', $dept_id);
$emp_list = D("User")->where($where)->getField('id,name');
$this->assign('emp_list', $emp_list);
} else {
/*獲取部門列表*/
$this->assign('dept_list', select_tree_menu($dept_tree));
$dept_list = tree_to_list($dept_tree);
$dept_list = rotate($dept_list);
$dept_list = $dept_list['id'];
/*獲取人員列表*/
$where['dept_id'] = array('in', $dept_list);
$emp_list = D("User")->where($where)->getField('id,name');
$this->assign('emp_list', $emp_list);
}
}
$map = $this->_search();
if ($auth['admin']) {
if (empty($map['dept_id'])) {
if (!empty($dept_list)) {
$map['dept_id'] = array('in', array_merge($dept_list, array($dept_id)));
} else {
$map['dept_id'] = array('eq', $dept_id);
}
}
} else {
$map['user_id'] = get_user_id();
}
if (method_exists($this, '_search_filter')) {
$this->_search_filter($map);
}
$model = D("WorkLog");
if (!empty($model)) {
$this->_list($model, $map);
}
$this->display();
}
示例4: getMenuList
public function getMenuList()
{
$menuTree = $this->getMenuTree(null, $where, 0, 3);
$menuList = tree_to_list($menuTree, 0, '_son', '_level', 'order');
//設置總條數
$this->totalCount = count($menuList);
//截取該頁的信息
$menuList = array_slice($menuList, ($this->p - 1) * $this->pageSize, $this->pageSize);
return $menuList;
}
示例5: del_tag
function del_tag($tag_id)
{
$model = M("UserTag");
$tag_list = tree_to_list(list_to_tree($this->get_tag_list("id,pid,name"), $tag_id));
$tag_list = rotate($tag_list);
$tag_list = implode(",", $tag_list['id']) . ",{$tag_id}";
$where['id'] = array('in', $tag_list);
$this->where($where)->delete();
$this->_del_data_by_tag($tag_list);
}
示例6: get_emp_list_by_dept_id
private function get_emp_list_by_dept_id($id)
{
$dept = tree_to_list(list_to_tree(M("Dept")->where('is_del=0')->select(), $id));
$dept = rotate($dept);
$dept = implode(",", $dept['id']) . ",{$id}";
$model = M("User");
$where['dept_id'] = array('in', $dept);
$data = $model->where($where)->select();
return $data;
}
示例7: read
function read()
{
$id = $_REQUEST['id'];
$model = M("Dept");
$dept = tree_to_list(list_to_tree(M("Dept")->where('is_del=0')->select(), $id));
$dept = rotate($dept);
$dept = implode(",", $dept['id']) . ",{$id}";
$model = D("UserView");
$where['is_del'] = array('eq', '0');
$where['dept_id'] = array('in', $dept);
$data = $model->where($where)->select();
$this->ajaxReturn($data, "", 1);
}
示例8: _assign_badge_count
protected function _assign_badge_count()
{
$node_list = D("Node")->access_list();
$system_folder_menu = D("SystemFolder")->get_folder_menu();
$user_folder_menu = D("UserFolder")->get_folder_menu();
$node_list = array_merge($node_list, $system_folder_menu, $user_folder_menu);
foreach ($node_list as $val) {
$badge_function = $val['badge_function'];
if (!empty($badge_function) and function_exists($badge_function) and $badge_function != 'badge_sum') {
if ($badge_function == 'badge_count_system_folder' or $badge_function == 'badge_count_user_folder') {
$badge_count[$val['id']] = $badge_function($val['fid']);
} else {
$badge_count[$val['id']] = $badge_function();
}
}
}
//$node_tree = list_to_tree($node_list);
foreach ($node_list as $key => $val) {
if ($val['badge_function'] == 'badge_sum') {
$child_menu = list_to_tree($node_list, $val['id']);
$child_menu = tree_to_list($child_menu);
//dump($child_menu);
$child_menu_id = rotate($child_menu);
$count = 0;
if (isset($child_menu_id['id'])) {
$child_menu_id = $child_menu_id['id'];
$count = 0;
foreach ($child_menu_id as $k1 => $v1) {
if (!empty($badge_count[$v1])) {
$count += $badge_count[$v1];
}
}
}
$badge_sum[$val['id']] = $count;
}
}
if (!empty($badge_count)) {
if (!empty($badge_sum)) {
$total = $badge_count + $badge_sum;
} else {
$total = $badge_count;
}
$this->assign('badge_count', $total);
}
}
示例9: node
public function node()
{
$node = M("Node");
if (!empty($_POST['s_pid'])) {
$pid = $_POST['s_pid'];
} else {
$pid = $node->where('pid=0')->order('sort asc')->getField('id');
}
$menu = array();
$menu = $node->field('id,pid,name,check_auth,"#" as url')->order('sort asc')->select();
$tree = list_to_tree($menu, $pid);
$this->assign('pid', $pid);
$list = tree_to_list($tree);
$this->assign('node_list', $list);
//$this->assign('menu',sub_tree_menu($list));
$role = M("Role")->select();
$this->assign('list', $role);
$list = $node->where('pid=0')->order('sort asc')->getField('id,name');
$this->assign('groupList', $list);
$this->display();
}
示例10: fetchSubMenu
public function fetchSubMenu()
{
$menuInfo = $this->_fetchCurrentMenuInfo();
//如果無此菜單,則證明為ajax方法.直接退出
if ($menuInfo == false) {
return;
}
$id = $menuInfo['id'];
$pid = $menuInfo['pid'];
/*
* 有記錄,查找出目錄結構
*/
$adminM = D('Admin/AdminMenu');
$adminM->setCurrentMenuId($id);
$menus = $adminM->fetchParetnsMenus();
$subMenu = $adminM->fetchSubMenu($menus, 1, 2);
$subMenu = tree_to_list($subMenu);
//添加CURRENT,parent信息
$subMenu = $this->_addCurrent($subMenu, $menus);
$tree = list_to_tree($subMenu, $pk = 'id', $pid = 'pid', $child = '_child', $menus[1]);
return '<ul class="nav nav-list">' . $this->_treeAddHtml($tree) . "</ul>";
}
示例11: ajaxRead
function ajaxRead()
{
$type = $_REQUEST['type'];
$id = $_REQUEST['id'];
switch ($type) {
case "company":
$model = M("Dept");
$dept = tree_to_list(list_to_tree(M("Dept")->select(), $id));
$dept = rotate($dept);
$dept = implode(",", $dept['id']) . ",{$id}";
$model = M("User");
$where['dept_id'] = array('in', $dept);
$data = $model->where($where)->field('id,emp_name,dept_id,email')->select();
break;
case "rank":
$model = M("User");
$where['rank_id'] = array('eq', $id);
$data = $model->where($where)->field('id,emp_name,email')->select();
break;
case "position":
$model = M("User");
$where['position_id'] = array('eq', $id);
$data = $model->where($where)->field('id,emp_name,email')->select();
break;
case "personal":
$model = M("FlowType");
if ($id == "#") {
$id = "";
}
$where['group'] = array('eq', $id);
$where['email'] = array('neq', '');
$where['user_id'] = array('eq', get_user_id());
$data = $model->where($where)->field('id,name as emp_name,email')->select();
break;
default:
}
if (true) {
// 讀取成功
$this->ajaxReturn($data, "", 1);
}
}
示例12: tree_to_list
/**
* 將list_to_tree的樹還原成列表
* @param array $tree 原來的樹
* @param string $child 孩子節點的鍵
* @param string $order 排序顯示的鍵,一般是主鍵 升序排列
* @param array $list 過渡用的中間數組,
* @return array 返回排過序的列表數組
* @author yangweijie <yangweijiester@gmail.com>
*/
function tree_to_list($tree, $child = '_child', $order = 'id', &$list = array())
{
if (is_array($tree)) {
$refer = array();
foreach ($tree as $key => $value) {
$reffer = $value;
if (isset($reffer[$child])) {
unset($reffer[$child]);
tree_to_list($value[$child], $child, $order, $list);
}
$list[] = $reffer;
}
$list = list_sort_by($list, $order, $sortby = 'asc');
}
return $list;
}
示例13: _fetchMenuList
/**
* 取係統菜單列表,用於顯示在上級菜單的OPTION
* @return ARRAY 包括有所有菜單信息的二級數組
* author:panjie 3792535@qq.com
*/
private function _fetchMenuList()
{
$menuModel = new MenuModel();
$data = $menuModel->getMenuTree(null, null, 0, 2);
return tree_to_list($data, 0, '_son');
}
示例14: select_tree_menu
function select_tree_menu($tree)
{
$html = "";
if (is_array($tree)) {
$list = tree_to_list($tree);
foreach ($list as $val) {
$html = $html . "<option value='{$val['id']}'>" . str_pad("", $val['level'] * 3, "│") . "├─" . "{$val['name']}</option>";
}
}
return $html;
}
示例15: read
function read()
{
$type = $_REQUEST['type'];
$id = $_REQUEST['id'];
switch ($type) {
case "company":
$model = M("Dept");
$dept = tree_to_list(list_to_tree(M("Dept")->where('is_del=0')->select(), $id));
$dept = rotate($dept);
$dept = implode(",", $dept['id']) . ",{$id}";
case "emp":
$model = M("Dept");
$dept = tree_to_list(list_to_tree(M("Dept")->where('is_del=0')->select(), $id));
$dept = rotate($dept);
$dept = implode(",", $dept['id']) . ",{$id}";
$sql = D("UserView")->buildSql();
$model = new Model();
$where['dept_id'] = array('in', $dept);
$where['is_del'] = array('eq', 0);
$data = $model->table($sql . "a")->where($where)->select();
break;
case "rank":
$sql = D("UserView")->buildSql();
$model = new Model();
$where['rank_id'] = array('eq', $id);
$where['is_del'] = array('eq', 0);
$data = $model->table($sql . "a")->where($where)->select();
break;
case "position":
$sql = D("UserView")->buildSql();
$model = new Model();
$where['position_id'] = array('eq', $id);
$where['is_del'] = array('eq', 0);
$data = $model->table($sql . "a")->where($where)->select();
break;
case "personal":
$model = D("UserTag");
if ($id == "#") {
$data = $model->get_data_list("Contact");
$data = rotate($data);
$data = $data['row_id'];
$where['id'] = array('not in', implode(",", $data));
} else {
$test = $model;
$data = $model->get_data_list("Contact", $id);
$data = rotate($data);
$data = $data['row_id'];
$where['id'] = array('in', implode(",", $data));
}
$model = M("Contact");
$where['is_del'] = array('eq', 0);
$data = $model->where($where)->field('id,name,position as position_name,email')->select();
//echo $model->getLastSql();
break;
default:
}
$new = array();
if (true) {
// 讀取成功
$this->ajaxReturn($data, dump($test, false), 1);
}
}