Gravity Forms
Add-On Framework
Getting started
About Me
From Graphic Designer to Multimedia Designer/Developer to Web Developer.
Gravity Forms
A shotgun introduction
Amazing Features
My 'go-to' forms plugin for WP sites
Advanced forms, surveys etc
Extendable, hooks, API functions
3rd party integrations
Easy to use, clients love it
Over a million sites using it*
GF itself doesn't provide everything
New fields, extended functionality
3rd party integration
Improved usability
Why Add-ons?
- Jump-starts your plugin dev
- Takes care of some of the standard crap
- Better integration
- Min. GF version
- Script enqueuing
- Locking API
- Clean uninstall
- Standardised UI elements
Add-On Framework
How it works
Extend one of the following classes:
- GFAddon
- GFFeedAddon
- GFPaymentAddon
GFAddon Class
For add-ons that are very simple
or don't fit into one of the more specialised cases
https://www.gravityhelp.com/documentation/article/gfaddon/
GFFeedAddon Class
For add-ons that allow users to create form feeds
- Easily add feed settings UI, conditional processing
- Eg. MailChimp add-on
https://www.gravityhelp.com/documentation/article/gffeedaddon/
GFPaymentAddon Class
For add-ons that collect payments. Handles:
- Payments via 3rd party websites (eg PayPal Standard)
- Credit card payments behind the scenes (eg Stripe)
https://www.gravityhelp.com/documentation/article/gfpaymentaddon/
Creating your own
Min. two main files:
- Your bootstrap / plugin file
- Your add-on class
Two files because add-ons could be attempting to load before Gravity Forms. This method waits for the "gform_loaded" filter to fire before loading your class.
Simple example
https://github.com/rocketgenius/simpleaddon
Bootstrap / plugin file:
/*
...
*/
define( 'GF_SIMPLE_ADDON_VERSION', '2.0' );
add_action( 'gform_loaded', array( 'GF_Simple_AddOn_Bootstrap', 'load' ), 5 );
class GF_Simple_AddOn_Bootstrap {
public static function load() {
if ( ! method_exists( 'GFForms', 'include_addon_framework' ) ) {
return;
}
require_once( 'class-gfsimpleaddon.php' );
GFAddOn::register( 'GFSimpleAddOn' );
}
}
function gf_simple_addon() {
return GFSimpleAddOn::get_instance();
}
Add-on class (class-gfsimpleaddon.php):
GFForms::include_addon_framework();
class GFSimpleAddOn extends GFAddOn {
protected $_version = GF_SIMPLE_ADDON_VERSION;
protected $_min_gravityforms_version = '1.9';
protected $_slug = 'simpleaddon';
protected $_path = 'simpleaddon/simpleaddon.php';
protected $_full_path = __FILE__;
protected $_title = 'Gravity Forms Simple Add-On';
protected $_short_title = 'Simple Add-On';
private static $_instance = null;
/**
* Get an instance of this class.
*
* @return GFSimpleAddOn
*/
public static function get_instance() {
if ( self::$_instance == null ) {
self::$_instance = new GFSimpleAddOn();
}
return self::$_instance;
}
...
Simple example
Scripts...
/**
* Return the scripts which should be enqueued.
*
* @return array
*/
public function scripts() {
$scripts = array(
array(
'handle' => 'my_script_js',
'src' => $this->get_base_url() . '/js/my_script.js',
'version' => $this->_version,
'deps' => array( 'jquery' ),
'strings' => array(
'foo' => esc_html__( 'Foo', 'simpleaddon' ),
'bar' => esc_html__( 'Bar', 'simpleaddon' )
),
'enqueue' => array(
array(
'admin_page' => array( 'form_settings' ),
'tab' => 'simpleaddon'
)
)
),
);
return array_merge( parent::scripts(), $scripts );
}
Styles...
/**
* Return the stylesheets which should be enqueued.
*
* @return array
*/
public function styles() {
$styles = array(
array(
'handle' => 'my_styles_css',
'src' => $this->get_base_url() . '/css/my_styles.css',
'version' => $this->_version,
'enqueue' => array(
array( 'field_types' => array( 'poll' ) )
)
)
);
return array_merge( parent::styles(), $styles );
}
Plugin page...
/**
* Creates a custom page for this add-on.
*/
public function plugin_page() {
echo 'This page appears in the Forms menu';
}
Plugin page...
Add-on settings...
/**
* Configures the settings which should be rendered on the add-on settings tab.
*
* @return array
*/
public function plugin_settings_fields() {
return array(
array(
'title' => esc_html__( 'Simple Add-On Settings', 'simpleaddon' ),
'fields' => array(
array(
'name' => 'mytextbox',
'tooltip' => esc_html__( 'This is the tooltip', 'simpleaddon' ),
'label' => esc_html__( 'This is the label', 'simpleaddon' ),
'type' => 'text',
'class' => 'small',
'feedback_callback' => array( $this, 'is_valid_setting' ),
)
)
)
);
}
Extract value with
$this->get_plugin_setting('mytextbox')
Add-on settings...
Form settings...
/**
* Configures the settings which should be rendered
* on the Form Settings > Simple Add-On tab.
*
* @return array
*/
public function form_settings_fields( $form ) {
return array(
array(
'title' => esc_html__( 'Simple Form Settings', 'simpleaddon' ),
'fields' => array(
array(
'label' => esc_html__( 'My Text Box', 'simpleaddon' ),
'type' => 'text',
'name' => 'mytext',
'tooltip' => esc_html__( 'This is the tooltip', 'simpleaddon' ),
'class' => 'medium',
'feedback_callback' => array( $this, 'is_valid_setting' ),
),
array(
'label' => esc_html__( 'My Text Area', 'simpleaddon' ),
'type' => 'textarea',
'name' => 'mytextarea',
'tooltip' => esc_html__( 'This is the tooltip', 'simpleaddon' ),
'class' => 'medium merge-tag-support mt-position-right',
),
),
),
);
}
Form settings...
Monetising
& Licensing
GFAddon > EDD > Licensing > Updates
Real-world demo
Bulk Actions
for Gravity Forms
Thanks
@BK4D
jetsloth.com
fullstackpasswords.io
Questions?