Wordpress

Как в WordPress создать копию страницы или записи

Часто в ходе работы приходится сталкиваться с задачей создания однотипных страниц, которые могут отличаться друг от друга только текстом. Например, это актуально при работе с блогами или интернет-магазинами, в процессе создания лендингов. Особенно данная опция стала актуальной после внедрения нового редактора в Wordpress — Гутенберг, который позволяет без знаний принципов работы с кодов и установки дополнительных плагинов с легкостью создавать насыщенные блоками и информацией страницы. При этом до сих пор, на момент написания статьи актуальной является версия 5.0.3, в Wordpress нет функции копирования записи и страницы. Но ее легко добавить, как с помощью плагинов, так и самостоятельно.

Копирование записей и страниц без плагинов

Есть распространенный миф, что установка дополнительных плагинов сильно тормозит работу WordPress. «Тормоза» вызывают только плохо оптимизированные плагины. Тем не менее, если вы хотите добавить функцию копирования записей и страниц без использования сторонних плагинов, это можно сделать.

Зайдите в Wordpress в разделе «Внешний вид» в пункт «Редактор».

Далее выберите среди доступных файлов function. php.

Прокрутите этот файл до конца и вставьте в него следующий код:

/*
 * Function for post duplication. Dups appear as drafts. User is redirected to the edit screen
 */
function rd_duplicate_post_as_draft(){
  global $wpdb;
  if (! ( isset( $_GET['post']) || isset( $_POST['post'])  || ( isset($_REQUEST['action']) && 'rd_duplicate_post_as_draft' == $_REQUEST['action'] ) ) ) {
    wp_die('No post to duplicate has been supplied!');
  }
 
  /*
   * Nonce verification
   */
  if ( !isset( $_GET['duplicate_nonce'] ) || !wp_verify_nonce( $_GET['duplicate_nonce'], basename( __FILE__ ) ) )
    return;
 
  /*
   * get the original post id
   */
  $post_id = (isset($_GET['post']) ? absint( $_GET['post'] ) : absint( $_POST['post'] ) );
  /*
   * and all the original post data then
   */
  $post = get_post( $post_id );
 
  /*
   * if you don't want current user to be the new post author,
   * then change next couple of lines to this: $new_post_author = $post->post_author;
   */
  $current_user = wp_get_current_user();
  $new_post_author = $current_user->ID;
 
  /*
   * if post data exists, create the post duplicate
   */
  if (isset( $post ) && $post != null) {
 
    /*
     * new post data array
     */
    $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'    => 'draft',
      'post_title'     => $post->post_title,
      'post_type'      => $post->post_type,
      'to_ping'        => $post->to_ping,
      'menu_order'     => $post->menu_order
    );
 
    /*
     * insert the post by wp_insert_post() function
     */
    $new_post_id = wp_insert_post( $args );
 
    /*
     * get all current post terms ad set them to the new post draft
     */
    $taxonomies = get_object_taxonomies($post->post_type); // returns array of taxonomy names for post type, ex 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);
    }
 
    /*
     * duplicate all post meta just in two SQL queries
     */
    $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;
        if( $meta_key == '_wp_old_slug' ) continue;
        $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);
    }
 
 
    /*
     * finally, redirect to the edit post screen for the new draft
     */
    wp_redirect( admin_url( 'post.php?action=edit&post=' . $new_post_id ) );
    exit;
  } else {
    wp_die('Post creation failed, could not find original post: ' . $post_id);
  }
}
add_action( 'admin_action_rd_duplicate_post_as_draft', 'rd_duplicate_post_as_draft' );
 
/*
 * Add the duplicate link to action list for post_row_actions
 */
function rd_duplicate_post_link( $actions, $post ) {
  if (current_user_can('edit_posts')) {
    $actions['duplicate'] = '<a href="' . wp_nonce_url('admin.php?action=rd_duplicate_post_as_draft&post=' . $post->ID, basename(__FILE__), 'duplicate_nonce' ) . '" title="Duplicate this item" rel="permalink">Создать копию</a>';
  }
  return $actions;
}
 
add_filter( 'post_row_actions', 'rd_duplicate_post_link', 10, 2 );

Далее сохраните изменения.

После этого остается зайти в раздел «Записи». Здесь вы увидите, что рядом с основными кнопками быстрого взаимодействия с записями появилась кнопка «Создать копию».

После нажатия на нее в разделе «Записи» создастся новый элемент, который получит статус черновика. При этом сразу откроется редактор для его изменения.

Обратите внимание: Приведенный выше код позволяет добавить функцию копирования только в раздел «Записи». Если требуется копировать страницы, измените в последней строчке кода post_row_actions на page_row_actions.

Копирование записей и страниц с помощью плагина Duplicate Post

Среди плагинов WordPress есть немалое количество тех, которые позволяют копировать страницы и записи. Рассмотрим один из таких плагинов — Duplicate Post.

Почему лучше использовать данный плагин, а не приведенный выше код:

  • Не потребуется захламлять файл function. php. Если регулярно добавлять нужные функции при помощью кода в файл function, со временем это приведет к тому, что работать с ним станет сложнее. А плагин всегда можно включить/выключить или удалить;
  • Плагин имеет тонкую настройку. Это мы рассмотрим ниже;
  • В отличие от приведенного выше кода, плагин сразу даст возможность копировать и записи и страницы, а вместе с тем и слайдеры, блоки и многое другое (при необходимости);
  • Плагин позволяет создавать копию нужной записи или страницы, не переходя сразу в режим редактирования, что бывает полезно в ряде случаев.

Вообщем, если говорить в двух словах, тонкая настройка и дополнительная функциональность позволяют плагину выиграть у метода прямой установки кода.

Сразу после установки плагина вы заметите, что в разделах «Записи» и «Страницы» появились две новых кнопки для быстрого редактирования — «Клонировать» и «Новый черновик». Нажимая на кнопку «Клонировать», вы создадите копию записи (страницы или другого элемента) и останетесь в списке всех записей. Нажимая на кнопку «Новый черновик», вы создадите копию элемента, но при этом сразу перейдете в его редактирование.

Чтобы настроить плагин Duplicate Post, нужно перейти в настройках к его параметрам. Здесь 3 раздела настроек.

«Что копировать». В этом разделе у вас есть возможность задать, какие параметры копируемого элемента будут добавлены в создаваемый черновик. В том числе, на этой странице настраивается префикс или суффикс заголовка, а также порядковый номер создаваемой копии и поля, которые не нужно копировать.

«Разрешения». В этом разделе можно выбрать, какие категории пользователей будут иметь право использования плагина Duplicate Post. По умолчанию это администратор и редактор. Также здесь можно настроить список элементов, для которых актуальна функция копирования.

«Отображать». В этом разделе настраивается, где именно будет отображаться функция копирования. По умолчанию ее можно найти не только в списке всех записей/страниц, но и в административной панели сверху, на экране редактирования и действий.

В целом, настройка плагина Duplicate Post проста и понятно, и его гораздо удобнее использовать, нежели работать просто с функцией, рассмотренной выше.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Close