display success flash message after forking
authorChristian Weiske <cweiske@cweiske.de>
Thu, 8 May 2014 20:29:09 +0000 (22:29 +0200)
committerChristian Weiske <cweiske@cweiske.de>
Thu, 8 May 2014 20:29:09 +0000 (22:29 +0200)
data/templates/display-head.htm
data/templates/flashmessages.htm [new file with mode: 0644]
src/phorkie/FlashMessage.php [new file with mode: 0644]
www/display.php
www/fork-remote.php
www/fork.php

index ba1f467080d5beda58c1506d09cd17b047d4fb62..f610f84174fd05e1d4db70fc33e1b4fbec68e81d 100644 (file)
@@ -1,9 +1,4 @@
-{% if forksuccess %}
-<div class="alert alert-success">
- <a href="#" class="close" data-dismiss="alert">×</a>
- Paste has been successfully forked.
-</div>
-{% endif %}
+{% include 'flashmessages.htm' %}
 
 <h1>{{repo.getTitle}}</h1>
 <div class="row repo-info">
diff --git a/data/templates/flashmessages.htm b/data/templates/flashmessages.htm
new file mode 100644 (file)
index 0000000..3ea654a
--- /dev/null
@@ -0,0 +1,6 @@
+{% for msgdata in flashmessages %}
+<div class="alert alert-{{msgdata.type}}">
+ <a href="#" class="close" data-dismiss="alert">×</a>
+ {{msgdata.msg}}
+</div>
+{% endfor %}
\ No newline at end of file
diff --git a/src/phorkie/FlashMessage.php b/src/phorkie/FlashMessage.php
new file mode 100644 (file)
index 0000000..80b8824
--- /dev/null
@@ -0,0 +1,27 @@
+<?php
+namespace phorkie;
+
+class FlashMessage
+{
+    public static function save($msg, $type = 'success')
+    {
+        $_SESSION['flashmessages'][] = array(
+            'msg'  => $msg,
+            'type' => $type
+        );
+    }
+
+    public static function getAll()
+    {
+        if (!isset($_SESSION['flashmessages'])
+            || !is_array($_SESSION['flashmessages'])
+        ) {
+            return array();
+        }
+
+        $msgs = $_SESSION['flashmessages'];
+        unset($_SESSION['flashmessages']);
+        return $msgs;
+    }
+}
+?>
index a41f4a8e65df5af5d9ee4d83e29099d8477b80cd..be79e4bd3a5e99067ab88b448cac71340048a7b1 100644 (file)
@@ -21,6 +21,7 @@ render(
         'repo' => $repo,
         'dh'   => new \Date_HumanDiff(),
         'htmlhelper' => new HtmlHelper(),
+        'flashmessages' => FlashMessage::getAll(),
     )
 );
 ?>
index f41f98134b49b862445e2dac30cdc9e94d605e1f..096f432d34c08f15636195e430d748aec7303c2d 100644 (file)
@@ -26,6 +26,7 @@ if (isset($_REQUEST['remote_url'])) {
             $new = $forker->forkRemote(
                 $gitUrl['url'], $fr->getUrl(), $gitUrl['title']
             );
+            FlashMessage::save('Remote paste has been forked');
             redirect($new->getLink('display', null, true));
         } catch (\Exception $e) {
             $error = $e->getMessage();
index 352f8bc28352dfe881272f8f2e5e5fb66fdf1a71..cddf2bb516fdc4075f9c74b3fdfd9f9f15982a1c 100644 (file)
@@ -16,6 +16,6 @@ $repo->loadFromRequest();
 $forker = new Forker();
 $new    = $forker->forkLocal($repo);
 
-//FIXME: where to put fork source link?
+FlashMessage::save('Paste has been forked');
 redirect($new->getLink('display', null, true));
 ?>