2017-02-03 3 views
2

Я не буду добиваться следующих целей: Я должен сохранить дубликат вновь созданного сообщения, если пользователь создает новое сообщение (cpt). Впоследствии я поставлю это новое сообщение с помощью Polylang на другой язык в качестве перевода для сообщения, созданного на первом шаге.WordPress Сохранение сообщения для перевода при создании нового сообщения

крюка в следующие действия должны привести к желаемому результату:

add_action('new_to_publish', 'duplicate_to_english'); 
add_action('draft_to_publish', 'duplicate_to_english'); 
add_action('pending_to_publish', 'duplicate_to_english'); 

function duplicate_to_english($post) 
{ 
    $en_post = pll_get_post($post->ID, 'en'); 
    if(empty($en_post)) { 
     $new_post = (array) $post; 
     unset($new_post['ID']); 
     // INFINITE LOOP 
     $en_id = wp_insert_post($new_post); 
     pll_set_post_language($en_id, 'en'); 
    } 

} 

Но, к сожалению, это приведет к бесконечной петле (как ожидалось). Теперь я ищу возможность избежать этого цикла. Моя первая идея заключалась в том, чтобы установить переменную $ _POST и выполнить только дублирование, если эта переменная установлена. Но я понятия не имею, как определить новый пост. Я обнаружил, что WordPress немедленно сохраняет авто-черновик при нажатии кнопки «Новая публикация», поэтому поиск сообщения ID = 0 не работает. Любой другой подход приветствуется.

ответ

0

Для всех, кто нуждается в решении:

Я использую метод, называемый, чтобы сохранить мета-данные для выполнения дублирования моего поста:

add_action ('save_post', 'save_meta', 1, 3); // save the custom fields 

function save_meta($post_id, $post, $update) 
{ 
    // here we check for the transient set in duplicate_post 
    // if existing delete it end return because we are saving only 
    // the duplicate. This will avoid infinite loop while saving the 
    // new translated post 
    $english = get_transient('saving_english'); 
    if($english) { 
     delete_transient('saving_english'); 
     return $post->ID; 
    } 

    // In case of auto saving draft we can return and don't duplicate the post 
    if (!wp_verify_nonce($_POST['nonce'], 'nonce')) { 
     return $post->ID; 
    } 

    if (! current_user_can ('edit_post', $post->ID)) { 
     return $post->ID; 
    } 

    // collect meta data from $_POST 
    $item_meta = $_POST['post_meta']; 

    // Updating meta data for the original post 
    loop_through_meta($item_meta, $post); 

    // looking for translated version 
    $en_id = pll_get_post($post->ID, 'en'); 

    // If the translated post is missing, set transient, 
    // duplicate the post and category and afterwards write 
    // the taxonomy entry for polylang 
    if (empty($en_id)) { 
     set_transient('saving_english', true); 
     if ($en_id = duplicate_post($post, $item_meta['title_english'])) { 
      pll_save_post_translations([ 
       'de' => $post->ID, 
       'en' => $en_id 
      ]); 
     } 
    // If the translated posts already exists deregister the hook 
    // to avoid infinite loop. 
    // But note the third parameter priority: It must be the same 
    // priority as used for registering the hook 
    } else { 
     remove_action('save_post', 'save__meta',1); 
     wp_update_post([ 
      'ID' => $en_id, 
      'post_title' => $item_meta['title_english'] 
     ]); 
     add_action ('save_post', 'save_meta', 1, 3); 
    } 

    // If we have an id save new meta to the translated post 
    if(!empty($en_id)) { 
     loopt_through_meta($item_meta, get_post($en_id)); 
    } 

} 

function duplicate_post ($post, $title) 
{ 
    $new_post = (array) $post; 
    unset($new_post['ID']); 
    $new_post['post_title'] = $title; 
    $new_id = wp_insert_post($new_post); 

    // Here we only need to set the custom category but not 
    // the Polylang taxonomy. 
    $taxonomies = get_object_taxonomies($post->post_type); 
    foreach ($taxonomies as $taxonomy) { 
     if($taxonomy != 'custom_categories') continue; 
     $post_terms = wp_get_object_terms($post->ID, $taxonomy, array('fields' => 'slugs')); 
     wp_set_object_terms($new_id, $post_terms, $taxonomy, false); 
    } 

    pll_set_post_language($new_id, 'en'); 
    return $new_id; 
} 

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

Смежные вопросы