iniznet / acf-builder-callback
Build fields with ACF builder and sanitize-escape callback
Installs: 309
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 1
Forks: 1
Open Issues: 3
Type:package
Requires
- php: ^7.4|^8.0
- stoutlogic/acf-builder: 1.12.0
Requires (Dev)
- phpunit/phpunit: 9.5.25
This package is auto-updated.
Last update: 2025-03-23 18:47:03 UTC
README
A package made for ACF Builder extension to quickly create ACF configuration with callback within builder.
Simple Example
$banner = new StoutLogic\AcfBuilder\FieldsBuilder('banner'); $banner ->addText('title', [ 'label' => 'Title', 'instructions' => 'Enter the title of the banner.', 'required' => true, 'maxlength' => 100, 'placeholder' => 'Enter title', 'sanitization_cb' => 'sanitize_greater_than_30', 'escape_cb' => 'escape_greater_than_30', ]) ->addWysiwyg('content') ->addImage('background_image') ->setLocation('post_type', '==', 'page') ->or('post_type', '==', 'post'); add_action('acf/init', function() use ($banner) { acf_add_local_field_group($banner->build()); }); /** * Handle the sanitization of the title field. * Ensures that the title is greater than 30 characters or nothing. * * @param mixed $value The value of the title field. * @param int|string $post_id The post ID. * @param array $field The field settings. * * @return mixed The sanitized value. */ function sanitize_greater_than_30($value, $post_id, $field) { if (strlen($value) > 30) { return $value; } return ''; } /** * Handle the escaping of the title field. * Ensures that the title is greater than 30 characters or nothing. * * @param mixed $value The value of the title field. * @param int|string $post_id The post ID. * @param array $field The field settings. * * @return mixed The escaped value. */ function escape_greater_than_30($value, $post_id, $field) { if (strlen($value) > 30) { return esc_html($value); } return ''; } // Call below somewhere within your application especially during initialization. iniznet\AcfBuilderCallback\FieldCallback::run();
If you're using the ACF Composer
<?php namespace App\Fields; use Log1x\AcfComposer\Field; use StoutLogic\AcfBuilder\FieldsBuilder; class Example extends Field { /** * The field group. * * @return array */ public function fields() { $example = new FieldsBuilder('example'); $example ->setLocation('post_type', '==', 'post'); $example ->addRepeater('items') ->addText('item', [ 'label' => 'Item', 'instructions' => 'Enter the item.', 'required' => true, 'maxlength' => 100, 'placeholder' => 'Enter item', 'sanitization_cb' => function ($value) { return strlen($value) > 30 ? $value : ''; }, 'escape_cb' => function ($value) { return strlen($value) > 30 ? esc_html($value) : ''; }, ]) ->endRepeater(); return $example->build(); } } // Call below somewhere within your application especially during initialization. iniznet\AcfBuilderCallback\FieldCallback::run();
TODO
- Field
sanitization_cb
callback - Field
escape_cb
callback - Field
choices_cb
callback, expect an array of choices as return value - Field
default_value_cb
callback - Refactor package to standalone & doesn't extending ACF Builder as child class
- Refactor package again but with best practices instead of the current one
Requirements
PHP 7.4 through 8.0 Tested.
Install
Use composer to install:
composer require iniznet/acf-builder-callback
If your project isn't using composer, you can require the autoload.php
file.
Tests
There are no tests for this package yet.
Bug Reports
If you discover a bug in ACF Builder Callback, please open an issue.
Contributing
Contributing whether it be through PRs, reporting an issue, or suggesting an idea is encouraged and appreciated.
License
ACF Builder Callback is provided under the MIT License.