{eac}Doojigger Providing Contextual Help

EarthAsylum Consulting WordPress eacDoojigger

Using contextual help in {eac}Doojigger derivative plugins and extensions.

Document Header

Homepage:https://eacDoojigger.earthasylum.com/
Author:EarthAsylum Consulting
Last Updated:05-Jun-2024
Contributors:earthasylum, kevinburkholder Requires {eac}Doojigger:2.5
WordPress URI:https://wordpress.org/plugins/search/earthasylum/
GitHub URI:https://github.com/EarthAsylum/docs.eacDoojigger/wiki/

Description

{eac}Doojigger has several methods available to easily add contextual help to your plugin administration screen and it automatically adds field-level help when rendering your options based on your option meta data.

To use contextual help, first, when defining your plugin class, use the plugin help trait...

class myAwesomePlugin extends \EarthAsylumConsulting\abstract_context
{
    /**
     * @trait methods for contextual help tabs
     */
    use \EarthAsylumConsulting\Traits\plugin_help;

    ...
}

Second, in your class _constructor method, add the action to call your rendering function...

public function __construct(array $header)
{
    parent::__construct($header);

    if ($this->is_admin())
    {
        // Register plugin options
        $this->add_action( "options_settings_page",         array($this, 'admin_options_settings') );

        // Add contextual help
        $this->add_action( 'options_settings_help',         array($this, 'admin_options_help') );
    }
}

In your plugin extensions, you use the same options_settings_help action but omit the plugin help trait (only the plugin should enable the help system).

Third, add your rendering function to add help tab(s) and (optionally) sidebar content...

public function admin_options_help()
{
    ob_start();
    ? >;
        Lorem ipsum dolor sit amet, consectetur adipiscing elit,
        sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
        Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
        Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
        Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
    < ? php

    $content = ob_get_clean();

    //  add a tab - tab_name , content , <details> heading (optional), priority (optional)
    $this->addPluginHelpTab('My Awesome Plugin', $content, ['My Awesome Plugin','open']);

    // add sidebar text/html
    $this->addPluginSidebarText('<h4>For more information:</h4>');

    // add sidebar link - title , url , tooltip (optional)
    $this->addPluginSidebarLink(
        "<span class='dashicons dashicons-editor-help'></span>Custom Plugins",
        'https://eacdoojigger.earthasylum.com/eacdoojigger/',
        "Custom Plugin Derivatives"
    );
}

You can also control when (on what option tab) your contextual help will appear by checking the current tab name...

public function admin_options_help()
{
    if ($this->plugin->isSettingsPage('General'))
    {
        //  content only on the 'General' tab
    }
}

Field-level help is automatically rendered from your options meta data.

Top
Help Methods

Enable or diisable the help system (and field-level help) or check if help system is enabled:

$this->pluginHelpEnabled(bool [,bool]);
if ( $this->pluginHelpEnabled() ) {...}

Add help content:

$this->addPluginHelpTab(
    'tab_name',
    'content_html',
    'content_header',   // optional <details> heading
    priority            // optional, default = 10
);
  • content_html may be a single string of text/html or an array of strings to be rendered as paragraphs.
  • content_header is an optional string to be rendered in a <details><summary> tag containing content_html.
  • content_header may be an array of ['...header...','open'] to open the <details> tag.

Add help sidebar links:

$this->addPluginSidebarLink(
    'title',
    'link',
    'tooltip'           // optional
)

Add help sidebar text:

$this->addPluginSidebarText(
    'content_html'
);
  • content_html may be a single string of text/html or an array of strings to be rendered as paragraphs.

Add field-level help (may be used after help tabs are rendered):

This method is automatically called when rendering your option fields using option['help'] or option['title']+option['info']. If option['help'] is an array, the array key is used as the help tab_name.

$this->addPluginHelpField(
    'tab_name',
    'label',
    'content_html'
);
  • tab_name should match 'tab_name' of addPluginHelpTab() otherwise reverts to first help tab.
  • tab_name may be an array of possible addPluginHelpTab() 'tab_name's, using the first match.
  • content_html may be a single string of text/html or an array of strings (not rendered as paragraphs).

Force all field-level help on the first help tab:

$this->plugin_help_fields_on_first_tab = true;      // default is false
Top
Other Screens

If your plugin or extension includes screen(s) other than the administrator settings page (e.g. custom posts or taxonomies), you can still easily make use of the {eac}Doojigger contextual help framework.

Rendering the help screen

Add an action to

  • Verify that you're on your custom screen.
  • Add help screen content.
  • Render the help screen.
    add_action( 'current_screen', array($this, 'render_help'));

    public function render_help($screen)
    {
        if ($screen->id == 'edit-' . 'my-awesome-screen')
        {
            //  add a tab - tab_name , content , <details> heading (optional), priority (optional)
            $this->addPluginHelpTab('My Awesome Screen', $content, ['My Awesome Screen','open']);

            $this->plugin_help_render($screen);
        }

    }

Add field-level contextual help

Where desired, add field level help

    $this->plugin->html_input_help('My Awesome Screen', 'field-name', [
            'label' =>  'Field Name',
            'help'  =>  'help content.'
        ]
    );
Top
Screen Shots
  1. My Awesome Plugin Contextual Help ContextualHelp
Top