summaryrefslogtreecommitdiffstats
path: root/settings/controller
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2015-10-26 23:07:06 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2015-10-26 23:07:06 +0100
commit0a9150b2dadaf0ffd5ea096312683ccb792ae50d (patch)
tree9d17cd82b2f52264da3891af885552d1a5d98fad /settings/controller
parent40ba8d267f57eae983f53dfa4b9195b5f134ff4a (diff)
parent2849f19cfe606d5b76077c7d1dd50db0835a5121 (diff)
downloadnextcloud-server-0a9150b2dadaf0ffd5ea096312683ccb792ae50d.tar.gz
nextcloud-server-0a9150b2dadaf0ffd5ea096312683ccb792ae50d.zip
Merge pull request #19813 from owncloud/stay-on-apps-category-refresh
Improve settings/apps page
Diffstat (limited to 'settings/controller')
-rw-r--r--settings/controller/appsettingscontroller.php47
1 files changed, 41 insertions, 6 deletions
diff --git a/settings/controller/appsettingscontroller.php b/settings/controller/appsettingscontroller.php
index f5cb043da20..bde00df062f 100644
--- a/settings/controller/appsettingscontroller.php
+++ b/settings/controller/appsettingscontroller.php
@@ -42,6 +42,8 @@ use OCP\IConfig;
* @package OC\Settings\Controller
*/
class AppSettingsController extends Controller {
+ const CAT_ENABLED = 0;
+ const CAT_DISABLED = 1;
/** @var \OCP\IL10N */
private $l10n;
@@ -95,12 +97,41 @@ class AppSettingsController extends Controller {
}
/**
+ * @param string|int $category
+ * @return int
+ */
+ protected function getCategory($category) {
+ if (is_string($category)) {
+ foreach ($this->listCategories() as $cat) {
+ if (isset($cat['ident']) && $cat['ident'] === $category) {
+ $category = (int) $cat['id'];
+ break;
+ }
+ }
+
+ // Didn't find the category, falling back to enabled
+ if (is_string($category)) {
+ $category = self::CAT_ENABLED;
+ }
+ }
+ return (int) $category;
+ }
+
+ /**
* @NoCSRFRequired
+ * @param string $category
* @return TemplateResponse
*/
- public function viewApps() {
+ public function viewApps($category = '') {
+ $categoryId = $this->getCategory($category);
+ if ($categoryId === self::CAT_ENABLED) {
+ // Do not use an arbitrary input string, because we put the category in html
+ $category = 'enabled';
+ }
+
$params = [];
$params['experimentalEnabled'] = $this->config->getSystemValue('appstore.experimental.enabled', false);
+ $params['category'] = $category;
$this->navigationManager->setActiveEntry('core_apps');
$templateResponse = new TemplateResponse($this->appName, 'apps', $params, 'user');
@@ -121,8 +152,8 @@ class AppSettingsController extends Controller {
return $this->cache->get('listCategories');
}
$categories = [
- ['id' => 0, 'displayName' => (string)$this->l10n->t('Enabled')],
- ['id' => 1, 'displayName' => (string)$this->l10n->t('Not enabled')],
+ ['id' => self::CAT_ENABLED, 'ident' => 'enabled', 'displayName' => (string)$this->l10n->t('Enabled')],
+ ['id' => self::CAT_DISABLED, 'ident' => 'disabled', 'displayName' => (string)$this->l10n->t('Not enabled')],
];
if($this->ocsClient->isAppStoreEnabled()) {
@@ -130,9 +161,12 @@ class AppSettingsController extends Controller {
$ocs = $this->ocsClient->getCategories(\OC_Util::getVersion());
if ($ocs) {
foreach($ocs as $k => $v) {
+ $name = str_replace('ownCloud ', '', $v);
+ $ident = str_replace(' ', '-', urlencode(strtolower($name)));
$categories[] = [
'id' => $k,
- 'displayName' => str_replace('ownCloud ', '', $v)
+ 'ident' => $ident,
+ 'displayName' => $name,
];
}
}
@@ -146,12 +180,13 @@ class AppSettingsController extends Controller {
/**
* Get all available apps in a category
*
- * @param int $category
+ * @param string $category
* @param bool $includeUpdateInfo Should we check whether there is an update
* in the app store?
* @return array
*/
- public function listApps($category = 0, $includeUpdateInfo = true) {
+ public function listApps($category = '', $includeUpdateInfo = true) {
+ $category = $this->getCategory($category);
$cacheName = 'listApps-' . $category . '-' . (int) $includeUpdateInfo;
if(!is_null($this->cache->get($cacheName))) {