Skip to content

Commit

Permalink
fix: zero showing in record cell and page (#7384)
Browse files Browse the repository at this point in the history
This PR fixes zero being displayed as empty in record cell and show page
in currency field #6802
I checked graphql resquests and the data is stored in the correct form
(0 or null). The problem only lies in the front end and how the field is
null checked.

---------

Co-authored-by: Félix Malfait <[email protected]>
  • Loading branch information
nganphan123 and FelixMalfait authored Oct 3, 2024
1 parent b8e406c commit da69317
Show file tree
Hide file tree
Showing 4 changed files with 13 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { CurrencyInput } from '@/ui/field/input/components/CurrencyInput';
import { FieldInputOverlay } from '../../../../../ui/field/input/components/FieldInputOverlay';
import { useCurrencyField } from '../../hooks/useCurrencyField';

import { isUndefinedOrNull } from '~/utils/isUndefinedOrNull';
import { FieldInputEvent } from './DateTimeFieldInput';

type CurrencyFieldInputProps = {
Expand Down Expand Up @@ -108,7 +109,7 @@ export const CurrencyFieldInput = ({

const handleSelect = (newValue: string) => {
setDraftValue({
amount: draftValue?.amount ?? '',
amount: isUndefinedOrNull(draftValue?.amount) ? '' : draftValue?.amount,
currencyCode: newValue as CurrencyCode,
});
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import { isFieldRelation } from '@/object-record/record-field/types/guards/isFie
import { computeEmptyDraftValue } from '@/object-record/record-field/utils/computeEmptyDraftValue';
import { isFieldValueEmpty } from '@/object-record/record-field/utils/isFieldValueEmpty';
import { isDefined } from '~/utils/isDefined';
import { isUndefinedOrNull } from '~/utils/isUndefinedOrNull';

type computeDraftValueFromFieldValueParams<FieldValue> = {
fieldDefinition: Pick<FieldDefinition<FieldMetadata>, 'type'>;
Expand All @@ -32,7 +33,9 @@ export const computeDraftValueFromFieldValue = <FieldValue>({
}

return {
amount: fieldValue?.amountMicros ? fieldValue.amountMicros / 1000000 : '',
amount: isUndefinedOrNull(fieldValue?.amountMicros)
? ''
: (fieldValue.amountMicros / 1000000).toString(),
currencyCode: fieldValue?.currencyCode ?? '',
} as unknown as FieldInputDraftValue<FieldValue>;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,10 @@ export const CurrencyDisplay = ({ currencyValue }: CurrencyDisplayProps) => {
? SETTINGS_FIELD_CURRENCY_CODES[currencyValue?.currencyCode]?.Icon
: null;

const amountToDisplay = (currencyValue?.amountMicros ?? 0) / 1000000;
const amountToDisplay =
currencyValue?.amountMicros != null
? currencyValue?.amountMicros / 1000000
: null;

if (!shouldDisplayCurrency) {
return <StyledEllipsisDisplay>{0}</StyledEllipsisDisplay>;
Expand All @@ -46,7 +49,7 @@ export const CurrencyDisplay = ({ currencyValue }: CurrencyDisplayProps) => {
/>{' '}
</>
)}
{amountToDisplay !== 0 ? formatAmount(amountToDisplay) : ''}
{amountToDisplay !== null ? formatAmount(amountToDisplay) : ''}
</StyledEllipsisDisplay>
);
};
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { useEffect, useMemo, useRef, useState } from 'react';
import { IMaskInput, IMaskInputProps } from 'react-imask';
import { useTheme } from '@emotion/react';
import styled from '@emotion/styled';
import { useEffect, useMemo, useRef, useState } from 'react';
import { IMaskInput, IMaskInputProps } from 'react-imask';
import { IconComponent, TEXT_INPUT_STYLE } from 'twenty-ui';

import { useRegisterInputEvents } from '@/object-record/record-field/meta-types/input/hooks/useRegisterInputEvents';
Expand Down Expand Up @@ -138,7 +138,6 @@ export const CurrencyInput = ({
mask={Number}
thousandsSeparator={','}
radix="."
unmask="typed"
onAccept={(value: string) => handleChange(value)}
inputRef={wrapperRef}
autoComplete="off"
Expand Down

0 comments on commit da69317

Please sign in to comment.