Empty tables are being saved to the db if a tablefield is empty

Created on 29 November 2024, 4 months ago

Problem/Motivation

As per: https://git.drupalcode.org/project/tablefield/-/merge_requests/15

In my opinion, the original question of this issue arises due to the fact that before saving the TablefieldItem, nowhere in the code is it checked whether the table elements are empty. Therefore, a situation arises that it is possible to save a table that consists entirely of empty rows and columns.

Such a check could be added to the widget by overriding the extractFormValues method of the 'WidgetBase' class.
The most appropriate in my opinion would be to do this in the setValue method in the 'TablefieldItem' itself.

The impacts of this are that:

On multivalue tablefield a new empty table is added every time the node is updated making the edit form longer and longer and database full with empty data if the user don't manually delete the table from the form.

This seems like it'd be good to get into 3.x if it is a breaking change or at least would require some testing against existing content.

as per: https://www.drupal.org/project/tablefield/issues/3385030 šŸ’¬ After upgrade to D10, empty tablefield output is displaying in paragraph on node Active

Steps to reproduce

Have an empty tablefield field, save it.

Proposed resolution

The approach suggested in the MR?

šŸ› Bug report
Status

Active

Version

2.0

Component

Code

Created by

šŸ‡ŗšŸ‡øUnited States erutan

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @erutan
  • I have applied changes in the TablefieldItem code to prevent saving empty tables by adding validation. This ensures empty rows and columns are not saved, reducing unnecessary database growth. Let me know if any further changes are required.

  • šŸ‡ŗšŸ‡øUnited States erutan
  • šŸ‡ŗšŸ‡øUnited States erutan

    Sorry for taking a while to get to this. :)

    It still applies cleanly to dev.

    Tablefields still keeps adding empty tables every time I save an entity with a tablefield field with this patch. This happens with existing entities, new entities, entities with empty tablefields or ones with data.

    This does clean up the following phpstan error:

    ------ -------------------------------------------------------------------------- 
      Line   modules/contrib/tablefield/src/Plugin/Field/FieldType/TablefieldItem.php  
     ------ -------------------------------------------------------------------------- 
      164    Cannot unset offset 'tablefield' on array<mixed, mixed>.                  
     ------ --------------------------------------------------------------------------
  • šŸ‡ŗšŸ‡øUnited States erutan

    As per: https://www.drupal.org/project/tablefield/issues/3385030#comment-15228612 šŸ’¬ After upgrade to D10, empty tablefield output is displaying in paragraph on node Active I rolled back /src/Element/TableField.php from the commit before https://git.drupalcode.org/project/tablefield/-/commit/26d63be6aa25d34d1... and "empty" tables stopped being saved. The interface still spawns an empty table below one with content in it, but as there are no spacers inserted into it it doesn't get saved as content.

    This is a pretty brute force approach (and I'm sure there's been updates to that file after this that need to pulled in) but I personally have no need to drag tables but would prefer them not being created every time an entity is saved.

    It seems like it'd be simpler to just not save any tables/cells that only have the spacer in them, but there could also just be a patch that rips out the drag and drop stuff and keeps up to date with current changes to the file.

  • šŸ‡©šŸ‡ŖGermany florianboehme Koblenz, šŸ‡©šŸ‡Ŗ

    Any updates on this? Iā€™m using 3.x-dev along with this patch (https://git.drupalcode.org/project/tablefield/-/merge_requests/15.patch). On the frontend, all empty tables are gone with these two new options in field formatter to hide empty cells/rows, which is great. However, on the backend, every time I save a node, a new empty table is created. Over time, this results in thousands of empty tables in the database. Any ideas?

  • šŸ‡®šŸ‡³India sayan_k_dutta

    Working on it.

  • Assigned to sayan_k_dutta
  • Status changed to Needs work 2 months ago
  • šŸ‡®šŸ‡³India sayan_k_dutta

    I have made the code changes to remove the empty rows whenever an entity is saved in the database. Also the empty rows are removed from being rendered on the webpage.
    Please review MR !33.

  • Pipeline finished with Failed
    2 months ago
    Total: 139s
    #409262
  • Pipeline finished with Failed
    2 months ago
    Total: 141s
    #409271
  • šŸ‡ØšŸ‡¦Canada Liam Morland Ontario, CA šŸ‡ØšŸ‡¦

    Tests are failing. Please rebase on 3.0.x.

  • Pipeline finished with Canceled
    about 2 months ago
    #425158
  • Pipeline finished with Failed
    about 2 months ago
    Total: 300s
    #425160
  • Pipeline finished with Canceled
    about 2 months ago
    Total: 172s
    #426131
  • Pipeline finished with Failed
    about 2 months ago
    Total: 435s
    #426133
  • Pipeline finished with Failed
    about 2 months ago
    Total: 324s
    #426155
  • šŸ‡®šŸ‡³India sayan_k_dutta

    Phpunit tests are still failing for some reason. If anyone can look into it.

  • šŸ‡ØšŸ‡¦Canada Liam Morland Ontario, CA šŸ‡ØšŸ‡¦

    I note that the merge request changes some things back to how they are in 8.x-2.x.

  • Pipeline finished with Failed
    about 1 month ago
    Total: 136s
    #434291
Production build 0.71.5 2024