Move Float fields to contrib

Created on 30 July 2015, over 9 years ago
Updated 9 February 2025, about 2 months ago

Problem/Motivation

Float fields are confusing unless you understand what a float is. If you create a float field on a node, I have no idea how to explain to a user that 10000.1 and 3.141 are stored without alteration but 1234.5678 is stored as 1234.57. #2542132: Drupal\field\Tests\Number\NumberFieldTest fails on SQLite suggest making all float fields doubles so they can store much large numbers but even with 8-byte storage float fields can be confusing. I suggest we move float to contrib since the use-case for floats is highly specialised and hardly ever what a site builder actually wants.

Proposed resolution

Create a new float module in contrib to provide the plugin.

Deprecate the core plugin. In the change record, we can link to the float module in contrib.

Because we want to discourage people from using the field type overall, I don't think we should go to the trouble of moving the field type to a float module in core then moving that module to contrib.

Remaining tasks

  1. Add a Float contrib project
  2. Deprecate float fields and widgets in 8.9.x
  3. Remove code in 9.0.x once the deprecations are committed
📌 Task
Status

Active

Version

11.0 🔥

Component

number.module

Created by

🇬🇧United Kingdom alexpott 🇪🇺🌍

Live updates comments and jobs are added and updated live.
  • Upgrade path

    It affects the ability to upgrade Drupal sites to a new major version. Preferred over version-specific tags such as D7 upgrade path.

  • Needs subsystem maintainer review

    It is used to alert the maintainer(s) of a particular core subsystem that an issue significantly impacts their subsystem, and their signoff is needed (see the governance policy draft for more information). Also, if you use this tag, make sure the issue component is set to the correct subsystem. If an issue significantly impacts more than one subsystem, use needs framework manager review instead.

  • Needs product manager review

    It is used to alert the product manager core committer(s) that an issue represents a significant new feature, UI change, or change to the "user experience" of Drupal, and their signoff is needed. If an issue significantly affects the usability of Drupal, use Needs usability review instead (see the governance policy draft for more information).

Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇬🇧United Kingdom catch

    Removing the upgrade path tag because I think we can do this without an actual update - just a module for sites to add from contrib if they use the field.

  • 🇬🇧United Kingdom catch

    When updating the issue summary, I forgot we don't have 📌 Create a way to declare a plugin as deprecated Needs work yet. Also if we only deprecate the plugin, it will still be in the UI for all Drupal 11 sites.

    So it might be better to go the module route in core after all, this would look like:

    1. Move the plugin and any test coverage to a new 'Float field' module.

    2. Add an upgrade path, in system module, to install the module on any site that's using the float field.

    3. Immediately/asap mark that module deprecated and do the other steps to move it to a contrib module.

  • 🇫🇮Finland lauriii Finland

    I went through different contrib use cases for floats and I didn't really find good examples where float would be used correctly as a bundle field. There are examples of valid use cases where float is used as a base field. This doesn't mean someone couldn't be using it for the right reasons as a bundle field but by nature float is probably something that would be more likely to be used as base field for use cases like computations.

    If float field type is a minimal maintenance feature for us, I'm wondering if we should keep float as a field type in core but start by marking it as no_ui: true? A contrib module could be then be added to add it to the Field UI for those that need it there.

  • 🇦🇹Austria maxilein

    I like the no_ui idea!

  • 🇬🇧United Kingdom catch

    Let's try no_ui here. The main issue is the UX issue presenting these as choices in the field UI, saves us having to do the full module and deprecation route and doesn't prevent us from doing that later if there's a new reason to.

  • 🇫🇮Finland lauriii Finland

    Removing the product review tag based on #38. Removing the subsystem maintainer review tag since removing the field type from UI is much less invasive than moving it to contrib.

  • Merge request !11165Set no_ui to true. → (Open) created by catch
  • 🇬🇧United Kingdom catch

    Pushed a two-line MR to see what breaks, if anything.

  • Pipeline finished with Failed
    about 2 months ago
    Total: 418s
    #420128
  • Pipeline finished with Success
    about 2 months ago
    Total: 800s
    #420145
  • 🇬🇧United Kingdom catch

    lol, two more lines necessary to get things green, so four lines in total.

    That's a lot easier than factoring out to a module and moving to contrib!

  • 🇬🇧United Kingdom alexpott 🇪🇺🌍

    Very nice - I think with the addition of a CR we are good to go here.

  • 🇬🇧United Kingdom catch

    Added a change record and updated the issue summary.

  • 🇬🇧United Kingdom alexpott 🇪🇺🌍

    Perfect.

  • Pipeline finished with Skipped
    about 2 months ago
    #420289
  • Pipeline finished with Skipped
    about 2 months ago
    #420290
    • lauriii committed b23f4270 on 11.x
      Issue #2542760 by catch, jhedstrom, alexpott, webchick, dawehner, yched...
  • 🇫🇮Finland lauriii Finland

    Committed b23f427 and pushed to 11.x. Thanks!

  • 🇨🇭Switzerland berdir Switzerland

    I agree that this is a very rarely used feature, but it is sometimes used, http://codcontrib.hank.vps-private.net/search?text=field_type%3A%20float... has 3 pages of results (quite a lot are just tests). default config of course still works, just linked to that for use cases.

    Unlike an optional module that non-developers can install, the no_ui flag requires that you implement an alter hook to be able to still add them through the UI.

    As a compromise, I added an untested example hook to revert this, if someone creates a module for doing that they can share it there.

  • 🇫🇮Finland lauriii Finland

    Not mentioned here but we discussed on Slack that it would be simple to create a module for this. We could add that to the CR in case that someone wants to create that.

  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024