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 */
56 * Is this a read-only page?
58 * @return boolean true
69 * Includes name of user and page number.
71 * @return string title of page
76 if ($this->page == 1) {
77 return sprintf(_("%s favorite notices"), $this->user->nickname);
79 return sprintf(_("%s favorite notices, page %d"),
80 $this->user->nickname,
88 * Check the input values and initialize the object.
89 * Shows an error page on bad input.
91 * @param array $args $_REQUEST data
93 * @return boolean success flag
96 function prepare($args)
98 parent::prepare($args);
100 $nickname = common_canonical_nickname($this->arg('nickname'));
102 $this->user = User::staticGet('nickname', $nickname);
105 $this->clientError(_('No such user.'));
109 $this->page = $this->trimmed('page');
121 * Just show the page. All args already handled.
123 * @param array $args $_REQUEST data
128 function handle($args)
130 parent::handle($args);
135 * Feeds for the <head> section
142 $feedurl = common_local_url('favoritesrss',
144 $this->user->nickname));
145 $feedtitle = sprintf(_('Feed for favorites of %s'),
146 $this->user->nickname);
148 $this->element('link', array('rel' => 'alternate',
150 'type' => 'application/rss+xml',
151 'title' => $feedtitle));
155 * show the personal group nav
160 function showLocalNav()
162 $nav = new PersonalGroupNav($this);
167 * Show the replies feed links
172 function showExportData()
174 $feedurl = common_local_url('favoritesrss',
176 $this->user->nickname));
178 $fl = new FeedList($this);
182 $fl->show(array(0=>array('href'=> $feedurl,
184 'version' => 'RSS 1.0',
185 'item' => 'Favorites')));
191 * A list of notices that this user has marked as a favorite
196 function showContent()
198 $notice = $this->user->favoriteNotices(($this->page-1)*NOTICES_PER_PAGE,
199 NOTICES_PER_PAGE + 1);
202 $this->serverError(_('Could not retrieve favorite notices.'));
206 $nl = new NoticeList($notice, $this);
210 $this->pagination($this->page > 1, $cnt > NOTICES_PER_PAGE,
211 $this->page, 'showfavorites',
212 array('nickname' => $this->user->nickname));