FIX: number format menu closes when selected
This commit is contained in:
committed by
Nicolás Hatcher Andrés
parent
e412f5fc22
commit
39174add1f
@@ -1,5 +1,5 @@
|
|||||||
import { Menu, MenuItem, styled } from "@mui/material";
|
import { Menu, MenuItem, styled } from "@mui/material";
|
||||||
import { type ComponentProps, useRef, useState } from "react";
|
import { type ComponentProps, useCallback, useRef, useState } from "react";
|
||||||
import { useTranslation } from "react-i18next";
|
import { useTranslation } from "react-i18next";
|
||||||
import FormatPicker from "./formatPicker";
|
import FormatPicker from "./formatPicker";
|
||||||
import { NumberFormats } from "./formatUtil";
|
import { NumberFormats } from "./formatUtil";
|
||||||
@@ -14,11 +14,15 @@ type FormatMenuProps = {
|
|||||||
|
|
||||||
const FormatMenu = (properties: FormatMenuProps) => {
|
const FormatMenu = (properties: FormatMenuProps) => {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const { onChange } = properties;
|
|
||||||
const [isMenuOpen, setMenuOpen] = useState(false);
|
const [isMenuOpen, setMenuOpen] = useState(false);
|
||||||
const [isPickerOpen, setPickerOpen] = useState(false);
|
const [isPickerOpen, setPickerOpen] = useState(false);
|
||||||
const anchorElement = useRef<HTMLDivElement>(null);
|
const anchorElement = useRef<HTMLDivElement>(null);
|
||||||
|
|
||||||
|
const onSelect = useCallback((s: string) => {
|
||||||
|
properties.onChange(s);
|
||||||
|
setMenuOpen(false);
|
||||||
|
}, [properties.onChange]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ChildrenWrapper
|
<ChildrenWrapper
|
||||||
@@ -33,18 +37,18 @@ const FormatMenu = (properties: FormatMenuProps) => {
|
|||||||
anchorEl={anchorElement.current}
|
anchorEl={anchorElement.current}
|
||||||
anchorOrigin={properties.anchorOrigin}
|
anchorOrigin={properties.anchorOrigin}
|
||||||
>
|
>
|
||||||
<MenuItemWrapper onClick={(): void => onChange(NumberFormats.AUTO)}>
|
<MenuItemWrapper onClick={(): void => onSelect(NumberFormats.AUTO)}>
|
||||||
<MenuItemText>{t("toolbar.format_menu.auto")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.auto")}</MenuItemText>
|
||||||
</MenuItemWrapper>
|
</MenuItemWrapper>
|
||||||
<MenuDivider />
|
<MenuDivider />
|
||||||
<MenuItemWrapper onClick={(): void => onChange(NumberFormats.NUMBER)}>
|
<MenuItemWrapper onClick={(): void => onSelect(NumberFormats.NUMBER)}>
|
||||||
<MenuItemText>{t("toolbar.format_menu.number")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.number")}</MenuItemText>
|
||||||
<MenuItemExample>
|
<MenuItemExample>
|
||||||
{t("toolbar.format_menu.number_example")}
|
{t("toolbar.format_menu.number_example")}
|
||||||
</MenuItemExample>
|
</MenuItemExample>
|
||||||
</MenuItemWrapper>
|
</MenuItemWrapper>
|
||||||
<MenuItemWrapper
|
<MenuItemWrapper
|
||||||
onClick={(): void => onChange(NumberFormats.PERCENTAGE)}
|
onClick={(): void => onSelect(NumberFormats.PERCENTAGE)}
|
||||||
>
|
>
|
||||||
<MenuItemText>{t("toolbar.format_menu.percentage")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.percentage")}</MenuItemText>
|
||||||
<MenuItemExample>
|
<MenuItemExample>
|
||||||
@@ -54,7 +58,7 @@ const FormatMenu = (properties: FormatMenuProps) => {
|
|||||||
|
|
||||||
<MenuDivider />
|
<MenuDivider />
|
||||||
<MenuItemWrapper
|
<MenuItemWrapper
|
||||||
onClick={(): void => onChange(NumberFormats.CURRENCY_EUR)}
|
onClick={(): void => onSelect(NumberFormats.CURRENCY_EUR)}
|
||||||
>
|
>
|
||||||
<MenuItemText>{t("toolbar.format_menu.currency_eur")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.currency_eur")}</MenuItemText>
|
||||||
<MenuItemExample>
|
<MenuItemExample>
|
||||||
@@ -62,7 +66,7 @@ const FormatMenu = (properties: FormatMenuProps) => {
|
|||||||
</MenuItemExample>
|
</MenuItemExample>
|
||||||
</MenuItemWrapper>
|
</MenuItemWrapper>
|
||||||
<MenuItemWrapper
|
<MenuItemWrapper
|
||||||
onClick={(): void => onChange(NumberFormats.CURRENCY_USD)}
|
onClick={(): void => onSelect(NumberFormats.CURRENCY_USD)}
|
||||||
>
|
>
|
||||||
<MenuItemText>{t("toolbar.format_menu.currency_usd")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.currency_usd")}</MenuItemText>
|
||||||
<MenuItemExample>
|
<MenuItemExample>
|
||||||
@@ -70,7 +74,7 @@ const FormatMenu = (properties: FormatMenuProps) => {
|
|||||||
</MenuItemExample>
|
</MenuItemExample>
|
||||||
</MenuItemWrapper>
|
</MenuItemWrapper>
|
||||||
<MenuItemWrapper
|
<MenuItemWrapper
|
||||||
onClick={(): void => onChange(NumberFormats.CURRENCY_GBP)}
|
onClick={(): void => onSelect(NumberFormats.CURRENCY_GBP)}
|
||||||
>
|
>
|
||||||
<MenuItemText>{t("toolbar.format_menu.currency_gbp")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.currency_gbp")}</MenuItemText>
|
||||||
<MenuItemExample>
|
<MenuItemExample>
|
||||||
@@ -80,7 +84,7 @@ const FormatMenu = (properties: FormatMenuProps) => {
|
|||||||
|
|
||||||
<MenuDivider />
|
<MenuDivider />
|
||||||
<MenuItemWrapper
|
<MenuItemWrapper
|
||||||
onClick={(): void => onChange(NumberFormats.DATE_SHORT)}
|
onClick={(): void => onSelect(NumberFormats.DATE_SHORT)}
|
||||||
>
|
>
|
||||||
<MenuItemText>{t("toolbar.format_menu.date_short")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.date_short")}</MenuItemText>
|
||||||
<MenuItemExample>
|
<MenuItemExample>
|
||||||
@@ -88,7 +92,7 @@ const FormatMenu = (properties: FormatMenuProps) => {
|
|||||||
</MenuItemExample>
|
</MenuItemExample>
|
||||||
</MenuItemWrapper>
|
</MenuItemWrapper>
|
||||||
<MenuItemWrapper
|
<MenuItemWrapper
|
||||||
onClick={(): void => onChange(NumberFormats.DATE_LONG)}
|
onClick={(): void => onSelect(NumberFormats.DATE_LONG)}
|
||||||
>
|
>
|
||||||
<MenuItemText>{t("toolbar.format_menu.date_long")}</MenuItemText>
|
<MenuItemText>{t("toolbar.format_menu.date_long")}</MenuItemText>
|
||||||
<MenuItemExample>
|
<MenuItemExample>
|
||||||
@@ -103,7 +107,7 @@ const FormatMenu = (properties: FormatMenuProps) => {
|
|||||||
</Menu>
|
</Menu>
|
||||||
<FormatPicker
|
<FormatPicker
|
||||||
numFmt={properties.numFmt}
|
numFmt={properties.numFmt}
|
||||||
onChange={properties.onChange}
|
onChange={onSelect}
|
||||||
open={isPickerOpen}
|
open={isPickerOpen}
|
||||||
onClose={(): void => setPickerOpen(false)}
|
onClose={(): void => setPickerOpen(false)}
|
||||||
onExited={properties.onExited}
|
onExited={properties.onExited}
|
||||||
|
|||||||
Reference in New Issue
Block a user