* @link http://status.net/
*/
-if (!defined('STATUSNET') && !defined('LACONICA')) {
- exit(1);
-}
+if (!defined('GNUSOCIAL')) { exit(1); }
define('PAGE_TYPE_PREFS_MOBILEPROFILE',
'application/vnd.wap.xhtml+xml, application/xhtml+xml, text/html;q=0.9');
{
public $DTD = null;
public $serveMobile = false;
+ public $reallyMobile = false;
public $mobileFeatures = array();
function __construct($DTD='http://www.wapforum.org/DTD/xhtml-mobile10.dtd')
parent::__construct();
}
- function onStartShowHTML($action)
+ public function onStartShowHTML(Action $action)
{
- // XXX: This should probably graduate to WAP20Plugin
+ // TODO: A lot of this should probably graduate to WAP20Plugin
- // If they are on the mobile site, serve them MP
- if ((common_config('site', 'mobileserver').'/'.
- common_config('site', 'path').'/' ==
- $_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'])) {
+ $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : null;
+
+ $cp = common_accept_to_prefs($httpaccept);
+ $sp = common_accept_to_prefs(PAGE_TYPE_PREFS_MOBILEPROFILE);
+
+ $type = common_negotiate_type($cp, $sp);
+ if (!$type) {
+ // TRANS: Client exception thrown when requesting a not supported media type.
+ throw new ClientException(_m('This page is not available in a '.
+ 'media type you accept.'), 406);
+ }
+
+ // If they are on the mobile site, serve them MP
+ if ((common_config('site', 'mobileserver').'/'.common_config('site', 'path').'/'
+ == $_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'])) {
$this->serveMobile = true;
- } else if (isset($_COOKIE['MobileOverride'])) {
+ } elseif (isset($_COOKIE['MobileOverride'])) {
// Cookie override is controlled by link at bottom.
$this->serveMobile = (bool)$_COOKIE['MobileOverride'];
- } else {
+ } elseif (strstr('application/vnd.wap.xhtml+xml', $type) !== false) {
// If they like the WAP 2.0 mimetype, serve them MP
- // @fixme $type is undefined, making this if case useless and spewing errors.
- // What's the intent?
- //if (strstr('application/vnd.wap.xhtml+xml', $type) !== false) {
- // $this->serveMobile = true;
- //} else {
- // If they are a mobile device that supports WAP 2.0,
- // serve them MP
-
- // XXX: Browser sniffing sucks
-
- // I really don't like going through this every page,
- // perhaps use $_SESSION or cookies
-
- // May be better to group the devices in terms of
- // low,mid,high-end
-
- // Or, detect the mobile devices based on their support for
- // MP 1.0, 1.1, or 1.2 may be ideal. Possible?
-
- $this->mobiledevices = array(
- 'alcatel',
- 'android',
- 'audiovox',
- 'au-mic,',
- 'avantgo',
- 'blackberry',
- 'blazer',
- 'cldc-',
- 'danger',
- 'epoc',
- 'ericsson',
- 'ericy',
- 'iphone',
- 'ipaq',
- 'ipod',
- 'j2me',
- 'lg',
- 'midp-',
- 'mobile',
- 'mot',
- 'netfront',
- 'nitro',
- 'nokia',
- 'opera mini',
- 'palm',
- 'palmsource',
- 'panasonic',
- 'philips',
- 'pocketpc',
- 'portalmmm',
- 'rover',
- 'samsung',
- 'sanyo',
- 'series60',
- 'sharp',
- 'sie-',
- 'smartphone',
- 'sony',
- 'symbian',
- 'up.browser',
- 'up.link',
- 'up.link',
- 'vodafone',
- 'wap1',
- 'wap2',
- 'webos',
- 'windows ce'
- );
-
- $blacklist = array(
- 'ipad', // Larger screen handles the full theme fairly well.
- );
-
- $httpuseragent = strtolower($_SERVER['HTTP_USER_AGENT']);
-
- foreach ($blacklist as $md) {
- if (strstr($httpuseragent, $md) !== false) {
- $this->serveMobile = false;
- return true;
- }
+ $this->serveMobile = true;
+ } elseif (array_key_exists('HTTP_USER_AGENT', $_SERVER)) {
+ // If they are a mobile device that supports WAP 2.0,
+ // serve them MP
+
+ // XXX: Browser sniffing sucks
+
+ // I really don't like going through this every page,
+ // perhaps use $_SESSION or cookies
+
+ // May be better to group the devices in terms of
+ // low,mid,high-end
+
+ // Or, detect the mobile devices based on their support for
+ // MP 1.0, 1.1, or 1.2 may be ideal. Possible?
+
+ $this->mobiledevices = array(
+ 'alcatel',
+ 'android',
+ 'audiovox',
+ 'au-mic,',
+ 'avantgo',
+ 'blackberry',
+ 'blazer',
+ 'cldc-',
+ 'danger',
+ 'epoc',
+ 'ericsson',
+ 'ericy',
+ 'iphone',
+ 'ipaq',
+ 'ipod',
+ 'j2me',
+ 'lg',
+ 'maemo',
+ 'midp-',
+ 'mobile',
+ 'mot',
+ 'netfront',
+ 'nitro',
+ 'nokia',
+ 'opera mini',
+ 'palm',
+ 'palmsource',
+ 'panasonic',
+ 'philips',
+ 'pocketpc',
+ 'portalmmm',
+ 'rover',
+ 'samsung',
+ 'sanyo',
+ 'series60',
+ 'sharp',
+ 'sie-',
+ 'smartphone',
+ 'sony',
+ 'symbian',
+ 'up.browser',
+ 'up.link',
+ 'up.link',
+ 'vodafone',
+ 'wap1',
+ 'wap2',
+ 'webos',
+ 'windows ce'
+ );
+
+ $blacklist = array(
+ 'ipad', // Larger screen handles the full theme fairly well.
+ );
+
+ $httpuseragent = strtolower($_SERVER['HTTP_USER_AGENT']);
+
+ foreach ($blacklist as $md) {
+ if (strstr($httpuseragent, $md) !== false) {
+ $this->serveMobile = false;
+ return true;
}
+ }
- foreach ($this->mobiledevices as $md) {
- if (strstr($httpuseragent, $md) !== false) {
- $this->setMobileFeatures($httpuseragent);
+ foreach ($this->mobiledevices as $md) {
+ if (strstr($httpuseragent, $md) !== false) {
+ $this->setMobileFeatures($httpuseragent);
- $this->serveMobile = true;
- break;
- }
+ $this->serveMobile = true;
+ $this->reallyMobile = true;
+ break;
}
- //}
-
- // If they are okay with MP, and the site has a mobile server,
- // redirect there
- if ($this->serveMobile &&
- common_config('site', 'mobileserver') !== false &&
- (common_config('site', 'mobileserver') !=
- common_config('site', 'server'))) {
-
- // FIXME: Redirect to equivalent page on mobile site instead
- common_redirect($this->_common_path(''), 302);
}
}
return true;
}
- // @fixme $type is undefined, making this if case useless and spewing errors.
- // What's the intent?
- //if (!$type) {
- $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ?
- $_SERVER['HTTP_ACCEPT'] : null;
-
- $cp = common_accept_to_prefs($httpaccept);
- $sp = common_accept_to_prefs(PAGE_TYPE_PREFS_MOBILEPROFILE);
-
- $type = common_negotiate_type($cp, $sp);
+ // If they are okay with MP, and the site has a mobile server,
+ // redirect there
+ if (common_config('site', 'mobileserver') !== false &&
+ common_config('site', 'mobileserver') != common_config('site', 'server')) {
- if (!$type) {
- throw new ClientException(_m('This page is not available in a '.
- 'media type you accept.'), 406);
- }
- //}
+ // FIXME: Redirect to equivalent page on mobile site instead
+ common_redirect($this->_common_path(''), 302);
+ }
header('Content-Type: '.$type);
- $action->extraHeaders();
- if (preg_match("/.*\/.*xml/", $type)) {
- // Required for XML documents
- $action->xw->startDocument('1.0', 'UTF-8');
+ if ($this->reallyMobile) {
+ $action->setDTD('html', '-//WAPFORUM//DTD XHTML Mobile 1.0//EN', $this->DTD);
}
- $action->xw->writeDTD('html',
- '-//WAPFORUM//DTD XHTML Mobile 1.0//EN',
- $this->DTD);
-
- $language = $action->getLanguage();
-
- $action->elementStart('html', array('xmlns' => 'http://www.w3.org/1999/xhtml',
- 'xml:lang' => $language));
- return false;
+ // continue
+ return true;
}
function setMobileFeatures($useragent)
}
}
- function onStartShowStatusNetStyles($action)
+ public function onStartShowStylesheets(Action $action)
{
if (!$this->serveMobile) {
return true;
$action->primaryCssLink();
+ $action->cssLink($this->path('mp-screen.css'),null,'screen');
if (file_exists(Theme::file('css/mp-screen.css'))) {
$action->cssLink('css/mp-screen.css', null, 'screen');
- } else {
- $action->cssLink($this->path('mp-screen.css'),null,'screen');
}
+ $action->cssLink($this->path('mp-handheld.css'),null,'handheld');
if (file_exists(Theme::file('css/mp-handheld.css'))) {
$action->cssLink('css/mp-handheld.css', null, 'handheld');
- } else {
- $action->cssLink($this->path('mp-handheld.css'),null,'handheld');
}
// Allow other plugins to load their styles.
- Event::handle('EndShowStatusNetStyles', array($action));
- Event::handle('EndShowLaconicaStyles', array($action));
+ Event::handle('EndShowStylesheets', array($action));
return false;
}
- function onStartShowUAStyles($action) {
+ public function onStartShowUAStyles(Action $action) {
if (!$this->serveMobile) {
return true;
}
return false;
}
- function onStartShowHeader($action)
+ public function onStartShowHeader(Action $action)
{
if (!$this->serveMobile) {
return true;
$action->elementStart('div', array('id' => 'header'));
$this->_showLogo($action);
- $this->_showPrimaryNav($action);
- if (common_logged_in()) {
- $action->showNoticeForm();
- }
+ $action->showPrimaryNav();
$action->elementEnd('div');
return false;
}
- function _showLogo($action)
+ protected function _showLogo(Action $action)
{
- $action->elementStart('address', 'vcard');
- $action->elementStart('a', array('class' => 'url home bookmark',
- 'href' => common_local_url('public')));
+ $action->elementStart('address');
+ if (common_config('singleuser', 'enabled')) {
+ $user = User::singleUser();
+ $url = common_local_url('showstream', array('nickname' => $user->getNickname()));
+ } else {
+ $url = common_local_url('public');
+ }
+
+ $action->elementStart('a', array('class' => 'h-card home bookmark',
+ 'href' => $url));
+
if (common_config('site', 'mobilelogo') ||
file_exists(Theme::file('logo.png')) ||
file_exists(Theme::file('mobilelogo.png'))) {
- $action->element('img', array('class' => 'photo',
+ $action->element('img', array('class' => 'u-photo',
'src' => (common_config('site', 'mobilelogo')) ? common_config('site', 'mobilelogo') :
((file_exists(Theme::file('mobilelogo.png'))) ? (Theme::path('mobilelogo.png')) : Theme::path('logo.png')),
'alt' => common_config('site', 'name')));
}
- $action->element('span', array('class' => 'fn org'), common_config('site', 'name'));
$action->elementEnd('a');
$action->elementEnd('address');
}
- function _showPrimaryNav($action)
+ public function onStartShowAside(Action $action)
{
- $user = common_current_user();
- $action->elementStart('ul', array('id' => 'site_nav_global_primary'));
- if ($user) {
- $action->menuItem(common_local_url('all', array('nickname' => $user->nickname)),
- _m('Home'));
- $action->menuItem(common_local_url('profilesettings'),
- _m('Account'));
- $action->menuItem(common_local_url('oauthconnectionssettings'),
- _m('Connect'));
- if ($user->hasRight(Right::CONFIGURESITE)) {
- $action->menuItem(common_local_url('siteadminpanel'),
- _m('Admin'), _m('Change site configuration'), false, 'nav_admin');
- }
- if (common_config('invite', 'enabled')) {
- $action->menuItem(common_local_url('invite'),
- _m('Invite'));
- }
- $action->menuItem(common_local_url('logout'),
- _m('Logout'));
- } else {
- if (!common_config('site', 'closed')) {
- $action->menuItem(common_local_url('register'),
- _m('Register'));
- }
- $action->menuItem(common_local_url('login'),
- _m('Login'));
- }
- if ($user || !common_config('site', 'private')) {
- $action->menuItem(common_local_url('peoplesearch'),
- _m('Search'));
- }
- $action->elementEnd('ul');
- }
-
- function onStartShowNoticeFormData($form)
- {
- if (!$this->serveMobile) {
- return true;
- }
-
- $form->out->element('textarea', array('id' => 'notice_data-text',
- 'cols' => 15,
- 'rows' => 4,
- 'name' => 'status_textarea'),
- ($form->content) ? $form->content : '');
-
- $contentLimit = Notice::maxContent();
-
- if ($contentLimit > 0) {
- $form->out->element('div', array('class' => 'count'),
- $contentLimit);
- }
-
- if (common_config('attachments', 'uploads')) {
- if ($this->mobileFeatures['inputfiletype']) {
- $form->out->hidden('MAX_FILE_SIZE', common_config('attachments', 'file_quota'));
- $form->out->element('label', array('for' => 'notice_data-attach'), _m('Attach'));
- $form->out->element('input', array('id' => 'notice_data-attach',
- 'type' => 'file',
- 'name' => 'attach',
- 'title' => _m('Attach a file')));
- }
- }
- if ($form->action) {
- $form->out->hidden('notice_return-to', $form->action, 'returnto');
+ if ($this->serveMobile) {
+ return false;
}
- $form->out->hidden('notice_in-reply-to', $form->inreplyto, 'inreplyto');
-
- return false;
}
- function onStartShowAside($action)
+ public function onStartShowLocalNavBlock(Action $action)
{
if ($this->serveMobile) {
- return false;
+ // @todo FIXME: "Show Navigation" / "Hide Navigation" needs i18n
+ $action->element('a', array('href' => '#', 'id' => 'navtoggle'), 'Show Navigation');
}
}
- function onEndShowScripts($action)
+ public function onEndShowScripts(Action $action)
{
+ // @todo FIXME: "Show Navigation" / "Hide Navigation" needs i18n
$action->inlineScript('
$(function() {
$("#mobile-toggle-disable").click(function() {
window.location.reload();
return false;
});
+ $("#navtoggle").click(function () {
+ $("#site_nav_local_views").fadeToggle();
+ var text = $("#navtoggle").text();
+ $("#navtoggle").text(
+ text == "Show Navigation" ? "Hide Navigation" : "Show Navigation");
+ });
});'
);
+
+ if ($this->serveMobile) {
+ $action->inlineScript('$(function() { $(".checkbox-wrapper").unbind("click"); });');
+ }
}
- function onEndShowInsideFooter($action)
+ public function onEndShowInsideFooter(Action $action)
{
if ($this->serveMobile) {
// TRANS: Link to switch site layout from mobile to desktop mode. Appears at very bottom of page.
return $proto.'://'.$serverpart.'/'.$pathpart.$relative;
}
- function onPluginVersion(&$versions)
+ function onPluginVersion(array &$versions)
{
$versions[] = array('name' => 'MobileProfile',
- 'version' => STATUSNET_VERSION,
+ 'version' => GNUSOCIAL_VERSION,
'author' => 'Sarven Capadisli',
'homepage' => 'http://status.net/wiki/Plugin:MobileProfile',
'rawdescription' =>
+ // TRANS: Plugin description.
_m('XHTML MobileProfile output for supporting user agents.'));
return true;
}