X-Git-Url: https://git.cweiske.de/grauphel.git/blobdiff_plain/8ee6bfe97633d31c6b89cebbc434837eca04d6dd..e19fc06310e26dab3ec372fb01676a802fc02234:/controller/guicontroller.php?ds=sidebyside
diff --git a/controller/guicontroller.php b/controller/guicontroller.php
index 97a7f10..8ebea8c 100644
--- a/controller/guicontroller.php
+++ b/controller/guicontroller.php
@@ -59,7 +59,18 @@ class GuiController extends Controller
*/
public function index()
{
- $this->checkDeps();
+ try {
+ $this->checkDeps();
+ } catch (\Exception $e) {
+ $res = new TemplateResponse('grauphel', 'error');
+ $res->setParams(
+ array(
+ 'message' => $e->getMessage(),
+ 'code' => $e->getCode(),
+ )
+ );
+ return $res;
+ }
$res = new TemplateResponse('grauphel', 'index');
$res->setParams(
@@ -85,21 +96,50 @@ class GuiController extends Controller
$note = $this->getNotes()->load($guid, false);
if ($note === null) {
- return new ErrorResponse('Note does not exist');
+ $res = new ErrorResponse('Note does not exist');
+ $res->setStatus(\OCP\AppFramework\Http::STATUS_NOT_FOUND);
+ return $res;
}
- $converter = new \OCA\Grauphel\Lib\Converter\Html();
+ $converter = new \OCA\Grauphel\Converter\Html();
$converter->internalLinkHandler = array($this, 'noteLinkHandler');
+
+ try {
+ $contentHtml = $converter->convert($note->{'note-content'});
+ } catch (\OCA\Grauphel\Converter\Exception $e) {
+ $contentHtml = '
'
+ . '
There was an error converting the note to HTML:
'
+ . '
' . htmlspecialchars($e->getMessage()) . '
'
+ . '
Please open a bug report at'
+ . ' '
+ . 'github.com/cweiske/grauphel/issues'
+ . ' and attach the XML version of the note.'
+ . '
';
+ }
+
$res->setParams(
array(
'note' => $note,
- 'note-content' => $converter->convert(
- $note->{'note-content'}
- ),
+ 'note-content' => $contentHtml,
+ 'links' => array(
+ 'json' => $this->urlGen->linkToRoute(
+ 'grauphel.api.note', array(
+ 'guid' => $guid, 'username' => $this->user->getUid()
+ )
+ ),
+ 'xml' => $this->urlGen->linkToRoute(
+ 'grauphel.notes.xml', array('guid' => $guid)
+ ),
+ )
)
);
- $this->addNavigation($res);
+ $selectedRawtag = 'grauphel:special:untagged';
+ if (count($note->tags) > 0) {
+ $selectedRawtag = $note->tags[0];
+ }
+
+ $this->addNavigation($res, $selectedRawtag);
return $res;
}
@@ -122,7 +162,7 @@ class GuiController extends Controller
*/
public function tag($rawtag)
{
- $notes = $this->getNotes()->loadNotesOverview(null, $rawtag);
+ $notes = $this->getNotes()->loadNotesOverview(null, $rawtag, true);
usort(
$notes,
function($noteA, $noteB) {
@@ -130,6 +170,17 @@ class GuiController extends Controller
}
);
+ foreach ($notes as &$note) {
+ $diffInDays = intval(
+ (time() - strtotime($note['last-change-date'])) / 86400
+ );
+ $value = 0 + $diffInDays;
+ if ($value > 160) {
+ $value = 160;
+ }
+ $note['dateColor'] = '#' . str_repeat(sprintf('%02X', $value), 3);
+ }
+
$res = new TemplateResponse('grauphel', 'tag');
$res->setParams(
array(
@@ -233,6 +284,7 @@ class GuiController extends Controller
'href' => $this->urlGen->linkToRoute(
'grauphel.gui.tag', array('rawtag' => $rawtag)
),
+ 'selected' => $rawtag == $selectedRawtag,
);
}
}
@@ -262,7 +314,7 @@ class GuiController extends Controller
protected function checkDeps()
{
if (!class_exists('OAuthProvider')) {
- throw new \Exception('PHP extension "oauth" is required');
+ throw new \Exception('PHP extension "oauth" is required', 1001);
}
}