Skip to content

Commit

Permalink
[UIPQB-179] Properly display string booleans (#205)
Browse files Browse the repository at this point in the history
  • Loading branch information
ncovercash committed Jan 9, 2025
1 parent 153a301 commit d4e5ca3
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 5 deletions.
4 changes: 3 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,9 @@

* [UIPQB-141](https://folio-org.atlassian.net/browse/UIPQB-141) Modal dialog focus inconsistencies across screenreaders.
* [UIPQB-162](https://folio-org.atlassian.net/browse/UIPQB-162) Errors when query includes a modified custom field.
* [UIPQB-175](https://folio-org.atlassian.net/browse/UIPQB-175) Displays the "Smth went wrong" page, when the user clicks on "Select operator" dropdown and selects any of them, if there are deleted custom fields
* [UIPQB-175](https://folio-org.atlassian.net/browse/UIPQB-175) Displays the "Smth went wrong" page, when the user clicks on "Select operator" dropdown and selects any of them, if there are deleted custom fields.
* [UIPQB-164](https://folio-org.atlassian.net/browse/UIPQB-164) Columns are reset when user modifies query.
* [UIPQB-179](https://folio-org.atlassian.net/browse/UIPQB-179) Fix string-based booleans improperly displaying.

## [1.2.7](https://github.com/folio-org/ui-plugin-query-builder/tree/v1.2.7) (2024-12-26)

Expand Down
19 changes: 15 additions & 4 deletions src/QueryBuilder/ResultViewer/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,16 +11,27 @@ export const formatValueByDataType = (value, dataType, intl, additionalParams =

switch (dataType) {
case DATA_TYPES.BooleanType:
return value
? <FormattedMessage id="ui-plugin-query-builder.options.true" />
: <FormattedMessage id="ui-plugin-query-builder.options.false" />;
// booleans may be returned as true booleans, or strings 'true' or 'false'
if (typeof value === 'string') {
return value === 'true' ? (
<FormattedMessage id="ui-plugin-query-builder.options.true" />
) : (
<FormattedMessage id="ui-plugin-query-builder.options.false" />
);
} else {
return value ? (
<FormattedMessage id="ui-plugin-query-builder.options.true" />
) : (
<FormattedMessage id="ui-plugin-query-builder.options.false" />
);
}

case DATA_TYPES.DateType:
return <FormattedDate value={value} />;

case DATA_TYPES.ArrayType:
if (additionalParams?.isInstanceLanguages) {
return value.map(lang => formattedLanguageName(lang, intl)).join(' | ');
return value.map((lang) => formattedLanguageName(lang, intl)).join(' | ');
}

return value.join(' | ');
Expand Down
39 changes: 39 additions & 0 deletions src/QueryBuilder/ResultViewer/utils.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
import '@testing-library/jest-dom';
import { render } from '@testing-library/react';
import { IntlProvider } from 'react-intl';
import { DATA_TYPES } from '../../constants/dataTypes';
import { formatValueByDataType } from './utils';

describe('formatValueByDataType returns correct value', () => {
test.each([
[undefined, DATA_TYPES.StringType, ''],
[null, DATA_TYPES.StringType, ''],

[true, DATA_TYPES.BooleanType, 'ui-plugin-query-builder.options.true'],
[false, DATA_TYPES.BooleanType, 'ui-plugin-query-builder.options.false'],
['true', DATA_TYPES.BooleanType, 'ui-plugin-query-builder.options.true'],
['false', DATA_TYPES.BooleanType, 'ui-plugin-query-builder.options.false'],

['2024-01-01T12:30:00Z', DATA_TYPES.StringType, '2024-01-01T12:30:00Z'],
['2024-01-01T12:30:00Z', DATA_TYPES.DateType, '1/1/2024'],
['2024-01-01T12:30:00Z', DATA_TYPES.DateType, '1/1/2024'],

[[], DATA_TYPES.ArrayType, ''],
[['a'], DATA_TYPES.ArrayType, 'a'],
[['a', 'b', 'c'], DATA_TYPES.ArrayType, 'a | b | c'],

[1234, DATA_TYPES.IntegerType, '1234'],
[12.34, DATA_TYPES.NumberType, '12.34'],

[false, DATA_TYPES.StringType, ''],
['foo', DATA_TYPES.StringType, 'foo'],
])('value=%j of type=%p renders to %p', (value, type, expected) => {
const formatted = formatValueByDataType(value, type, null);

if (typeof formatted === 'string') {
expect(formatted).toBe(expected);
} else {
expect(render(<IntlProvider>{formatted}</IntlProvider>).container.innerHTML).toBe(expected);
}
});
});

0 comments on commit d4e5ca3

Please sign in to comment.