mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-05 21:49:28 +01:00
* making opend tabs and active tab persistent over sessions and reloads
This commit is contained in:
parent
5823f0a569
commit
8da9e9be85
@ -441,6 +441,7 @@ class jdots_framework extends egw_framework
|
||||
{
|
||||
egw_time::setUserPrefs($tz); // throws exception, if tz is invalid
|
||||
|
||||
$GLOBALS['egw']->preferences->read_repository();
|
||||
$GLOBALS['egw']->preferences->add('common','tz',$tz);
|
||||
$GLOBALS['egw']->preferences->save_repository();
|
||||
}
|
||||
@ -637,6 +638,34 @@ class jdots_framework extends egw_framework
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Ajax callback which is called whenever a previously opened tab is closed or
|
||||
* opened.
|
||||
*
|
||||
* @param $tablist is an array which contains each tab as an associative array
|
||||
* with the keys 'appName' and 'active'
|
||||
*/
|
||||
public function ajax_tab_changed_state($tablist)
|
||||
{
|
||||
$tabs = array();
|
||||
foreach($tablist as $data)
|
||||
{
|
||||
$tabs[] = $data['appName'];
|
||||
if ($data['active']) $active = $data['appName'];
|
||||
}
|
||||
$tabs = implode(',',$tabs);
|
||||
|
||||
if ($tabs != $GLOBALS['egw_info']['user']['preferences']['common']['open_tabs'] ||
|
||||
$active != $GLOBALS['egw_info']['user']['preferences']['common']['active_tab'])
|
||||
{
|
||||
error_log(__METHOD__.'('.array2string($tablist).") storing common prefs: open_tabs='$tabs', active_tab='$active'");
|
||||
$GLOBALS['egw']->preferences->read_repository();
|
||||
$GLOBALS['egw']->preferences->change('common', 'open_tabs', $tabs);
|
||||
$GLOBALS['egw']->preferences->change('common', 'active_tab', $active);
|
||||
$GLOBALS['egw']->preferences->save_repository(true);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Ajax callback to store opened/closed status of menu's within one apps sidebox
|
||||
*
|
||||
@ -751,6 +780,20 @@ class jdots_framework extends egw_framework
|
||||
{
|
||||
unset($apps['sitemgr-link']);
|
||||
}
|
||||
|
||||
// Restore Tabs
|
||||
foreach(explode(',',$GLOBALS['egw_info']['user']['preferences']['common']['open_tabs']) as $n => $app)
|
||||
{
|
||||
if (isset($apps[$app])) // user might no longer have app rights
|
||||
{
|
||||
$apps[$app]['opened'] = $n;
|
||||
if ($GLOBALS['egw_info']['user']['preferences']['common']['active_tab'] == $app)
|
||||
{
|
||||
$apps[$app]['active'] = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!($default_app = $GLOBALS['egw_info']['user']['preferences']['common']['default_app']))
|
||||
{
|
||||
$default_app = 'home';
|
||||
|
@ -40,6 +40,9 @@ function egw_fw(_sidemenuId, _tabsId, _splitterId, _webserverUrl, _sideboxSizeCa
|
||||
this.sideboxSizeCallback = _sideboxSizeCallback;
|
||||
window.egw_webserverUrl = _webserverUrl;
|
||||
|
||||
this.serializedTabState = '';
|
||||
this.notifyTabChangeEnabled = false;
|
||||
|
||||
this.sidemenuUi = null;
|
||||
this.tabsUi = null;
|
||||
|
||||
@ -209,6 +212,9 @@ egw_fw.prototype.setActiveApp = function(_app)
|
||||
if (_app.tab)
|
||||
{
|
||||
this.tabsUi.showTab(_app.tab);
|
||||
|
||||
//Going to a new tab changes the tab state
|
||||
this.notifyTabChange(_app.tab);
|
||||
}
|
||||
|
||||
//Resize the scroll area...
|
||||
@ -274,6 +280,8 @@ egw_fw.prototype.tabCloseClickCallback = function(_sender)
|
||||
//At least one tab must stay open
|
||||
if (tabsUi.tabs.length > 1)
|
||||
{
|
||||
this.tag.parentFw.notifyTabChangeEnabled = false;
|
||||
|
||||
tabsUi.removeTab(this);
|
||||
app.tab = null;
|
||||
app.browser = null;
|
||||
@ -283,6 +291,10 @@ egw_fw.prototype.tabCloseClickCallback = function(_sender)
|
||||
|
||||
//Set the active application to the application of the currently active tab
|
||||
app.parentFw.setActiveApp(tabsUi.activeTab.tag);
|
||||
|
||||
this.tag.parentFw.notifyTabChangeEnabled = true;
|
||||
|
||||
this.tag.parentFw.notifyTabChange();
|
||||
}
|
||||
|
||||
tabsUi.setCloseable(tabsUi.tabs.length > 1);
|
||||
@ -336,6 +348,45 @@ egw_fw.prototype.applicationClickCallback = function(_sender)
|
||||
this.tag.parentFw.applicationTabNavigate(this.tag, this.tag.indexUrl);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Creates an ordered list with all opened tabs and whether the tab is currently active
|
||||
*/
|
||||
egw_fw.prototype.assembleTabList = function()
|
||||
{
|
||||
var result = new Array;
|
||||
for (var i = 0; i < this.tabsUi.tabs.length; i++)
|
||||
{
|
||||
var tab = this.tabsUi.tabs[i];
|
||||
result[i] = {
|
||||
'appName': tab.tag.appName,
|
||||
'active': tab == this.tabsUi.activeTab
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
egw_fw.prototype.notifyTabChange = function()
|
||||
{
|
||||
if (this.notifyTabChangeEnabled)
|
||||
{
|
||||
//Send the current tab list to the server
|
||||
var data = this.assembleTabList();
|
||||
|
||||
//Serialize the tab list and check whether it really has changed since the last
|
||||
//submit
|
||||
var serialized = egw_json_encode(data);
|
||||
if (serialized != this.serializedTabState)
|
||||
{
|
||||
this.serializedTabState = serialized;
|
||||
|
||||
var request = new egw_json_request("home.jdots_framework.ajax_tab_changed_state", [data]);
|
||||
request.sendRequest();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks whether the application already owns a tab and creates one if it doesn't exist
|
||||
*/
|
||||
@ -358,16 +409,18 @@ egw_fw.prototype.createApplicationTab = function(_app)
|
||||
*
|
||||
* @param egw_fw_class_application _app
|
||||
* @param string _url optional url, default index page of app
|
||||
* @param bool _hidden specifies, whether the application should be set active
|
||||
* after opening the tab
|
||||
*/
|
||||
egw_fw.prototype.applicationTabNavigate = function(_app, _url, _useIframe)
|
||||
egw_fw.prototype.applicationTabNavigate = function(_app, _url, _useIframe, _hidden)
|
||||
{
|
||||
//Create the tab for that application
|
||||
this.createApplicationTab(_app);
|
||||
|
||||
if (typeof _url == 'undefined')
|
||||
if (typeof _url == 'undefined' || _url == null)
|
||||
_url = _app.indexUrl;
|
||||
|
||||
if (typeof _useIframe == 'undefined')
|
||||
if (typeof _useIframe == 'undefined' || _useIframe == null)
|
||||
{
|
||||
if (!_url.match(/menuaction=/))
|
||||
{
|
||||
@ -389,7 +442,15 @@ egw_fw.prototype.applicationTabNavigate = function(_app, _url, _useIframe)
|
||||
|
||||
_app.browser.browse(_url, true);//_useIframe);
|
||||
|
||||
this.setActiveApp(_app);
|
||||
//
|
||||
if (typeof _hidden == 'undefined' || !_hidden)
|
||||
{
|
||||
this.setActiveApp(_app);
|
||||
}
|
||||
else
|
||||
{
|
||||
this.notifyTabChange();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -436,6 +497,8 @@ egw_fw.prototype.parseAppFromUrl = function(_url)
|
||||
egw_fw.prototype.loadApplicationsCallback = function(apps)
|
||||
{
|
||||
var defaultApp = null;
|
||||
var restore = [];
|
||||
var activeTabIdx = 0;
|
||||
|
||||
//Iterate through the application array returned
|
||||
for (var i = 0; i < apps.length; i++)
|
||||
@ -459,11 +522,20 @@ egw_fw.prototype.loadApplicationsCallback = function(apps)
|
||||
}
|
||||
|
||||
//If this entry is the default entry, show it using the click callback
|
||||
if (app.isDefault && (app.isDefault === true))
|
||||
if (app.isDefault && (app.isDefault === true) && (restore.length == 0))
|
||||
{
|
||||
defaultApp = appData;
|
||||
}
|
||||
|
||||
//If the opened field is set, add the application to the restore array.
|
||||
if ((typeof app.opened != 'undefined') && (app.opened !== false))
|
||||
{
|
||||
defaultApp = null;
|
||||
restore[app.opened] = appData;
|
||||
if (app.active)
|
||||
activeTabIdx = app.opened;
|
||||
}
|
||||
|
||||
this.applications[appData.appName] = appData;
|
||||
}
|
||||
|
||||
@ -480,7 +552,19 @@ egw_fw.prototype.loadApplicationsCallback = function(apps)
|
||||
this.applicationTabNavigate(defaultApp);
|
||||
}
|
||||
|
||||
// restore the already opened tabs
|
||||
if (restore.length > 0)
|
||||
{
|
||||
for (var i = 0; i < restore.length; i++)
|
||||
//The last parameter is the so called "hidden" parameter
|
||||
this.applicationTabNavigate(restore[i], null, null, i != activeTabIdx);
|
||||
}
|
||||
|
||||
this.scrollAreaUi.update();
|
||||
|
||||
//Set the current state of the tabs and activate TabChangeNotification.
|
||||
this.serializedTabState = egw_json_encode(this.assembleTabList());
|
||||
this.notifyTabChangeEnabled = true;
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user