Fixes #1837 timestamp funkiness

git-svn-id: http://svn.automattic.com/wordpress/trunk@3074 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
matt 2005-11-14 09:56:41 +00:00
parent f1bd822833
commit f059c4f049
2 changed files with 34 additions and 23 deletions

View File

@ -836,14 +836,11 @@ function update_meta($mid, $mkey, $mvalue) {
function touch_time($edit = 1, $for_post = 1) { function touch_time($edit = 1, $for_post = 1) {
global $month, $post, $comment; global $month, $post, $comment;
if ($for_post && ('draft' == $post->post_status)) {
$checked = 'checked="checked" ';
$edit = false;
} else {
$checked = ' ';
}
echo '<fieldset><legend><input type="checkbox" class="checkbox" name="edit_date" value="1" id="timestamp" '.$checked.'/> <label for="timestamp">'.__('Edit timestamp').'</label></legend>'; if ( $for_post )
$edit = ( ('draft' == $post->post_status) && (!$post->post_date || '0000-00-00 00:00:00' == $post->post_date) ) ? false : true;
echo '<fieldset><legend><input type="checkbox" class="checkbox" name="edit_date" value="1" id="timestamp" /> <label for="timestamp">'.__('Edit timestamp').'</label></legend>';
$time_adj = time() + (get_settings('gmt_offset') * 3600); $time_adj = time() + (get_settings('gmt_offset') * 3600);
$post_date = ($for_post) ? $post->post_date : $comment->comment_date; $post_date = ($for_post) ? $post->post_date : $comment->comment_date;
@ -873,19 +870,11 @@ function touch_time($edit = 1, $for_post = 1) {
<input type="text" id="hh" name="hh" value="<?php echo $hh ?>" size="2" maxlength="2" /> : <input type="text" id="hh" name="hh" value="<?php echo $hh ?>" size="2" maxlength="2" /> :
<input type="text" id="mn" name="mn" value="<?php echo $mn ?>" size="2" maxlength="2" /> <input type="text" id="mn" name="mn" value="<?php echo $mn ?>" size="2" maxlength="2" />
<input type="hidden" id="ss" name="ss" value="<?php echo $ss ?>" size="2" maxlength="2" /> <input type="hidden" id="ss" name="ss" value="<?php echo $ss ?>" size="2" maxlength="2" />
<?php _e('Existing timestamp'); ?>: <?php
<?php if ( $edit ) {
_e('Existing timestamp');
// We might need to readjust to display proper existing timestamp echo ": {$month[$mm]} $jj, $aa @ $hh:$mn";
if ($for_post && ('draft' == $post->post_status)) {
$jj = mysql2date('d', $post_date);
$mm = mysql2date('m', $post_date);
$aa = mysql2date('Y', $post_date);
$hh = mysql2date('H', $post_date);
$mn = mysql2date('i', $post_date);
$ss = mysql2date('s', $post_date);
} }
echo "{$month[$mm]} $jj, $aa @ $hh:$mn";
?> ?>
</fieldset> </fieldset>
<?php <?php

View File

@ -54,10 +54,17 @@ function wp_insert_post($postarr = array()) {
$post_name = sanitize_title($post_name); $post_name = sanitize_title($post_name);
} }
if (empty($post_date))
$post_date = current_time('mysql'); // If the post date is empty (due to having been new or a draft) and status is not 'draft', set date to now
if (empty($post_date_gmt)) if (empty($post_date)) {
$post_date_gmt = get_gmt_from_date($post_date); if ( 'draft' != $post_status )
$post_date = current_time('mysql');
}
if (empty($post_date_gmt)) {
if ( 'draft' != $post_status )
$post_date_gmt = get_gmt_from_date($post_date);
}
if ( empty($comment_status) ) { if ( empty($comment_status) ) {
if ( $update ) if ( $update )
@ -382,6 +389,21 @@ function wp_update_post($postarr = array()) {
$postarr = array_merge($post, $postarr); $postarr = array_merge($post, $postarr);
$postarr['post_category'] = $post_cats; $postarr['post_category'] = $post_cats;
// Drafts shouldn't be assigned a date unless explicitly done so by the user
if ( 'draft' == $post['post_status'] && empty($postarr['edit_date']) && empty($postarr['post_date']) &&
('0000-00-00 00:00:00' == $post['post_date']) )
$clear_date = true;
else
$clear_date = false;
// Merge old and new fields with new fields overwriting old ones.
$postarr = array_merge($post, $postarr);
$postarr['post_category'] = $post_cats;
if ( $clear_date ) {
$postarr['post_date'] = '';
$postarr['post_date_gmt'] = '';
}
return wp_insert_post($postarr); return wp_insert_post($postarr);
} }