wake-up-neo.com

Laden Sie tinyMCE/wp_editor () über AJAX

Mögliches Duplizieren:
Laden von wp_editor () über AJAX/jQuery

Es gibt mehrere Fragen dazu ( wie diese , oder jene ), aber keine von ihnen bietet mir eine Lösung.

Die Situation: Ich habe eine Metabox. In dieser Metabox möchte ich tinyMCE-Editoren dynamisch hinzufügen.

Der Code:

PHP:

add_action('wp_ajax_insert_tinymce', 'insert_tinymce');
function insert_tinymce(){
    wp_editor('','editor-id');
    exit;
}

JS:

$.post(
    global.ajaxurl,
    {
        action : 'insert_tinymce'
    },
    function(response) {

        $(response).appendTo('#target-div');

        console.log(tinyMCE); // no instance of 'editor-id'
        console.log(tinyMCEPreInit.mceInit); // 'editor-id' not listed
        console.log(tinyMCE.activeEditor); // null
    }
);

Das Ergebnis ist ein Editorfenster (mit HTML und visuellen Registerkarten), eine Upload-Schaltfläche und ein Textbereich, jedoch vollständig ohne Schaltflächen.

Was ich versucht habe (wie in den anderen Fragen vorgeschlagen):

// In the response function
tinyMCE.init({
    skin : "wp_theme",
    mode : "exact",
    elements : "editor-id",
    theme: "advanced"
});


// In the response function
tinyMCE.init(tinyMCEPreInit.mceInit['editor-id']);


// in the PHP
ob_start();
wp_editor( '', 'editor-id' );
echo ob_get_clean();

Dieser erste funktioniert, aber ich müsste viele Einstellungen manuell vornehmen, und meine benutzerdefinierten Schaltflächen werden nicht angezeigt.

Der zweite funktioniert offensichtlich nicht, da in editor-id kein tinyMCEPreInit.mceInit aufgeführt ist.

Die dritte (Ausgabepufferung) macht keinen Unterschied.


Ich habe festgestellt, dass wp_editor() die tinyMCE-Instanzen zu tinyMCEPreInit hinzufügt und über den admin_print_footer_scripts-Hook hinzufügt. Also müsste ich tinyMCEPreInit dynamisch aktualisieren (ohne die Instanz des Haupteditors zu verlieren) und dann tinyMCE.init(tinyMCEPreInit.mceInit['editor-id']) auslösen -VIELLEICHT

Jede Hilfe sehr geschätzt ;-)

Vielen Dank!

4
xsonic

ihr Beitrag hier hat mir geholfen, eine Lösung zu finden. Zusammen mit der Eigenschaft mceInit musste ich auch das von wp_editor generierte qtInit abrufen.

Das Folgende ist der relevante Code in meiner Klasse. Grundsätzlich habe ich wp_editor so laufen lassen, dass das Javascript generiert wird. Ich verwende Hooks, um das Javascript abzurufen, damit ich es in der Ajax-Antwort wiedergeben kann.

// ajax call to get wp_editor
add_action( 'wp_ajax_wp_editor_box_editor_html', 'wp_editor_box::editor_html' );
add_action( 'wp_ajax_nopriv_wp_editor_box_editor_html', 'wp_editor_box::editor_html' );

// used to capture javascript settings generated by the editor
add_filter( 'tiny_mce_before_init', 'wp_editor_box::tiny_mce_before_init', 10, 2 );
add_filter( 'quicktags_settings', 'wp_editor_box::quicktags_settings', 10, 2 );

class wp_editor_box {

    /*
    * AJAX Call Used to Generate the WP Editor
    */

    public static function editor_html() {
        $content = stripslashes( $_POST['content'] );
        wp_editor($content, $_POST['id'], array(
            'textarea_name' => $_POST['textarea_name']
        ) );
        $mce_init = self::get_mce_init($_POST['id']);
        $qt_init = self::get_qt_init($_POST['id']); ?>
        <script type="text/javascript">
            tinyMCEPreInit.mceInit = jQuery.extend( tinyMCEPreInit.mceInit, <?php echo $mce_init ?>);
            tinyMCEPreInit.qtInit = jQuery.extend( tinyMCEPreInit.qtInit, <?php echo $qt_init ?>);
        </script>
        <?php
        die();
    }

    /*
    * Used to retrieve the javascript settings that the editor generates
    */

    private static $mce_settings = null;
    private static $qt_settings = null;

    public static function quicktags_settings( $qtInit, $editor_id ) {
        self::$qt_settings = $qtInit;
                    return $qtInit;
    }

    public static function tiny_mce_before_init( $mceInit, $editor_id ) {
        self::$mce_settings = $mceInit;
                    return $mceInit;
    }

    /*
    * Code coppied from _WP_Editors class (modified a little)
    */
    private function get_qt_init($editor_id) {
        if ( !empty(self::$qt_settings) ) {
            $options = self::_parse_init( self::$qt_settings );
            $qtInit .= "'$editor_id':{$options},";
            $qtInit = '{' . trim($qtInit, ',') . '}';
        } else {
            $qtInit = '{}';
        }
        return $qtInit;
    }

    private function get_mce_init($editor_id) {
        if ( !empty(self::$mce_settings) ) {
            $options = self::_parse_init( self::$mce_settings );
            $mceInit .= "'$editor_id':{$options},";
            $mceInit = '{' . trim($mceInit, ',') . '}';
        } else {
            $mceInit = '{}';
        }
        return $mceInit;
    }

    private static function _parse_init($init) {
        $options = '';

        foreach ( $init as $k => $v ) {
            if ( is_bool($v) ) {
                $val = $v ? 'true' : 'false';
                $options .= $k . ':' . $val . ',';
                continue;
            } elseif ( !empty($v) && is_string($v) && ( ('{' == $v{0} && '}' == $v{strlen($v) - 1}) || ('[' == $v{0} && ']' == $v{strlen($v) - 1}) || preg_match('/^\(?function ?\(/', $v) ) ) {
                $options .= $k . ':' . $v . ',';
                continue;
            }
            $options .= $k . ':"' . $v . '",';
        }

        return '{' . trim( $options, ' ,' ) . '}';
    }

}


// the ajax respnose code
success : function(response){
    textarea.replaceWith(response);
    tinyMCE.init(tinyMCEPreInit.mceInit[data.id]);
    try { quicktags( tinyMCEPreInit.qtInit[data.id] ); } catch(e){}
}
3
Mike Allen