mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-08 23:59:28 +00:00
70d865a703
- NavigationWidget.css: added margin-right to icons in the header menu - FilterWidget.js: function sideMenuHook now calls the renamed refreshSideMenuHook function - NavigationWidget.js: - Added comments - Renamed function _printNavItem to _buildLeftMenuStructure - Added funtion _buildHeaderMenuStructure to build the header menu - Added function refreshSideMenuHook to call a controller that will refresh the left menu array and GUI - infocenterPersonDataset.js: - Renamed function refreshSideMenu to refreshSideMenuHook - Now this function calls the NavigationWidget -> refreshSideMenuHook function
244 lines
5.9 KiB
JavaScript
244 lines
5.9 KiB
JavaScript
/**
|
|
* FH-Complete
|
|
*
|
|
* @package
|
|
* @author
|
|
* @copyright Copyright (c) 2016 fhcomplete.org
|
|
* @license GPLv3
|
|
* @link https://fhcomplete.org
|
|
* @since Version 1.0.0
|
|
*/
|
|
|
|
/**
|
|
* FHC_NavigationWidget
|
|
*/
|
|
var FHC_NavigationWidget = {
|
|
//------------------------------------------------------------------------------------------------------------------
|
|
// Public methods
|
|
|
|
/**
|
|
* Renders the header menu (top horizontal menu)
|
|
*/
|
|
renderHeaderMenu: function() {
|
|
|
|
// Retrives the header menu array
|
|
FHC_AjaxClient.ajaxCallGet(
|
|
'system/Navigation/header',
|
|
{
|
|
navigation_page: FHC_NavigationWidget._getNavigationWidgetCalled()
|
|
},
|
|
{
|
|
successCallback: function(data, textStatus, jqXHR) {
|
|
|
|
if (FHC_AjaxClient.hasData(data))
|
|
{
|
|
var strHeaderMenu = '';
|
|
|
|
jQuery.each(FHC_AjaxClient.getData(data), function(i, e) {
|
|
if (e != null) strHeaderMenu += FHC_NavigationWidget._buildHeaderMenuStructure(e);
|
|
});
|
|
|
|
$(".menu-header-items").html(strHeaderMenu);
|
|
}
|
|
}
|
|
}
|
|
);
|
|
},
|
|
|
|
/**
|
|
* Renders the side left menu
|
|
*/
|
|
renderSideMenu: function() {
|
|
|
|
// Retrives the left menu array
|
|
FHC_AjaxClient.ajaxCallGet(
|
|
'system/Navigation/menu',
|
|
{
|
|
navigation_page: FHC_NavigationWidget._getNavigationWidgetCalled()
|
|
},
|
|
{
|
|
successCallback: function(data, textStatus, jqXHR) {
|
|
|
|
if (FHC_AjaxClient.hasData(data))
|
|
{
|
|
FHC_NavigationWidget._printCollapseIcon(); // Applies bootstrap SB Admin 2 theme elements to the left menu
|
|
|
|
var strLeftMenu = '';
|
|
|
|
// Builds left menu
|
|
jQuery.each(FHC_AjaxClient.getData(data), function(i, e) {
|
|
if (e != null) strLeftMenu += FHC_NavigationWidget._buildLeftMenuStructure(e);
|
|
});
|
|
|
|
$("#side-menu").html(strLeftMenu); // render left menu
|
|
$("#side-menu").metisMenu(); // call the Bootstrap SB Admin 2 theme renderer
|
|
}
|
|
|
|
// If this global function is present...
|
|
if (typeof sideMenuHook == 'function')
|
|
{
|
|
sideMenuHook(); // ...then call it
|
|
}
|
|
}
|
|
}
|
|
);
|
|
},
|
|
|
|
/**
|
|
* Calls URL to retrive a refreshed menu array
|
|
*/
|
|
refreshSideMenuHook: function(url) {
|
|
|
|
FHC_AjaxClient.ajaxCallGet(
|
|
url,
|
|
{
|
|
navigation_page: FHC_NavigationWidget._getNavigationWidgetCalled()
|
|
},
|
|
{
|
|
successCallback: function(data, textStatus, jqXHR) {
|
|
FHC_NavigationWidget.renderSideMenu();
|
|
},
|
|
errorCallback: function(jqXHR, textStatus, errorThrown) {
|
|
alert(textStatus);
|
|
}
|
|
}
|
|
);
|
|
},
|
|
|
|
//------------------------------------------------------------------------------------------------------------------
|
|
// Private methods
|
|
|
|
/**
|
|
* Applies bootstrap SB Admin 2 theme elements to the left menu
|
|
*/
|
|
_printCollapseIcon: function() {
|
|
// Hiding/showing navigation menu - works only with sb admin 2 template!!
|
|
if(!$("#collapseicon").length)
|
|
$("#side-menu").parent().append(
|
|
'<div id="collapseicon" title="hide Menu" class="text-right" style="cursor: pointer; color: #337ab7">' +
|
|
' <i class="fa fa-angle-double-left fa-fw"></i>' +
|
|
'</div>'
|
|
);
|
|
|
|
$("#collapseicon").click(function() {
|
|
$("#page-wrapper").css('margin-left', '0px');
|
|
$("#side-menu").hide();
|
|
$("#collapseicon").hide();
|
|
$("#collapseinicon").show();
|
|
});
|
|
|
|
$("#collapseinicon").click(function() {
|
|
$("#page-wrapper").css('margin-left', '250px');
|
|
$("#side-menu").show();
|
|
$("#collapseicon").show();
|
|
$("#collapseinicon").hide();
|
|
});
|
|
},
|
|
|
|
/**
|
|
* Recursively builds the header menu structure
|
|
*/
|
|
_buildHeaderMenuStructure: function(item) {
|
|
|
|
var strHeaderMenu = '';
|
|
|
|
if (item['icon'] != 'undefined' && item['icon'] != '')
|
|
{
|
|
strHeaderMenu += '<i class="navbar-brand-icon fa fa-' + item['icon'] + ' fa-fw"></i>';
|
|
}
|
|
|
|
var target = '';
|
|
if (item['target'] != null) target = item['target'];
|
|
|
|
strHeaderMenu += '<a class="navbar-brand" href="' + item['link'] + '" target="' + target + '">' + item['description'] + '</a>';
|
|
|
|
return strHeaderMenu;
|
|
},
|
|
|
|
/**
|
|
* Recursively builds the left menu structure
|
|
*/
|
|
_buildLeftMenuStructure: function(item, depth = 1) {
|
|
|
|
strLeftMenu = "";
|
|
var expanded = item['expand'] != null && item['expand'] === true ? ' active' : '';
|
|
|
|
strLeftMenu += '<li class="' + expanded + '">';
|
|
|
|
if (item['subscriptLinkClass'] != null && item['subscriptDescription'] != null)
|
|
{
|
|
strLeftMenu += '<span>';
|
|
}
|
|
|
|
var target = '';
|
|
if (item['target'] != null) target = item['target'];
|
|
|
|
strLeftMenu += '<a href="' + item['link'] + '"' + expanded + ' target="' + target + '">';
|
|
|
|
if (item['icon'] != 'undefined')
|
|
{
|
|
strLeftMenu += '<i class="fa fa-' + item['icon'] + ' fa-fw"></i> ';
|
|
}
|
|
|
|
strLeftMenu += item['description'];
|
|
|
|
if (item['children'] != null && Object.keys(item['children']).length > 0)
|
|
{
|
|
strLeftMenu += '<span class="fa arrow"></span>';
|
|
}
|
|
|
|
strLeftMenu += '</a>';
|
|
|
|
if (item['subscriptLinkClass'] != null && item['subscriptDescription'] != null)
|
|
{
|
|
strLeftMenu += '<a class="' + item['subscriptLinkClass'] + ' menuSubscriptLink" value="' + item['subscriptLinkValue'] + '" href="#">' +
|
|
' (' + item['subscriptDescription'] + ')' +
|
|
'</a>';
|
|
strLeftMenu += '</span>';
|
|
}
|
|
|
|
if (item['children'] != null && Object.keys(item['children']).length > 0)
|
|
{
|
|
var level = '';
|
|
if (depth === 1)
|
|
{
|
|
level = 'second';
|
|
}
|
|
else if (depth > 1)
|
|
{
|
|
level = 'third';
|
|
}
|
|
|
|
strLeftMenu += '<ul class="nav nav-' + level + '-level" ' + expanded + '>';
|
|
|
|
jQuery.each(item['children'], function(i, e) {
|
|
if (e != null) strLeftMenu += FHC_NavigationWidget._buildLeftMenuStructure(e, ++depth);
|
|
});
|
|
|
|
strLeftMenu += '</ul>';
|
|
}
|
|
|
|
strLeftMenu += '</li>';
|
|
|
|
return strLeftMenu;
|
|
},
|
|
|
|
/**
|
|
* Returns the URI of the caller
|
|
*/
|
|
_getNavigationWidgetCalled: function() {
|
|
return FHC_JS_DATA_STORAGE_OBJECT.called_path + "/" + FHC_JS_DATA_STORAGE_OBJECT.called_method;
|
|
}
|
|
};
|
|
|
|
/**
|
|
* When JQuery is up
|
|
*/
|
|
$(document).ready(function() {
|
|
|
|
FHC_NavigationWidget.renderHeaderMenu();
|
|
|
|
FHC_NavigationWidget.renderSideMenu();
|
|
|
|
});
|