From dc30183867474db3f592d8a4beda83624a42eb2a Mon Sep 17 00:00:00 2001 From: agrippa Date: Mon, 9 Oct 2023 19:50:21 -0400 Subject: [PATCH] EditWalletRules: Integer quorum percent (#1856) --- hub/components/EditWalletRules/Form/index.tsx | 1 - hub/components/EditWalletRules/RulesDetailsInputs.tsx | 2 ++ hub/components/EditWalletRules/SliderValue/index.tsx | 10 ++++++++-- 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/hub/components/EditWalletRules/Form/index.tsx b/hub/components/EditWalletRules/Form/index.tsx index ac90bdec9c..8d17b0919c 100644 --- a/hub/components/EditWalletRules/Form/index.tsx +++ b/hub/components/EditWalletRules/Form/index.tsx @@ -29,7 +29,6 @@ interface Props } function Form(props: Props & { title: string; description: string }) { - console.log('form props', props); const [showCouncilOptions, setShowCouncilOptions] = useState( props.initialCouncilRules?.canVote || false, ); diff --git a/hub/components/EditWalletRules/RulesDetailsInputs.tsx b/hub/components/EditWalletRules/RulesDetailsInputs.tsx index 4cbccd6e7f..940729cd40 100644 --- a/hub/components/EditWalletRules/RulesDetailsInputs.tsx +++ b/hub/components/EditWalletRules/RulesDetailsInputs.tsx @@ -226,6 +226,7 @@ export function QuorumPercent(props: Props) { }); props.onRulesChange?.(newRules); }} + integer /> `${val}%`} + step={1} /> diff --git a/hub/components/EditWalletRules/SliderValue/index.tsx b/hub/components/EditWalletRules/SliderValue/index.tsx index 9f1c90baad..a372f8bb89 100644 --- a/hub/components/EditWalletRules/SliderValue/index.tsx +++ b/hub/components/EditWalletRules/SliderValue/index.tsx @@ -10,6 +10,7 @@ interface Props { value: number; units: React.ReactNode; onChange?(value: number): void; + integer?: boolean; } export function SliderValue(props: Props) { @@ -32,9 +33,14 @@ export function SliderValue(props: Props) { /.*?(([0-9]*\.)?[0-9]+).*/g, '$1', ); - const parsed = parseFloat(text); + const parsed = props.integer + ? Math.floor(parseFloat(text)) + : parseFloat(text); const value = Number.isNaN(parsed) ? props.min : parsed; - props.onChange?.(Math.max(props.min, value)); + const newValue = Math.max(props.min, value); + setValue(String(props.value)); // this is to force the input to update to the correct value + // even if the user enters an invalid value that doesnt actually change props.value + props.onChange?.(newValue); }} />