X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fnoticelist.php;h=c9d43c097a20437de1aa5e4dfeedc5fc6aef51bc;hb=0590f2975e6c5b26bbe6121da5c49890e035721e;hp=f18b2d66841ffa7a2998123c0f30a2fa8cad9157;hpb=19b965d99188fde59cdd39b668df8951bc0f180c;p=quix0rs-gnu-social.git diff --git a/lib/noticelist.php b/lib/noticelist.php index f18b2d6684..c9d43c097a 100644 --- a/lib/noticelist.php +++ b/lib/noticelist.php @@ -28,13 +28,7 @@ * @link http://status.net/ */ -if (!defined('STATUSNET') && !defined('LACONICA')) { - exit(1); -} - -require_once INSTALLDIR.'/lib/favorform.php'; -require_once INSTALLDIR.'/lib/disfavorform.php'; -require_once INSTALLDIR.'/lib/attachmentlist.php'; +if (!defined('GNUSOCIAL') && !defined('STATUSNET')) { exit(1); } /** * widget for displaying a list of notices @@ -59,15 +53,41 @@ class NoticeList extends Widget var $notice = null; + protected $addressees = true; + protected $attachments = true; + protected $id_prefix = null; + protected $maxchars = 0; + protected $options = true; + protected $show_n = NOTICES_PER_PAGE; + /** * constructor * * @param Notice $notice stream of notices from DB_DataObject */ - function __construct($notice, $out=null) + function __construct(Notice $notice, $out=null, array $prefs=array()) { parent::__construct($out); $this->notice = $notice; + + // integer preferences + foreach(array('show_n', 'maxchars') as $key) { + if (array_key_exists($key, $prefs)) { + $this->$key = (int)$prefs[$key]; + } + } + // boolean preferences + foreach(array('addressees', 'attachments', 'options') as $key) { + if (array_key_exists($key, $prefs)) { + $this->$key = (bool)$prefs[$key]; + } + } + // string preferences + foreach(array('id_prefix') as $key) { + if (array_key_exists($key, $prefs)) { + $this->$key = $prefs[$key]; + } + } } /** @@ -76,24 +96,24 @@ class NoticeList extends Widget * "Uses up" the stream by looping through it. So, probably can't * be called twice on the same list. * - * @return int count of notices listed. + * @param integer $n The amount of notices to show. + * + * @return int Total amount of notices actually available. */ - function show() + public function show() { - $this->out->elementStart('div', array('id' =>'notices_primary')); $this->out->elementStart('ol', array('class' => 'notices xoxo')); - $cnt = 0; - - while ($this->notice->fetch() && $cnt <= NOTICES_PER_PAGE) { - $cnt++; - - if ($cnt > NOTICES_PER_PAGE) { - break; - } + $notices = $this->notice->fetchAll(); + $total = count($notices); + $notices = array_slice($notices, 0, $this->show_n); + + self::prefill($notices); + + foreach ($notices as $notice) { try { - $item = $this->newListItem($this->notice); + $item = $this->newListItem($notice); $item->show(); } catch (Exception $e) { // we log exceptions and continue @@ -103,9 +123,7 @@ class NoticeList extends Widget } $this->out->elementEnd('ol'); - $this->out->elementEnd('div'); - - return $cnt; + return $total; } /** @@ -118,8 +136,35 @@ class NoticeList extends Widget * * @return NoticeListItem a list item for displaying the notice */ - function newListItem($notice) + function newListItem(Notice $notice) { - return new NoticeListItem($notice, $this->out); + $prefs = array('addressees' => $this->addressees, + 'attachments' => $this->attachments, + 'id_prefix' => $this->id_prefix, + 'maxchars' => $this->maxchars, + 'options' => $this->options); + return new NoticeListItem($notice, $this->out, $prefs); + } + + static function prefill(array &$notices) + { + $scoped = Profile::current(); + $notice_ids = Notice::_idsOf($notices); + + if (Event::handle('StartNoticeListPrefill', array(&$notices, $notice_ids, $scoped))) { + + // Prefill attachments + Notice::fillAttachments($notices); + // Prefill repeat data + Notice::fillRepeats($notices); + // Prefill the profiles + $profiles = Notice::fillProfiles($notices); + + if ($scoped instanceof Profile) { + Notice::pivotGet('repeat_of', $notice_ids, array('profile_id' => $scoped->id)); + } + + Event::handle('EndNoticeListPrefill', array(&$notices, &$profiles, $notice_ids, $scoped)); + } } }