forked from GNUsocial/gnu-social
Updates to reply status box
This commit is contained in:
parent
84021e021e
commit
7524555242
@ -118,10 +118,9 @@ class NoticeTreeItem extends NoticeListItem
|
|||||||
if ($cnt > 1) $this->out->text("s"); //there has to be a better way to do this...
|
if ($cnt > 1) $this->out->text("s"); //there has to be a better way to do this...
|
||||||
}
|
}
|
||||||
|
|
||||||
//TODO: Rewrite this too
|
|
||||||
//Show response form
|
//Show response form
|
||||||
$this->out->elementStart('div', array('id' => 'form' . $this->notice->id, 'class' => 'replyform'));
|
$this->out->elementStart('div', array('id' => 'form' . $this->notice->id, 'class' => 'replyform'));
|
||||||
$noticeform = new NoticeForm($this->out, null, null, null, $this->notice->id);
|
$noticeform = new ReplyForm($this->out, null, null, null, $this->notice->id);
|
||||||
$noticeform->show();
|
$noticeform->show();
|
||||||
$this->out->elementEnd('div');
|
$this->out->elementEnd('div');
|
||||||
return;
|
return;
|
||||||
@ -137,6 +136,7 @@ class NoticeTreeItem extends NoticeListItem
|
|||||||
{
|
{
|
||||||
if (common_logged_in()) {
|
if (common_logged_in()) {
|
||||||
$this->out->text(' ');
|
$this->out->text(' ');
|
||||||
|
//Why doesn't common_local_url work here?
|
||||||
$reply_url = '/notice/respond?replyto=' . $this->profile->nickname . '&inreplyto=' . $this->notice->id;
|
$reply_url = '/notice/respond?replyto=' . $this->profile->nickname . '&inreplyto=' . $this->notice->id;
|
||||||
$this->out->elementStart('a', array('href' => $reply_url,
|
$this->out->elementStart('a', array('href' => $reply_url,
|
||||||
'class' => 'notice_reply',
|
'class' => 'notice_reply',
|
||||||
@ -149,3 +149,60 @@ class NoticeTreeItem extends NoticeListItem
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class ReplyForm extends NoticeForm
|
||||||
|
{
|
||||||
|
//Changing the text. We have to either repeat ids or get hacky. I vote repeat ids.
|
||||||
|
function formData()
|
||||||
|
{
|
||||||
|
if (Event::handle('StartShowNoticeFormData', array($this))) {
|
||||||
|
// XXX: vary by defined max size
|
||||||
|
$this->out->element('textarea', array('id' => 'notice_data-text',
|
||||||
|
'cols' => 35,
|
||||||
|
'rows' => 4,
|
||||||
|
'name' => 'status_textarea'),
|
||||||
|
($this->content) ? $this->content : '');
|
||||||
|
|
||||||
|
$contentLimit = Notice::maxContent();
|
||||||
|
|
||||||
|
if ($contentLimit > 0) {
|
||||||
|
$this->out->elementStart('dl', 'form_note');
|
||||||
|
$this->out->element('dt', null, _('Available characters'));
|
||||||
|
$this->out->element('dd', array('id' => 'notice_text-count'),
|
||||||
|
$contentLimit);
|
||||||
|
$this->out->elementEnd('dl');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (common_config('attachments', 'uploads')) {
|
||||||
|
$this->out->element('label', array('for' => 'notice_data-attach'),_('Attach'));
|
||||||
|
$this->out->element('input', array('id' => 'notice_data-attach',
|
||||||
|
'type' => 'file',
|
||||||
|
'name' => 'attach',
|
||||||
|
'title' => _('Attach a file')));
|
||||||
|
$this->out->hidden('MAX_FILE_SIZE', common_config('attachments', 'file_quota'));
|
||||||
|
}
|
||||||
|
if ($this->action) {
|
||||||
|
$this->out->hidden('notice_return-to', $this->action, 'returnto');
|
||||||
|
}
|
||||||
|
$this->out->hidden('notice_in-reply-to', $this->inreplyto, 'inreplyto');
|
||||||
|
|
||||||
|
if ($this->user->shareLocation()) {
|
||||||
|
$this->out->hidden('notice_data-lat', empty($this->lat) ? (empty($this->profile->lat) ? null : $this->profile->lat) : $this->lat, 'lat');
|
||||||
|
$this->out->hidden('notice_data-lon', empty($this->lon) ? (empty($this->profile->lon) ? null : $this->profile->lon) : $this->lon, 'lon');
|
||||||
|
$this->out->hidden('notice_data-location_id', empty($this->location_id) ? (empty($this->profile->location_id) ? null : $this->profile->location_id) : $this->location_id, 'location_id');
|
||||||
|
$this->out->hidden('notice_data-location_ns', empty($this->location_ns) ? (empty($this->profile->location_ns) ? null : $this->profile->location_ns) : $this->location_ns, 'location_ns');
|
||||||
|
|
||||||
|
$this->out->elementStart('div', array('id' => 'notice_data-geo_wrap',
|
||||||
|
'title' => common_local_url('geocode')));
|
||||||
|
$this->out->checkbox('notice_data-geo', _('Share my location'), true);
|
||||||
|
$this->out->elementEnd('div');
|
||||||
|
$this->out->inlineScript(' var NoticeDataGeo_text = {'.
|
||||||
|
'ShareDisable: ' .json_encode(_('Do not share my location')).','.
|
||||||
|
'ErrorTimeout: ' .json_encode(_('Sorry, retrieving your geo location is taking longer than expected, please try again later')).
|
||||||
|
'}');
|
||||||
|
}
|
||||||
|
|
||||||
|
Event::handle('EndShowNoticeFormData', array($this));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -16,4 +16,8 @@
|
|||||||
}
|
}
|
||||||
div.replyform {
|
div.replyform {
|
||||||
display: none;
|
display: none;
|
||||||
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
.replyform .form_notice {
|
||||||
|
width: 75%;
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user