web-dev-qa-db-fra.com

Variable non définie - Type de message personnalisé

J'ai lu de nombreuses questions connexes et j'ai essayé tout ce que je pouvais, alors assurez-vous qu'il s'agit bien d'un doublon avant de le signaler, s'il vous plaît.

J'utilise WordPress depuis environ 6 ans, donc quand je dis que je suis coincé, je le pense vraiment.

J'essaie d'ajouter des méta-boîtes personnalisées à un CPT, boat. Ci-dessous mon code et l'erreur que je reçois.

Message d'erreur:

Notice: Undefined variable: boat_make in /path/to/file/wp-content/plugins/syb/admin/class-syb-admin.php on line 150

Ce message d'erreur est le même pour les deux champs.

Voici mon code:

/**
 * Register all of the hooks related to the admin area functionality
 * of the plugin.
 *
 * @since    1.0.0
 * @access   private
 */
private function define_admin_hooks() {

    ...

    /**
     * Add metabox and register custom fields
     *
     * @link https://code.tutsplus.com/articles/rock-solid-wordpress-30-themes-using-custom-post-types--net-12093
     */
    $this->loader->add_action( 'add_meta_boxes', $plugin_admin, 'rerender_meta_options' );
    $this->loader->add_action( 'save_post', $plugin_admin, 'save_meta_options' );

}

...

/**
 * Save Custom Fields
 *
 * @since    1.0.0
 */
public function save_meta_options() {
    if ( ! current_user_can( '' ) ) return;
    global $post;

    update_post_meta($post->ID, "customer_id", $_POST["customer_id"]);
    update_post_meta($post->ID, "boat_make", $_POST["boat_make"]);
}

/**
 * Create a meta box for our custom fields
 *
 * @since    1.0.0
 */ 
public function rerender_meta_options() {
    add_meta_box("boat-meta", "Boat Details", array($this, "display_meta_options"), "boat", "normal", "low");
}

/**
 * Display meta box and custom fields
 *
 * @since    1.0.0
 */  
public function display_meta_options() {
    global $post; 

    $custom = get_post_custom($post->ID);
    var_dump($custom);

    if (isset($custom["customer_id"][0])) {
        $customer_id = $custom["customer_id"][0];
    }  

    ?>
    <label><?php _e( 'Boat Colour:', $this->plugin_name ); ?></label><input name="customer_id" value="<?php echo $customer_id; ?>" /><br>
    <?php 

    if (isset($custom["boat_make"][0])) {
        $boat_make = $custom["boat_make"][0];
    }  

    ?>
    <label><?php _e( 'Boat Make:', $this->plugin_name ); ?></label><textarea name="boat_make"><?php echo $boat_make; ?></textarea>
    <?php
}

Méthode de chargement:

class Syb_Loader {

/**
 * The array of actions registered with WordPress.
 *
 * @since    1.0.0
 * @access   protected
 * @var      array    $actions    The actions registered with WordPress to fire when the plugin loads.
 */
protected $actions;

/**
 * The array of filters registered with WordPress.
 *
 * @since    1.0.0
 * @access   protected
 * @var      array    $filters    The filters registered with WordPress to fire when the plugin loads.
 */
protected $filters;

/**
 * Initialize the collections used to maintain the actions and filters.
 *
 * @since    1.0.0
 */
public function __construct() {

    $this->actions = array();
    $this->filters = array();

}

/**
 * Add a new action to the collection to be registered with WordPress.
 *
 * @since    1.0.0
 * @param    string               $hook             The name of the WordPress action that is being registered.
 * @param    object               $component        A reference to the instance of the object on which the action is defined.
 * @param    string               $callback         The name of the function definition on the $component.
 * @param    int                  $priority         Optional. The priority at which the function should be fired. Default is 10.
 * @param    int                  $accepted_args    Optional. The number of arguments that should be passed to the $callback. Default is 1.
 */
public function add_action( $hook, $component, $callback, $priority = 10, $accepted_args = 1 ) {
    $this->actions = $this->add( $this->actions, $hook, $component, $callback, $priority, $accepted_args );
}

/**
 * Add a new filter to the collection to be registered with WordPress.
 *
 * @since    1.0.0
 * @param    string               $hook             The name of the WordPress filter that is being registered.
 * @param    object               $component        A reference to the instance of the object on which the filter is defined.
 * @param    string               $callback         The name of the function definition on the $component.
 * @param    int                  $priority         Optional. The priority at which the function should be fired. Default is 10.
 * @param    int                  $accepted_args    Optional. The number of arguments that should be passed to the $callback. Default is 1
 */
public function add_filter( $hook, $component, $callback, $priority = 10, $accepted_args = 1 ) {
    $this->filters = $this->add( $this->filters, $hook, $component, $callback, $priority, $accepted_args );
}

/**
 * A utility function that is used to register the actions and hooks into a single
 * collection.
 *
 * @since    1.0.0
 * @access   private
 * @param    array                $hooks            The collection of hooks that is being registered (that is, actions or filters).
 * @param    string               $hook             The name of the WordPress filter that is being registered.
 * @param    object               $component        A reference to the instance of the object on which the filter is defined.
 * @param    string               $callback         The name of the function definition on the $component.
 * @param    int                  $priority         The priority at which the function should be fired.
 * @param    int                  $accepted_args    The number of arguments that should be passed to the $callback.
 * @return   array                                  The collection of actions and filters registered with WordPress.
 */
private function add( $hooks, $hook, $component, $callback, $priority, $accepted_args ) {

    $hooks[] = array(
        'hook'          => $hook,
        'component'     => $component,
        'callback'      => $callback,
        'priority'      => $priority,
        'accepted_args' => $accepted_args
    );

    return $hooks;

}

/**
 * Register the filters and actions with WordPress.
 *
 * @since    1.0.0
 */
public function run() {

    foreach ( $this->filters as $hook ) {
        add_filter( $hook['hook'], array( $hook['component'], $hook['callback'] ), $hook['priority'], $hook['accepted_args'] );
    }

    foreach ( $this->actions as $hook ) {
        add_action( $hook['hook'], array( $hook['component'], $hook['callback'] ), $hook['priority'], $hook['accepted_args'] );
    }

}

}
1
yobddigi

Avant de sauvegarder vos métadonnées, vous avez if ( ! current_user_can( '' ) ) return

Je n'ai jamais utilisé current_user_can et une chaîne de capacités vide, je ne suis donc pas sûr des résultats attendus, mais il est fort possible que cela retourne une valeur false, et vous revenez à ce stade.

Assurez-vous également de désinfecter vos données $ _POST avant de les coller dans la base de données.

1
De Coder

Ce n'est même pas que $ custom ["boat_make"] [0], mais même pas $ custom ["boat_make"] est défini.

A cause de cela, vous ne pouvez pas demander: if (isset($custom["boat_make"][0]))

Vérifiez votre base de données et voyez si la méta publication existe pour "boat_make"

À quoi ça ressemble quand vous faites votre var_dump($custom);?

0
De Coder