Контактная форма Wordpress 7 устанавливает получателя из пользовательского шорткода

Я не могу заставить это работать. И кажется невозможным получить какую-либо реальную документацию процесса.

У меня есть собственный шорткод в файле functions.php, который получает адрес электронной почты из внешнего API. Я хотел бы использовать этот шорткод в поле «КОМУ» (т.е. получатель) в WPCF7. Но он продолжает выдавать мне предупреждение об ошибке «синтаксическая ошибка».

Мне нужно найти способ заставить поле получателя принимать пользовательский шорткод из моего файла functions.php.

Я пробовал плагин динамического текста, но он не работает.

Вот пример моего шорткода

function single_email() {
    global $contact;
    return $contact->email;
}add_shortcode( 'contact_email', 'single_email' );

Может быть, что-то вроде использования «wpcf7_special_mail_tags» и «do_shortcode()»? Хотя не совсем уверен, как это работает.

Использование версии 4.4.2 WPCF7.


person axelra82    schedule 27.05.2016    source источник
comment
Вы имеете в виду, что вам нужно создать шорткод contact_email, верно?   -  person Purvik Dhorajiya    schedule 27.05.2016
comment
Виноват! Да, add_shortcode. Я исправил вопрос.   -  person axelra82    schedule 27.05.2016


Ответы (2)


Не могли бы вы проверить код ниже?

wpcf7_add_shortcode('contact_email', 'single_email', true);
function single_email(){
    global $contact;
    return $contact->email;
}
person Purvik Dhorajiya    schedule 27.05.2016
comment
Ошибка - это просто синтаксическая ошибка для поля to. На всякий случай моей текущей версией WPCF является версия 4.4.2. - person axelra82; 27.05.2016

Вы можете использовать так, чтобы создать новое поле в таблице wp_options и использовать так.

На странице контактов

      <div class="contant">
      <div class="section">
        <div class="contact_pannel">
          <h1>You can find us literally anywhere, just push a button and we’re there</h1>
          <div class="lf_pannel">
          <form action="" method="" id='myForm'  onsubmit=" return pretendValidation();  ">
            <h2>Use this form to send us a message:</h2>
            <div class="fild">
                <label class="label">Name</label>
                <input name="Name"   type="text" class="input">
            </div>

            <div class="fild">
                <label class="label">Email</label>
                <input name="Email" type="email" class="input" required=required  >
            </div>

            <div class="fild">
                <label class="label">Company</label>
                <input name="Company" type="text" class="input">
            </div>

            <div class="fild">
                <label class="label">Subject</label>
                <input name="Subject" type="text" class="input">
            </div>

            <div class="fild">
                <label class="label">Message</label>
                <textarea class="input" style="height:90px;" id='Message'></textarea>
            </div>
                <input name="submitt" type="submit" id="submitt" style="display:none;">

            <a href="javascript:void(0);" class="send_button margin_right23" onclick="document.getElementById('mailed').style.display = 'none'; document.getElementById('submitt').click();" >Send Message</a>
          </form>

          <div class="  wpcf7-display-none " id="mailed"   role="alert">Your message was sent successfully. Thanks.</div>
          </div>

          <div class="rg_pannel">


          <?php echo html_entity_decode(  get_option('admin_address') );?>





          </div> 
        </div> 
      </div>
    </div>

    <script>
    function pretendValidation(){


    jQuery(document).ready(function($) {

        // We'll pass this variable to the PHP function example_ajax_request
        var fruit = 'Banana';
          // console.log($( "#myForm" ).serialize());
        // This does the ajax request

        $.post( "<?=get_template_directory_uri () ;?>/contact_ajax.php",
        { myForm: $( "#myForm" ).serialize(), Message: $( "#Message" ).val() },
        function( data ) {
          console.log( data ); // John

        });




         $('#myForm')[0].reset();

         $( "#mailed" ).show( "slow" );

    });
        return false;
    }
    </script>

После этого вам нужно создать страницу ajax, подобную этой

contact_ajax.php

<?php

/** Load WordPress Bootstrap */
require_once  ( '../../../wp-load.php' );

// echo "1232".site_url();


// print_r($_REQUEST);

$params = array();
parse_str($_REQUEST['myForm'], $params);
$params['Message']= $_REQUEST['Message'];
// print_r($params);

$to      = get_option('your_email_field_name');
// $to      = "[email protected]";
$subject = 'Fokus Tech Contact Form';
  $message = "Hello,\n"
            ."Name: ".$params ['Name']."\n"
            ."Email: ". $params ['Email']."\n"
            ."Company: ".$params ['Company']."\n"
            ."Subject: ". $params ['Subject']."\n"
            ."Message: ".$params['Message'] ."\n"

;
$headers = 'From: [email protected]' . "\r\n" .
    'Reply-To: [email protected]' . "\r\n" .
    'X-Mailer: PHP/' . phpversion();

mail($to, $subject, $message, $headers);

?>
person Gorakh Yadav    schedule 27.05.2016