becklyn/ordered-form-bundle

This bundle adds functionality for ordering form elements

Installs: 19 345

Dependents: 1

Suggesters: 1

Security: 0

Stars: 5

Watchers: 2

Forks: 1

Open Issues: 0

Type:symfony-bundle

1.4.0 2024-01-17 12:49 UTC

This package is auto-updated.

Last update: 2024-04-17 13:27:30 UTC


README

A bundle that makes form fields sortable.

Installation

composer require becklyn/ordered-form-bundle

Usage

This bundle adds a new form option called position:

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;

class SomeForm extends AbstractType
{
    /**
     * @inheritDoc
     */
    public function buildForm (FormBuilderInterface $builder, array $options) : void
    {
        $builder
            ->add("field", null, [
                "position" => /* some value */
            ]);
    }
}

The supported values are:

Value Description
"position" => "first" Places the element as the first element in the form.
"position" => "last" Places the element as the last element in the form.
"position" => 42 A simple sort order (the lower the number, the more at the top it is). Works with any integer.
"position" => ["before" => "otherfield"] Places the field before another one.
"position" => ["after" => "otherfield"] Places the field after another one.

Caveats

This bundle focuses on speed, so the sorting is not perfect. As it is pretty easy to create a conflicting, this bundle tries a best-effort sorting, but this implies:

  • A first field isn't guaranteed to be the first one (eg. if there are multiple first).
  • before and after only guarantee the relative order, not how big the distance is between these fields (it tries to place them immediately next to each other).

If the configuration of the form is sensible and conflict-free, then the order will work as expected.