threadi / wp-easy-setup
Provides a simple react-driven plugin-setup for WordPress-backend.
1.2.1
2024-09-05 11:04 UTC
- dev-master
- 1.2.1
- 1.2.0
- 1.0.4
- dev-feature/checkForDirectory
- dev-feature/addSkipOption
- dev-fix/compatiblityWithPreWp66
- dev-feature/addVendorPathConfig
- dev-feature/addFieldsReloading
- dev-fix/missingErrorMessages
- dev-fix/betterCheckForFieldsToMark
- dev-feature/updateVendorDirDetection
- dev-feature/optimizeEmbedding
- dev-feature/optimizeHandling
This package is auto-updated.
Last update: 2024-09-05 12:35:39 UTC
README
Requirements
- composer to install this package.
- npm to compile the scripts.
- WordPress-plugin where this setup will be used
Installation
composer require threadi/wp-easy-setup
- Switch to
vendor/thread/wp-easy-setup
- Run
npm i
to install dependencies. - Run
npm run build
to compile the scripts.
Usage
Embed
Add this in the page where you want to show the setup.
$setup_obj = \wpEasySetup\Setup::get_instance();
$setup_obj->set_url( 'website-URL' );
$setup_obj->set_path( 'website-path' );
$setup_obj->set_texts( array(
'title_error' => __( 'Error', 'your-text-domain' ),
'txt_error_1' => __( 'The following error occurred:', 'your-text-domain' ),
'txt_error_2' => __( 'text after error', 'your-text-domain' ),
) );
$setup_obj->set_config( array( /* your custom setup configuration */ ) );
$setup_obj->display( 'your-setup-name' );
Hint: line 1 to 4 should be run before any output, e.g. via 'admin_init' hook.
Custom configuration
The array must contain following entries:
- name => the unique name for the setup (e.g. the plugin slug)
- title => the language-specific title of the setup for the header of it
- steps => list of steps (see below)
- back_button_label => language-specific title for the back-button
- continue_button_label => language-specific title for the continue-button
- finish_button_label => language-specific title for the finish-button
Steps
Steps are defined as array with step-number as index and fields-configuration as value. Example:
1 => array( /* fields in step 1 */ ),
2 => array( /* fields in step 2 */ )
The fields-configuration is defined as array with the following structure:
1 => array(
'field_1_name' => array(
'type' => 'field-type',
'label' => __( 'the label', 'your-text-domain' ),
'help' => __( 'the help text', 'your-text-domain' ),
'placeholder' => __( 'the placeholder', 'your-text-domain' ),
'required' => true, // true if required for next step
'validation_callback' => 'example::validate', // PHP-callback to validate the entry
),
'field_2_name' => array(
'type' => 'field-type',
'label' => __( 'the label', 'your-text-domain' ),
'help' => __( 'the help text', 'your-text-domain' ),
'placeholder' => __( 'the placeholder', 'your-text-domain' ),
'required' => true, // true if required for next step
'validation_callback' => 'example::validate', // PHP-callback to validate the entry
),
Field-types
Following field-types are supported:
- CheckboxControl => shows a simple checkbox for "yes/no"
- ProgressBar => shows a progressbar which will process what is defined via hook "wp_easy_setup_process"
- RadioControl => shows a group of radio-boxes where the user should decide what to choose
- TextControl => shows a single input-text-field
- Text => shows the text you defined in array-key "text"
Other array keys
- label => is the label above the field
- help => shows a html-formatted text below the field
- placeholder => is used as such on field which support it
- required => true if field is required for next step
- validation_callback => PHP-callback to validate the entry