3 * StatusNet - the distributed open-source microblogging tool
4 * Copyright (C) 2011, StatusNet, Inc.
6 * The message list widget
10 * This program is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU Affero General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Affero General Public License for more details.
20 * You should have received a copy of the GNU Affero General Public License
21 * along with this program. If not, see <http://www.gnu.org/licenses/>.
25 * @author Evan Prodromou <evan@status.net>
26 * @copyright 2011 StatusNet, Inc.
27 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
28 * @link http://status.net/
31 if (!defined('STATUSNET')) {
32 // This check helps protect against security problems;
33 // your code file can't be executed directly from the web.
42 * @author Evan Prodromou <evan@status.net>
43 * @copyright 2011 StatusNet, Inc.
44 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
45 * @link http://status.net/
48 abstract class MessageList extends Widget
55 * @param HTMLOutputter $out Output context
56 * @param Message $message Stream of messages to show
58 function __construct($out, $message)
60 parent::__construct($out);
61 $this->message = $message;
67 * Uses newItem() to create each new item.
69 * @return integer count of messages seen.
75 $this->out->elementStart('div', array('id' =>'notices_primary'));
77 $this->out->element('h2', null, _('Messages'));
79 $this->out->elementStart('ul', 'notices messages');
81 while ($this->message->fetch() && $cnt <= MESSAGES_PER_PAGE) {
85 if ($cnt > MESSAGES_PER_PAGE) {
89 $mli = $this->newItem($this->message);
94 $this->out->elementEnd('ul');
96 $this->out->elementEnd('div');
100 * Create a new message item for a message
102 * @param Message $message The message to show
104 * @return MessageListItem an item to show
106 abstract function newItem($message);