Skip to content

Commit

Permalink
#2016 Expression Builder Dropdown should change label when switched b…
Browse files Browse the repository at this point in the history
…etween Fields and Functions. (#2017)

Signed-off-by: srikant <[email protected]>
Co-authored-by: Matt Howard <[email protected]>
  • Loading branch information
srikant-ch5 and matthoward366 authored Jun 13, 2024
1 parent 059ed78 commit 25ed4e5
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@
"expression.values.empty.table.label": "No values found",
"expression.functions.table.label": "Functions table",
"expression.fields.dropdown": "Fields",
"expression.functions.dropdown": "General Functions",
"expression.add.column": "Add",
"expression.fields.title": "Fields",
"expression.values.title": "Values",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ export const MESSAGE_KEYS = {
EXPRESSION_VALUES_EMPTY_TABLE_LABEL: "expression.values.empty.table.label",
EXPRESSION_FUNCTIONS_TABLE_LABEL: "expression.functions.table.label",
EXPRESSION_FIELDS_DROPDOWN_TITLE: "expression.fields.dropdown",
EXPRESSION_FUNCTIONS_DROPDOWN_TITLE: "expression.functions.dropdown",
EXPRESSION_FIELDS_TITLE: "expression.fields.title",
EXPRESSION_VALUES_TITLE: "expression.values.title",
EXPRESSION_FIELD_COLUMN: "expression.field.column",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -596,7 +596,7 @@ export default class ExpressionSelectFieldOrFunction extends React.Component {
const first = items.slice(0, 1);
const last = items.slice(1);
items = first.concat({ value: this.recentUseCat, label: this.recentUseCat }, last);
const label = (this.state.functionCategory === this.recentUseCat) ? this.recentUseCat : this.props.functionList[this.state.functionCategory].locLabel;
const selectedFunctionItem = (this.state.functionCategory === this.recentUseCat) ? this.recentUseCat : this.props.functionList[this.state.functionCategory].locLabel;
const header = formatMessage(this.reactIntl,
MESSAGE_KEYS.TABLE_SEARCH_HEADER);
const listBoxMenuIconTranslationIds = {
Expand All @@ -608,7 +608,8 @@ export default class ExpressionSelectFieldOrFunction extends React.Component {
<Layer level={this.props.controller.getLight() ? 1 : 0}>
<Dropdown
id={"properties-expression-function-select-dropdown-" + this.uuid}
label={label}
label={formatMessage(this.reactIntl, MESSAGE_KEYS.EXPRESSION_FUNCTIONS_DROPDOWN_TITLE)}
selectedItem={selectedFunctionItem}
items={items}
onChange={this.onFunctionCatChange}
translateWithId={(id) => listBoxMenuIconTranslationIds[id]}
Expand All @@ -620,13 +621,18 @@ export default class ExpressionSelectFieldOrFunction extends React.Component {

_makeFieldDropdown() {
const items = [];
let selectedFieldItemLabel = "";
const selectedField = this.fields.field_categories.find((category) => category.id === this.state.fieldCategory);
if (selectedField) {
selectedFieldItemLabel = selectedField.locLabel;
}
for (let i = 0; i < this.fields.field_categories.length; i++) {
items.push({ value: this.fields.field_categories[i].id, label: this.fields.field_categories[i].locLabel });
}
const first = items.slice(0, 1);
const last = items.slice(1);
const newItems = first.concat({ value: this.recentUseCat, label: this.recentUseCat }, last);
const label = (this.state.fieldCategory === this.recentUseCat) ? this.recentUseCat : items[0].label;
const selectedFieldItem = (this.state.fieldCategory === this.recentUseCat) ? this.recentUseCat : selectedFieldItemLabel;
const header = formatMessage(this.reactIntl,
MESSAGE_KEYS.TABLE_SEARCH_HEADER);
const listBoxMenuIconTranslationIds = {
Expand All @@ -638,7 +644,8 @@ export default class ExpressionSelectFieldOrFunction extends React.Component {
<Layer level={this.props.controller.getLight() ? 1 : 0}>
<Dropdown
id={"properties-expression-field-select-dropdown-" + this.uuid}
label={label}
label={formatMessage(this.reactIntl, MESSAGE_KEYS.EXPRESSION_FIELDS_DROPDOWN_TITLE)}
selectedItem={selectedFieldItem}
items={newItems}
onChange={this.onFieldCatChange}
translateWithId={(id) => listBoxMenuIconTranslationIds[id]}
Expand Down

0 comments on commit 25ed4e5

Please sign in to comment.