Last active
April 26, 2019 15:31
-
-
Save vishalkakadiya/735691e184255cd285725c3474109008 to your computer and use it in GitHub Desktop.
How to add custom settings in WordPress Admin ?
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/* | |
* This program is free software: you can redistribute it and/or modify | |
* it under the terms of the GNU General Public License as published by | |
* the Free Software Foundation, either version 3 of the License, or | |
* (at your option) any later version. | |
* | |
* This program is distributed in the hope that it will be useful, | |
* but WITHOUT ANY WARRANTY; without even the implied warranty of | |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
* GNU General Public License for more details. | |
*/ | |
class MySettingsPage | |
{ | |
/** | |
* Holds the values to be used in the fields callbacks | |
*/ | |
private $options; | |
/** | |
* Start up | |
*/ | |
public function __construct() | |
{ | |
add_action( 'admin_menu', array( $this, 'add_plugin_page' ) ); | |
add_action( 'admin_init', array( $this, 'page_init' ) ); | |
} | |
/** | |
* Add options page | |
*/ | |
public function add_plugin_page() | |
{ | |
// This page will be under "Settings" | |
/* | |
add_options_page( | |
'Settings Admin', | |
'My Settings', | |
'manage_options', | |
'my-setting-admin', | |
array( $this, 'create_admin_page' ) | |
); | |
*/ | |
// add top level menu page | |
add_menu_page( | |
'Settings Admin', | |
'My Settings', | |
'manage_options', | |
'my-setting-admin', | |
array( $this, 'create_admin_page' ) | |
); | |
} | |
/** | |
* Options page callback | |
*/ | |
public function create_admin_page() | |
{ | |
// Set class property | |
$this->options = get_option( 'my_option_name' ); | |
?> | |
<div class="wrap"> | |
<h1>My Settings</h1> | |
<form method="post" action="options.php"> | |
<?php | |
// This prints out all hidden setting fields | |
settings_fields( 'my_option_group' ); | |
do_settings_sections( 'my-setting-admin' ); | |
submit_button(); | |
?> | |
</form> | |
</div> | |
<?php | |
} | |
/** | |
* Register and add settings | |
*/ | |
public function page_init() | |
{ | |
register_setting( | |
'my_option_group', // Option group | |
'my_option_name', // Option name | |
array( $this, 'sanitize' ) // Sanitize | |
); | |
add_settings_section( | |
'setting_section_id', // ID | |
'My Custom Settings', // Title | |
array( $this, 'print_section_info' ), // Callback | |
'my-setting-admin' // Page | |
); | |
add_settings_field( | |
'id_number', // ID | |
'ID Number', // Title | |
array( $this, 'id_number_callback' ), // Callback | |
'my-setting-admin', // Page | |
'setting_section_id' // Section | |
); | |
add_settings_field( | |
'title', | |
'Title', | |
array( $this, 'title_callback' ), | |
'my-setting-admin', | |
'setting_section_id' | |
); | |
} | |
/** | |
* Sanitize each setting field as needed | |
* | |
* @param array $input Contains all settings fields as array keys | |
*/ | |
public function sanitize( $input ) | |
{ | |
$new_input = array(); | |
if( isset( $input['id_number'] ) ) | |
$new_input['id_number'] = absint( $input['id_number'] ); | |
if( isset( $input['title'] ) ) | |
$new_input['title'] = sanitize_text_field( $input['title'] ); | |
return $new_input; | |
} | |
/** | |
* Print the Section text | |
*/ | |
public function print_section_info() | |
{ | |
print 'Enter your settings below:'; | |
} | |
/** | |
* Get the settings option array and print one of its values | |
*/ | |
public function id_number_callback() | |
{ | |
printf( | |
'<input type="text" id="id_number" name="my_option_name[id_number]" value="%s" />', | |
isset( $this->options['id_number'] ) ? esc_attr( $this->options['id_number']) : '' | |
); | |
} | |
/** | |
* Get the settings option array and print one of its values | |
*/ | |
public function title_callback() | |
{ | |
printf( | |
'<input type="text" id="title" name="my_option_name[title]" value="%s" />', | |
isset( $this->options['title'] ) ? esc_attr( $this->options['title']) : '' | |
); | |
} | |
} | |
if( is_admin() ) | |
$my_settings_page = new MySettingsPage(); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment