Form Widget

- added public js code to handle validation and ajax submit
- added widget initializer
- added form widget
- added acceptance test for adding the widget
This commit is contained in:
Jonathan Labreuille
2015-08-20 16:52:51 +02:00
parent eda2188611
commit c883de9aa8
5 changed files with 243 additions and 8 deletions

110
lib/Form/Widget.php Normal file
View File

@ -0,0 +1,110 @@
<?php
namespace MailPoet\Form;
if(!defined('ABSPATH')) exit;
class Widget extends \WP_Widget {
function __construct() {
return parent::__construct(
'mailpoet_form',
__('MailPoet Subscription Form'),
array(
'title' => __('Newsletter subscription form')
)
);
}
public function update($new_instance, $old_instance) {
$instance = $old_instance;
$instance['title'] = strip_tags($new_instance['title']);
$instance['form'] = (int)$new_instance['form'];
return $instance;
}
public function form($instance) {
$instance = wp_parse_args(
(array)$instance,
array(
'title' => __('Subscribe to our Newsletter')
)
);
// set title
$title = isset($instance['title']) ? strip_tags($instance['title']) : '';
$output = '';
$output .= '<p>';
$output .= ' <label for="'.$this->get_field_id('title').'">';
$output .= __('Title:' );
$output .= ' </label>';
$output .= ' <input type="text" class="widefat"';
$output .= ' id="'.$this->get_field_id('title').'"';
$output .= ' name="'.$this->get_field_name('title').'"';
$output .= ' value="'.esc_attr($title).'"';
$output .= ' />';
$output .= '</p>';
$output .= '<p>';
$output .= ' <a href="javascript:;" class="mailpoet_form_new">';
$output .= __('Create a new form');
$output .= ' </a>';
$output .= '</p>';
echo $output;
}
function widget($args, $instance = null) {
extract($args);
if($instance === null) { $instance = $args; }
$title = apply_filters(
'widget_title',
$instance['title'],
$instance,
$this->id_base
);
$output = '';
// before widget
$output .= (isset($before_widget) ? $before_widget : '');
// title
$output .= $before_title.$title.$after_title;
// form
$form_id = $this->id_base.'_'.$this->number;
$form_type = 'widget';
$output .= '<div class="mailpoet_form mailpoet_form_'.$form_type.'">';
$output .= '<form '.
'id="'.$form_id.'" '.
'method="post" '.
'action="'.admin_url('admin-post.php?action=mailpoet_form_subscribe').'" '.
'class="mailpoet_form mailpoet_form_'.$form_type.'" novalidate>';
$output .= ' <p>';
$output .= ' <label>'.__('E-mail');
$output .= ' <input type="email" name="email"';
$output .= ' data-validation-engine="validate[required,custom[email]]"';
$output .= ' />';
$output .= ' </label>';
$output .= ' </p>';
$output .= ' <p>';
$output .= ' <label>';
$output .= ' <input type="submit" value="'.esc_attr('Subscribe!').'" />';
$output .= ' </label>';
$output .= ' </p>';
$output .= '</form>';
$output .= '</div>';
// after widget
$output .= (isset($after_widget) ? $after_widget : '');
echo $output;
}
}