web-dev-qa-db-fra.com

Comment ajouter du javascript personnalisé à WordPress Admin?

Je veux ajouter un code jquery personnalisé à la page Modifier le message, quelque chose de vraiment simple comme montrer un div quand quelqu'un appuie sur Publier.

La seule restriction est que je veux y parvenir en utilisant un plugin, pas en piratant les fichiers de modèle d'administration.

J'ai essayé de faire écho à certaines balises de script à l'aide de certaines actions, mais cela ne semble pas être le cas.

30
Nacho

Utilisez le admin_enqueue_scripts et l'action wp_enqueue_script méthode pour ajouter des scripts personnalisés à l'interface d'administration.

Cela suppose que vous avez myscript.js dans votre dossier de plugin. Changez en conséquence. Le my_custom_script le handle doit être unique pour votre module et votre script.

function my_enqueue($hook) {
    // Only add to the edit.php admin page.
    // See WP docs.
    if ('edit.php' !== $hook) {
        return;
    }
    wp_enqueue_script('my_custom_script', plugin_dir_url(__FILE__) . '/myscript.js');
}

add_action('admin_enqueue_scripts', 'my_enqueue');
62
Tim

Il existe un extrait pour votre fichier functions.php:

function custom_admin_js() {
    $url = get_bloginfo('template_directory') . '/js/wp-admin.js';
    echo '"<script type="text/javascript" src="'. $url . '"></script>"';
}
add_action('admin_footer', 'custom_admin_js');

Fonctionne très bien sur Wordpress 3.2.1.

42
Fedir RYKHTIK
<?php
function add_jquery_data() {
    global $parent_file;

    if ( isset( $_GET['action'] ) && $_GET['action'] == 'edit' && isset( $_GET['post'] ) && $parent_file == 'edit.php') {
    // Do some stuff.
    }
}

add_filter('admin_head', 'add_jquery_data');

?>
19
Sean Fisher

admin_enqueue_scripts et wp_enqueue_script est le moyen préféré pour ajouter des fichiers javascript au tableau de bord.

// I'm using an anonymous function for brevity.
add_action( 'admin_enqueue_scripts', function() {
    wp_enqueue_script( 'handle', plugin_dir_url( __FILE__ ) . '/script.js' );
} );

Si vous voulez sortir le javascript en utilisant votre fonction PHP cependant, wp_add_inline_script ne semble pas fonctionner. À la place, vous pouvez utiliser admin_print_scripts pour renvoyer directement le script, y compris les balises de script elles-mêmes. Assurez-vous simplement de définir une priorité élevée afin qu'elle se charge après toutes les bibliothèques requises, telles que jQuery.

add_action( 'admin_print_scripts', function() {
    // I'm using NOWDOC notation to allow line breaks and unescaped quotation marks.
    echo <<<'EOT'
<script type="text/javascript">
jQuery(function($){
    // Do stuff here.
});
</script>
EOT;
}, PHP_INT_MAX );
3
Shaun Cockerill

Si vous voulez obtenir de la fantaisie et filtrer où vous voulez charger le fichier ou non, mieux vaut utiliser get_current_screen .

function myproject_admin_enqueue() {

    $screen = get_current_screen();

    // load on the NEW and EDIT screens of all post types
    if ( 'post' === $screen->base ) {
        wp_enqueue_script('my_custom_script', plugin_dir_url( __FILE__ ) . 'all-admin.js');
    }

    // load on the NEW and EDIT screens of one post type
    if ( 'post' === $screen->base && 'myposttype' === $screen->post_type ) {
        wp_enqueue_script('my_custom_script', plugin_dir_url( __FILE__ ) . 'mypostype-admin.js');
    }

    // load only when adding a NEW post, not when editing an existing one.
    if ( 'post' === $screen->base && 'add' === $screen->action ) {
        wp_enqueue_script('my_custom_script', plugin_dir_url( __FILE__ ) . 'new-admin.js');
    }

}
add_action('admin_enqueue_scripts', 'myproject_admin_enqueue');
0
squarecandy