Or, embed this snippet using GenerateWP WordPress Plugin.

Download

Clone

holiday1

class Custom_Settings_Page {

	public function __construct() {

		add_action( 'admin_menu', array( $this, 'add_admin_menu' ) );
		add_action( 'admin_init', array( $this, 'init_settings'  ) );

	}

	public function add_admin_menu() {

		add_options_page(
			esc_html__( '休日設定', 'wp_onishi' ),
			esc_html__( '休日設定', 'wp_onishi' ),
			'manage_options',
			'setting_holidays',
			array( $this, 'page_layout' )
		);

	}

	public function init_settings() {

		register_setting(
			'settings_group',
			'myholidays'
		);

		add_settings_section(
			'myholidays_section',
			'',
			false,
			'myholidays'
		);

		add_settings_field(
			'holiday_start',
			__( '休日開始日', 'wp_onishi' ),
			array( $this, 'render_holiday_start_field' ),
			'myholidays',
			'myholidays_section'
		);
		add_settings_field(
			'holiday_end',
			__( '休日終了日', 'wp_onishi' ),
			array( $this, 'render_holiday_end_field' ),
			'myholidays',
			'myholidays_section'
		);

	}

	public function page_layout() {

		// Check required user capability
		if ( !current_user_can( 'manage_options' ) )  {
			wp_die( esc_html__( 'You do not have sufficient permissions to access this page.', 'wp_onishi' ) );
		}

		// Admin Page Layout
		echo '<div class="wrap">' . "n";
		echo '	<h1>' . get_admin_page_title() . '</h1>' . "n";
		echo '	<form action="options.php" method="post">' . "n";

		settings_fields( 'settings_group' );
		do_settings_sections( 'myholidays' );
		submit_button();

		echo '	</form>' . "n";
		echo '</div>' . "n";

	}

	function render_holiday_start_field() {

		// Retrieve data from the database.
		$options = get_option( 'myholidays' );

		// Set default value.
		$value = isset( $options['holiday_start'] ) ? $options['holiday_start'] : '';

		// Field output.
		echo '<input type="date" name="myholidays[holiday_start]" class="regular-text holiday_start_field" placeholder="' . esc_attr__( '', 'wp_onishi' ) . '" value="' . esc_attr( $value ) . '">';

	}

	function render_holiday_end_field() {

		// Retrieve data from the database.
		$options = get_option( 'myholidays' );

		// Set default value.
		$value = isset( $options['holiday_end'] ) ? $options['holiday_end'] : '';

		// Field output.
		echo '<input type="date" name="myholidays[holiday_end]" class="regular-text holiday_end_field" placeholder="' . esc_attr__( '', 'wp_onishi' ) . '" value="' . esc_attr( $value ) . '">';

	}

}

new Custom_Settings_Page;