| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219 | 
							- <?php
 
- //Permet le log/surcouhe d'une redirection de navigation
 
- Action::register('navigation_redirect',function(&$response){
 
- 	global $_;
 
- 	$url = base64_decode($_['url']);
 
- 	Log::put("Ouverture de l'url: ".$url,'Navigation');
 
- 	Plugin::callHook('navigation_redirect',array($url));
 
- 	header('location: '.$url);
 
- });
 
- //Récuperation d'une liste de menuitem
 
- Action::register('navigation_tree_search',function(&$response){
 
- 	global $myUser,$_,$myFirm;
 
- 	if (!$myUser->connected()) return;
 
- 	require_once(__DIR__.SLASH.'MenuItem.class.php');
 
- 	if(!isset($_['menu']) || !is_numeric($_['menu'])) throw new Exception("Menu non spécifié");
 
- 	if(!$menu = MenuItem::getById($_['menu'])) throw new Exception("Aucun menu ne correspond en base");
 
- 	$response['rows'] = array();
 
- 	$filters = array('menu'=>$_['menu']);
 
- 	if(!$myUser->can('navigation','configure')) $filters['user'] = $myUser->login;
 
- 	$items = array();
 
- 	//affichage des menu de la firm ou des menu inter firm (0)
 
- 	if(isset($_['firm'])){
 
- 		if(!$myUser->superadmin && !$myUser->haveFirm($_['firm'])) throw new Exception('Vous ne pouvez pas modifier le menu d\'un établissement auquel vous n\'avez pas accès');
 
- 		$filters['firm'] = $_['firm'];
 
- 	}else{
 
- 		$filters['firm:IN'] = array($myFirm->id,0);
 
- 	}
 
- 	//Récupération des catégories principales
 
- 	foreach(MenuItem::loadAll($filters, array('sort')) as $item){
 
- 		$row = $item->toArray();
 
- 		$row['class'] = $item->parent!=''  ? 'navigation-line-child' : '';
 
- 		if(!$row['editable']) $row['class'] .= ' not-editable';
 
- 		$row['target'] = MenuItem::target(!empty($item->target)?$item->target:'redirect');
 
- 		$row['shortcut'] = ($menu->slug == MenuItem::MENU_SHORTCUT && !empty($menu->user)) ? true : false;
 
- 		$items[$row['id']] = $row;
 
- 		if(empty($row['parent']))
 
- 			$response['rows'][$row['id']] = $row;
 
- 	}
 
- 	//Classement pas catégories
 
- 	foreach ($items as $k=>$item) {
 
- 		if(empty($item['parent'])) continue;
 
- 		if(!isset($response['rows'][$item['parent']]['childs'])) $response['rows'][$item['parent']]['childs'] = array();
 
- 		$response['rows'][$item['parent']]['childs'][] = $item;
 
- 	}
 
- 	//Tri des sous catégories par ordre de sort
 
- 	foreach ($response['rows'] as $key=>$parent) {
 
- 		if(!isset($response['rows'][$key]['childs'])) continue;
 
- 		usort($response['rows'][$key]['childs'], function($a,$b){
 
- 			return $a['sort'] - $b['sort'];
 
- 		});
 
- 	}
 
- 	//Le array_values permet la réinitialisation des clés qui impactent sur l'ordre final
 
- 	$response['rows'] = array_values($response['rows']);
 
- });
 
- //Sauvegarde des configurations de navigation
 
- Action::register('navigation_setting_save',function(&$response){
 
- 	global $myUser,$_,$conf,$myFirm;
 
- 	User::check_access('navigation','edit');
 
- 	require_once(__DIR__.SLASH.'MenuItem.class.php');
 
- 	if($conf->get("navigation_allow_custom_menu")==0 && !$myUser->can('navigation','configure')) throw new Exception("Permissions insuffisantes", 403);
 
- 	if(!isset($_['menu']) || !is_numeric($_['menu'])) throw new Exception("Menu non spécifié");
 
- 	if(isset($_['fields'])){
 
- 		foreach(Configuration::setting('navigation') as $key=>$value){
 
- 			if(!is_array($value)) continue;
 
- 			$allowed[] = $key;
 
- 		}
 
- 		foreach ($_['fields'] as $key => $value)
 
- 			if(in_array($key, $allowed)) $conf->put($key,$value);
 
- 	}
 
- 	$filters = array('menu'=>$_['menu'],'firm'=>$_['firm']);
 
- 	if(!$myUser->can('navigation','configure')) $filters['user'] = $myUser->login;
 
- 	if(!$myUser->superadmin) $filters['editable'] = '1';
 
- 	if(!$myUser->superadmin && $_['firm']==0) throw new Exception('Seul un superadmin peut définir un menu pour tous les établissements');
 
- 	if(!$myUser->superadmin && !$myUser->haveFirm($_['firm'])) throw new Exception('Vous ne pouvez pas modifier le menu d\'un établissement auquel vous n\'avez pas accès');
 
- 	$menuItems = array();
 
- 	$parameters = array('menu'=>$_['menu'],'firm'=>$_['firm']);
 
- 	if(!empty($_['items'])){
 
- 		foreach($_['items'] as $i => $item){
 
- 			$menuItem = !empty($item['id']) ? MenuItem::getById($item['id']) : new MenuItem();
 
- 			$menuItem->menu = $_['menu'];
 
- 			$menuItem->firm = $_['firm'];
 
- 			$menuItem->icon = $item['icon'];
 
- 			$menuItem->label = $item['label'];
 
- 			if(isset($item['url'])) $menuItem->url = str_replace(ROOT_URL.'/','',$item['url']);
 
- 			$menuItem->target = isset($item['target']) && !empty($item['target']) ? $item['target'] : 'redirect';
 
- 			if(isset($item['visibility'])) $menuItem->visibility = $item['visibility'];
 
- 			$menuItem->user = $myUser->can('navigation','configure') ? '' : $myUser->login;
 
- 			$menuItem->sort = $i;
 
- 			$menuItem->parent = NULL;
 
- 			$menuItem->slug = slugify($menuItem->label);
 
- 			if(MenuItem::rowCount(array('slug'=>$menuItem->slug)) < 0)
 
- 				$item->slug .='_'.time();
 
- 			$menuItem->save();
 
- 			$menuItems[] = $menuItem->id;
 
- 			if(!empty($item['childs'])){
 
- 				foreach($item['childs'] as $j => $subItem){
 
- 					$menuSubItem = !empty($subItem['id']) ? MenuItem::getById($subItem['id']) : new MenuItem();
 
- 					$menuSubItem->menu = $_['menu'];
 
- 					$menuSubItem->firm = $_['firm'];
 
- 					$menuSubItem->icon = $subItem['icon'];
 
- 					$menuSubItem->label = $subItem['label'];
 
- 					if(isset($subItem['url'])) $menuSubItem->url = str_replace(ROOT_URL.'/','',$subItem['url']);
 
- 					if(isset($subItem['target'])) $menuSubItem->target = $subItem['target'];
 
- 					if(isset($subItem['visibility'])) $menuSubItem->visibility = $subItem['visibility'];
 
- 					$menuSubItem->user = $myUser->can('navigation','configure') ? '' : $myUser->login;
 
- 					$menuSubItem->sort = $j;
 
- 					$menuSubItem->parent = $menuItem->id;
 
- 					$menuSubItem->slug = $menuItem->slug.'_'.slugify($menuSubItem->label);
 
- 					if(MenuItem::rowCount(array('slug'=>$menuSubItem->slug)) <0)
 
- 						$menuSubItem->slug .='_'.time();
 
- 					$menuSubItem->save();
 
- 					$menuItems[] = $menuSubItem->id;
 
- 				}
 
- 			} else {
 
- 				MenuItem::change(array('parent'=>NULL), array('parent'=>$item['id']));
 
- 			}
 
- 		}
 
- 		if(!empty($menuItems)) $parameters['id:NOT IN'] = implode(',', $menuItems);
 
- 	}
 
- 	MenuItem::delete($parameters);
 
- });
 
