forked from GNUsocial/gnu-social
Make WebChannel and AjaxWebChannel work
These command-output channels were using the old common_element_* functions. They now take an $out constructor parameter, and use that for output. The WebChannel has pretty remedial output; it would be nice if it output a real formatted page.
This commit is contained in:
parent
15b96f78ab
commit
2d063650ef
@ -141,9 +141,9 @@ class NewnoticeAction extends Action
|
||||
|
||||
if ($cmd) {
|
||||
if ($this->boolean('ajax')) {
|
||||
$cmd->execute(new AjaxWebChannel());
|
||||
$cmd->execute(new AjaxWebChannel($this));
|
||||
} else {
|
||||
$cmd->execute(new WebChannel());
|
||||
$cmd->execute(new WebChannel($this));
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
@ -105,9 +105,14 @@ class XMPPChannel extends Channel
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
class WebChannel extends Channel
|
||||
{
|
||||
var $out = null;
|
||||
|
||||
function __construct($out=null)
|
||||
{
|
||||
$this->out = $out;
|
||||
}
|
||||
|
||||
function source()
|
||||
{
|
||||
@ -129,9 +134,14 @@ class WebChannel extends Channel
|
||||
# XXX: buffer all output and send it at the end
|
||||
# XXX: even better, redirect to appropriate page
|
||||
# depending on what command was run
|
||||
common_show_header(_('Command results'));
|
||||
common_element('p', null, $text);
|
||||
common_show_footer();
|
||||
$this->out->startHTML();
|
||||
$this->out->elementStart('head');
|
||||
$this->out->element('title', null, _('Command results'));
|
||||
$this->out->elementEnd('head');
|
||||
$this->out->elementStart('body');
|
||||
$this->out->element('p', array('id' => 'command_result'), $text);
|
||||
$this->out->elementEnd('body');
|
||||
$this->out->endHTML();
|
||||
}
|
||||
|
||||
function error($user, $text)
|
||||
@ -140,36 +150,33 @@ class WebChannel extends Channel
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
class AjaxWebChannel extends WebChannel
|
||||
{
|
||||
|
||||
function output($user, $text)
|
||||
{
|
||||
common_start_html('text/xml;charset=utf-8', true);
|
||||
common_element_start('head');
|
||||
common_element('title', null, _('Command results'));
|
||||
common_element_end('head');
|
||||
common_element_start('body');
|
||||
common_element('p', array('id' => 'command_result'), $text);
|
||||
common_element_end('body');
|
||||
common_element_end('html');
|
||||
$this->out->startHTML('text/xml;charset=utf-8');
|
||||
$this->out->elementStart('head');
|
||||
$this->out->element('title', null, _('Command results'));
|
||||
$this->out->elementEnd('head');
|
||||
$this->out->elementStart('body');
|
||||
$this->out->element('p', array('id' => 'command_result'), $text);
|
||||
$this->out->elementEnd('body');
|
||||
$this->out->endHTML();
|
||||
}
|
||||
|
||||
function error($user, $text)
|
||||
{
|
||||
common_start_html('text/xml;charset=utf-8', true);
|
||||
common_element_start('head');
|
||||
common_element('title', null, _('Ajax Error'));
|
||||
common_element_end('head');
|
||||
common_element_start('body');
|
||||
common_element('p', array('id' => 'error'), $text);
|
||||
common_element_end('body');
|
||||
common_element_end('html');
|
||||
$this->out->startHTML('text/xml;charset=utf-8');
|
||||
$this->out->elementStart('head');
|
||||
$this->out->element('title', null, _('Ajax Error'));
|
||||
$this->out->elementEnd('head');
|
||||
$this->out->elementStart('body');
|
||||
$this->out->element('p', array('id' => 'error'), $text);
|
||||
$this->out->elementEnd('body');
|
||||
$this->out->endHTML();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
class MailChannel extends Channel
|
||||
{
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user