* @link http://status.net/
*/
-if (!defined('STATUSNET') && !defined('LACONICA')) {
- exit(1);
-}
-
-require_once INSTALLDIR.'/lib/form.php';
+if (!defined('GNUSOCIAL')) { exit(1); }
/**
* Form for posting a notice
*/
function __construct($action, $options=null)
{
- // XXX: ??? Is this to keep notice forms distinct?
- // Do we have to worry about sub-second race conditions?
- // XXX: Needs to be above the parent::__construct() call...?
-
- $this->id_suffix = time();
-
parent::__construct($action);
+ // When creating a notice form we don't want to collide with
+ // possibly existing HTML elements, as naming conventions are similar.
+ $this->id_suffix = rand();
+
if (is_null($options)) {
$options = array();
}
if (empty($this->to_profile) &&
!empty($this->inreplyto)) {
- $notice = Notice::staticGet('id', $this->inreplyto);
+ $notice = Notice::getKV('id', $this->inreplyto);
if (!empty($notice)) {
$this->to_profile = $notice->getProfile();
}
$this->out->element('legend', null, _('Send a notice'));
}
+ protected function placeholderText()
+ {
+ if ($this->inreplyto) {
+ return _('Write a reply...');
+ }
+
+ return _('Share your status...');
+ }
+
/**
* Data elements
*
sprintf(_('What\'s up, %s?'), $this->user->nickname));
// XXX: vary by defined max size
$this->out->element('textarea', array('class' => 'notice_data-text',
+ 'required' => 'required',
+ 'placeholder' => $this->placeholderText(),
'cols' => 35,
'rows' => 4,
'name' => 'status_textarea'),
if (common_config('attachments', 'uploads')) {
$this->out->hidden('MAX_FILE_SIZE', common_config('attachments', 'file_quota'));
- $this->out->elementStart('label', array('class' => 'notice_data-attach'));
- // TRANS: Input label in notice form for adding an attachment.
- $this->out->text(_('Attach'));
+ $this->out->element('label', array('class' => 'notice_data-attach',
+ 'for' => $this->id().'-notice_data-attach'),
+ // TRANS: Input label in notice form for adding an attachment.
+ _('Attach'));
+ // The actual input element tends to be hidden with CSS.
$this->out->element('input', array('class' => 'notice_data-attach',
'type' => 'file',
'name' => 'attach',
+ 'id' => $this->id().'-notice_data-attach',
// TRANS: Title for input field to attach a file to a notice.
'title' => _('Attach a file.')));
- $this->out->elementEnd('label');
}
if (!empty($this->actionName)) {
$this->out->hidden('notice_return-to', $this->actionName, 'returnto');
$toWidget->show();
$this->out->elementEnd('div');
- if ($this->user->shareLocation()) {
+ if ($this->profile->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');
'data-api' => common_local_url('geocode')));
// @fixme checkbox method allows no way to change the id without changing the name
- //// TRANS: Checkbox label to allow sharing geo location in notices.
//$this->out->checkbox('notice_data-geo', _('Share my location'), true);
- $this->out->elementStart('label', 'notice_data-geo');
$this->out->element('input', array(
'name' => 'notice_data-geo',
'type' => 'checkbox',
'id' => $this->id() . '-notice_data-geo',
'checked' => true, // ?
));
- $this->out->text(' ');
- // TRANS: Field label to add location to a notice.
- $this->out->text(_('Share my location'));
- $this->out->elementEnd('label');
+ $this->out->element('label', array('class' => 'notice_data-geo',
+ 'for' => $this->id().'-notice_data-geo'),
+ // TRANS: Checkbox label to allow sharing geo location in notices.
+ _('Share my location'));
$this->out->elementEnd('div');
// TRANS: Text to not share location for a notice in notice form.