diff options
author | Robin Appelman <icewind@owncloud.com> | 2012-10-26 20:12:14 +0200 |
---|---|---|
committer | Robin Appelman <icewind@owncloud.com> | 2012-10-26 20:13:24 +0200 |
commit | da57fbc93a6df7f477bf680f1a97c1b43075f3b5 (patch) | |
tree | c602edd73b75e136c2285f474e12d8712b05019d | |
parent | d428d72dabf1d0f451f5dedc8e7e5cc654e04ffb (diff) | |
download | nextcloud-server-da57fbc93a6df7f477bf680f1a97c1b43075f3b5.tar.gz nextcloud-server-da57fbc93a6df7f477bf680f1a97c1b43075f3b5.zip |
show/hide navigation entries after enabling/disabling app
-rw-r--r-- | core/ajax/navigationdetect.php | 22 | ||||
-rw-r--r-- | settings/js/apps.js | 34 |
2 files changed, 56 insertions, 0 deletions
diff --git a/core/ajax/navigationdetect.php b/core/ajax/navigationdetect.php new file mode 100644 index 00000000000..c7d0bd38dbc --- /dev/null +++ b/core/ajax/navigationdetect.php @@ -0,0 +1,22 @@ +<?php + +$RUNTIME_NOAPPS = true; + +require_once '../../lib/base.php'; + +OC_Util::checkAdminUser(); +OCP\JSON::callCheck(); + +$app = $_GET['app']; + +//load the one app and see what it adds to the navigation +OC_App::loadApp($app); + +$navigation = OC_App::getNavigation(); + +$navIds = array(); +foreach ($navigation as $nav) { + $navIds[] = $nav['id']; +} + +OCP\JSON::success(array('nav_ids' => array_values($navIds), 'nav_entries' => $navigation)); diff --git a/settings/js/apps.js b/settings/js/apps.js index 8de95100c4c..e45abf9b3dd 100644 --- a/settings/js/apps.js +++ b/settings/js/apps.js @@ -51,6 +51,7 @@ OC.Settings.Apps = OC.Settings.Apps || { } else { element.data('active',false); + OC.Settings.Apps.removeNavigation(appid); element.val(t('settings','Enable')); } },'json'); @@ -61,6 +62,7 @@ OC.Settings.Apps = OC.Settings.Apps || { OC.dialogs.alert('Error while enabling app','Error'); } else { + OC.Settings.Apps.addNavigation(appid); element.data('active',true); element.val(t('settings','Disable')); } @@ -87,6 +89,38 @@ OC.Settings.Apps = OC.Settings.Apps || { applist.last().after(app); } return app; + }, + removeNavigation: function(appid){ + $.getJSON(OC.filePath('core','ajax','navigationdetect.php'), {app: appid}).done(function(response){ + if(response.status === 'success'){ + var navIds=response.nav_ids; + for(var i=0; i< navIds.length; i++){ + $('#apps').children('li[data-id="'+navIds[i]+'"]').remove(); + } + } + }); + }, + addNavigation: function(appid){ + $.getJSON(OC.filePath('core','ajax','navigationdetect.php'), {app: appid}).done(function(response){ + if(response.status === 'success'){ + var navEntries=response.nav_entries; + for(var i=0; i< navEntries.length; i++){ + var entry = navEntries[i]; + var container = $('#apps'); + + if(container.children('li[data-id="'+entry.id+'"]').length === 0){ + var li=$('<li></li>'); + li.attr('data-id', entry.id); + var a=$('<a></a>'); + a.attr('style', 'background-image: url('+entry.icon+')'); + a.text(entry.name); + a.attr('href', entry.href); + li.append(a); + container.append(li); + } + } + } + }); } }; |