X-Git-Url: https://git.cweiske.de/grauphel.git/blobdiff_plain/f7ecfa21088175bc236b1136c1a4b2aa2488f37c..21e7415fe5a418ef6dd7f29d3749b11cc9adaa7d:/controller/guicontroller.php diff --git a/controller/guicontroller.php b/controller/guicontroller.php index 2c05750..1a4d023 100644 --- a/controller/guicontroller.php +++ b/controller/guicontroller.php @@ -59,20 +59,74 @@ class GuiController extends Controller $this->checkDeps(); $res = new TemplateResponse('grauphel', 'index'); - $res->setParams(array('apiurl' => $this->getApiUrl())); + $res->setParams( + array( + 'apiroot' => $this->getApiRootUrl(), + 'apiurl' => $this->urlGen->linkToRoute('grauphel.api.index') + ) + ); $this->addNavigation($res); $this->addStats($res); return $res; } - protected function addNavigation(TemplateResponse $res) + /** + * Show all notes of a tag + * + * @NoAdminRequired + * @NoCSRFRequired + */ + public function tag($rawtag) + { + $notes = $this->getNotes()->loadNotesOverview(null, $rawtag); + + $res = new TemplateResponse('grauphel', 'tag'); + $res->setParams( + array( + 'tag' => $this->getPrettyTagName($rawtag), + 'rawtag' => $rawtag, + 'notes' => $notes, + ) + ); + $this->addNavigation($res, $rawtag); + + return $res; + } + + protected function addNavigation(TemplateResponse $res, $selectedRawtag = null) { $nav = new \OCP\Template('grauphel', 'appnavigation', ''); - $nav->assign('apiurl', $this->getApiUrl()); + $nav->assign('apiroot', $this->getApiRootUrl()); $params = $res->getParams(); $params['appNavigation'] = $nav; $res->setParams($params); + + if ($this->user === null) { + return; + } + + $rawtags = $this->getNotes()->getTags(); + sort($rawtags); + array_unshift( + $rawtags, + 'grauphel:special:all', 'grauphel:special:untagged' + ); + + $tags = array(); + foreach ($rawtags as $rawtag) { + $name = $this->getPrettyTagName($rawtag); + if ($name !== false) { + $tags[] = array( + 'name' => $name, + 'id' => $rawtag, + 'href' => $this->urlGen->linkToRoute( + 'grauphel.gui.tag', array('rawtag' => $rawtag) + ), + ); + } + } + $nav->assign('tags', $tags); } protected function addStats(TemplateResponse $res) @@ -82,12 +136,12 @@ class GuiController extends Controller } $username = $this->user->getUid(); - $notes = new \OCA\Grauphel\Lib\NoteStorage($this->urlGen); + $notes = $this->getNotes(); $tokens = new \OCA\Grauphel\Lib\TokenStorage(); $nav = new \OCP\Template('grauphel', 'indexStats', ''); - $nav->assign('notes', count($notes->loadNotesOverview($username))); - $nav->assign('syncrev', $notes->loadSyncData($username)->latestSyncRevision); + $nav->assign('notes', count($notes->loadNotesOverview())); + $nav->assign('syncrev', $notes->loadSyncData()->latestSyncRevision); $nav->assign('tokens', count($tokens->loadForUser($username, 'access'))); $params = $res->getParams(); @@ -102,7 +156,7 @@ class GuiController extends Controller } } - protected function getApiUrl() + protected function getApiRootUrl() { //we need to remove the trailing / for tomdroid and conboy return rtrim( @@ -112,5 +166,23 @@ class GuiController extends Controller '/' ); } + + protected function getNotes() + { + $username = $this->user->getUid(); + $notes = new \OCA\Grauphel\Lib\NoteStorage($this->urlGen); + $notes->setUsername($username); + return $notes; + } + + protected function getPrettyTagName($rawtag) + { + if (substr($rawtag, 0, 16) == 'system:notebook:') { + return substr($rawtag, 16); + } else if (substr($rawtag, 0, 17) == 'grauphel:special:') { + return '*' . substr($rawtag, 17) . '*'; + } + return false; + } } ?>