Spreadsheet Editor: Row Filters
This patch adds support for filtering rows based on rules and values. Filters will work for any attribute data source, they are a property of the spreadsheet rather than of the attribute system. The properties displayed in the row filter can depend on data type of the currently visible column with that name. If the name is no longer visible, the row filter filter is grayed out, but it will remember the value until a column with its name is visible again. Note: The comments in `screen.c` combined with tagging the sidebar for redraw after the main region point to a lack of understanding or technical debt, that is a point to improve in the future. **Future Improvements** * T89272: A search menu for visible columns when adding a new filter. * T89273: Possibly a "Range" operation. Differential Revision: https://developer.blender.org/D10959
This commit is contained in:
@@ -39,7 +39,7 @@ extern "C" {
|
||||
|
||||
/* Blender file format version. */
|
||||
#define BLENDER_FILE_VERSION BLENDER_VERSION
|
||||
#define BLENDER_FILE_SUBVERSION 3
|
||||
#define BLENDER_FILE_SUBVERSION 4
|
||||
|
||||
/* Minimum Blender version that supports reading file written with the current
|
||||
* version. Older Blender versions will test this and show a warning if the file
|
||||
|
@@ -1357,12 +1357,21 @@ static void write_area(BlendWriter *writer, ScrArea *area)
|
||||
}
|
||||
else if (sl->spacetype == SPACE_SPREADSHEET) {
|
||||
BLO_write_struct(writer, SpaceSpreadsheet, sl);
|
||||
|
||||
SpaceSpreadsheet *sspreadsheet = (SpaceSpreadsheet *)sl;
|
||||
|
||||
LISTBASE_FOREACH (SpreadsheetRowFilter *, row_filter, &sspreadsheet->row_filters) {
|
||||
BLO_write_struct(writer, SpreadsheetRowFilter, row_filter);
|
||||
BLO_write_string(writer, row_filter->value_string);
|
||||
}
|
||||
|
||||
LISTBASE_FOREACH (SpreadsheetColumn *, column, &sspreadsheet->columns) {
|
||||
BLO_write_struct(writer, SpreadsheetColumn, column);
|
||||
BLO_write_struct(writer, SpreadsheetColumnID, column->id);
|
||||
BLO_write_string(writer, column->id->name);
|
||||
/* While the display name is technically runtime data, we write it here, otherwise the row
|
||||
* filters might not now their type if their region draws before the main region.
|
||||
* This would ideally be cleared here. */
|
||||
BLO_write_string(writer, column->display_name);
|
||||
}
|
||||
LISTBASE_FOREACH (SpreadsheetContext *, context, &sspreadsheet->context_path) {
|
||||
switch (context->type) {
|
||||
@@ -1743,11 +1752,18 @@ static void direct_link_area(BlendDataReader *reader, ScrArea *area)
|
||||
SpaceSpreadsheet *sspreadsheet = (SpaceSpreadsheet *)sl;
|
||||
|
||||
sspreadsheet->runtime = NULL;
|
||||
|
||||
BLO_read_list(reader, &sspreadsheet->row_filters);
|
||||
LISTBASE_FOREACH (SpreadsheetRowFilter *, row_filter, &sspreadsheet->row_filters) {
|
||||
BLO_read_data_address(reader, &row_filter->value_string);
|
||||
}
|
||||
BLO_read_list(reader, &sspreadsheet->columns);
|
||||
LISTBASE_FOREACH (SpreadsheetColumn *, column, &sspreadsheet->columns) {
|
||||
BLO_read_data_address(reader, &column->id);
|
||||
BLO_read_data_address(reader, &column->id->name);
|
||||
/* While the display name is technically runtime data, it is loaded here, otherwise the row
|
||||
* filters might not now their type if their region draws before the main region.
|
||||
* This would ideally be cleared here. */
|
||||
BLO_read_data_address(reader, &column->display_name);
|
||||
}
|
||||
|
||||
BLO_read_list(reader, &sspreadsheet->context_path);
|
||||
|
Reference in New Issue
Block a user