forked from GNUsocial/gnu-social
		
	Moved the common_avatar_* functions to the Avatar class. Typically either as methods on the object or as static methods. Replaced all the uses of the functions in other modules.
		
			
				
	
	
		
			298 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			298 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Laconica, the distributed open-source microblogging tool
 | |
|  *
 | |
|  * common superclass for direct messages inbox and outbox
 | |
|  *
 | |
|  * PHP version 5
 | |
|  *
 | |
|  * LICENCE: This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Affero General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Affero General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Affero General Public License
 | |
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  *
 | |
|  * @category  Message
 | |
|  * @package   Laconica
 | |
|  * @author    Evan Prodromou <evan@controlyourself.ca>
 | |
|  * @copyright 2008 Control Yourself, Inc.
 | |
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
 | |
|  * @link      http://laconi.ca/
 | |
|  */
 | |
| 
 | |
| if (!defined('LACONICA')) {
 | |
|     exit(1);
 | |
| }
 | |
| 
 | |
| require_once INSTALLDIR.'/lib/personal.php';
 | |
| 
 | |
| define('MESSAGES_PER_PAGE', 20);
 | |
| 
 | |
| /**
 | |
|  * common superclass for direct messages inbox and outbox
 | |
|  *
 | |
|  * @category Message
 | |
|  * @package  Laconica
 | |
|  * @author   Evan Prodromou <evan@controlyourself.ca>
 | |
|  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
 | |
|  * @link     http://laconi.ca/
 | |
|  * @see      InboxAction
 | |
|  * @see      OutboxAction
 | |
|  */
 | |
| 
 | |
| class MailboxAction extends PersonalAction
 | |
