X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fnewnotice.php;h=5f6a224848d2baa976de75aa97f0900dbb5629c8;hb=f26ed4626641d934eb8be8359bcc4aef03c97968;hp=23f31028bc94d7df46eb459da0112ffdc58fa3e3;hpb=52600ce0b063e68e622b19699841e41b5ddbf2d1;p=quix0rs-gnu-social.git diff --git a/actions/newnotice.php b/actions/newnotice.php index 23f31028bc..5f6a224848 100644 --- a/actions/newnotice.php +++ b/actions/newnotice.php @@ -20,56 +20,90 @@ if (!defined('LACONICA')) { exit(1); } class NewnoticeAction extends Action { - + function handle($args) { parent::handle($args); # XXX: Ajax! if (!common_logged_in()) { - common_user_error(_t('Not logged in.')); + common_user_error(_('Not logged in.')); } else if ($_SERVER['REQUEST_METHOD'] == 'POST') { - $id = $this->save_new_notice(); - if ($id) { - common_broadcast_notices($id); - common_redirect(common_local_url('shownotice', - array('notice' => $id)), 303); - } else { - common_server_error(_t('Problem saving notice.')); - } + $this->save_new_notice(); } else { $this->show_form(); } } function save_new_notice() { + $user = common_current_user(); assert($user); # XXX: maybe an error instead... - $notice = DB_DataObject::factory('notice'); + $notice = new Notice(); assert($notice); $notice->profile_id = $user->id; # user id *is* profile id + $notice->is_local = 1; $notice->created = DB_DataObject_Cast::dateTime(); - $notice->content = trim($this->arg('content')); + # Default theme uses 'content' for something else + $notice->content = $this->trimmed('status_textarea'); + + if (!$notice->content) { + $this->show_form(_('No content!')); + return; + } else if (strlen($notice->content) > 140) { + $this->show_form(_('That\'s too long. Max notice size is 140 chars.')); + return; + } + + $notice->rendered = common_render_content($notice->content, $notice); + + $id = $notice->insert(); + + if (!$id) { + common_server_error(_('Problem saving notice.')); + return; + } - $val = $notice->validate(); - if ($val === TRUE) { - return $notice->insert(); + $orig = clone($notice); + $notice->uri = common_notice_uri($notice); + + if (!$notice->update($orig)) { + common_server_error(_('Problem saving notice.')); + return; + } + + common_save_replies($notice); + $notice->saveTags(); + common_broadcast_notice($notice); + + $returnto = $this->trimmed('returnto'); + if ($returnto) { + $url = common_local_url($returnto, + array('nickname' => $user->nickname)); } else { - // XXX: display some info - return NULL; + $url = common_local_url('shownotice', + array('notice' => $id)); } + common_redirect($url, 303); } - function show_form() { - common_show_header(_t('New notice')); - common_element_start('form', array('id' => 'newnotice', 'method' => 'POST', - 'action' => common_local_url('newnotice'))); - common_element('span', 'nickname', $profile->nickname); - common_element('textarea', array('rows' => 3, 'cols' => 60, - 'name' => 'content', - 'id' => 'content'), - ' '); - common_submit('submit', _t('Send')); - common_element_end('form'); + function show_top($content=NULL) { + common_notice_form(NULL, $content); + } + + function show_form($msg=NULL) { + $content = $this->trimmed('status_textarea'); + if (!$content) { + $replyto = $this->trimmed('replyto'); + $profile = Profile::staticGet('nickname', $replyto); + if ($profile) { + $content = '@' . $profile->nickname . ' '; + } + } + common_show_header(_('New notice'), NULL, $content, + array($this, 'show_top')); + if ($msg) { + common_element('p', 'error', $msg); + } common_show_footer(); } -} \ No newline at end of file +}