A
A
Andr Lw12016-04-25 08:29:46
WordPress
Andr Lw1, 2016-04-25 08:29:46

Why is post_date not specified when duplicating a post?

There is a script that duplicates the post with all its parameters. But it is not possible to specify a different publication date when duplicating.
Here's a script:

// дубликат поста
/*
 * Функция создает дубликат поста в виде черновика и редиректит на его страницу редактирования
 */
function true_duplicate_post_as_draft(){
  global $wpdb;
  if (! ( isset( $_GET['post']) || isset( $_POST['post'])  || ( isset($_REQUEST['action']) && 'true_duplicate_post_as_draft' == $_REQUEST['action'] ) ) ) {
    wp_die('Нечего дублировать!');
  }
 
  /*
   * получаем ID оригинального поста
   */
  $post_id = (isset($_GET['post']) ? $_GET['post'] : $_POST['post']);
  /*
   * а затем и все его данные
   */
  $post = get_post( $post_id );
 
  /*
   * если вы не хотите, чтобы текущий автор был автором нового поста
   * тогда замените следующие две строчки на: $new_post_author = $post->post_author;
   * при замене этих строк автор будет копироваться из оригинального поста
   */
  $current_user = wp_get_current_user();
  $new_post_author = $current_user->ID;
 
  /*
   * если пост существует, создаем его дубликат
   */
  if (isset( $post ) && $post != null) {
 
    /*
     * массив данных нового поста
     */
    $args = array(
      'comment_status' => $post->comment_status,
      'ping_status'    => $post->ping_status,
      'post_author'    => $new_post_author,
      'post_content'   => $post->post_content,
      'post_excerpt'   => $post->post_excerpt,
      'post_name'      => $post->post_name,
      'post_parent'    => $post->post_parent,
      'post_password'  => $post->post_password,
      'post_status'    => 'publish', // черновик, если хотите сразу публиковать - замените на publish
      'post_title'     => $post->post_title,
      'post_type'      => $post->post_type,
      'to_ping'        => $post->to_ping,
      'menu_order'     => $post->menu_order,
      'post_date'		 => '0000-00-00 00:00:00',
      'post_date_gmt'		 => '0000-00-00 00:00:00',
      'post_modified'	=> '0000-00-00 00:00:00',
      'post_modified_gmt'	=> '0000-00-00 00:00:00'
    );
 
    /*
     * создаем пост при помощи функции wp_insert_post()
     */
    $new_post_id = wp_insert_post( $args );
 
    /*
     * присваиваем новому посту все элементы таксономий (рубрики, метки и т.д.) старого
     */
    $taxonomies = get_object_taxonomies($post->post_type); // возвращает массив названий таксономий, используемых для указанного типа поста, например array("category", "post_tag");
    foreach ($taxonomies as $taxonomy) {
      $post_terms = wp_get_object_terms($post_id, $taxonomy, array('fields' => 'slugs'));
      wp_set_object_terms($new_post_id, $post_terms, $taxonomy, false);
    }
 
    /*
     * дублируем все произвольные поля
     */
    $post_meta_infos = $wpdb->get_results("SELECT meta_key, meta_value FROM $wpdb->postmeta WHERE post_id=$post_id");
    if (count($post_meta_infos)!=0) {
      $sql_query = "INSERT INTO $wpdb->postmeta (post_id, meta_key, meta_value) ";
      foreach ($post_meta_infos as $meta_info) {
        $meta_key = $meta_info->meta_key;
        $meta_value = addslashes($meta_info->meta_value);
        $sql_query_sel[]= "SELECT $new_post_id, '$meta_key', '$meta_value'";
      }
      $sql_query.= implode(" UNION ALL ", $sql_query_sel);
      $wpdb->query($sql_query);
    }
 
 
    /*
     * и наконец, перенаправляем пользователя на страницу редактирования нового поста
     */
    wp_redirect( admin_url( 'post.php?action=edit&post=' . $new_post_id ) );
    exit;
  } else {
    wp_die('Ошибка создания поста, не могу найти оригинальный пост с ID=: ' . $post_id);
  }
}
add_action( 'admin_action_true_duplicate_post_as_draft', 'true_duplicate_post_as_draft' );
 
/*
 * Добавляем ссылку дублирования поста для post_row_actions
 */
function true_duplicate_post_link( $actions, $post ) {
  if (current_user_can('edit_posts')) {
    $actions['duplicate'] = '<a href="admin.php?action=true_duplicate_post_as_draft&amp;post=' . $post->ID . '" title="Дублировать этот пост" rel="permalink">Дублировать</a>';
  }
  return $actions;
}
 
add_filter( 'post_row_actions', 'true_duplicate_post_link', 10, 2 );

Answer the question

In order to leave comments, you need to log in

1 answer(s)
I
Ivan Kozlov, 2016-04-25
@trampick

'post_date' => '0000-00-00 00:00:00',
'post_date_gmt' => '0000-00-00 00:00:00',
'post_modified' => '0000-00-00 00:00 :00',
'post_modified_gmt' => '0000-00-00 00:00:00'
these timings are responsible for adding the date.
Do like this:

$new_post_date = current_time('mysql');
$new_post_date_gmt = get_gmt_from_date($new_post_date);
 $args = array(
      'comment_status' => $post->comment_status,
      'ping_status'    => $post->ping_status,
      'post_author'    => $new_post_author,
      'post_content'   => $post->post_content,
      'post_excerpt'   => $post->post_excerpt,
      'post_name'      => $post->post_name,
      'post_parent'    => $post->post_parent,
      'post_password'  => $post->post_password,
      'post_status'    => 'publish', // черновик, если хотите сразу публиковать - замените на publish
      'post_title'     => $post->post_title,
      'post_type'      => $post->post_type,
      'to_ping'        => $post->to_ping,
      'menu_order'     => $post->menu_order,
      'post_date' => $new_post_date,
      'post_date_gmt' => $new_post_date_gmt,
      'post_modified' => $new_post_date,
      'post_modified_gmt' => $new_post_date_gmt,
    );

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question