From c01be416b57690a610e88b486c92ad12c3fe4587 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Krzysztof=20Zi=C4=99cina?= Date: Thu, 23 Mar 2023 20:43:35 +0100 Subject: [PATCH] fix: change min/max rent inputs from number to text with only numbers (#1599) --- detroit-ui-components/src/forms/Field.tsx | 21 ++++++++++--------- .../src/components/filters/FilterForm.tsx | 19 ++++++++++++++--- .../components/finder/FinderRentalCosts.tsx | 6 +++++- sites/public/src/pages/finder.tsx | 4 +++- 4 files changed, 35 insertions(+), 15 deletions(-) diff --git a/detroit-ui-components/src/forms/Field.tsx b/detroit-ui-components/src/forms/Field.tsx index d8c7991841..62a2a47fcb 100644 --- a/detroit-ui-components/src/forms/Field.tsx +++ b/detroit-ui-components/src/forms/Field.tsx @@ -1,4 +1,4 @@ -import React, { useMemo } from "react" +import React, { ChangeEvent, useMemo } from "react" import { ErrorMessage } from "@bloom-housing/ui-components" import { UseFormMethods, RegisterOptions } from "react-hook-form" @@ -59,20 +59,21 @@ const Field = (props: FieldProps) => { if (props.bordered && (props.type === "radio" || props.type === "checkbox")) controlClasses.push("field-border") - const formatValue = () => { - if (props.getValues && props.setValue) { - const currencyValue = props.getValues(props.name) - const numericIncome = parseFloat(currencyValue) - if (!isNaN(numericIncome)) { - props.setValue(props.name, numericIncome.toFixed(2)) - } + const filterNumbers = (e: ChangeEvent) => { + if (props.setValue) { + props.setValue(props.name, e.target.value.replace(/[a-z]|[A-Z]/g, "").match(/^\d*\.?\d?\d?/g)) } } let inputProps = { ...props.inputProps } - if (props.type === "currency") inputProps = { ...inputProps, step: 0.01, onBlur: formatValue } + if (props.type === "currency") { + inputProps = { + ...inputProps, + onChange: filterNumbers, + } + } - const type = (props.type === "currency" && "number") || props.type || "text" + const type = (props.type === "currency" && "text") || props.type || "text" const isRadioOrCheckbox = ["radio", "checkbox"].includes(type) const label = useMemo(() => { diff --git a/sites/public/src/components/filters/FilterForm.tsx b/sites/public/src/components/filters/FilterForm.tsx index 8917469173..021b7a26ae 100644 --- a/sites/public/src/components/filters/FilterForm.tsx +++ b/sites/public/src/components/filters/FilterForm.tsx @@ -118,7 +118,16 @@ const FilterForm = (props: FilterFormProps) => { // This is causing a linting issue with unbound-method, see issue: // https://github.com/react-hook-form/react-hook-form/issues/2887 // eslint-disable-next-line @typescript-eslint/unbound-method - const { handleSubmit, errors, register, reset, trigger, watch: formWatch } = useForm() + const { + handleSubmit, + errors, + register, + reset, + trigger, + watch: formWatch, + setValue, + getValues, + } = useForm() const minRent = formWatch("minRent") const maxRent = formWatch("maxRent") @@ -247,10 +256,12 @@ const FilterForm = (props: FilterFormProps) => { { { const dollarSign = useRouter().locale !== "ar" const numericFields = props.activeQuestion?.fields.filter((field) => field.type === "number") @@ -26,11 +28,13 @@ const FinderRentalCosts = (props: { { // eslint-disable-next-line @typescript-eslint/unbound-method - const { register, handleSubmit, trigger, errors, watch } = useForm() + const { register, handleSubmit, trigger, errors, watch, setValue, getValues } = useForm() const [questionIndex, setQuestionIndex] = useState(0) const [formData, setFormData] = useState([]) const [isDisclaimer, setIsDisclaimer] = useState(false) @@ -324,6 +324,8 @@ const Finder = () => { trigger={trigger} minRent={minRent} maxRent={maxRent} + setValue={setValue} + getValues={getValues} /> )}