Skip to content

Commit

Permalink
Merge pull request #8628 from LedgerHQ/fix/release-live-15143
Browse files Browse the repository at this point in the history
Release - fix(lld): use a debounce on memotag field
  • Loading branch information
KVNLS authored Dec 6, 2024
2 parents a68c16b + 3a9758f commit a5832e8
Show file tree
Hide file tree
Showing 5 changed files with 36 additions and 7 deletions.
5 changes: 5 additions & 0 deletions .changeset/seven-ravens-rest.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"ledger-live-desktop": minor
---

LLD: LIVE-15143 use a debounce on the memotag field
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,14 @@ import { render, screen, fireEvent } from "tests/testUtils";
import MemoTagField from "../components/MemoTagField";

describe("MemoTagField", () => {
beforeAll(() => {
jest.useFakeTimers();
});

afterAll(() => {
jest.useRealTimers();
});

it("renders MemoTagField with label and text field", () => {
render(<MemoTagField showLabel={true} />);
expect(screen.getByText(/Tag \/ Memo/gi)).toBeInTheDocument();
Expand All @@ -19,12 +27,14 @@ describe("MemoTagField", () => {
expect(screen.queryByText(/Tag \/ Memo/gi)).not.toBeInTheDocument();
});

it("should call onChange when input value changes", () => {
it("should call onChange when input value changes with a debounce", () => {
const handleChange = jest.fn();
render(<MemoTagField onChange={handleChange} />);
fireEvent.change(screen.getByPlaceholderText(/Enter Tag \/ Memo/gi), {
target: { value: "new memo" },
});
expect(handleChange).not.toHaveBeenCalled();
jest.runAllTimers();
expect(handleChange).toHaveBeenCalledTimes(1);
});

Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import React from "react";
import React, { useState, useEffect } from "react";
import Input, { Props as InputBaseProps } from "~/renderer/components/Input";
import { useDebounce } from "@ledgerhq/live-common//hooks/useDebounce";
import Label from "~/renderer/components/Label";
import Box from "~/renderer/components/Box";
import { useTranslation } from "react-i18next";
import { Flex, Text, Tooltip } from "@ledgerhq/react-ui";
import styled from "styled-components";
import InfoCircle from "~/renderer/icons/InfoCircle";

const TooltipContainer = styled(Box)`
background-color: ${({ theme }) => theme.colors.palette.neutral.c100};
padding: 10px;
Expand All @@ -30,6 +30,7 @@ type MemoTagFieldProps = InputBaseProps & {
placeholder?: string;
label?: string;
tooltipText?: string;
validationHandler?: (newValue: string) => string;
};

const MemoTagField = ({
Expand All @@ -44,8 +45,20 @@ const MemoTagField = ({
placeholder,
label,
tooltipText,
validationHandler,
}: MemoTagFieldProps) => {
const { t } = useTranslation();
const [memoValue, setMemoValue] = useState(value);
const debouncedMemoValue = useDebounce(memoValue, 300);

useEffect(() => {
if (debouncedMemoValue !== value) onChange?.(debouncedMemoValue || "");
}, [debouncedMemoValue, onChange, value]);

const handleChange = (newValue: string) => {
setMemoValue(validationHandler ? validationHandler(newValue) : newValue);
};

return (
<Box flow={1}>
{showLabel && (
Expand All @@ -68,10 +81,10 @@ const MemoTagField = ({
<Flex justifyContent="end">{CaracterCountComponent && <CaracterCountComponent />}</Flex>
<Input
placeholder={placeholder ?? t("MemoTagField.placeholder")}
onChange={onChange}
onChange={handleChange}
warning={warning}
error={error}
value={value}
value={memoValue}
spellCheck="false"
ff="Inter"
maxMemoLength={maxMemoLength}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ const MemoField = ({ onChange, account, transaction, status, autoFocus }: MemoTa

const onTransferIdFieldChange = useCallback(
(value: string) => {
value = value.replace(/\D/g, "");
if (value !== "") onChange(bridge.updateTransaction(transaction, { transferId: value }));
else onChange(bridge.updateTransaction(transaction, { transferId: undefined }));
},
Expand All @@ -32,6 +31,7 @@ const MemoField = ({ onChange, account, transaction, status, autoFocus }: MemoTa
onChange={onTransferIdFieldChange}
spellCheck="false"
autoFocus={autoFocus}
validationHandler={newValue => newValue.replace(/\D/g, "")}
/>
);
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ const TagField = ({ onChange, account, transaction, autoFocus }: Props) => {
const onChangeTag = useCallback(
(str: string) => {
const bridge = getAccountBridge(account);
const tag = BigNumber(str.replace(/[^0-9]/g, ""));
const tag = BigNumber(str);
const patch = {
tag:
!tag.isNaN() &&
Expand All @@ -37,6 +37,7 @@ const TagField = ({ onChange, account, transaction, autoFocus }: Props) => {
value={String(transaction.tag || "")}
onChange={onChangeTag}
autoFocus={autoFocus}
validationHandler={str => str.replace(/[^0-9]/g, "")}
/>
);
};
Expand Down

0 comments on commit a5832e8

Please sign in to comment.