Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stevegrunwell/wp-admin-tabbed-settings-pages
A polyfill for Trac #51086, bringing tabbed settings pages into WP-Admin.
https://github.com/stevegrunwell/wp-admin-tabbed-settings-pages
polyfill wordpress wordpress-development wordpress-plugin-settings
Last synced: 2 months ago
JSON representation
A polyfill for Trac #51086, bringing tabbed settings pages into WP-Admin.
- Host: GitHub
- URL: https://github.com/stevegrunwell/wp-admin-tabbed-settings-pages
- Owner: stevegrunwell
- Created: 2020-08-20T21:10:49.000Z (over 4 years ago)
- Default Branch: develop
- Last Pushed: 2020-08-27T17:24:37.000Z (over 4 years ago)
- Last Synced: 2024-10-31T19:37:08.309Z (2 months ago)
- Topics: polyfill, wordpress, wordpress-development, wordpress-plugin-settings
- Language: PHP
- Homepage: https://core.trac.wordpress.org/ticket/51086
- Size: 75.2 KB
- Stars: 14
- Watchers: 5
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# WP-Admin Tabbed Settings Pages (Polyfill)
[![Build Status](https://travis-ci.com/stevegrunwell/wp-admin-tabbed-settings-pages.svg?branch=develop)](https://travis-ci.com/stevegrunwell/wp-admin-tabbed-settings-pages)
[![WordPress Trac #51086](https://img.shields.io/badge/trac%20ticket-51086-blue)](https://core.trac.wordpress.org/ticket/51086)This package contains a polyfill for [WordPress Core Trac ticket #51086](https://core.trac.wordpress.org/ticket/51086), wherein a standard for tabbed settings pages within WP-Admin has been proposed.
The proposal centers around a new function as part of [the Settings API](https://codex.wordpress.org/Settings_API): `do_tabbed_settings_sections()`, which is identical to [`do_settings_sections()`](https://developer.wordpress.org/reference/functions/do_settings_sections/) except that each section is rendered in a separate tab.
![A side-by-side comparison of the classic, non-tabbed settings UI and the tabbed version](.github/screenshots/side-by-side.png)
As a bonus, the included script respects the URL hash, enabling browser history for tabs as well as the ability to link directly to specific tabs!
Best of all, you don't have to wait for WordPress Core to accept the change to start using it today, as this package contains the same code (and is maintained by the person who submitted the Trac ticket). This version of the code is even designed to step aside if it detects the function within WordPress core sometime in the future!
## Installation
To run this polyfill as a stand-alone WordPress plugin, [grab the latest zip file]() and install it as you would any other WordPress plugin.
If you'd rather bundle this as a dependency in another plugin, you may load it via Composer:
```sh
$ composer require stevegrunwell/wp-admin-tabbed-settings-pages
```It's worth noting that the `composer.json` does not include the plugin bootstrap file in the autoloader, so it's necessary to explicitly require this file after WordPress has been loaded (such as when your plugin is loading):
```php
// Please adjust this path as appropriate.
require_once __DIR__ . '/vendor/stevegrunwell/wp-admin-tabbed-settings-pages/wp-admin-tabbed-settings-pages.php';
```## Usage
As long as you're leveraging the [WordPress Settings API](https://codex.wordpress.org/Settings_API), the only change necessary is replacing your call to `do_settings_sections($page)` with `do_tabbed_settings_sections($page)`.
For an example of how this might look, [please see the WP-Admin Tabbed Settings Pages demo plugin attached to the Trac ticket](https://core.trac.wordpress.org/attachment/ticket/51086/wp-admin-tabbed-settings-pages-demo.php).