Флажки страницы настроек плагина для типов записей - PullRequest
0 голосов
/ 12 октября 2019

Я пытаюсь зафиксировать настройки с помощью флажков рядом со списком типов сообщений на сайте.

Цель состоит в том, чтобы иметь возможность выборочно применять макет с пользовательским стилем к редактору блоков для указанных типов записей, так что основная область блока редактирования удаляется и отображаются только мета-поля настраиваемых полей для ввода данных.

До сих пор я мог вручную жестко задавать типы сообщений, к которым я хочу применить этот стиль, но хотел бы сделать это удобно на странице настроек.

Я могу получить список типов записей, которые будут динамически отображаться на странице настроек для плагина, с помощью функции get_post_types (), а затем выполнить итерации по ним и добавить флажки. Все идет нормально.

Проблема сохранения настроек между сохранениями.

Я нашел следующий код в StackOverflow, который я изменил в качестве отправной точки. Я могу или не могу начать с правильного места. Идентификационные номера и названия заголовков взяты из примера кода, и, если они заполнены, они сохраняются между сохранением и загрузкой страницы.

{
    /**
     * 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', 
            'Layout for Data Entry', 
            '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>Add Custom layout for Data Entry for Block Editor</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
            'Post Types', // 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'
        );          



        add_settings_field(
            'post-type', 
            'Post Type', 
            array( $this, 'post_types_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 'Select the post types to apply the layout to:';
    }

    /** 
     * 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']) : ''
        );
    }

    public function post_types_callback()
    {
      $args = array(
      'public'   => true
      );

      $output = 'names'; // names or objects, note names is the default
      $operator = 'and'; // 'and' or 'or'

      $post_types = get_post_types( $args, $output, $operator ); 

      foreach ( $post_types  as $post_type ) {
        echo '<p>';
        printf(
          '<input type="checkbox" id="[$post_type]" name="my_option_name[$post_type]" value="%s" />',
          isset( $this->options[$post_type] ) ? esc_attr( $this->options[$post_type]) : ''
        );
        echo $post_type . ' </p>';
      }

    }
}

if( is_admin() )
    $my_settings_page = new MySettingsPage();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...