- Action::register('navigation_widget_load',function(&$response){
 
- 	global $myUser;
 
- 	User::check_access('navigation','read');
 
- 	Plugin::need('dashboard/DashboardWidget');
 
- 	$widget = DashboardWidget::current();
 
- 	if(empty($widget->data('title'))){
 
- 		$widget->title =  'Bloc Menu';
 
- 	}else{
 
- 		$widget->title =  '';
 
- 		$widget->icon = '';
 
- 	}
 
- 	if(!empty($widget->data('color'))) $widget->background = $widget->data('color');
 
- 	ob_start();
 
- 	require_once(__DIR__.SLASH.'widget.php');
 
- 	$widget->content = ob_get_clean();
 
- 	echo json_encode($widget);
 
- 	exit;
 
- });
 
- Action::register('navigation_widget_configure_save',function(&$response){
 
- 	global $myUser,$_;
 
- 	User::check_access('navigation','read');
 
- 	Plugin::need('dashboard/DashboardWidget');
 
- 	$widget = DashboardWidget::getById($_['id']);
 
- 	$url =  str_replace(ROOT_URL.'/','',$_['widget-url']);
 
- 	$widget->data('url',$url);
 
- 	$widget->data('redirect',$_['widget-redirect']);
 
- 	$widget->data('icon',$_['widget-icon']);
 
- 	$widget->data('title',$_['widget-title']);
 
- 	$widget->data('color',$_['widget-color']);
 
- 	$widget->save();
 
- });
 
- Action::register('navigation_widget_configure',function(&$response){
 
- 	global $myUser;
 
- 	User::check_access('navigation','read');
 
- 	Plugin::need('dashboard/DashboardWidget');
 
- 	$widget = DashboardWidget::current();
 
- 	ob_start();
 
- 	require_once(__DIR__.SLASH.'widget.configure.php');
 
- 	$content = ob_get_clean();
 
- 	echo $content;
 
- 	exit;
 
- });
 
- Action::register('navigation_widget_configure_autocomplete',function(&$response){
 
- 	global $myUser,$_;
 
- 	User::check_access('navigation','read');
 
- 	require_once(__DIR__.SLASH.'MenuItem.class.php');
 
- 	if(!$myUser->connected()) throw new Exception("Vous devez être connecté",401);
 
- 	if(empty($_['keyword'])) return;
 
- 	$rows = array();
 
- 	foreach(MenuItem::staticQuery('SELECT item.* FROM {{table}} item LEFT JOIN {{table}} menu ON item.menu=menu.id  WHERE item.label LIKE ? AND item.menu!=? AND menu.user=?',array('%'.$_['keyword'].'%',0,$myUser->login),true) as $menu){
 
- 		$row = $menu->toArray();
 
- 		$row['name'] = $row['label'];
 
- 		$rows[] = $row;
 
- 	}
 
- 	Plugin::callHook("menu_main", array(&$pages));
 
- 	foreach($pages as $page){
 
- 		if( strpos(slugify($page['label']), slugify($_["keyword"])) === false ) continue;
 
- 		$icon = isset($page['icon'])? $page['icon'] : 'far fa-bookmark';
 
- 		$row =  $page;
 
- 		$row['name'] = $page['label'];
 
- 		$rows[] = $row;
 
- 	}
 
- 	usort ($rows , function($a,$b){return $a['sort']>$b['sort']?-1:1;});
 
- 	$response['rows'] = $rows;
 
- });
 
 
  |