3 * Laconica, the distributed open-source microblogging tool
9 * LICENCE: This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
24 * @author Evan Prodromou <evan@controlyourself.ca>
25 * @copyright 2008-2009 Control Yourself, Inc.
26 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
27 * @link http://laconi.ca/
30 if (!defined('LACONICA')) {
34 require_once INSTALLDIR.'/lib/personalgroupnav.php';
35 require_once INSTALLDIR.'/lib/noticelist.php';
36 require_once INSTALLDIR.'/lib/feedlist.php';
43 * @author Evan Prodromou <evan@controlyourself.ca>
44 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
45 * @link http://laconi.ca/
48 class ShowfavoritesAction extends Action
50 /** User we're getting the faves of */
52 /** Page of the faves we're on */
58 * Includes name of user and page number.
60 * @return string title of page
65 if ($this->page == 1) {
66 return sprintf(_("%s favorite notices"), $this->user->nickname);
68 return sprintf(_("%s favorite notices, page %d"),
69 $this->user->nickname,
77 * Check the input values and initialize the object.
78 * Shows an error page on bad input.
80 * @param array $args $_REQUEST data
82 * @return boolean success flag
85 function prepare($args)
87 parent::prepare($args);
89 $nickname = common_canonical_nickname($this->arg('nickname'));
91 $this->user = User::staticGet('nickname', $nickname);
94 $this->clientError(_('No such user.'));
98 $this->page = $this->trimmed('page');
110 * Just show the page. All args already handled.
112 * @param array $args $_REQUEST data
117 function handle($args)
119 parent::handle($args);
124 * Feeds for the <head> section
131 $feedurl = common_local_url('favoritesrss',
133 $this->user->nickname));
134 $feedtitle = sprintf(_('Feed for favorites of %s'),
135 $this->user->nickname);
137 $this->element('link', array('rel' => 'alternate',
139 'type' => 'application/rss+xml',
140 'title' => $feedtitle));
144 * show the personal group nav
149 function showLocalNav()
151 $nav = new PersonalGroupNav($this);
156 * Show the replies feed links
161 function showExportData()
163 $feedurl = common_local_url('favoritesrss',
165 $this->user->nickname));
167 $fl = new FeedList($this);
171 $fl->show(array(0=>array('href'=> $feedurl,
173 'version' => 'RSS 1.0',
174 'item' => 'Favorites')));
180 * A list of notices that this user has marked as a favorite
185 function showContent()
187 $notice = $this->user->favoriteNotices(($this->page-1)*NOTICES_PER_PAGE,
188 NOTICES_PER_PAGE + 1);
191 $this->serverError(_('Could not retrieve favorite notices.'));
195 $nl = new NoticeList($notice, $this);
199 $this->pagination($this->page > 1, $cnt > NOTICES_PER_PAGE,
200 $this->page, 'showfavorites',
201 array('nickname' => $this->user->nickname));