8 – Some #states not working for custom field but do work on identical webform field

I’m working on a project where I’m programmatically cherry picking elements from a webform and then creating a custom form with all sorts of alterations and additions to the “cloned” webform fields.

$my_custom_field = $webform->getElement($webform_field_id, TRUE);

I’m then rendering a number of custom fields like the above in a custom form that extends from FormBase. The custom webform consists of fields, custom containers, attributes etc.

Everything works fine, #states included, apart from the “pattern” state and a few other states that are based on relative values e.g. “greater” / “greater_equal” / “lower” / “lower_equal”. I’m adding these #states programmatically to the custom fields.


$custom_field('#states') = (
  'visible' => (
    ':input(name="controlling_field_name")' => (
      'value' =>
        // I've tested this pattern, it works in the webform field fine.
        'pattern' => $some_regex_pattern,

Apart from ‘pattern’, I’ve tried ‘between’ and ‘greater’, ‘greater_equal’, ‘lower’ and ‘lower_equal’ with no success.

The same exact #states (same field being dependant on same controlling field under the same exact conditions) work fine on the original webform field (when I view the webform on the admin theme for example) which makes me think that something is missing from / messing up with these #states on my custom theme.

No JS errors in the console whatsoever.

The structure of “data-drupal-states” when I render this custom field (webform field “clone”) in my custom theme is exactly the same as the webform field that’s rendered on the admin theme ie in its “native” webform.

Other #states work fine for the custom field (“value”, “checked” etc.).

Any ideas on what’s possibly messing up these specific states?