Как загрузить Web-запись Base64 Wave Audio в WordPress Post (интерфейсная форма) - PullRequest
0 голосов
/ 23 декабря 2019

Я создал почтовую форму WordPress, которая хорошо работает

И я хочу добавить поле:

Браузер, записывающий аудиофайл На основе base64 - (файл BLOB-объекта)

И загружать при публикации. Мой код JavaScript: https://subinsb.com/html5-record-mic-voice/

Это мой пример кода:

<?php
if ( isset( $_POST['submitted'] ) && isset( $_POST['post_nonce_field'] ) && wp_verify_nonce( $_POST['post_nonce_field'], 'post_nonce' ) ) {

    if ( trim( $_POST['postTitle'] ) === '' ) {
        $postTitleError = 'Please enter a title.';
        $hasError = true;
    }

    $post_information = array(
        'post_title' => wp_strip_all_tags( $_POST['postTitle'] ),
        'post_content' => $_POST['postContent'],
        'episode' => $_POST['postEpisode'],
        'post_type' => 'post',
        'post_status' => 'draft'
    );

    $post_id = wp_insert_post( $post_information );
    add_post_meta($post_id, 'episode', $_POST['postEpisode'], true);



/* upload file here */

    $file_name = $_FILES['fileToUpload']['name'];
    $file_temp = $_FILES['fileToUpload']['tmp_name'];

    $upload_dir = wp_upload_dir();
    $image_data = file_get_contents( $file_temp );
    $filename = basename( $file_name );
    $filetype = wp_check_filetype($file_name);
    $filename = time().'.'.$filetype['ext'];

    if ( wp_mkdir_p( $upload_dir['path'] ) ) {
      $file = $upload_dir['path'] . '/' . $filename;
    }
    else {
      $file = $upload_dir['basedir'] . '/' . $filename;
    }

    file_put_contents( $file, $image_data );
    $wp_filetype = wp_check_filetype( $filename, null );
    $attachment = array(
      'post_mime_type' => $wp_filetype['type'],
      'post_title' => sanitize_file_name( $filename ),
      'post_content' => '',
      'post_status' => 'inherit'
    );

    $attach_id = wp_insert_attachment( $attachment, $file );
    require_once( ABSPATH . 'wp-admin/includes/image.php' );
    $attach_data = wp_generate_attachment_metadata( $attach_id, $file,$post_id );
    wp_update_attachment_metadata( $attach_id, $attach_data,$post_id );

    echo $attach_id;
    }





?>
<?php if ( $postTitleError != '' ) { ?>
    <span class="error"><?php echo $postTitleError; ?></span>
    <div class="clearfix"></div>
<?php } ?>
<?php
if ( $post_id ) {
    wp_redirect( home_url() );
    exit;
}
?>
<form action="" id="primaryPostForm" method="POST" enctype="multipart/form-data">

    <fieldset>
        <label for="postTitle"><?php _e('Post Title:', 'framework') ?></label>

        <input type="text" name="postTitle" id="postTitle" class="required" value="" />
    </fieldset>

    <fieldset>
        <label for="postContent"><?php _e('Post Content:', 'framework') ?></label>

        <textarea name="postContent" id="postContent" rows="8" cols="30" class="required"></textarea>
    </fieldset>


    <fieldset>
        <label for="postEpisode"></label>

        <textarea name="postEpisode" id="postEpisode" rows="8" cols="30" class="required"></textarea>
    </fieldset>



    <?php
    /*----------------- recorder filed here -----------------*/
    ?>
    <audio controls id="audio"></audio>
    <div>
      <a class="button recordButton" id="record">Record</a>
      <a class="button recordButton" id="recordFor5">Record For 5 Seconds</a>
      <a class="button disabled one" id="pause">Pause</a>
      <a class="button disabled one" id="stop">Reset</a>
    </div><br/>
    <div>
      <input class="button" type="checkbox" id="live"/>
      <label for="live">Live Output</label>
    </div>
        <div data-type="wav">
            <p>WAV Controls:</p>
            <a class="button disabled one" id="play">Play</a>
            <a class="button disabled one" id="download">Download</a>
      <a class="button disabled one" id="base64">Base64 URL</a>
      <a class="button disabled one" id="save">Upload to Server</a>
        </div>



    <canvas id="level" height="200" width="500"></canvas>


    <fieldset>
    <?php wp_nonce_field( 'post_nonce', 'post_nonce_field' ); ?>
        <input type="hidden" name="submitted" id="submitted" value="true" />

        <button type="submit"><?php _e('Add Post', 'framework') ?></button>
    </fieldset>

</form>

Файл JavaScript:

            function restore(){
              $("#record, #live").removeClass("disabled");
              $(".one").addClass("disabled");
              Fr.voice.stop();
            }
            $(document).ready(function(){
              $(document).on("click", "#record:not(.disabled)", function(){
                elem = $(this);
                Fr.voice.record($("#live").is(":checked"), function(){
                  elem.addClass("disabled");
                  $("#live").addClass("disabled");
                  $(".one").removeClass("disabled");
                });
              });

              $(document).on("click", "#stop:not(.disabled)", function(){
                restore();
              });

              $(document).on("click", "#play:not(.disabled)", function(){
                Fr.voice.export(function(url){
                  $("#audio").attr("src", url);
                  $("#audio")[0].play();
                }, "URL");
                restore();
              });

              $(document).on("click", "#download:not(.disabled)", function(){
                Fr.voice.export(function(url){
                  $("<a href='"+url+"' download='MyRecording.wav'></a>")[0].click();
                }, "URL");
                restore();
              });

              $(document).on("click", "#base64:not(.disabled)", function(){
                Fr.voice.export(function(url){
                  console.log("Here is the base64 URL : " + url);
                  alert("Check the web console for the URL");

                  $("<a href='"+ url +"' target='_blank'></a>")[0].click();
                }, "base64");
                restore();
              });

              $(document).on("click", "#mp3:not(.disabled)", function(){
                alert("The conversion to MP3 will take some time (even 10 minutes), so please wait....");
                Fr.voice.export(function(url){
                  console.log("Here is the MP3 URL : " + url);
                  alert("Check the web console for the URL");

                  $("<a href='"+ url +"' target='_blank'></a>")[0].click();
                }, "mp3");
                restore();
              });
            });

Я искал несколько сайтов и, к сожалению, не нашел ни одногоправильное решение этой проблемы.

Я хочу загрузить этот файл вместе с сообщением. И отобразить в пользовательском поле в бэкенде

Может кто-нибудь мне помочь?

...