dwnload / wp-settings-api
A PHP class abstraction that removes all the headaches of the WordPress settings API under the hood and builds a nice options panel on the fly.
Installs: 9 974
Dependents: 3
Suggesters: 0
Security: 0
Stars: 11
Watchers: 2
Forks: 1
Open Issues: 1
Requires
- php: ^8.0
- ext-json: *
- thefrosty/wp-utilities: ^3.0
Requires (Dev)
- dealerdirect/phpcodesniffer-composer-installer: ^1.0
- inpsyde/php-coding-standards: dev-development
- phpcompatibility/php-compatibility: *
- phpunit/php-code-coverage: ^9
- phpunit/phpunit: ^9
- roave/security-advisories: dev-master
- roots/wordpress: ~6.5
- slevomat/coding-standard: ~8.12
- squizlabs/php_codesniffer: ^3.2
- wp-phpunit/wp-phpunit: ~6.5
- yoast/phpunit-polyfills: ^2.0
Suggests
- frontpack/composer-assets-plugin: Composer plugin for copying of frontend assets into public directory.
- dev-develop
- v3.11.1
- v3.11.0
- v3.10.0
- v3.9.0
- v3.8.2
- v3.8.1
- v3.8.0
- v3.7.0
- v3.6.1
- v3.6.0
- v3.5.0
- v3.4.1
- v3.4.0
- v3.3.2
- v3.3.1
- 3.3.0
- 3.2.3
- 3.2.2
- 3.2.0
- 3.1.1
- 3.1.0
- 3.0.0
- 2.6.0
- 2.5.1
- 2.5.0
- 2.4.5
- 2.4.3
- 2.4.2
- 2.4.0
- 2.2.0
- 2.1.5
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.3
- 2.0.2
- 2.0.1
- dev-dependabot/composer/develop/yoast/phpunit-polyfills-tw-3.0
This package is auto-updated.
Last update: 2024-11-09 05:52:04 UTC
README
It's a PHP class wrapper for handling WordPress Settings API.
Package Installation (via Composer)
To install this package, edit your composer.json
file:
{ "require": { "dwnload/wp-settings-api": "^3.8" } }
Now run:
$ composer install dwnload/wp-settings-api
Usage Example
@see examples/Example.php
Suggested package
⭐️ frontpack/composer-assets-plugin
As of v3.2.1, this shouldn't be needed any more (unless you are filtering local assets only). Assets will now be loaded via the jsdelivr CDN.
Otherwise, since this is a PHP package and not a WordPress plugin the assets included can't be loaded properly.
In order to have the settings page inherit the styles and use the proper JS, you've got to copy the
/assets
directory to your plugin or theme. Then add the following to filter the asset src to your
directory:
<?php declare(strict_types=1); namespace Vendor\Package; use Dwnload\WpSettingsApi\Api\Script; use Dwnload\WpSettingsApi\Api\Style; use Dwnload\WpSettingsApi\WpSettingsApi; use TheFrosty\WpUtilities\Plugin\AbstractHookProvider; use TheFrosty\WpUtilities\Plugin\HooksTrait; /** * Class WpSettingsApi * * @package Dwnload\WpSettingsApi */ class WpSettingsApiScripts extends AbstractHookProvider { public function addHooks(array $scripts): void { \add_filter(WpSettingsApi::FILTER_PREFIX . 'admin_scripts', [$this, 'adminScripts']); \add_filter(WpSettingsApi::FILTER_PREFIX . 'admin_styles', [$this, 'adminStyles']); } /** * The default script needs to be moved from the vendor directory somewhere into our app since the * vendor directory is outside of the doc root. * @param Script[] $scripts * @return array */ public function adminScripts(array $scripts): array { \array_walk($scripts, function (Script $script, int $key) use (&$scripts) { switch ($script->getHandle()) { case WpSettingsApi::ADMIN_SCRIPT_HANDLE: /** * If you're not using the `TheFrosty\WpUtilities\Plugin\AbstractHookProvider` * use `plugins_url()` in place of the `$this->getPlugin()->getUrl` or any other WP * function that will point to the asset. * (Should match `frontpack/composer-assets-plugin configs`) */ $scripts[$key]->setSrc($this->getPlugin()->getUrl('assets/js/admin.js')); break; case WpSettingsApi::ADMIN_MEDIA_HANDLE: /** * If you're not using the `TheFrosty\WpUtilities\Plugin\AbstractHookProvider` * use `plugins_url()` in place of the `$this->getPlugin()->getUrl` or any other WP * function that will point to the asset. * (Should match `frontpack/composer-assets-plugin configs`) */ $scripts[$key]->setSrc($this->getPlugin()->getUrl('assets/js/wp-media-uploader.js')); break; } $this->registerScript($script); }); return $scripts; } /** * The default style needs to be moved from the vendor directory somewhere into our app since the * vendor directory is outside of the doc root. * @param Style[] $styles * @return array */ public function adminStyles(array $styles): array { \array_walk($styles, function (Style $style, int $key) use (&$styles) { if ($style->getHandle() === WpSettingsApi::ADMIN_STYLE_HANDLE) { /** * If you're not using the `TheFrosty\WpUtilities\Plugin\AbstractHookProvider` * use `plugins_url()` in place of the `$this->getPlugin()->getUrl` or any other WP * function that will point to the asset. */ $styles[$key]->setSrc($this->getPlugin()->getUrl('assets/css/admin.css')); $this->registerStyle($style); } }); return $styles; } /** * If the script is not registered before being returned back to the filter the src still uses * the vendor directory file path. * @param Script $script */ private function registerScript(Script $script): void { \wp_register_script( $script->getHandle(), $script->getSrc(), $script->getDependencies(), $script->getVersion(), $script->getInFooter() ); } /** * If the style is not registered before being returned back to the filter the src still uses * the vendor directory file path. * @param Style $style */ private function registerStyle(Style $style): void { \wp_register_style( $style->getHandle(), $style->getSrc(), $style->getDependencies(), $style->getVersion(), $style->getMedia() ); } }