4 * StatusNet, the distributed open-source microblogging tool
6 * Widget to show a sortable list of profiles
10 * LICENCE: 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 Zach Copley <zach@status.net>
26 * @copyright 2011 StatusNet, Inc.
27 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
28 * @link http://status.net/
31 if (!defined('STATUSNET')) {
35 require_once INSTALLDIR . '/lib/subscriptionlist.php';
38 * Widget to show a sortable list of subscriptions
42 * @author Zach Copley <zach@status.net>
43 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
44 * @link http://status.net/
47 class SortableSubscriptionList extends SubscriptionList
49 /** Owner of this list */
52 function __construct($profile, $owner=null, $action=null)
54 parent::__construct($profile, $owner, $action);
56 $this->owner = $owner;
61 $this->out->elementStart('table', array('class' => 'profile_list xoxo'));
62 $this->out->elementStart('thead');
63 $this->out->elementStart('tr');
65 $tableHeaders = array(
66 'nickname' => _m('Nickname'),
67 'created' => _m('Created')
70 foreach ($tableHeaders as $id => $label) {
72 $attrs = array('id' => $id);
73 $current = (!empty($this->action->sort) && $this->action->sort == $id);
75 if ($current || empty($this->action->sort) && $id == 'nickname') {
76 $attrs['class'] = 'current';
79 if ($current && $this->action->reverse) {
80 $attrs['class'] .= ' reverse';
81 $attrs['class'] = trim($attrs['class']);
84 $this->out->elementStart('th', $attrs);
87 $params = array('sort' => $id);
89 if (!empty($this->action->q)) {
90 $params['q'] = $this->action->q;
93 if ($current && !$this->action->reverse) {
94 $params['reverse'] = 'true';
99 $filter = $this->action->arg('filter');
101 if (!empty($filter)) {
102 $args['filter'] = $filter;
105 $linkAttrs['href'] = common_local_url(
106 $this->action->arg('action'), $args, $params
109 $this->out->element('a', $linkAttrs, $label);
110 $this->out->elementEnd('th');
113 $this->out->element('th', array('id' => 'subscriptions'), 'Subscriptions');
114 $this->out->element('th', array('id' => 'notices'), 'Notices');
115 $this->out->element('th', array('id' => 'controls'), null);
117 $this->out->elementEnd('tr');
118 $this->out->elementEnd('thead');
120 $this->out->elementStart('tbody');
125 $this->out->elementEnd('tbody');
126 $this->out->elementEnd('table');
129 function showProfiles()
133 while ($this->profile->fetch()) {
135 if($cnt > PROFILES_PER_PAGE) {
139 $odd = ($cnt % 2 == 0); // for zebra striping
141 $pli = $this->newListItem($this->profile, $odd);
148 function newListItem($profile, $odd)
150 return new SortableSubscriptionListItem($profile, $this->owner, $this->action, $odd);
154 class SortableSubscriptionListItem extends SubscriptionListItem
156 /** Owner of this list */
159 function __construct($profile, $owner, $action, $alt)
161 parent::__construct($profile, $owner, $action);
163 $this->alt = $alt; // is this row alternate?
164 $this->owner = $owner;
170 'class' => 'profile',
171 'id' => 'profile-' . $this->profile->id
175 $attr['class'] .= ' alt';
178 $this->out->elementStart('tr', $attr);
183 $this->out->elementEnd('tr');
186 function startProfile()
188 $this->out->elementStart('td', 'entity_profile vcard entry-content');
191 function endProfile()
193 $this->out->elementEnd('td');
196 function startActions()
198 $this->out->elementStart('td', 'entity_actions');
199 $this->out->elementStart('ul');
202 function endActions()
204 $this->out->elementEnd('ul');
205 $this->out->elementEnd('td');
210 if (Event::handle('StartProfileListItem', array($this))) {
212 if (Event::handle('StartProfileListItemProfile', array($this))) {
213 $this->showProfile();
214 Event::handle('EndProfileListItemProfile', array($this));
218 $this->showCreatedDate();
219 $this->showSubscriberCount();
220 $this->showNoticeCount();
222 if (Event::handle('StartProfileListItemActions', array($this))) {
223 $this->showActions();
224 Event::handle('EndProfileListItemActions', array($this));
227 Event::handle('EndProfileListItem', array($this));
231 function showSubscriberCount()
233 $this->out->elementStart('td', 'entry_subscriber_count');
234 $this->out->raw($this->profile->subscriberCount());
235 $this->out->elementEnd('td');
238 function showCreatedDate()
240 $this->out->elementStart('td', 'entry_created');
241 $this->out->raw(date('j M Y', strtotime($this->profile->created)));
242 $this->out->elementEnd('td');
245 function showNoticeCount()
247 $this->out->elementStart('td', 'entry_notice_count');
248 $this->out->raw($this->profile->noticeCount());
249 $this->out->elementEnd('td');
253 * Overrided to truncate the bio if it's real long, because it
254 * looks better that way in the SortableSubscriptionList's table
258 if (!empty($this->profile->bio)) {
259 $cutoff = 140; // XXX Should this be configurable?
260 $bio = htmlspecialchars($this->profile->bio);
262 if (mb_strlen($bio) > $cutoff) {
263 $bio = mb_substr($bio, 0, $cutoff - 1)
264 .'<a href="' . $this->profile->profileurl .'">…</a>';
267 $this->out->elementStart('p', 'note');
268 $this->out->raw($bio);
269 $this->out->elementEnd('p');
274 * Only show the tags if we're logged in
278 if (common_logged_in()) {