| {
 | |
|     var $page = null;
 | |
| 
 | |
|     function prepare($args) 
 | |
|     {
 | |
|         parent::prepare($args);
 | |
| 
 | |
|         $nickname   = common_canonical_nickname($this->arg('nickname'));
 | |
|         $this->user = User::staticGet('nickname', $nickname);
 | |
|         $this->page = $this->trimmed('page');
 | |
| 
 | |
|         if (!$this->page) {
 | |
|             $this->page = 1;
 | |
|         }
 | |
| 
 | |
|         common_set_returnto($this->selfUrl());
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * output page based on arguments
 | |
|      *
 | |
|      * @param array $args HTTP arguments (from $_REQUEST)
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
| 
 | |
|     function handle($args)
 | |
|     {
 | |
|         parent::handle($args);
 | |
| 
 | |
|         if (!$this->user) {
 | |
|             $this->clientError(_('No such user.'), 404);
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         $cur = common_current_user();
 | |
| 
 | |
|         if (!$cur || $cur->id != $this->user->id) {
 | |
|             $this->clientError(_('Only the user can read their own mailboxes.'),
 | |
|                 403);
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         $this->showPage();
 | |
|     }
 | |
| 
 | |
|     function showLocalNav()
 | |
|     {
 | |
|         $nav = new PersonalGroupNav($this);
 | |
|         $nav->show();
 | |
|     }
 | |
| 
 | |
|     function showNoticeForm()
 | |
|     {
 | |
|         $message_form = new MessageForm($this);
 | |
|         $message_form->show();
 | |
|     }
 | |
| 
 | |
|     function showContent()
 | |
|     {
 | |
|         $message = $this->getMessages();
 | |
| 
 | |
|         if ($message) {
 | |
|             $cnt = 0;
 | |
|             $this->elementStart('div', array('id' =>'notices_primary'));
 | |
|             $this->element('h2', null, _('Notices'));
 | |
|             $this->elementStart('ul', 'notices');
 | |
| 
 | |
|             while ($message->fetch() && $cnt <= MESSAGES_PER_PAGE) {
 | |
|                 $cnt++;
 | |
| 
 | |
|                 if ($cnt > MESSAGES_PER_PAGE) {
 | |
|                     break;
 | |
|                 }
 | |
| 
 | |
|                 $this->showMessage($message);
 | |
|             }
 | |
| 
 | |
|             $this->elementEnd('ul');
 | |
| 
 | |
|             $this->pagination($this->page > 1, $cnt > MESSAGES_PER_PAGE,
 | |
|                               $this->page, $this->trimmed('action'),
 | |
|                               array('nickname' => $this->user->nickname));
 | |
|             $this->elementEnd('div');
 | |
|             $message->free();
 | |
|             unset($message);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     function getMessages()
 | |
|     {
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * returns the profile we want to show with the message
 | |
|      *
 | |
|      * For inboxes, we show the sender; for outboxes, the recipient.
 | |
|      *
 | |
|      * @param Message $message The message to get the profile for
 | |
|      *
 | |
|      * @return Profile The profile that matches the message
 | |
|      */
 | |
| 
 | |
|     function getMessageProfile($message)
 | |
|     {
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * show a single message in the list format
 | |
|      *
 | |
|      * XXX: This needs to be extracted out into a MessageList similar
 | |
|      * to NoticeList.
 | |
|      *
 | |
|      * @param Message $message the message to show
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
| 
 | |
|     function showMessage($message)
 | |
|     {
 | |
|         $this->elementStart('li', array('class' => 'hentry notice',
 | |
|                                          'id' => 'message-' . $message->id));
 | |
| 
 | |
|         $profile = $this->getMessageProfile($message);
 | |
| 
 | |
|         $this->elementStart('div', 'entry-title');
 | |
|         $this->elementStart('span', 'vcard author');
 | |
|         $this->elementStart('a', array('href' => $profile->profileurl,
 | |
|                                        'class' => 'url'));
 | |
|         $avatar = $profile->getAvatar(AVATAR_STREAM_SIZE);
 | |
|         $this->element('img', array('src' => ($avatar) ?
 | |
|                                     $avatar->displayUrl() :
 | |
|                                     Avatar::defaultImage(AVATAR_STREAM_SIZE),
 | |
|                                     'class' => 'photo avatar',
 | |
|                                     'width' => AVATAR_STREAM_SIZE,
 | |
|                                     'height' => AVATAR_STREAM_SIZE,
 | |
|                                     'alt' =>
 | |
|                                     ($profile->fullname) ? $profile->fullname :
 | |
|                                     $profile->nickname));
 | |
|         $this->element('span', array('class' => 'nickname fn'),
 | |
|                             $profile->nickname);
 | |
|         $this->elementEnd('a');
 | |
|         $this->elementEnd('span');
 | |
| 
 | |
|         // FIXME: URL, image, video, audio
 | |
|         $this->elementStart('p', array('class' => 'entry-content'));
 | |
|         $this->raw($message->rendered);
 | |
|         $this->elementEnd('p');
 | |
|         $this->elementEnd('div');
 | |
| 
 | |
|         $messageurl = common_local_url('showmessage',
 | |
|                                        array('message' => $message->id));
 | |
| 
 | |
|         // XXX: we need to figure this out better. Is this right?
 | |
|         if (strcmp($message->uri, $messageurl) != 0 &&
 | |
|             preg_match('/^http/', $message->uri)) {
 | |
|             $messageurl = $message->uri;
 | |
|         }
 | |
| 
 | |
|         $this->elementStart('div', 'entry-content');
 | |
|         $this->elementStart('dl', 'timestamp');
 | |
|         $this->element('dt', null, _('Published'));
 | |
|         $this->elementStart('dd', null);
 | |
|         $dt = common_date_iso8601($message->created);
 | |
|         $this->elementStart('a', array('rel' => 'bookmark',
 | |
|                                        'href' => $messageurl));
 | |
|         $this->element('abbr', array('class' => 'published',
 | |
|                                      'title' => $dt),
 | |
|                                common_date_string($message->created));
 | |
|         $this->elementEnd('a');
 | |
|         $this->elementEnd('dd');
 | |
|         $this->elementEnd('dl');
 | |
| 
 | |
|         if ($message->source) {
 | |
|             $this->elementStart('dl', 'device');
 | |
|             $this->elementStart('dt');
 | |
|             $this->text(_('From'));
 | |
|             $this->elementEnd('dt');
 | |
|             $this->showSource($message->source);
 | |
|             $this->elementEnd('dl');
 | |
|         }
 | |
|         $this->elementEnd('div');
 | |
| 
 | |
|         $this->elementEnd('li');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Show the page notice
 | |
|      *
 | |
|      * Shows instructions for the page
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
| 
 | |
|     function showPageNotice()
 | |
|     {
 | |
|         $instr  = $this->getInstructions();
 | |
|         $output = common_markup_to_html($instr);
 | |
| 
 | |
|         $this->elementStart('div', 'instructions');
 | |
|         $this->raw($output);
 | |
|         $this->elementEnd('div');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Show the source of the message
 | |
|      *
 | |
|      * Returns either the name (and link) of the API client that posted the notice,
 | |
|      * or one of other other channels.
 | |
|      *
 | |
|      * @param string $source the source of the message 
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
| 
 | |
|     function showSource($source) 
 | |
|     {
 | |
|         $source_name = _($source);
 | |
|         switch ($source) {
 | |
|         case 'web':
 | |
|         case 'xmpp':
 | |
|         case 'mail':
 | |
|         case 'omb':
 | |
|         case 'api':
 | |
|             $this->element('dd', null, $source_name);
 | |
|             break;
 | |
|         default:
 | |
|             $ns = Notice_source::staticGet($source);
 | |
|             if ($ns) {
 | |
|                 $this->elementStart('dd', null);
 | |
|                 $this->element('a', array('href' => $ns->url,
 | |
|                                           'rel' => 'external'),
 | |
|                                $ns->name);
 | |
|                 $this->elementEnd('dd');
 | |
|             } else {
 | |
|                 $this->element('dd', null, $source_name);
 | |
|             }
 | |
|             break;
 | |
|         }
 | |
|         return;
 | |
|     }
 | |
| 
 | |
| }
 |