]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
move inbox notice list to repeat plugin
authorEvan Prodromou <evan@status.net>
Thu, 10 Dec 2009 18:34:11 +0000 (13:34 -0500)
committerEvan Prodromou <evan@status.net>
Thu, 10 Dec 2009 18:34:11 +0000 (13:34 -0500)
actions/all.php
plugins/Repeat/inboxnoticelist.php [new file with mode: 0644]

index 2c96298fafd41e8582ba56c7acaf3fe5c918ead8..08fbacaef19bee14ca851999c1922208ba521726 100644 (file)
@@ -144,7 +144,7 @@ class AllAction extends ProfileAction
 
     function showContent()
     {
-        $nl = new InboxNoticeList($this->notice, $this->user, $this);
+        $nl = new NoticeList($this->notice, $this->user, $this);
 
         $cnt = $nl->show();
 
@@ -168,87 +168,3 @@ class AllAction extends ProfileAction
         }
     }
 }
-
-class InboxNoticeList extends NoticeList
-{
-    var $owner = null;
-
-    function __construct($notice, $owner, $out=null)
-    {
-        parent::__construct($notice, $out);
-        $this->owner  = $owner;
-    }
-
-    function newListItem($notice)
-    {
-        return new InboxNoticeListItem($notice, $this->owner, $this->out);
-    }
-}
-
-class InboxNoticeListItem extends NoticeListItem
-{
-    var $owner = null;
-    var $ib    = null;
-
-    function __construct($notice, $owner, $out=null)
-    {
-        parent::__construct($notice, $out);
-        $this->owner = $owner;
-
-        $this->ib = Notice_inbox::pkeyGet(array('user_id' => $owner->id,
-                                                'notice_id' => $notice->id));
-    }
-
-    function showAuthor()
-    {
-        parent::showAuthor();
-        if ($this->ib->source == NOTICE_INBOX_SOURCE_FORWARD) {
-            $this->out->element('span', 'forward', _('Fwd'));
-        }
-    }
-
-    function showEnd()
-    {
-        if ($this->ib->source == NOTICE_INBOX_SOURCE_FORWARD) {
-
-            $forward = new Forward();
-
-            // FIXME: scary join!
-
-            $forward->query('SELECT profile_id '.
-                            'FROM forward JOIN subscription ON forward.profile_id = subscription.subscribed '.
-                            'WHERE subscription.subscriber = ' . $this->owner->id . ' '.
-                            'AND forward.notice_id = ' . $this->notice->id . ' '.
-                            'ORDER BY forward.created ');
-
-            $n = 0;
-
-            $firstForwarder = null;
-
-            while ($forward->fetch()) {
-                if (empty($firstForwarder)) {
-                    $firstForwarder = Profile::staticGet('id', $forward->profile_id);
-                }
-                $n++;
-            }
-
-            $forward->free();
-            unset($forward);
-
-            $this->out->elementStart('span', 'forwards');
-
-            $link = XMLStringer::estring('a', array('href' => $firstForwarder->profileurl),
-                                         $firstForwarder->nickname);
-
-            if ($n == 1) {
-                $this->out->raw(sprintf(_('Forwarded by %s'), $link));
-            } else {
-                // XXX: use that cool ngettext thing
-                $this->out->raw(sprintf(_('Forwarded by %s and %d other(s)'), $link, $n - 1));
-            }
-
-            $this->out->elementEnd('span');
-        }
-        parent::showEnd();
-    }
-}
diff --git a/plugins/Repeat/inboxnoticelist.php b/plugins/Repeat/inboxnoticelist.php
new file mode 100644 (file)
index 0000000..809fbe8
--- /dev/null
@@ -0,0 +1,85 @@
+<?php
+
+class InboxNoticeList extends NoticeList
+{
+    var $owner = null;
+
+    function __construct($notice, $owner, $out=null)
+    {
+        parent::__construct($notice, $out);
+        $this->owner  = $owner;
+    }
+
+    function newListItem($notice)
+    {
+        return new InboxNoticeListItem($notice, $this->owner, $this->out);
+    }
+}
+
+class InboxNoticeListItem extends NoticeListItem
+{
+    var $owner = null;
+    var $ib    = null;
+
+    function __construct($notice, $owner, $out=null)
+    {
+        parent::__construct($notice, $out);
+        $this->owner = $owner;
+
+        $this->ib = Notice_inbox::pkeyGet(array('user_id' => $owner->id,
+                                                'notice_id' => $notice->id));
+    }
+
+    function showAuthor()
+    {
+        parent::showAuthor();
+        if ($this->ib->source == NOTICE_INBOX_SOURCE_FORWARD) {
+            $this->out->element('span', 'forward', _('Fwd'));
+        }
+    }
+
+    function showEnd()
+    {
+        if ($this->ib->source == NOTICE_INBOX_SOURCE_FORWARD) {
+
+            $forward = new Forward();
+
+            // FIXME: scary join!
+
+            $forward->query('SELECT profile_id '.
+                            'FROM forward JOIN subscription ON forward.profile_id = subscription.subscribed '.
+                            'WHERE subscription.subscriber = ' . $this->owner->id . ' '.
+                            'AND forward.notice_id = ' . $this->notice->id . ' '.
+                            'ORDER BY forward.created ');
+
+            $n = 0;
+
+            $firstForwarder = null;
+
+            while ($forward->fetch()) {
+                if (empty($firstForwarder)) {
+                    $firstForwarder = Profile::staticGet('id', $forward->profile_id);
+                }
+                $n++;
+            }
+
+            $forward->free();
+            unset($forward);
+
+            $this->out->elementStart('span', 'forwards');
+
+            $link = XMLStringer::estring('a', array('href' => $firstForwarder->profileurl),
+                                         $firstForwarder->nickname);
+
+            if ($n == 1) {
+                $this->out->raw(sprintf(_('Forwarded by %s'), $link));
+            } else {
+                // XXX: use that cool ngettext thing
+                $this->out->raw(sprintf(_('Forwarded by %s and %d other(s)'), $link, $n - 1));
+            }
+
+            $this->out->elementEnd('span');
+        }
+        parent::showEnd();
+    }
+}