0

Been updating an old but one of my favorite unsupported plugins. I have made all the functions current and the plugin works well just a couple bugs to fix when running in define('WP_DEBUG', true); So this plugin try's to load defaults but I get errors creating a new widget weather or not there is a default ad. I have been searching for a better way to do this with no luck. The problem is the $instance['name'] remains undefined until the widget is saved. would appreciate any help Thank You

Errors I Get one instance of this

Notice: Undefined index: name in /var/www/public_html/wp-content/plugins/advertising-manager/lib/Advman/Widget.php on line 56

I get this for each result

Notice: Undefined index: name in /var/www/public_html/wp-content/plugins/advertising-manager/lib/Advman/Widget.php on line 58

Here Is The Code Widget php

    <?php
class Advman_Widget extends WP_Widget
{
    function Advman_Widget()
    {
        $widget_ops = array('classname' => 'Advman_Widget', 'description' => __('Place an ad', 'advman'));
        parent::__construct('advman', __('Advertisement', 'advman'), $widget_ops);
    }
    function widget($args, $instance)
    {
        extract($args); //nb. $name comes out of this, hence the use of $n
        global $advman_engine;

        $n = $instance['name'] == '' ? $advman_engine->getSetting('default-ad') : $instance['name'];
        $ad = $advman_engine->selectAd($n);

        if (!empty($ad)) {
            $suppress = !empty($instance['suppress']);
            $title = apply_filters('widget_title', $instance['title']);

            $ad_code = $ad->display();
            echo $suppress ? ($title . $ad_code) : ($before_widget . $before_title . $title . $after_title . $ad_code . $after_widget);
            $advman_engine->incrementStats($ad);
        }
    }

    function update($new_instance, $old_instance)
    {
        $instance = $old_instance;
        $instance['title'] = strip_tags(stripslashes($new_instance['title']));
        $instance['suppress'] = !empty($new_instance['suppress']);
        $instance['name'] = $new_instance['name'];
        return $instance;
    }

    function form($instance)
    {
        global $advman_engine;

        $ads = $advman_engine->getAds();
        $names = array();
        // Loop through ads, and get only unique ad names
        foreach ($ads as $ad) {
            $names[$ad->name] = $ad->name;
        }

    $title = isset( $instance['title'] ) ? esc_attr( $instance['title'] ) : '';
    $checked = !empty($instance['suppress']) ? 'checked="checked"' : '';
?>
            <p><label for="<?php echo $this->get_field_id('title'); ?>"><?php _e('Title:', 'advman'); ?> <input class="widefat" id="<?php echo $this->get_field_id('title'); ?>" name="<?php echo $this->get_field_name('title'); ?>" type="text" value="<?php echo $title; ?>" /></label></p>
            <p>
                <label for="<?php echo $this->get_field_id('name'); ?>"><?php _e('Select an ad to display:', 'advman'); ?>
                <select class="widefat" id="<?php echo $this->get_field_id('name'); ?>" name="<?php echo $this->get_field_name('name'); ?>">
                    <option value=""<?php echo $instance['name'] == "" ? " selected='selected'" : ''; ?>><?php _e('Default Ad', 'advman'); ?></option>
<?php foreach ($names as $name) : ''?>
                    <option value="<?php echo $name; ?>"<?php echo $name == $instance['name'] ? " selected='selected'" : ''; ?>>#<?php echo $name; ?></option>
<?php endforeach; ?>
                </select>
                </label>
            </p>
            <p><label for="<?php echo $this->get_field_id('suppress'); ?>"><?php _e('Hide widget formatting', 'advman'); ?> <input class="checkbox" id="<?php echo $this->get_field_id('suppress'); ?>" name="<?php echo $this->get_field_name('suppress'); ?>" type="checkbox" <?php echo $checked; ?> /></label></p>
        <?php
    }
}
?>

1 Answer 1

1

I found my problem sometimes it helps to do something else for a while

I was using isset() on an assignment before any selections could be made

My Fix

// I Added 
if(!isset($instance['name']) || empty($instance['name'])) { 
$instance['name'] = ""; 




//Added it here
$title = isset( $instance['title'] ) ? esc_attr( $instance['title'] ) : '';
if(!isset($instance['name']) || empty($instance['name'])) { 
$instance['name'] = ""; 
}   
$checked = !empty($instance['suppress']) ? 'checked="checked"' : '';

Not the answer you're looking for? Browse other questions tagged or ask your own question.