<?php
-
/**
* StatusNet, the distributed open-source microblogging tool
*
* @category Application
* @package StatusNet
* @author Zach Copley <zach@status.net>
- * @copyright 2008-2009 StatusNet, Inc.
+ * @copyright 2008-2010 StatusNet, Inc.
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-if (!defined('STATUSNET') && !defined('LACONICA')) {
- exit(1);
-}
-
-require_once INSTALLDIR . '/lib/widget.php';
-
-define('APPS_PER_PAGE', 20);
+if (!defined('GNUSOCIAL')) { exit(1); }
/**
* Widget to show a list of OAuth applications
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-
class ApplicationList extends Widget
{
/** Current application, application query */
/** Owner of this list */
var $owner = null;
- /** Action object using us. */
- var $action = null;
-
- function __construct($application, $owner=null, $action=null, $connections = false)
+ function __construct($application, Profile $owner, Action $out=null)
{
- parent::__construct($action);
+ parent::__construct($out);
$this->application = $application;
$this->owner = $owner;
- $this->action = $action;
- $this->connections = $connections;
}
function show()
if($cnt > APPS_PER_PAGE) {
break;
}
- $this->showapplication();
+ $this->showApplication();
}
$this->out->elementEnd('ul');
function showApplication()
{
+ $this->out->elementStart('li', array('class' => 'application h-entry',
+ 'id' => 'oauthclient-' . $this->application->id));
- $user = common_current_user();
-
- $this->out->elementStart('li', array('class' => 'application',
- 'id' => 'oauthclient-' . $this->application->id));
+ $this->out->elementStart('a', array('href' => common_local_url('showapplication',
+ array('id' => $this->application->id)),
+ 'class' => 'h-card'));
if (!empty($this->application->icon)) {
- $this->out->element('img', array('src' => $this->application->icon));
+ $this->out->element('img', array('src' => $this->application->icon,
+ 'class' => 'avatar u-photo'));
}
- if (!$this->connections) {
- $this->out->elementStart('a',
- array('href' => common_local_url('showapplication',
- array('nickname' => $user->nickname,
- 'id' => $this->application->id)),
- 'class' => 'url'));
-
- $this->out->raw($this->application->name);
- $this->out->elementEnd('a');
- } else {
- $this->out->elementStart('a', array('href' => $this->application->source_url,
- 'class' => 'url'));
- $this->out->raw($this->application->name);
- $this->out->elementEnd('a');
- }
+ $this->out->text($this->application->name);
+ $this->out->elementEnd('a');
$this->out->raw(' by ');
- $this->out->elementStart('a', array('href' => $this->application->homepage,
- 'class' => 'url'));
- $this->out->raw($this->application->organization);
- $this->out->elementEnd('a');
+ $this->out->element('a', array('href' => $this->application->homepage,
+ 'class' => 'u-url'),
+ $this->application->organization);
- $this->out->elementStart('p', 'note');
- $this->out->raw($this->application->description);
- $this->out->elementEnd('p');
+ $this->out->element('p', 'note', $this->application->description);
$this->out->elementEnd('li');
- if ($this->connections) {
- $appUser = Oauth_application_user::getByKeys($this->owner, $this->application);
-
- if (empty($appUser)) {
- common_debug("empty appUser!");
- }
-
- $this->out->elementStart('li');
-
- $access = ($this->application->access_type & Oauth_application::$writeAccess)
- ? 'read-write' : 'read-only';
-
- $txt = 'Approved ' . common_exact_date($appUser->modified) .
- " $access for access.";
-
- $this->out->raw($txt);
- $this->out->elementEnd('li');
-
- // XXX: Add revoke access button
- }
}
/* Override this in subclasses. */
-
function showOwnerControls()
{
return;
}
-
- function highlight($text)
- {
- return htmlspecialchars($text);
- }
}