initSettings(); } else { add_action( 'plugins_loaded', array( $this, 'initSettings' ), 10 ); } } public function initSettings() { // Just for demo purposes. Not needed per say. $this->theme = wp_get_theme(); // Set the default arguments $this->setArguments(); // Set a few help tabs so you can see how it's done $this->setHelpTabs(); // Create the sections and fields $this->setSections(); if ( ! isset( $this->args['opt_name'] ) ) { // No errors please return; } // If Redux is running as a plugin, this will remove the demo notice and links //add_action( 'redux/loaded', array( $this, 'remove_demo' ) ); // Function to test the compiler hook and demo CSS output. // Above 10 is a priority, but 2 in necessary to include the dynamically generated CSS to be sent to the function. //add_filter('redux/options/'.$this->args['opt_name'].'/compiler', array( $this, 'compiler_action' ), 10, 3); // Change the arguments after they've been declared, but before the panel is created //add_filter('redux/options/'.$this->args['opt_name'].'/args', array( $this, 'change_arguments' ) ); // Change the default value of a field after it's been set, but before it's been useds //add_filter('redux/options/'.$this->args['opt_name'].'/defaults', array( $this,'change_defaults' ) ); // Dynamically add a section. Can be also used to modify sections/fields //add_filter('redux/options/' . $this->args['opt_name'] . '/sections', array($this, 'dynamic_section')); $this->ReduxFramework = new ReduxFramework( $this->sections, $this->args ); } /** * This is a test function that will let you see when the compiler hook occurs. * It only runs if a field set with compiler=>true is changed. * */ function compiler_action( $options, $css, $changed_values ) { echo '
";
print_r( $changed_values ); // Values that have changed since the last save
echo "";
//print_r($options); //Option values
//print_r($css); // Compiler selector CSS values compiler => array( CSS SELECTORS )
/*
// Demo of how to use the dynamic CSS and write your own static CSS file
$filename = dirname(__FILE__) . '/style' . '.css';
global $wp_filesystem;
if( empty( $wp_filesystem ) ) {
require_once( ABSPATH .'/wp-admin/includes/file.php' );
WP_Filesystem();
}
if( $wp_filesystem ) {
$wp_filesystem->put_contents(
$filename,
$css,
FS_CHMOD_FILE // predefined mode settings for WP files
);
}
*/
}
/**
* Custom function for filtering the sections array. Good for child themes to override or add to the sections.
* Simply include this function in the child themes functions.php file.
* NOTE: the defined constants for URLs, and directories will NOT be available at this point in a child theme,
* so you must use get_template_directory_uri() if you want to use any of the built in icons
* */
function dynamic_section( $sections ) {
//$sections = array();
$sections[] = array(
'title' => __( 'Section via hook', 'redux-framework-demo' ),
'desc' => __( 'This is a section created by adding a filter to the sections array. Can be used by child themes to add/remove sections from the options.
', 'redux-framework-demo' ), 'icon' => 'el-icon-paper-clip', // Leave this as a blank section, no options just some intro text set above. 'fields' => array() ); return $sections; } /** * Filter hook for filtering the args. Good for child themes to override or add to the args array. Can also be used in other functions. * */ function change_arguments( $args ) { //$args['dev_mode'] = true; return $args; } /** * Filter hook for filtering the default value of any given field. Very useful in development mode. * */ function change_defaults( $defaults ) { $defaults['str_replace'] = 'Testing filter hook!'; return $defaults; } // Remove the demo link and the notice of integrated demo from the redux-framework plugin function remove_demo() { // Used to hide the demo mode link from the plugin page. Only used when Redux is a plugin. if ( class_exists( 'ReduxFrameworkPlugin' ) ) { remove_filter( 'plugin_row_meta', array( ReduxFrameworkPlugin::instance(), 'plugin_metalinks' ), null, 2 ); // Used to hide the activation notice informing users of the demo panel. Only used when Redux is a plugin. remove_action( 'admin_notices', array( ReduxFrameworkPlugin::instance(), 'admin_notices' ) ); } } public function setSections() { /** * Used within different fields. Simply examples. Search for ACTUAL DECLARATION for field examples * */ // Background Patterns Reader $sample_patterns_path = ReduxFramework::$_dir . '../sample/patterns/'; $sample_patterns_url = ReduxFramework::$_url . '../sample/patterns/'; $sample_patterns = array(); if ( is_dir( $sample_patterns_path ) ) : if ( $sample_patterns_dir = opendir( $sample_patterns_path ) ) : $sample_patterns = array(); while ( ( $sample_patterns_file = readdir( $sample_patterns_dir ) ) !== false ) { if ( stristr( $sample_patterns_file, '.png' ) !== false || stristr( $sample_patterns_file, '.jpg' ) !== false ) { $name = explode( '.', $sample_patterns_file ); $name = str_replace( '.' . end( $name ), '', $sample_patterns_file ); $sample_patterns[] = array( 'alt' => $name, 'img' => $sample_patterns_url . $sample_patterns_file ); } } endif; endif; ob_start(); $ct = wp_get_theme(); $this->theme = $ct; $item_name = $this->theme->get( 'Name' ); $tags = $this->theme->Tags; $screenshot = $this->theme->get_screenshot(); $class = $screenshot ? 'has-screenshot' : ''; $customize_title = sprintf( __( 'Customize “%s”', 'redux-framework-demo' ), $this->theme->display( 'Name' ) ); ?>theme->display( 'Description' ); ?>
theme->parent() ) { printf( '' . __( 'This child theme requires its parent theme, %2$s.', 'redux-framework-demo' ) . '
', __( 'http://codex.wordpress.org/Child_Themes', 'redux-framework-demo' ), $this->theme->parent()->display( 'Name' ) ); } ?>This is the Description. Again HTML is allowed2
', 'redux-framework-demo' ), 'fields' => array( array( 'id' => 'opt-text-email', 'type' => 'text', 'title' => __( 'Text Option - Email Validated', 'redux-framework-demo' ), 'subtitle' => __( 'This is a little space under the Field Title in the Options table, additional info is good in here.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'email', 'msg' => 'custom error message', 'default' => 'test@test.com', // 'text_hint' => array( // 'title' => 'Valid Email Required!', // 'content' => 'This field required a valid email address.' // ) ), array( 'id' => 'opt-text-post-type', 'type' => 'text', 'title' => __( 'Text Option with Data Attributes', 'redux-framework-demo' ), 'subtitle' => __( 'You can also pass an options array if you want. Set the default to whatever you like.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'data' => 'post_type', ), array( 'id' => 'opt-multi-text', 'type' => 'multi_text', 'title' => __( 'Multi Text Option - Color Validated', 'redux-framework-demo' ), 'validate' => 'color', 'subtitle' => __( 'If you enter an invalid color it will be removed. Try using the text "blue" as a color. ;)', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ) ), array( 'id' => 'opt-text-url', 'type' => 'text', 'title' => __( 'Text Option - URL Validated', 'redux-framework-demo' ), 'subtitle' => __( 'This must be a URL.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'url', 'default' => 'http://reduxframework.com', // 'text_hint' => array( // 'title' => '', // 'content' => 'Please enter a valid URL in this field.' // ) ), array( 'id' => 'opt-text-numeric', 'type' => 'text', 'title' => __( 'Text Option - Numeric Validated', 'redux-framework-demo' ), 'subtitle' => __( 'This must be numeric.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'numeric', 'default' => '0', ), array( 'id' => 'opt-text-comma-numeric', 'type' => 'text', 'title' => __( 'Text Option - Comma Numeric Validated', 'redux-framework-demo' ), 'subtitle' => __( 'This must be a comma separated string of numerical values.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'comma_numeric', 'default' => '0', ), array( 'id' => 'opt-text-no-special-chars', 'type' => 'text', 'title' => __( 'Text Option - No Special Chars Validated', 'redux-framework-demo' ), 'subtitle' => __( 'This must be a alpha numeric only.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'no_special_chars', 'default' => '0' ), array( 'id' => 'opt-text-str_replace', 'type' => 'text', 'title' => __( 'Text Option - Str Replace Validated', 'redux-framework-demo' ), 'subtitle' => __( 'You decide.', 'redux-framework-demo' ), 'desc' => __( 'This field\'s default value was changed by a filter hook!', 'redux-framework-demo' ), 'validate' => 'str_replace', 'str' => array( 'search' => ' ', 'replacement' => 'thisisaspace' ), 'default' => 'This is the default.' ), array( 'id' => 'opt-text-preg_replace', 'type' => 'text', 'title' => __( 'Text Option - Preg Replace Validated', 'redux-framework-demo' ), 'subtitle' => __( 'You decide.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'preg_replace', 'preg' => array( 'pattern' => '/[^a-zA-Z_ -]/s', 'replacement' => 'no numbers' ), 'default' => '0' ), array( 'id' => 'opt-text-custom_validate', 'type' => 'text', 'title' => __( 'Text Option - Custom Callback Validated', 'redux-framework-demo' ), 'subtitle' => __( 'You decide.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate_callback' => 'redux_validate_callback_function', 'default' => '0' ), array( 'id' => 'opt-text-custom_validate-class', 'type' => 'text', 'title' => __( 'Text Option - Custom Callback Validated - Class', 'redux-framework-demo' ), 'subtitle' => __( 'You decide.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate_callback' => array( $this, 'validate_callback_function' ), // You can pass the current class // Or pass the class name and method //'validate_callback' => array( // 'Redux_Framework_sample_config', // 'validate_callback_function' //), 'default' => '0' ), array( 'id' => 'opt-textarea-no-html', 'type' => 'textarea', 'title' => __( 'Textarea Option - No HTML Validated', 'redux-framework-demo' ), 'subtitle' => __( 'All HTML will be stripped', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'no_html', 'default' => 'No HTML is allowed in here.' ), array( 'id' => 'opt-textarea-html', 'type' => 'textarea', 'title' => __( 'Textarea Option - HTML Validated', 'redux-framework-demo' ), 'subtitle' => __( 'HTML Allowed (wp_kses)', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'html', //see http://codex.wordpress.org/Function_Reference/wp_kses_post 'default' => 'HTML is allowed in here.' ), array( 'id' => 'opt-textarea-some-html', 'type' => 'textarea', 'title' => __( 'Textarea Option - HTML Validated Custom', 'redux-framework-demo' ), 'subtitle' => __( 'Custom HTML Allowed (wp_kses)', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'html_custom', 'default' => 'Some HTML is allowed in here.
', 'allowed_html' => array( '' ) //see http://codex.wordpress.org/Function_Reference/wp_kses ), array( 'id' => 'opt-textarea-js', 'type' => 'textarea', 'title' => __( 'Textarea Option - JS Validated', 'redux-framework-demo' ), 'subtitle' => __( 'JS will be escaped', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'validate' => 'js' ), ) ); $this->sections[] = array( 'icon' => 'el-icon-check', 'title' => __( 'Radio/Checkbox Fields', 'redux-framework-demo' ), 'desc' => __( 'This is the Description. Again HTML is allowed
', 'redux-framework-demo' ), 'fields' => array( array( 'id' => 'opt-checkbox', 'type' => 'checkbox', 'title' => __( 'Checkbox Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'default' => '1'// 1 = on | 0 = off ), array( 'id' => 'opt-multi-check', 'type' => 'checkbox', 'title' => __( 'Multi Checkbox Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), //Must provide key => value pairs for multi checkbox options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), //See how std has changed? you also don't need to specify opts that are 0. 'default' => array( '1' => '1', '2' => '0', '3' => '0' ) ), array( 'id' => 'opt-checkbox-data', 'type' => 'checkbox', 'title' => __( 'Multi Checkbox Option (with menu data)', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'data' => 'menu' ), array( 'id' => 'opt-checkbox-sidebar', 'type' => 'checkbox', 'title' => __( 'Multi Checkbox Option (with sidebar data)', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'data' => 'sidebars' ), array( 'id' => 'opt-radio', 'type' => 'radio', 'title' => __( 'Radio Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), //Must provide key => value pairs for radio options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), 'default' => '2' ), array( 'id' => 'opt-radio-data', 'type' => 'radio', 'title' => __( 'Multi Checkbox Option (with menu data)', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'data' => 'menu' ), array( 'id' => 'opt-image-select', 'type' => 'image_select', 'title' => __( 'Images Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), //Must provide key => value(array:title|img) pairs for radio options 'options' => array( '1' => array( 'title' => 'Opt 1', 'img' => 'images/align-none.png' ), '2' => array( 'title' => 'Opt 2', 'img' => 'images/align-left.png' ), '3' => array( 'title' => 'Opt 3', 'img' => 'images/align-center.png' ), '4' => array( 'title' => 'Opt 4', 'img' => 'images/align-right.png' ) ), 'default' => '2' ), array( 'id' => 'opt-image-select-layout', 'type' => 'image_select', 'title' => __( 'Images Option for Layout', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This uses some of the built in images, you can use them for layout options.', 'redux-framework-demo' ), //Must provide key => value(array:title|img) pairs for radio options 'options' => array( '1' => array( 'alt' => '1 Column', 'img' => ReduxFramework::$_url . 'assets/img/1col.png' ), '2' => array( 'alt' => '2 Column Left', 'img' => ReduxFramework::$_url . 'assets/img/2cl.png' ), '3' => array( 'alt' => '2 Column Right', 'img' => ReduxFramework::$_url . 'assets/img/2cr.png' ), '4' => array( 'alt' => '3 Column Middle', 'img' => ReduxFramework::$_url . 'assets/img/3cm.png' ), '5' => array( 'alt' => '3 Column Left', 'img' => ReduxFramework::$_url . 'assets/img/3cl.png' ), '6' => array( 'alt' => '3 Column Right', 'img' => ReduxFramework::$_url . 'assets/img/3cr.png' ) ), 'default' => '2' ), array( 'id' => 'opt-sortable', 'type' => 'sortable', 'title' => __( 'Sortable Text Option', 'redux-framework-demo' ), 'subtitle' => __( 'Define and reorder these however you want.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'options' => array( 'si1' => 'Item 1', 'si2' => 'Item 2', 'si3' => 'Item 3', ) ), array( 'id' => 'opt-check-sortable', 'type' => 'sortable', 'mode' => 'checkbox', // checkbox or text 'title' => __( 'Sortable Text Option', 'redux-framework-demo' ), 'subtitle' => __( 'Define and reorder these however you want.', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'options' => array( 'si1' => false, 'si2' => true, 'si3' => false, ) ), ) ); $this->sections[] = array( 'icon' => 'el-icon-list-alt', 'title' => __( 'Select Fields', 'redux-framework-demo' ), 'desc' => __( 'This is the Description. Again HTML is allowed
', 'redux-framework-demo' ), 'fields' => array( array( 'id' => 'opt-select', 'type' => 'select', 'title' => __( 'Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), //Must provide key => value pairs for select options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), 'default' => '2' ), array( 'id' => 'opt-multi-select', 'type' => 'select', 'multi' => true, 'title' => __( 'Multi Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), //Must provide key => value pairs for radio options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), 'required' => array( 'select', 'equals', array( '1', '3' ) ), 'default' => array( '2', '3' ) ), array( 'id' => 'opt-select-image', 'type' => 'select_image', 'title' => __( 'Select Image', 'redux-framework-demo' ), 'subtitle' => __( 'A preview of the selected image will appear underneath the select box.', 'redux-framework-demo' ), 'options' => $sample_patterns, // Alternatively //'options' => Array( // 'img_name' => 'img_path' // ) 'default' => 'tree_bark.png', ), array( 'id' => 'opt-info', 'type' => 'info', 'desc' => __( 'You can easily add a variety of data from WordPress.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-categories', 'type' => 'select', 'data' => 'categories', 'title' => __( 'Categories Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-categories-multi', 'type' => 'select', 'data' => 'categories', 'multi' => true, 'title' => __( 'Categories Multi Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-pages', 'type' => 'select', 'data' => 'pages', 'title' => __( 'Pages Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-multi-select-pages', 'type' => 'select', 'data' => 'pages', 'multi' => true, 'title' => __( 'Pages Multi Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-tags', 'type' => 'select', 'data' => 'tags', 'title' => __( 'Tags Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-multi-select-tags', 'type' => 'select', 'data' => 'tags', 'multi' => true, 'title' => __( 'Tags Multi Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-menus', 'type' => 'select', 'data' => 'menus', 'title' => __( 'Menus Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-multi-select-menus', 'type' => 'select', 'data' => 'menu', 'multi' => true, 'title' => __( 'Menus Multi Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-post-type', 'type' => 'select', 'data' => 'post_type', 'title' => __( 'Post Type Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-multi-select-post-type', 'type' => 'select', 'data' => 'post_type', 'multi' => true, 'title' => __( 'Post Type Multi Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-multi-select-sortable', 'type' => 'select', 'data' => 'post_type', 'multi' => true, 'sortable' => true, 'title' => __( 'Post Type Multi Select Option + Sortable', 'redux-framework-demo' ), 'subtitle' => __( 'This field also has sortable enabled!', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-posts', 'type' => 'select', 'data' => 'post', 'title' => __( 'Posts Select Option2', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-multi-select-posts', 'type' => 'select', 'data' => 'post', 'multi' => true, 'title' => __( 'Posts Multi Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-roles', 'type' => 'select', 'data' => 'roles', 'title' => __( 'User Role Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-capabilities', 'type' => 'select', 'data' => 'capabilities', 'multi' => true, 'title' => __( 'Capabilities Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), ), array( 'id' => 'opt-select-elusive', 'type' => 'select', 'data' => 'elusive-icons', 'title' => __( 'Elusive Icons Select Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'Here\'s a list of all the elusive icons by name and icon.', 'redux-framework-demo' ), ), ) ); $theme_info = '' . __( 'Theme URL: ', 'redux-framework-demo' ) . '' . $this->theme->get( 'ThemeURI' ) . '
'; $theme_info .= ''; $theme_info .= '' . __( 'Version: ', 'redux-framework-demo' ) . $this->theme->get( 'Version' ) . '
'; $theme_info .= '' . $this->theme->get( 'Description' ) . '
'; $tabs = $this->theme->get( 'Tags' ); if ( ! empty( $tabs ) ) { $theme_info .= ''; } $theme_info .= 'This is the Description. Again HTML is allowed
', 'redux-framework-demo' ), 'fields' => array( array( 'id' => 'opt-datepicker', 'type' => 'date', 'title' => __( 'Date Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ) ), array( 'id' => 'opt-divide', 'type' => 'divide' ), array( 'id' => 'opt-button-set', 'type' => 'button_set', 'title' => __( 'Button Set Option', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), //Must provide key => value pairs for radio options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), 'default' => '2' ), array( 'id' => 'opt-button-set-multi', 'type' => 'button_set', 'title' => __( 'Button Set, Multi Select', 'redux-framework-demo' ), 'subtitle' => __( 'No validation can be done on this field type', 'redux-framework-demo' ), 'desc' => __( 'This is the description field, again good for additional info.', 'redux-framework-demo' ), 'multi' => true, //Must provide key => value pairs for radio options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), 'default' => array( '2', '3' ) ), array( 'id' => 'opt-info-field', 'type' => 'info', 'desc' => __( 'This is the info field, if you want to break sections up.', 'redux-framework-demo' ) ), array( 'id' => 'opt-info-warning', 'type' => 'info', 'style' => 'warning', 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an info field with the warning style applied and a header.', 'redux-framework-demo' ) ), array( 'id' => 'opt-info-success', 'type' => 'info', 'style' => 'success', 'icon' => 'el-icon-info-sign', 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an info field with the success style applied, a header and an icon.', 'redux-framework-demo' ) ), array( 'id' => 'opt-info-critical', 'type' => 'info', 'style' => 'critical', 'icon' => 'el-icon-info-sign', 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an info field with the critical style applied, a header and an icon.', 'redux-framework-demo' ) ), array( 'id' => 'opt-raw_info', 'type' => 'info', 'required' => array( '18', 'equals', array( '1', '2' ) ), 'raw_html' => true, 'desc' => $sampleHTML, ), array( 'id' => 'opt-info-normal', 'type' => 'info', 'notice' => true, 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an info notice field with the normal style applied, a header and an icon.', 'redux-framework-demo' ) ), array( 'id' => 'opt-notice-info', 'type' => 'info', 'notice' => true, 'style' => 'info', 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an info notice field with the info style applied, a header and an icon.', 'redux-framework-demo' ) ), array( 'id' => 'opt-notice-warning', 'type' => 'info', 'notice' => true, 'style' => 'warning', 'icon' => 'el-icon-info-sign', 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an info notice field with the warning style applied, a header and an icon.', 'redux-framework-demo' ) ), array( 'id' => 'opt-notice-success', 'type' => 'info', 'notice' => true, 'style' => 'success', 'icon' => 'el-icon-info-sign', 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an info notice field with the success style applied, a header and an icon.', 'redux-framework-demo' ) ), array( 'id' => 'opt-notice-critical', 'type' => 'info', 'notice' => true, 'style' => 'critical', 'icon' => 'el-icon-info-sign', 'title' => __( 'This is a title.', 'redux-framework-demo' ), 'desc' => __( 'This is an notice field with the critical style applied, a header and an icon.', 'redux-framework-demo' ) ), array( 'id' => 'opt-custom-callback', 'type' => 'callback', 'title' => __( 'Custom Field Callback', 'redux-framework-demo' ), 'subtitle' => __( 'This is a completely unique field type', 'redux-framework-demo' ), 'desc' => __( 'This is created with a callback function, so anything goes in this field. Make sure to define the function though.', 'redux-framework-demo' ), 'callback' => 'redux_my_custom_field' ), array( 'id' => 'opt-custom-callback-class', 'type' => 'callback', 'title' => __( 'Custom Field Callback - Class', 'redux-framework-demo' ), 'subtitle' => __( 'This is a completely unique field type', 'redux-framework-demo' ), 'desc' => __( 'This is created with a callback function, so anything goes in this field. Make sure to define the function though.', 'redux-framework-demo' ), //'callback' => array( $this, 'class_field_callback' ) // Can use the current class object 'callback' => array( 'Redux_Framework_sample_config', 'class_field_callback' ) // Can use just class name ), array( 'id' => 'opt-customizer-only-in-section', 'type' => 'select', 'title' => __( 'Customizer Only Option', 'redux-framework-demo' ), 'subtitle' => __( 'The subtitle is NOT visible in customizer', 'redux-framework-demo' ), 'desc' => __( 'The field desc is NOT visible in customizer.', 'redux-framework-demo' ), 'customizer_only' => true, //Must provide key => value pairs for select options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), 'default' => '2' ), ) ); $this->sections[] = array( 'icon' => 'el-icon-list-alt', 'title' => __( 'Customizer Only', 'redux-framework-demo' ), 'desc' => __( 'This Section should be visible only in Customizer
', 'redux-framework-demo' ), 'customizer_only' => true, 'fields' => array( array( 'id' => 'opt-customizer-only', 'type' => 'select', 'title' => __( 'Customizer Only Option', 'redux-framework-demo' ), 'subtitle' => __( 'The subtitle is NOT visible in customizer', 'redux-framework-demo' ), 'desc' => __( 'The field desc is NOT visible in customizer.', 'redux-framework-demo' ), 'customizer_only' => true, //Must provide key => value pairs for select options 'options' => array( '1' => 'Opt 1', '2' => 'Opt 2', '3' => 'Opt 3' ), 'default' => '2' ), ) ); $this->sections[] = array( 'title' => __( 'Import / Export', 'redux-framework-demo' ), 'desc' => __( 'Import and Export your Redux Framework settings from file, text or URL.', 'redux-framework-demo' ), 'icon' => 'el-icon-refresh', 'fields' => array( array( 'id' => 'opt-import-export', 'type' => 'import_export', 'title' => 'Import Export', 'subtitle' => 'Save and restore your Redux options', 'full_width' => false, ), ), ); $this->sections[] = array( 'type' => 'divide', ); $this->sections[] = array( 'icon' => 'el-icon-info-sign', 'title' => __( 'Theme Information', 'redux-framework-demo' ), 'desc' => __( 'This is the Description. Again HTML is allowed
', 'redux-framework-demo' ), 'fields' => array( array( 'id' => 'opt-raw-info', 'type' => 'raw', 'content' => $item_info, ) ), ); if ( file_exists( trailingslashit( dirname( __FILE__ ) ) . 'README.html' ) ) { $tabs['docs'] = array( 'icon' => 'el-icon-book', 'title' => __( 'Documentation', 'redux-framework-demo' ) ); } } public function setHelpTabs() { // Custom page help tabs, displayed using the help API. Tabs are shown in order of definition. $this->args['help_tabs'][] = array( 'id' => 'redux-help-tab-1', 'title' => __( 'Theme Information 1', 'redux-framework-demo' ), 'content' => __( 'This is the tab content, HTML is allowed.
', 'redux-framework-demo' ) ); $this->args['help_tabs'][] = array( 'id' => 'redux-help-tab-2', 'title' => __( 'Theme Information 2', 'redux-framework-demo' ), 'content' => __( 'This is the tab content, HTML is allowed.
', 'redux-framework-demo' ) ); // Set the help sidebar $this->args['help_sidebar'] = __( 'This is the sidebar content, HTML is allowed.
', 'redux-framework-demo' ); } /** * All the possible arguments for Redux. * For full documentation on arguments, please refer to: https://github.com/ReduxFramework/ReduxFramework/wiki/Arguments * */ public function setArguments() { $theme = wp_get_theme(); // For use with some settings. Not necessary. $this->args = array( // TYPICAL -> Change these values as you need/desire 'opt_name' => 'redux_demo', // This is where your data is stored in the database and also becomes your global variable name. 'display_name' => $theme->get( 'Name' ), // Name that appears at the top of your panel 'display_version' => $theme->get( 'Version' ), // Version that appears at the top of your panel 'menu_type' => 'menu', //Specify if the admin menu should appear or not. Options: menu or submenu (Under appearance only) 'allow_sub_menu' => true, // Show the sections below the admin menu item or not 'menu_title' => __( 'Sample Options', 'redux-framework-demo' ), 'page_title' => __( 'Sample Options', 'redux-framework-demo' ), // You will need to generate a Google API key to use this feature. // Please visit: https://developers.google.com/fonts/docs/developer_api#Auth 'google_api_key' => '', // Set it you want google fonts to update weekly. A google_api_key value is required. 'google_update_weekly' => false, // Must be defined to add google fonts to the typography module 'async_typography' => true, // Use a asynchronous font on the front end or font string //'disable_google_fonts_link' => true, // Disable this in case you want to create your own google fonts loader 'admin_bar' => true, // Show the panel pages on the admin bar 'admin_bar_icon' => 'dashicons-portfolio', // Choose an icon for the admin bar menu 'admin_bar_priority' => 50, // Choose an priority for the admin bar menu 'global_variable' => '', // Set a different name for your global variable other than the opt_name 'dev_mode' => true, // Show the time the page took to load, etc 'update_notice' => true, // If dev_mode is enabled, will notify developer of updated versions available in the GitHub Repo 'customizer' => true, // Enable basic customizer support //'open_expanded' => true, // Allow you to start the panel in an expanded way initially. //'disable_save_warn' => true, // Disable the save warning when a user changes a field // OPTIONAL -> Give you extra features 'page_priority' => null, // Order where the menu appears in the admin area. If there is any conflict, something will not show. Warning. 'page_parent' => 'themes.php', // For a full list of options, visit: http://codex.wordpress.org/Function_Reference/add_submenu_page#Parameters 'page_permissions' => 'manage_options', // Permissions needed to access the options panel. 'menu_icon' => '', // Specify a custom URL to an icon 'last_tab' => '', // Force your panel to always open to a specific tab (by id) 'page_icon' => 'icon-themes', // Icon displayed in the admin panel next to your menu_title 'page_slug' => '_options', // Page slug used to denote the panel 'save_defaults' => true, // On load save the defaults to DB before user clicks save or not 'default_show' => false, // If true, shows the default value next to each field that is not the default value. 'default_mark' => '', // What to print by the field's title if the value shown is default. Suggested: * 'show_import_export' => true, // Shows the Import/Export panel when not used as a field. // CAREFUL -> These options are for advanced use only 'transient_time' => 60 * MINUTE_IN_SECONDS, 'output' => true, // Global shut-off for dynamic CSS output by the framework. Will also disable google fonts output 'output_tag' => true, // Allows dynamic CSS to be generated for customizer and google fonts, but stops the dynamic CSS from going to the head // 'footer_credit' => '', // Disable the footer credit of Redux. Please leave if you can help it. // FUTURE -> Not in use yet, but reserved or partially implemented. Use at your own risk. 'database' => '', // possible: options, theme_mods, theme_mods_expanded, transient. Not fully functional, warning! 'system_info' => false, // REMOVE // HINTS 'hints' => array( 'icon' => 'icon-question-sign', 'icon_position' => 'right', 'icon_color' => 'lightgray', 'icon_size' => 'normal', 'tip_style' => array( 'color' => 'light', 'shadow' => true, 'rounded' => false, 'style' => '', ), 'tip_position' => array( 'my' => 'top left', 'at' => 'bottom right', ), 'tip_effect' => array( 'show' => array( 'effect' => 'slide', 'duration' => '500', 'event' => 'mouseover', ), 'hide' => array( 'effect' => 'slide', 'duration' => '500', 'event' => 'click mouseleave', ), ), ) ); // ADMIN BAR LINKS -> Setup custom links in the admin bar menu as external items. $this->args['admin_bar_links'][] = array( 'id' => 'redux-docs', 'href' => 'http://docs.reduxframework.com/', 'title' => __( 'Documentation', 'redux-framework-demo' ), ); $this->args['admin_bar_links'][] = array( //'id' => 'redux-support', 'href' => 'https://github.com/ReduxFramework/redux-framework/issues', 'title' => __( 'Support', 'redux-framework-demo' ), ); $this->args['admin_bar_links'][] = array( 'id' => 'redux-extensions', 'href' => 'reduxframework.com/extensions', 'title' => __( 'Extensions', 'redux-framework-demo' ), ); // SOCIAL ICONS -> Setup custom links in the footer for quick links in your panel footer icons. $this->args['share_icons'][] = array( 'url' => 'https://github.com/ReduxFramework/ReduxFramework', 'title' => 'Visit us on GitHub', 'icon' => 'el-icon-github' //'img' => '', // You can use icon OR img. IMG needs to be a full URL. ); $this->args['share_icons'][] = array( 'url' => 'https://www.facebook.com/pages/Redux-Framework/243141545850368', 'title' => 'Like us on Facebook', 'icon' => 'el-icon-facebook' ); $this->args['share_icons'][] = array( 'url' => 'http://twitter.com/reduxframework', 'title' => 'Follow us on Twitter', 'icon' => 'el-icon-twitter' ); $this->args['share_icons'][] = array( 'url' => 'http://www.linkedin.com/company/redux-framework', 'title' => 'Find us on LinkedIn', 'icon' => 'el-icon-linkedin' ); // Panel Intro text -> before the form if ( ! isset( $this->args['global_variable'] ) || $this->args['global_variable'] !== false ) { if ( ! empty( $this->args['global_variable'] ) ) { $v = $this->args['global_variable']; } else { $v = str_replace( '-', '_', $this->args['opt_name'] ); } $this->args['intro_text'] = sprintf( __( 'Did you know that Redux sets a global variable for you? To access any of your saved options from within your code you can use your global variable: $%1$s
', 'redux-framework-demo' ), $v ); } else { $this->args['intro_text'] = __( 'This text is displayed above the options panel. It isn\'t required, but more info is always better! The intro_text field accepts all HTML.
', 'redux-framework-demo' ); } // Add content after the form. $this->args['footer_text'] = __( 'This text is displayed below the options panel. It isn\'t required, but more info is always better! The footer_text field accepts all HTML.
', 'redux-framework-demo' ); } public function validate_callback_function( $field, $value, $existing_value ) { $error = true; $value = 'just testing'; /* do your validation if(something) { $value = $value; } elseif(something else) { $error = true; $value = $existing_value; } */ $return['value'] = $value; $field['msg'] = 'your custom error message'; if ( $error == true ) { $return['error'] = $field; } return $return; } public function class_field_callback( $field, $value ) { print_r( $field ); echo '