3 * StatusNet - the distributed open-source microblogging tool
4 * Copyright (C) 2011, StatusNet, Inc.
6 * Adapter to show bookmarks in a nicer way
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.
38 * An adapter to show bookmarks in a nicer way
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 class BookmarkListItem extends NoticeListItemAdapter
52 $this->nli->out->elementStart('div', 'entry-title');
53 $this->nli->showAuthor();
55 $this->nli->out->elementEnd('div');
58 function showContent()
60 $notice = $this->nli->notice;
61 $out = $this->nli->out;
63 $nb = Bookmark::getByNotice($notice);
66 common_log(LOG_ERR, "No bookmark for notice {$notice->id}");
67 parent::showContent();
69 } else if (empty($nb->url)) {
70 common_log(LOG_ERR, "No url for bookmark {$nb->id} for notice {$notice->id}");
71 parent::showContent();
75 $profile = $notice->getProfile();
77 $out->elementStart('p', array('class' => 'entry-content'));
79 // Whether to nofollow
81 $attrs = array('href' => $nb->url,
82 'class' => 'bookmark-title');
84 $nf = common_config('nofollow', 'external');
86 if ($nf == 'never' || ($nf == 'sometimes' and $out instanceof ShowstreamAction)) {
87 $attrs['rel'] = 'external';
89 $attrs['rel'] = 'nofollow external';
92 $out->elementStart('h3');
96 $out->elementEnd('h3');
98 // Replies look like "for:" tags
100 $replies = $notice->getReplies();
101 $tags = $notice->getTags();
103 if (!empty($replies) || !empty($tags)) {
105 $out->elementStart('ul', array('class' => 'bookmark-tags'));
107 foreach ($replies as $reply) {
108 $other = Profile::getKV('id', $reply);
109 if (!empty($other)) {
110 $out->elementStart('li');
111 $out->element('a', array('rel' => 'tag',
112 'href' => $other->profileurl,
113 'title' => $other->getBestName()),
114 sprintf('for:%s', $other->nickname));
115 $out->elementEnd('li');
120 foreach ($tags as $tag) {
123 $out->elementStart('li');
125 array('rel' => 'tag',
126 'href' => Notice_tag::url($tag)),
128 $out->elementEnd('li');
133 $out->elementEnd('ul');
136 if (!empty($nb->description)) {
138 array('class' => 'bookmark-description'),
142 $out->elementEnd('p');