@popmenu/ordering-ui 0.147.0 → 0.149.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/MenuTab/MenuTab.styles.d.ts +1 -0
- package/build/cjs/components/MenuTab/MenuTabProps.d.ts +8 -2
- package/build/cjs/components/MenuTabGroup/MenuTabGroup.styles.d.ts +1 -1
- package/build/cjs/components/MenuTabGroup/MenuTabGroupProps.d.ts +6 -6
- package/build/cjs/components/QuantityPicker/QuantityPicker.d.ts +1 -1
- package/build/cjs/components/QuantityPicker/QuantityPickerProps.d.ts +7 -1
- package/build/cjs/components/ReactionCounter/ReactionCounterProps.d.ts +1 -1
- package/build/cjs/components/SelectableChip/SelectableChipProps.d.ts +7 -2
- package/build/cjs/components/SelectableChipGroup/SelectableChipGroup.d.ts +5 -1
- package/build/cjs/components/SelectableChipGroup/index.d.ts +0 -1
- package/build/cjs/components/index.d.ts +0 -1
- package/build/cjs/index.js +313 -122
- package/build/cjs/index.js.map +1 -1
- package/build/esm/components/DishModifierCard/ModifierControls.js +1 -1
- package/build/esm/components/DishModifierCard/ModifierControls.js.map +1 -1
- package/build/esm/components/MenuItem/MenuItem.js +3 -3
- package/build/esm/components/MenuItem/MenuItem.js.map +1 -1
- package/build/esm/components/MenuSection/MenuSection.js +3 -3
- package/build/esm/components/MenuSection/MenuSection.js.map +1 -1
- package/build/esm/components/MenuTab/MenuTab.js +22 -6
- package/build/esm/components/MenuTab/MenuTab.js.map +1 -1
- package/build/esm/components/MenuTab/MenuTab.styles.d.ts +1 -0
- package/build/esm/components/MenuTab/MenuTab.styles.js +26 -14
- package/build/esm/components/MenuTab/MenuTab.styles.js.map +1 -1
- package/build/esm/components/MenuTab/MenuTabProps.d.ts +8 -2
- package/build/esm/components/MenuTabGroup/MenuTabGroup.js +46 -6
- package/build/esm/components/MenuTabGroup/MenuTabGroup.js.map +1 -1
- package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.d.ts +1 -1
- package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.js +41 -39
- package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.js.map +1 -1
- package/build/esm/components/MenuTabGroup/MenuTabGroupProps.d.ts +6 -6
- package/build/esm/components/QuantityPicker/QuantityPicker.d.ts +1 -1
- package/build/esm/components/QuantityPicker/QuantityPicker.js +91 -16
- package/build/esm/components/QuantityPicker/QuantityPicker.js.map +1 -1
- package/build/esm/components/QuantityPicker/QuantityPicker.styles.js +8 -3
- package/build/esm/components/QuantityPicker/QuantityPicker.styles.js.map +1 -1
- package/build/esm/components/QuantityPicker/QuantityPickerProps.d.ts +7 -1
- package/build/esm/components/ReactionCounter/ReactionCounter.js +5 -2
- package/build/esm/components/ReactionCounter/ReactionCounter.js.map +1 -1
- package/build/esm/components/ReactionCounter/ReactionCounterProps.d.ts +1 -1
- package/build/esm/components/SelectableChip/SelectableChip.js +16 -5
- package/build/esm/components/SelectableChip/SelectableChip.js.map +1 -1
- package/build/esm/components/SelectableChip/SelectableChip.styles.js +9 -21
- package/build/esm/components/SelectableChip/SelectableChip.styles.js.map +1 -1
- package/build/esm/components/SelectableChip/SelectableChipProps.d.ts +7 -2
- package/build/esm/components/SelectableChipGroup/SelectableChipGroup.d.ts +5 -1
- package/build/esm/components/SelectableChipGroup/SelectableChipGroup.js +4 -6
- package/build/esm/components/SelectableChipGroup/SelectableChipGroup.js.map +1 -1
- package/build/esm/components/SelectableChipGroup/SelectableChipGroup.styles.js +4 -4
- package/build/esm/components/SelectableChipGroup/SelectableChipGroup.styles.js.map +1 -1
- package/build/esm/components/SelectableChipGroup/index.d.ts +0 -1
- package/build/esm/components/index.d.ts +0 -1
- package/build/esm/theme/overrides.js +36 -1
- package/build/esm/theme/overrides.js.map +1 -1
- package/build/esm/theme/props.js +9 -0
- package/build/esm/theme/props.js.map +1 -1
- package/package.json +2 -2
- package/build/cjs/components/SelectableChipGroup/SelectableChipGroupProps.d.ts +0 -6
- package/build/esm/components/SelectableChipGroup/SelectableChipGroupProps.d.ts +0 -6
|
@@ -1,15 +1,31 @@
|
|
|
1
1
|
import React__default from 'react';
|
|
2
|
-
import {
|
|
2
|
+
import { Typography } from '@material-ui/core';
|
|
3
3
|
import { Clock } from '@popmenu/web-icons';
|
|
4
4
|
import { Icon } from '@popmenu/common-ui';
|
|
5
|
+
import classNames from 'classnames';
|
|
5
6
|
import { useMenuTabStyles } from './MenuTab.styles.js';
|
|
6
7
|
|
|
7
8
|
const MenuTab = (props) => {
|
|
8
|
-
const {
|
|
9
|
-
const classes = useMenuTabStyles({ isUnavailable });
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
9
|
+
const { href, value, label, onClick, selected, isUnavailable, unavailableLabel } = props;
|
|
10
|
+
const classes = useMenuTabStyles({ isUnavailable, selected });
|
|
11
|
+
const handleClick = (event) => {
|
|
12
|
+
event.preventDefault();
|
|
13
|
+
onClick(event, value);
|
|
14
|
+
};
|
|
15
|
+
const handleKeyDown = (event) => {
|
|
16
|
+
if (event.key === ' ') {
|
|
17
|
+
event.preventDefault();
|
|
18
|
+
onClick(event, value);
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
return (React__default.createElement("li", null,
|
|
22
|
+
React__default.createElement(Typography, { variant: "body2" },
|
|
23
|
+
React__default.createElement("a", { href: href, className: classNames(classes.root, { [classes.selected]: selected }), onClick: handleClick, onKeyDown: handleKeyDown, "aria-current": selected ? 'page' : undefined },
|
|
24
|
+
isUnavailable && React__default.createElement(Icon, { icon: Clock, "aria-hidden": "true", size: "large", className: classes.icon }),
|
|
25
|
+
label,
|
|
26
|
+
isUnavailable && React__default.createElement("span", { className: classes.visuallyHidden },
|
|
27
|
+
", ",
|
|
28
|
+
unavailableLabel)))));
|
|
13
29
|
};
|
|
14
30
|
|
|
15
31
|
export { MenuTab };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuTab.js","sources":["../../../../src/components/MenuTab/MenuTab.tsx"],"sourcesContent":["import React from 'react'\nimport {
|
|
1
|
+
{"version":3,"file":"MenuTab.js","sources":["../../../../src/components/MenuTab/MenuTab.tsx"],"sourcesContent":["import React from 'react'\nimport { Typography } from '@material-ui/core'\nimport { Clock } from '@popmenu/web-icons'\nimport { Icon } from '@popmenu/common-ui'\nimport classNames from 'classnames'\n\nimport { useMenuTabStyles } from './MenuTab.styles'\nimport { MenuTabProps } from './MenuTabProps'\n\nexport const MenuTab = (props: MenuTabProps) => {\n const { href, value, label, onClick, selected, isUnavailable, unavailableLabel } = props\n const classes = useMenuTabStyles({ isUnavailable, selected })\n\n const handleClick = (event: React.MouseEvent<HTMLAnchorElement>) => {\n event.preventDefault()\n onClick(event, value)\n }\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLAnchorElement>) => {\n if (event.key === ' ') {\n event.preventDefault()\n onClick(event, value)\n }\n }\n\n return (\n <li>\n <Typography variant=\"body2\">\n <a\n href={href}\n className={classNames(classes.root, { [classes.selected]: selected })}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n aria-current={selected ? 'page' : undefined}\n >\n {isUnavailable && <Icon icon={Clock} aria-hidden=\"true\" size=\"large\" className={classes.icon} />}\n {label}\n {isUnavailable && <span className={classes.visuallyHidden}>, {unavailableLabel}</span>}\n </a>\n </Typography>\n </li>\n )\n}\n"],"names":["React"],"mappings":";;;;;;;AASa,MAAA,OAAO,GAAG,CAAC,KAAmB,KAAI;AAC7C,IAAA,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,gBAAgB,EAAE,GAAG,KAAK;IACxF,MAAM,OAAO,GAAG,gBAAgB,CAAC,EAAE,aAAa,EAAE,QAAQ,EAAE,CAAC;AAE7D,IAAA,MAAM,WAAW,GAAG,CAAC,KAA0C,KAAI;QACjE,KAAK,CAAC,cAAc,EAAE;AACtB,QAAA,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;AACvB,KAAC;AAED,IAAA,MAAM,aAAa,GAAG,CAAC,KAA6C,KAAI;AACtE,QAAA,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE;YACrB,KAAK,CAAC,cAAc,EAAE;AACtB,YAAA,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;;AAEzB,KAAC;AAED,IAAA,QACEA,cAAA,CAAA,aAAA,CAAA,IAAA,EAAA,IAAA;AACE,QAAAA,cAAA,CAAA,aAAA,CAAC,UAAU,EAAA,EAAC,OAAO,EAAC,OAAO,EAAA;AACzB,YAAAA,cAAA,CAAA,aAAA,CAAA,GAAA,EAAA,EACE,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,UAAU,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,GAAG,QAAQ,EAAE,CAAC,EACrE,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,aAAa,EACV,cAAA,EAAA,QAAQ,GAAG,MAAM,GAAG,SAAS,EAAA;AAE1C,gBAAA,aAAa,IAAIA,cAAC,CAAA,aAAA,CAAA,IAAI,IAAC,IAAI,EAAE,KAAK,EAAc,aAAA,EAAA,MAAM,EAAC,IAAI,EAAC,OAAO,EAAC,SAAS,EAAE,OAAO,CAAC,IAAI,EAAI,CAAA;gBAC/F,KAAK;AACL,gBAAA,aAAa,IAAIA,cAAM,CAAA,aAAA,CAAA,MAAA,EAAA,EAAA,SAAS,EAAE,OAAO,CAAC,cAAc,EAAA;;AAAK,oBAAA,gBAAgB,CAAQ,CACpF,CACO,CACV;AAET;;;;"}
|
|
@@ -3,22 +3,34 @@ import { makeStyles } from '@material-ui/core';
|
|
|
3
3
|
const useMenuTabStyles = makeStyles(({ palette, spacing }) => ({
|
|
4
4
|
icon: {
|
|
5
5
|
minWidth: spacing(2.5),
|
|
6
|
+
marginRight: spacing(1),
|
|
6
7
|
},
|
|
7
|
-
root:
|
|
8
|
-
|
|
9
|
-
'
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
root: {
|
|
9
|
+
display: 'inline-flex',
|
|
10
|
+
alignItems: 'center',
|
|
11
|
+
justifyContent: 'center',
|
|
12
|
+
textDecoration: 'none',
|
|
13
|
+
color: ({ isUnavailable }) => (isUnavailable ? palette.grey[700] : 'inherit'),
|
|
14
|
+
padding: spacing(1.5, 2),
|
|
15
|
+
whiteSpace: 'nowrap',
|
|
12
16
|
maxWidth: spacing(29.5),
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
17
|
+
outlineOffset: -2,
|
|
18
|
+
},
|
|
19
|
+
selected: {
|
|
20
|
+
fontWeight: 500,
|
|
21
|
+
borderBottom: `2px solid ${palette.primary.main}`,
|
|
22
|
+
},
|
|
23
|
+
visuallyHidden: {
|
|
24
|
+
position: 'absolute',
|
|
25
|
+
width: 1,
|
|
26
|
+
height: 1,
|
|
27
|
+
padding: 0,
|
|
28
|
+
margin: -1,
|
|
29
|
+
overflow: 'hidden',
|
|
30
|
+
clip: 'rect(0, 0, 0, 0)',
|
|
31
|
+
whiteSpace: 'nowrap',
|
|
32
|
+
border: 0,
|
|
33
|
+
},
|
|
22
34
|
}));
|
|
23
35
|
|
|
24
36
|
export { useMenuTabStyles };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuTab.styles.js","sources":["../../../../src/components/MenuTab/MenuTab.styles.ts"],"sourcesContent":["import { makeStyles, Theme } from '@material-ui/core'\n\nexport interface MenuTabStylesProps {\n isUnavailable: boolean | undefined\n}\nexport const useMenuTabStyles = makeStyles<Theme, MenuTabStylesProps>(({ palette, spacing }) => ({\n icon: {\n minWidth: spacing(2.5),\n },\n root: ({ isUnavailable }) => (
|
|
1
|
+
{"version":3,"file":"MenuTab.styles.js","sources":["../../../../src/components/MenuTab/MenuTab.styles.ts"],"sourcesContent":["import { makeStyles, Theme } from '@material-ui/core'\n\nexport interface MenuTabStylesProps {\n isUnavailable: boolean | undefined\n selected: boolean | undefined\n}\n\nexport const useMenuTabStyles = makeStyles<Theme, MenuTabStylesProps>(({ palette, spacing }) => ({\n icon: {\n minWidth: spacing(2.5),\n marginRight: spacing(1),\n },\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n textDecoration: 'none',\n color: ({ isUnavailable }) => (isUnavailable ? palette.grey[700] : 'inherit'),\n padding: spacing(1.5, 2),\n whiteSpace: 'nowrap',\n maxWidth: spacing(29.5),\n outlineOffset: -2,\n },\n selected: {\n fontWeight: 500,\n borderBottom: `2px solid ${palette.primary.main}`,\n },\n visuallyHidden: {\n position: 'absolute',\n width: 1,\n height: 1,\n padding: 0,\n margin: -1,\n overflow: 'hidden',\n clip: 'rect(0, 0, 0, 0)',\n whiteSpace: 'nowrap',\n border: 0,\n },\n}))\n"],"names":[],"mappings":";;AAOO,MAAM,gBAAgB,GAAG,UAAU,CAA4B,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM;AAC/F,IAAA,IAAI,EAAE;AACJ,QAAA,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC;AACtB,QAAA,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;AACxB,KAAA;AACD,IAAA,IAAI,EAAE;AACJ,QAAA,OAAO,EAAE,aAAa;AACtB,QAAA,UAAU,EAAE,QAAQ;AACpB,QAAA,cAAc,EAAE,QAAQ;AACxB,QAAA,cAAc,EAAE,MAAM;QACtB,KAAK,EAAE,CAAC,EAAE,aAAa,EAAE,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;AAC7E,QAAA,OAAO,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;AACxB,QAAA,UAAU,EAAE,QAAQ;AACpB,QAAA,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC;QACvB,aAAa,EAAE,EAAE;AAClB,KAAA;AACD,IAAA,QAAQ,EAAE;AACR,QAAA,UAAU,EAAE,GAAG;AACf,QAAA,YAAY,EAAE,CAAa,UAAA,EAAA,OAAO,CAAC,OAAO,CAAC,IAAI,CAAE,CAAA;AAClD,KAAA;AACD,IAAA,cAAc,EAAE;AACd,QAAA,QAAQ,EAAE,UAAU;AACpB,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,MAAM,EAAE,CAAC;AACT,QAAA,OAAO,EAAE,CAAC;QACV,MAAM,EAAE,EAAE;AACV,QAAA,QAAQ,EAAE,QAAQ;AAClB,QAAA,IAAI,EAAE,kBAAkB;AACxB,QAAA,UAAU,EAAE,QAAQ;AACpB,QAAA,MAAM,EAAE,CAAC;AACV,KAAA;AACF,CAAA,CAAC;;;;"}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
import
|
|
2
|
-
export type MenuTabProps =
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type MenuTabProps = {
|
|
3
|
+
onClick: (event: React.MouseEvent<HTMLAnchorElement> | React.KeyboardEvent<HTMLAnchorElement>, value: string) => void;
|
|
4
|
+
value: string;
|
|
5
|
+
label: string;
|
|
6
|
+
href: string;
|
|
7
|
+
selected: boolean;
|
|
3
8
|
isUnavailable: boolean;
|
|
9
|
+
unavailableLabel: string;
|
|
4
10
|
};
|
|
@@ -1,13 +1,53 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
1
|
+
import React__default, { useRef, useState, useCallback, useEffect } from 'react';
|
|
2
|
+
import { IconButton } from '@material-ui/core';
|
|
3
|
+
import { ChevronLeft, ChevronRight } from '@popmenu/web-icons';
|
|
4
|
+
import { Icon } from '@popmenu/common-ui';
|
|
3
5
|
import { useMenuTabGroupStyles } from './MenuTabGroup.styles.js';
|
|
4
6
|
|
|
5
7
|
const MenuTabGroup = (props) => {
|
|
6
|
-
const { children, ...
|
|
8
|
+
const { children, scrollLeftLabel, scrollRightLabel, ...restProps } = props;
|
|
7
9
|
const classes = useMenuTabGroupStyles();
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
10
|
+
const scrollContainerRef = useRef(null);
|
|
11
|
+
const [showLeftButton, setShowLeftButton] = useState(false);
|
|
12
|
+
const [showRightButton, setShowRightButton] = useState(false);
|
|
13
|
+
const updateScrollButtons = useCallback(() => {
|
|
14
|
+
const container = scrollContainerRef.current;
|
|
15
|
+
if (!container)
|
|
16
|
+
return;
|
|
17
|
+
const { scrollLeft, scrollWidth, clientWidth } = container;
|
|
18
|
+
setShowLeftButton(scrollLeft > 0);
|
|
19
|
+
setShowRightButton(scrollLeft + clientWidth < scrollWidth - 1);
|
|
20
|
+
}, []);
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
const container = scrollContainerRef.current;
|
|
23
|
+
if (!container)
|
|
24
|
+
return;
|
|
25
|
+
updateScrollButtons();
|
|
26
|
+
container.addEventListener('scroll', updateScrollButtons);
|
|
27
|
+
window.addEventListener('resize', updateScrollButtons);
|
|
28
|
+
return () => {
|
|
29
|
+
container.removeEventListener('scroll', updateScrollButtons);
|
|
30
|
+
window.removeEventListener('resize', updateScrollButtons);
|
|
31
|
+
};
|
|
32
|
+
}, [updateScrollButtons]);
|
|
33
|
+
const scrollLeft = () => {
|
|
34
|
+
const container = scrollContainerRef.current;
|
|
35
|
+
if (!container)
|
|
36
|
+
return;
|
|
37
|
+
container.scrollBy({ left: -container.clientWidth, behavior: 'smooth' });
|
|
38
|
+
};
|
|
39
|
+
const scrollRight = () => {
|
|
40
|
+
const container = scrollContainerRef.current;
|
|
41
|
+
if (!container)
|
|
42
|
+
return;
|
|
43
|
+
container.scrollBy({ left: container.clientWidth, behavior: 'smooth' });
|
|
44
|
+
};
|
|
45
|
+
return (React__default.createElement("nav", { className: classes.root, ...restProps },
|
|
46
|
+
showLeftButton && (React__default.createElement(IconButton, { className: classes.scrollButtonLeft, onClick: scrollLeft, "aria-label": scrollLeftLabel, size: "small" },
|
|
47
|
+
React__default.createElement(Icon, { icon: ChevronLeft, "aria-hidden": "true" }))),
|
|
48
|
+
React__default.createElement("ul", { ref: scrollContainerRef, className: classes.flexContainer }, children),
|
|
49
|
+
showRightButton && (React__default.createElement(IconButton, { className: classes.scrollButtonRight, onClick: scrollRight, "aria-label": scrollRightLabel, size: "small" },
|
|
50
|
+
React__default.createElement(Icon, { icon: ChevronRight, "aria-hidden": "true" })))));
|
|
11
51
|
};
|
|
12
52
|
|
|
13
53
|
export { MenuTabGroup };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuTabGroup.js","sources":["../../../../src/components/MenuTabGroup/MenuTabGroup.tsx"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"MenuTabGroup.js","sources":["../../../../src/components/MenuTabGroup/MenuTabGroup.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from 'react'\nimport { IconButton } from '@material-ui/core'\nimport { ChevronLeft, ChevronRight } from '@popmenu/web-icons'\nimport { Icon } from '@popmenu/common-ui'\n\nimport { MenuTabGroupProps } from './MenuTabGroupProps'\nimport { useMenuTabGroupStyles } from './MenuTabGroup.styles'\n\nexport const MenuTabGroup = (props: MenuTabGroupProps) => {\n const { children, scrollLeftLabel, scrollRightLabel, ...restProps } = props\n const classes = useMenuTabGroupStyles()\n const scrollContainerRef = useRef<HTMLUListElement>(null)\n const [showLeftButton, setShowLeftButton] = useState(false)\n const [showRightButton, setShowRightButton] = useState(false)\n\n const updateScrollButtons = useCallback(() => {\n const container = scrollContainerRef.current\n if (!container) return\n\n const { scrollLeft, scrollWidth, clientWidth } = container\n setShowLeftButton(scrollLeft > 0)\n setShowRightButton(scrollLeft + clientWidth < scrollWidth - 1)\n }, [])\n\n useEffect(() => {\n const container = scrollContainerRef.current\n if (!container) return\n\n updateScrollButtons()\n\n container.addEventListener('scroll', updateScrollButtons)\n window.addEventListener('resize', updateScrollButtons)\n\n return () => {\n container.removeEventListener('scroll', updateScrollButtons)\n window.removeEventListener('resize', updateScrollButtons)\n }\n }, [updateScrollButtons])\n\n const scrollLeft = () => {\n const container = scrollContainerRef.current\n if (!container) return\n container.scrollBy({ left: -container.clientWidth, behavior: 'smooth' })\n }\n\n const scrollRight = () => {\n const container = scrollContainerRef.current\n if (!container) return\n container.scrollBy({ left: container.clientWidth, behavior: 'smooth' })\n }\n\n return (\n <nav className={classes.root} {...restProps}>\n {showLeftButton && (\n <IconButton className={classes.scrollButtonLeft} onClick={scrollLeft} aria-label={scrollLeftLabel} size=\"small\">\n <Icon icon={ChevronLeft} aria-hidden=\"true\" />\n </IconButton>\n )}\n\n <ul ref={scrollContainerRef} className={classes.flexContainer}>\n {children}\n </ul>\n\n {showRightButton && (\n <IconButton\n className={classes.scrollButtonRight}\n onClick={scrollRight}\n aria-label={scrollRightLabel}\n size=\"small\"\n >\n <Icon icon={ChevronRight} aria-hidden=\"true\" />\n </IconButton>\n )}\n </nav>\n )\n}\n"],"names":["React"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const useMenuTabGroupStyles: (props?: any) => import("@material-ui/styles").ClassNameMap<"root">;
|
|
1
|
+
export declare const useMenuTabGroupStyles: (props?: any) => import("@material-ui/styles").ClassNameMap<"root" | "flexContainer" | "scrollButtonLeft" | "scrollButtonRight">;
|
|
@@ -1,48 +1,50 @@
|
|
|
1
1
|
import { makeStyles } from '@material-ui/core';
|
|
2
2
|
|
|
3
|
+
const scrollButtonBase = {
|
|
4
|
+
position: 'absolute',
|
|
5
|
+
zIndex: 1,
|
|
6
|
+
backgroundColor: 'white',
|
|
7
|
+
height: '100%',
|
|
8
|
+
top: 0,
|
|
9
|
+
display: 'flex',
|
|
10
|
+
alignItems: 'center',
|
|
11
|
+
justifyContent: 'center',
|
|
12
|
+
width: 40,
|
|
13
|
+
opacity: 1,
|
|
14
|
+
'& svg': {
|
|
15
|
+
height: 24,
|
|
16
|
+
width: 24,
|
|
17
|
+
},
|
|
18
|
+
};
|
|
3
19
|
const useMenuTabGroupStyles = makeStyles(() => ({
|
|
4
20
|
root: {
|
|
5
|
-
position: 'relative'
|
|
6
|
-
overflow: 'hidden'
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
'&:first-child': {
|
|
20
|
-
left: 0,
|
|
21
|
-
background: 'linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) calc(100% - 8px), rgba(255, 255, 255, 0) 100%)',
|
|
22
|
-
},
|
|
23
|
-
'&:last-child': {
|
|
24
|
-
right: 0,
|
|
25
|
-
background: 'linear-gradient(to left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) calc(100% - 8px), rgba(255, 255, 255, 0) 100%)',
|
|
26
|
-
},
|
|
27
|
-
/* Ensure tab container fills height */
|
|
28
|
-
'& .MuiSvgIcon-root': {
|
|
29
|
-
height: '24px',
|
|
30
|
-
width: '24px',
|
|
31
|
-
},
|
|
32
|
-
},
|
|
33
|
-
/* Adjust scroller to prevent tabs from being hidden */
|
|
34
|
-
'.MuiTabs-scroller': {
|
|
35
|
-
padding: '0 40px' /* Match scroll button width */,
|
|
36
|
-
height: '100%' /* Ensure it fills parent height */,
|
|
37
|
-
},
|
|
38
|
-
/* Ensure tab container fills height */
|
|
39
|
-
'.MuiTabs-flexContainer': {
|
|
40
|
-
height: '100%',
|
|
41
|
-
},
|
|
42
|
-
/* Remove buttons when scroll is all the way to the left or right */
|
|
43
|
-
'& .MuiTabScrollButton-root.Mui-disabled': {
|
|
21
|
+
position: 'relative',
|
|
22
|
+
overflow: 'hidden',
|
|
23
|
+
display: 'flex',
|
|
24
|
+
alignItems: 'center',
|
|
25
|
+
},
|
|
26
|
+
flexContainer: {
|
|
27
|
+
display: 'flex',
|
|
28
|
+
listStyle: 'none',
|
|
29
|
+
margin: 0,
|
|
30
|
+
padding: 0,
|
|
31
|
+
overflowX: 'auto',
|
|
32
|
+
scrollbarWidth: 'none',
|
|
33
|
+
msOverflowStyle: 'none',
|
|
34
|
+
'&::-webkit-scrollbar': {
|
|
44
35
|
display: 'none',
|
|
45
36
|
},
|
|
37
|
+
height: '100%',
|
|
38
|
+
},
|
|
39
|
+
scrollButtonLeft: {
|
|
40
|
+
...scrollButtonBase,
|
|
41
|
+
left: 0,
|
|
42
|
+
background: 'linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) calc(100% - 8px), rgba(255, 255, 255, 0) 100%)',
|
|
43
|
+
},
|
|
44
|
+
scrollButtonRight: {
|
|
45
|
+
...scrollButtonBase,
|
|
46
|
+
right: 0,
|
|
47
|
+
background: 'linear-gradient(to left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) calc(100% - 8px), rgba(255, 255, 255, 0) 100%)',
|
|
46
48
|
},
|
|
47
49
|
}));
|
|
48
50
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuTabGroup.styles.js","sources":["../../../../src/components/MenuTabGroup/MenuTabGroup.styles.ts"],"sourcesContent":["import { makeStyles } from '@material-ui/core'\n\
|
|
1
|
+
{"version":3,"file":"MenuTabGroup.styles.js","sources":["../../../../src/components/MenuTabGroup/MenuTabGroup.styles.ts"],"sourcesContent":["import { makeStyles } from '@material-ui/core'\n\nconst scrollButtonBase = {\n position: 'absolute' as const,\n zIndex: 1,\n backgroundColor: 'white',\n height: '100%',\n top: 0,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: 40,\n opacity: 1,\n '& svg': {\n height: 24,\n width: 24,\n },\n}\n\nexport const useMenuTabGroupStyles = makeStyles(() => ({\n root: {\n position: 'relative',\n overflow: 'hidden',\n display: 'flex',\n alignItems: 'center',\n },\n flexContainer: {\n display: 'flex',\n listStyle: 'none',\n margin: 0,\n padding: 0,\n overflowX: 'auto',\n scrollbarWidth: 'none',\n msOverflowStyle: 'none',\n '&::-webkit-scrollbar': {\n display: 'none',\n },\n height: '100%',\n },\n scrollButtonLeft: {\n ...scrollButtonBase,\n left: 0,\n background:\n 'linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) calc(100% - 8px), rgba(255, 255, 255, 0) 100%)',\n },\n scrollButtonRight: {\n ...scrollButtonBase,\n right: 0,\n background:\n 'linear-gradient(to left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) calc(100% - 8px), rgba(255, 255, 255, 0) 100%)',\n },\n}))\n"],"names":[],"mappings":";;AAEA,MAAM,gBAAgB,GAAG;AACvB,IAAA,QAAQ,EAAE,UAAmB;AAC7B,IAAA,MAAM,EAAE,CAAC;AACT,IAAA,eAAe,EAAE,OAAO;AACxB,IAAA,MAAM,EAAE,MAAM;AACd,IAAA,GAAG,EAAE,CAAC;AACN,IAAA,OAAO,EAAE,MAAM;AACf,IAAA,UAAU,EAAE,QAAQ;AACpB,IAAA,cAAc,EAAE,QAAQ;AACxB,IAAA,KAAK,EAAE,EAAE;AACT,IAAA,OAAO,EAAE,CAAC;AACV,IAAA,OAAO,EAAE;AACP,QAAA,MAAM,EAAE,EAAE;AACV,QAAA,KAAK,EAAE,EAAE;AACV,KAAA;CACF;MAEY,qBAAqB,GAAG,UAAU,CAAC,OAAO;AACrD,IAAA,IAAI,EAAE;AACJ,QAAA,QAAQ,EAAE,UAAU;AACpB,QAAA,QAAQ,EAAE,QAAQ;AAClB,QAAA,OAAO,EAAE,MAAM;AACf,QAAA,UAAU,EAAE,QAAQ;AACrB,KAAA;AACD,IAAA,aAAa,EAAE;AACb,QAAA,OAAO,EAAE,MAAM;AACf,QAAA,SAAS,EAAE,MAAM;AACjB,QAAA,MAAM,EAAE,CAAC;AACT,QAAA,OAAO,EAAE,CAAC;AACV,QAAA,SAAS,EAAE,MAAM;AACjB,QAAA,cAAc,EAAE,MAAM;AACtB,QAAA,eAAe,EAAE,MAAM;AACvB,QAAA,sBAAsB,EAAE;AACtB,YAAA,OAAO,EAAE,MAAM;AAChB,SAAA;AACD,QAAA,MAAM,EAAE,MAAM;AACf,KAAA;AACD,IAAA,gBAAgB,EAAE;AAChB,QAAA,GAAG,gBAAgB;AACnB,QAAA,IAAI,EAAE,CAAC;AACP,QAAA,UAAU,EACR,4HAA4H;AAC/H,KAAA;AACD,IAAA,iBAAiB,EAAE;AACjB,QAAA,GAAG,gBAAgB;AACnB,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,UAAU,EACR,2HAA2H;AAC9H,KAAA;AACF,CAAA,CAAC;;;;"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import
|
|
2
|
-
type
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type MenuTabGroupProps = {
|
|
3
|
+
children: React.ReactNode;
|
|
4
|
+
scrollLeftLabel: string;
|
|
5
|
+
scrollRightLabel: string;
|
|
6
|
+
} & React.HTMLAttributes<HTMLElement>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { QuantityPickerProps } from './QuantityPickerProps';
|
|
2
|
-
export declare const QuantityPicker: ({ value, onChange, disabled, preventManualChange, disableIncrement, variation, name, min, max, }: QuantityPickerProps) => JSX.Element;
|
|
2
|
+
export declare const QuantityPicker: ({ id, value, onChange, disabled, preventManualChange, disableIncrement, variation, name, min, max, incrementButtonTitle, decrementButtonTitle, }: QuantityPickerProps) => JSX.Element;
|
|
@@ -1,21 +1,79 @@
|
|
|
1
1
|
import { TextField } from '@material-ui/core';
|
|
2
2
|
import { IconButton, Icon } from '@popmenu/common-ui';
|
|
3
3
|
import { MinusCircle, PlusCircle } from '@popmenu/web-icons';
|
|
4
|
-
import React__default, { useRef, useState, useEffect } from 'react';
|
|
4
|
+
import React__default, { useRef, useState, useCallback, useEffect } from 'react';
|
|
5
5
|
import { useQuantityPickerStyles, useQuantityInputStyles, useStartAdornmentStyles, useEndAdornmentStyles } from './QuantityPicker.styles.js';
|
|
6
6
|
|
|
7
|
-
const
|
|
7
|
+
const LIVE_REGION_CLEAR_DELAY = 2000;
|
|
8
|
+
const QuantityPicker = ({ id, value, onChange, disabled, preventManualChange, disableIncrement, variation, name, min = 0, max = 99, incrementButtonTitle, decrementButtonTitle, }) => {
|
|
8
9
|
const fieldClasses = useQuantityPickerStyles();
|
|
9
10
|
const inputClasses = useQuantityInputStyles({ variation, value });
|
|
10
11
|
const startAdornmentClasses = useStartAdornmentStyles({ variation, value });
|
|
11
12
|
const endAdornmentClasses = useEndAdornmentStyles({ variation, value });
|
|
12
13
|
const inputRef = useRef(null);
|
|
13
14
|
const [shouldSelect, setShouldSelect] = useState(false);
|
|
15
|
+
const [liveRegionMessage, setLiveRegionMessage] = useState('');
|
|
16
|
+
const liveRegionTimeoutRef = useRef(null);
|
|
17
|
+
// Clear the live region message after a delay to avoid stale announcements
|
|
18
|
+
const announceLiveRegion = useCallback((message) => {
|
|
19
|
+
if (liveRegionTimeoutRef.current) {
|
|
20
|
+
clearTimeout(liveRegionTimeoutRef.current);
|
|
21
|
+
}
|
|
22
|
+
setLiveRegionMessage(message);
|
|
23
|
+
liveRegionTimeoutRef.current = setTimeout(() => {
|
|
24
|
+
setLiveRegionMessage('');
|
|
25
|
+
}, LIVE_REGION_CLEAR_DELAY);
|
|
26
|
+
}, []);
|
|
27
|
+
// Cleanup timeout on unmount
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
return () => {
|
|
30
|
+
if (liveRegionTimeoutRef.current) {
|
|
31
|
+
clearTimeout(liveRegionTimeoutRef.current);
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
}, []);
|
|
14
35
|
const onIncrement = (event) => {
|
|
15
|
-
|
|
36
|
+
const newValue = value + 1;
|
|
37
|
+
onChange(event, { quantity: newValue, reason: 'increment' });
|
|
38
|
+
announceLiveRegion(String(newValue));
|
|
16
39
|
};
|
|
17
40
|
const onDecrement = (event) => {
|
|
18
|
-
|
|
41
|
+
const newValue = value - 1;
|
|
42
|
+
onChange(event, { quantity: newValue, reason: 'decrement' });
|
|
43
|
+
announceLiveRegion(String(newValue));
|
|
44
|
+
};
|
|
45
|
+
const handleKeyDown = (event) => {
|
|
46
|
+
let newValue = null;
|
|
47
|
+
switch (event.key) {
|
|
48
|
+
case 'ArrowUp':
|
|
49
|
+
event.preventDefault();
|
|
50
|
+
if (value < max && !disableIncrement) {
|
|
51
|
+
newValue = value + 1;
|
|
52
|
+
onChange(event, { quantity: newValue, reason: 'increment' });
|
|
53
|
+
}
|
|
54
|
+
break;
|
|
55
|
+
case 'ArrowDown':
|
|
56
|
+
event.preventDefault();
|
|
57
|
+
if (value > min) {
|
|
58
|
+
newValue = value - 1;
|
|
59
|
+
onChange(event, { quantity: newValue, reason: 'decrement' });
|
|
60
|
+
}
|
|
61
|
+
break;
|
|
62
|
+
case 'Home':
|
|
63
|
+
event.preventDefault();
|
|
64
|
+
if (value !== min) {
|
|
65
|
+
newValue = min;
|
|
66
|
+
onChange(event, { quantity: newValue, reason: 'decrement' });
|
|
67
|
+
}
|
|
68
|
+
break;
|
|
69
|
+
case 'End':
|
|
70
|
+
event.preventDefault();
|
|
71
|
+
if (value !== max && !disableIncrement) {
|
|
72
|
+
newValue = max;
|
|
73
|
+
onChange(event, { quantity: newValue, reason: 'increment' });
|
|
74
|
+
}
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
19
77
|
};
|
|
20
78
|
const handleChange = (event) => {
|
|
21
79
|
if (preventManualChange) {
|
|
@@ -44,18 +102,35 @@ const QuantityPicker = ({ value, onChange, disabled, preventManualChange, disabl
|
|
|
44
102
|
setShouldSelect(false);
|
|
45
103
|
}
|
|
46
104
|
}, [shouldSelect, value]);
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
React__default.createElement(
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
105
|
+
const isAtMin = value <= min;
|
|
106
|
+
const isAtMax = value >= max || disableIncrement;
|
|
107
|
+
return (React__default.createElement(React__default.Fragment, null,
|
|
108
|
+
React__default.createElement(TextField, { id: id, classes: fieldClasses, type: "text", variant: variation === 'itemCount' ? 'filled' : 'standard', value: value, disabled: disabled, onChange: handleChange, onKeyDown: handleKeyDown, inputRef: inputRef, InputProps: {
|
|
109
|
+
classes: inputClasses,
|
|
110
|
+
disableUnderline: true,
|
|
111
|
+
endAdornment: (React__default.createElement(IconButton, { title: incrementButtonTitle, "aria-controls": id, "aria-disabled": isAtMax || disabled, tabIndex: -1, className: endAdornmentClasses.root, color: "default", onClick: onIncrement, disabled: disabled || isAtMax },
|
|
112
|
+
React__default.createElement(Icon, { icon: PlusCircle, "aria-hidden": "true" }))),
|
|
113
|
+
startAdornment: (React__default.createElement(IconButton, { title: decrementButtonTitle, "aria-controls": id, "aria-disabled": isAtMin || disabled, tabIndex: -1, className: startAdornmentClasses.root, color: "default", onClick: onDecrement, disabled: disabled || isAtMin },
|
|
114
|
+
React__default.createElement(Icon, { icon: MinusCircle, "aria-hidden": "true" }))),
|
|
115
|
+
}, inputProps: {
|
|
116
|
+
role: 'spinbutton',
|
|
117
|
+
inputMode: 'numeric',
|
|
118
|
+
'aria-label': `${name} quantity`,
|
|
119
|
+
'aria-valuenow': value,
|
|
120
|
+
'aria-valuemin': min,
|
|
121
|
+
'aria-valuemax': max,
|
|
122
|
+
} }),
|
|
123
|
+
React__default.createElement("output", { "aria-live": "polite", style: {
|
|
124
|
+
position: 'absolute',
|
|
125
|
+
width: 1,
|
|
126
|
+
height: 1,
|
|
127
|
+
padding: 0,
|
|
128
|
+
margin: -1,
|
|
129
|
+
overflow: 'hidden',
|
|
130
|
+
clip: 'rect(0, 0, 0, 0)',
|
|
131
|
+
whiteSpace: 'nowrap',
|
|
132
|
+
border: 0,
|
|
133
|
+
} }, liveRegionMessage)));
|
|
59
134
|
};
|
|
60
135
|
|
|
61
136
|
export { QuantityPicker };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuantityPicker.js","sources":["../../../../src/components/QuantityPicker/QuantityPicker.tsx"],"sourcesContent":["import { TextField } from '@material-ui/core'\nimport { Icon, IconButton } from '@popmenu/common-ui'\nimport { MinusCircle, PlusCircle } from '@popmenu/web-icons'\nimport React, { ChangeEvent, MouseEventHandler, useEffect, useRef, useState } from 'react'\n\nimport {\n useEndAdornmentStyles,\n useQuantityInputStyles,\n useQuantityPickerStyles,\n useStartAdornmentStyles,\n} from './QuantityPicker.styles'\nimport { QuantityPickerProps } from './QuantityPickerProps'\n\nexport const QuantityPicker = ({\n value,\n onChange,\n disabled,\n preventManualChange,\n disableIncrement,\n variation,\n name,\n min = 0,\n max = 99,\n}: QuantityPickerProps): JSX.Element => {\n const fieldClasses = useQuantityPickerStyles()\n const inputClasses = useQuantityInputStyles({ variation, value })\n const startAdornmentClasses = useStartAdornmentStyles({ variation, value })\n const endAdornmentClasses = useEndAdornmentStyles({ variation, value })\n\n const inputRef = useRef<HTMLInputElement>(null)\n const [shouldSelect, setShouldSelect] = useState(false)\n\n const onIncrement: MouseEventHandler<HTMLButtonElement> = (event) => {\n onChange(event, { quantity: value + 1, reason: 'increment' })\n }\n\n const onDecrement: MouseEventHandler<HTMLButtonElement> = (event) => {\n onChange(event, { quantity: value - 1, reason: 'decrement' })\n }\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n if (preventManualChange) {\n event.preventDefault()\n return\n }\n let newValue = parseInt(event.target.value, 10)\n\n if (isNaN(newValue)) {\n newValue = min\n setShouldSelect(true)\n } else {\n setShouldSelect(false)\n }\n\n // Clamp value between min and max\n if (newValue < min) newValue = min\n if (newValue > max) newValue = max\n\n onChange(event, { quantity: newValue, reason: 'change' })\n }\n\n useEffect(() => {\n if (shouldSelect && inputRef.current) {\n inputRef.current.focus()\n inputRef.current.select()\n setShouldSelect(false)\n }\n }, [shouldSelect, value])\n\n return (\n <TextField\n aria-label={`${name} Quantity`}\n classes={fieldClasses}\n type=\"number\"\n variant={variation === 'itemCount' ? 'filled' : 'standard'}\n value={value}\n disabled={disabled}\n onChange={handleChange}\n inputRef={inputRef}\n InputProps={{\n classes: inputClasses,\n disableUnderline: true,\n endAdornment: (\n <IconButton\n aria-label={`increase quantity ${name}`}\n className={endAdornmentClasses.root}\n color=\"default\"\n onClick={onIncrement}\n disabled={disabled || value >= max || disableIncrement}\n >\n <Icon icon={PlusCircle} />\n </IconButton>\n ),\n startAdornment: (\n <IconButton\n aria-label={`decrease quantity ${name}`}\n className={startAdornmentClasses.root}\n color=\"default\"\n onClick={onDecrement}\n disabled={disabled || value <= min}\n >\n <Icon icon={MinusCircle} />\n </IconButton>\n ),\n }}\n inputProps={{\n 'aria-label': `${name} quantity`,\n min,\n max,\n }}\n />\n )\n}\n"],"names":["React"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"QuantityPicker.js","sources":["../../../../src/components/QuantityPicker/QuantityPicker.tsx"],"sourcesContent":["import { TextField } from '@material-ui/core'\nimport { Icon, IconButton } from '@popmenu/common-ui'\nimport { MinusCircle, PlusCircle } from '@popmenu/web-icons'\nimport React, { ChangeEvent, KeyboardEvent, MouseEventHandler, useCallback, useEffect, useRef, useState } from 'react'\n\nimport {\n useEndAdornmentStyles,\n useQuantityInputStyles,\n useQuantityPickerStyles,\n useStartAdornmentStyles,\n} from './QuantityPicker.styles'\nimport { QuantityPickerProps } from './QuantityPickerProps'\n\nconst LIVE_REGION_CLEAR_DELAY = 2000\n\nexport const QuantityPicker = ({\n id,\n value,\n onChange,\n disabled,\n preventManualChange,\n disableIncrement,\n variation,\n name,\n min = 0,\n max = 99,\n incrementButtonTitle,\n decrementButtonTitle,\n}: QuantityPickerProps): JSX.Element => {\n const fieldClasses = useQuantityPickerStyles()\n const inputClasses = useQuantityInputStyles({ variation, value })\n const startAdornmentClasses = useStartAdornmentStyles({ variation, value })\n const endAdornmentClasses = useEndAdornmentStyles({ variation, value })\n\n const inputRef = useRef<HTMLInputElement>(null)\n const [shouldSelect, setShouldSelect] = useState(false)\n const [liveRegionMessage, setLiveRegionMessage] = useState('')\n const liveRegionTimeoutRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n // Clear the live region message after a delay to avoid stale announcements\n const announceLiveRegion = useCallback((message: string) => {\n if (liveRegionTimeoutRef.current) {\n clearTimeout(liveRegionTimeoutRef.current)\n }\n setLiveRegionMessage(message)\n liveRegionTimeoutRef.current = setTimeout(() => {\n setLiveRegionMessage('')\n }, LIVE_REGION_CLEAR_DELAY)\n }, [])\n\n // Cleanup timeout on unmount\n useEffect(() => {\n return () => {\n if (liveRegionTimeoutRef.current) {\n clearTimeout(liveRegionTimeoutRef.current)\n }\n }\n }, [])\n\n const onIncrement: MouseEventHandler<HTMLButtonElement> = (event) => {\n const newValue = value + 1\n onChange(event, { quantity: newValue, reason: 'increment' })\n announceLiveRegion(String(newValue))\n }\n\n const onDecrement: MouseEventHandler<HTMLButtonElement> = (event) => {\n const newValue = value - 1\n onChange(event, { quantity: newValue, reason: 'decrement' })\n announceLiveRegion(String(newValue))\n }\n\n const handleKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {\n let newValue: number | null = null\n\n switch (event.key) {\n case 'ArrowUp':\n event.preventDefault()\n if (value < max && !disableIncrement) {\n newValue = value + 1\n onChange(event, { quantity: newValue, reason: 'increment' })\n }\n break\n case 'ArrowDown':\n event.preventDefault()\n if (value > min) {\n newValue = value - 1\n onChange(event, { quantity: newValue, reason: 'decrement' })\n }\n break\n case 'Home':\n event.preventDefault()\n if (value !== min) {\n newValue = min\n onChange(event, { quantity: newValue, reason: 'decrement' })\n }\n break\n case 'End':\n event.preventDefault()\n if (value !== max && !disableIncrement) {\n newValue = max\n onChange(event, { quantity: newValue, reason: 'increment' })\n }\n break\n default:\n break\n }\n }\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n if (preventManualChange) {\n event.preventDefault()\n return\n }\n let newValue = parseInt(event.target.value, 10)\n\n if (isNaN(newValue)) {\n newValue = min\n setShouldSelect(true)\n } else {\n setShouldSelect(false)\n }\n\n // Clamp value between min and max\n if (newValue < min) newValue = min\n if (newValue > max) newValue = max\n\n onChange(event, { quantity: newValue, reason: 'change' })\n }\n\n useEffect(() => {\n if (shouldSelect && inputRef.current) {\n inputRef.current.focus()\n inputRef.current.select()\n setShouldSelect(false)\n }\n }, [shouldSelect, value])\n\n const isAtMin = value <= min\n const isAtMax = value >= max || disableIncrement\n\n return (\n <>\n <TextField\n id={id}\n classes={fieldClasses}\n type=\"text\"\n variant={variation === 'itemCount' ? 'filled' : 'standard'}\n value={value}\n disabled={disabled}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n inputRef={inputRef}\n InputProps={{\n classes: inputClasses,\n disableUnderline: true,\n endAdornment: (\n <IconButton\n title={incrementButtonTitle}\n aria-controls={id}\n aria-disabled={isAtMax || disabled}\n tabIndex={-1}\n className={endAdornmentClasses.root}\n color=\"default\"\n onClick={onIncrement}\n disabled={disabled || isAtMax}\n >\n <Icon icon={PlusCircle} aria-hidden=\"true\" />\n </IconButton>\n ),\n startAdornment: (\n <IconButton\n title={decrementButtonTitle}\n aria-controls={id}\n aria-disabled={isAtMin || disabled}\n tabIndex={-1}\n className={startAdornmentClasses.root}\n color=\"default\"\n onClick={onDecrement}\n disabled={disabled || isAtMin}\n >\n <Icon icon={MinusCircle} aria-hidden=\"true\" />\n </IconButton>\n ),\n }}\n inputProps={{\n role: 'spinbutton',\n inputMode: 'numeric',\n 'aria-label': `${name} quantity`,\n 'aria-valuenow': value,\n 'aria-valuemin': min,\n 'aria-valuemax': max,\n }}\n />\n {/* Live region for announcing value changes when buttons are pressed */}\n <output\n aria-live=\"polite\"\n style={{\n position: 'absolute',\n width: 1,\n height: 1,\n padding: 0,\n margin: -1,\n overflow: 'hidden',\n clip: 'rect(0, 0, 0, 0)',\n whiteSpace: 'nowrap',\n border: 0,\n }}\n >\n {liveRegionMessage}\n </output>\n </>\n )\n}\n"],"names":["React"],"mappings":"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"}
|
|
@@ -4,6 +4,9 @@ const useQuantityPickerStyles = makeStyles((theme) => ({
|
|
|
4
4
|
root: {
|
|
5
5
|
height: theme.spacing(7),
|
|
6
6
|
backgroundColor: 'none',
|
|
7
|
+
'&:has(:focus-visible)': {
|
|
8
|
+
outline: `2px solid ${theme.palette.info.main}`,
|
|
9
|
+
},
|
|
7
10
|
},
|
|
8
11
|
}));
|
|
9
12
|
const useQuantityInputStyles = makeStyles((theme) => ({
|
|
@@ -19,15 +22,17 @@ const useQuantityInputStyles = makeStyles((theme) => ({
|
|
|
19
22
|
},
|
|
20
23
|
'-moz-appearance': 'textfield',
|
|
21
24
|
fontWeight: 600,
|
|
22
|
-
padding: 0,
|
|
23
25
|
textAlign: 'center',
|
|
24
26
|
zIndex: (props) => (props.value === 0 && props.variation === 'modifierCount' ? -1 : 1),
|
|
25
27
|
backgroundColor: (props) => (props.variation === 'modifierCount' ? theme.palette.grey[100] : 'unset'),
|
|
26
28
|
alignSelf: (props) => (props.variation === 'modifierCount' ? 'stretch' : 'unset'),
|
|
27
29
|
height: (props) => (props.variation === 'modifierCount' ? 'auto' : 'unset'),
|
|
28
|
-
|
|
30
|
+
minHeight: theme.spacing(3),
|
|
31
|
+
minWidth: (props) => (props.variation === 'modifierCount' ? theme.spacing(5) : theme.spacing(3)),
|
|
29
32
|
borderRadius: (props) => (props.variation === 'modifierCount' ? theme.spacing(1) : 'unset'),
|
|
30
|
-
margin:
|
|
33
|
+
margin: theme.spacing(1),
|
|
34
|
+
padding: 0,
|
|
35
|
+
outline: 'none !important',
|
|
31
36
|
},
|
|
32
37
|
}));
|
|
33
38
|
const useStartAdornmentStyles = makeStyles((theme) => ({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuantityPicker.styles.js","sources":["../../../../src/components/QuantityPicker/QuantityPicker.styles.ts"],"sourcesContent":["import { makeStyles, Theme } from '@material-ui/core'\nimport { QuantityPickerProps } from './QuantityPickerProps'\n\nexport const useQuantityPickerStyles = makeStyles((theme) => ({\n root: {\n height: theme.spacing(7),\n backgroundColor: 'none',\n },\n}))\n\nexport const useQuantityInputStyles = makeStyles<Theme, Pick<QuantityPickerProps, 'variation' | 'value'>>((theme) => ({\n root: {\n height: '100%',\n width: 'min-content',\n borderRadius: theme.spacing(12.5),\n background: (props) => (props.variation === 'modifierCount' ? 'unset' : theme.palette.grey[100]),\n },\n input: {\n '&::-webkit-clear-button, &::-webkit-outer-spin-button, &::-webkit-inner-spin-button': {\n display: 'none',\n },\n '-moz-appearance': 'textfield',\n fontWeight: 600,\n
|
|
1
|
+
{"version":3,"file":"QuantityPicker.styles.js","sources":["../../../../src/components/QuantityPicker/QuantityPicker.styles.ts"],"sourcesContent":["import { makeStyles, Theme } from '@material-ui/core'\nimport { QuantityPickerProps } from './QuantityPickerProps'\n\nexport const useQuantityPickerStyles = makeStyles((theme) => ({\n root: {\n height: theme.spacing(7),\n backgroundColor: 'none',\n '&:has(:focus-visible)': {\n outline: `2px solid ${theme.palette.info.main}`,\n },\n },\n}))\n\nexport const useQuantityInputStyles = makeStyles<Theme, Pick<QuantityPickerProps, 'variation' | 'value'>>((theme) => ({\n root: {\n height: '100%',\n width: 'min-content',\n borderRadius: theme.spacing(12.5),\n background: (props) => (props.variation === 'modifierCount' ? 'unset' : theme.palette.grey[100]),\n },\n input: {\n '&::-webkit-clear-button, &::-webkit-outer-spin-button, &::-webkit-inner-spin-button': {\n display: 'none',\n },\n '-moz-appearance': 'textfield',\n fontWeight: 600,\n textAlign: 'center',\n zIndex: (props) => (props.value === 0 && props.variation === 'modifierCount' ? -1 : 1),\n backgroundColor: (props) => (props.variation === 'modifierCount' ? theme.palette.grey[100] : 'unset'),\n alignSelf: (props) => (props.variation === 'modifierCount' ? 'stretch' : 'unset'),\n height: (props) => (props.variation === 'modifierCount' ? 'auto' : 'unset'),\n minHeight: theme.spacing(3),\n minWidth: (props) => (props.variation === 'modifierCount' ? theme.spacing(5) : theme.spacing(3)),\n borderRadius: (props) => (props.variation === 'modifierCount' ? theme.spacing(1) : 'unset'),\n margin: theme.spacing(1),\n padding: 0,\n outline: 'none !important',\n },\n}))\n\nexport const useStartAdornmentStyles = makeStyles<Theme, Pick<QuantityPickerProps, 'variation' | 'value'>>((theme) => ({\n root: {\n color: theme.palette.text.primary,\n zIndex: (props) => (props.value === 0 && props.variation === 'modifierCount' ? -1 : 1),\n },\n}))\n\nexport const useEndAdornmentStyles = makeStyles<Theme, Pick<QuantityPickerProps, 'variation' | 'value'>>((theme) => ({\n root: {\n color: theme.palette.text.primary,\n },\n}))\n"],"names":[],"mappings":";;AAGa,MAAA,uBAAuB,GAAG,UAAU,CAAC,CAAC,KAAK,MAAM;AAC5D,IAAA,IAAI,EAAE;AACJ,QAAA,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;AACxB,QAAA,eAAe,EAAE,MAAM;AACvB,QAAA,uBAAuB,EAAE;YACvB,OAAO,EAAE,aAAa,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAE,CAAA;AAChD,SAAA;AACF,KAAA;AACF,CAAA,CAAC;AAEW,MAAA,sBAAsB,GAAG,UAAU,CAA0D,CAAC,KAAK,MAAM;AACpH,IAAA,IAAI,EAAE;AACJ,QAAA,MAAM,EAAE,MAAM;AACd,QAAA,KAAK,EAAE,aAAa;AACpB,QAAA,YAAY,EAAE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;QACjC,UAAU,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACjG,KAAA;AACD,IAAA,KAAK,EAAE;AACL,QAAA,qFAAqF,EAAE;AACrF,YAAA,OAAO,EAAE,MAAM;AAChB,SAAA;AACD,QAAA,iBAAiB,EAAE,WAAW;AAC9B,QAAA,UAAU,EAAE,GAAG;AACf,QAAA,SAAS,EAAE,QAAQ;QACnB,MAAM,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,KAAK,CAAC,IAAI,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,EAAE,GAAG,CAAC,CAAC;QACtF,eAAe,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC;QACrG,SAAS,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,SAAS,GAAG,OAAO,CAAC;QACjF,MAAM,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,MAAM,GAAG,OAAO,CAAC;AAC3E,QAAA,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;AAC3B,QAAA,QAAQ,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChG,YAAY,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;AAC3F,QAAA,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;AACxB,QAAA,OAAO,EAAE,CAAC;AACV,QAAA,OAAO,EAAE,iBAAiB;AAC3B,KAAA;AACF,CAAA,CAAC;AAEW,MAAA,uBAAuB,GAAG,UAAU,CAA0D,CAAC,KAAK,MAAM;AACrH,IAAA,IAAI,EAAE;AACJ,QAAA,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO;QACjC,MAAM,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,KAAK,CAAC,IAAI,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,EAAE,GAAG,CAAC,CAAC;AACvF,KAAA;AACF,CAAA,CAAC;AAEW,MAAA,qBAAqB,GAAG,UAAU,CAA0D,CAAC,KAAK,MAAM;AACnH,IAAA,IAAI,EAAE;AACJ,QAAA,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO;AAClC,KAAA;AACF,CAAA,CAAC;;;;"}
|
|
@@ -4,8 +4,10 @@ export type QuantityChangeEvent = {
|
|
|
4
4
|
reason: string;
|
|
5
5
|
};
|
|
6
6
|
export interface QuantityPickerProps {
|
|
7
|
+
/** Unique ID for the spinbutton input - required for aria-controls on buttons */
|
|
8
|
+
id: string;
|
|
7
9
|
/** Callback for when the quantity is increased or decreased for the parent form */
|
|
8
|
-
onChange: (event: ChangeEvent<HTMLInputElement> | React.MouseEvent<HTMLButtonElement, MouseEvent>, change: QuantityChangeEvent) => void;
|
|
10
|
+
onChange: (event: ChangeEvent<HTMLInputElement> | React.MouseEvent<HTMLButtonElement, MouseEvent> | React.KeyboardEvent<HTMLInputElement>, change: QuantityChangeEvent) => void;
|
|
9
11
|
/** the quantity represented by the picker */
|
|
10
12
|
value: number;
|
|
11
13
|
/** determines if picker is active */
|
|
@@ -22,4 +24,8 @@ export interface QuantityPickerProps {
|
|
|
22
24
|
variation: 'itemCount' | 'modifierCount';
|
|
23
25
|
/** name of the modifier the quantity picker is assigned to */
|
|
24
26
|
name: string;
|
|
27
|
+
/** Accessible title for the increment button (e.g., "Add adult") - used for i18n */
|
|
28
|
+
incrementButtonTitle: string;
|
|
29
|
+
/** Accessible title for the decrement button (e.g., "Remove adult") - used for i18n */
|
|
30
|
+
decrementButtonTitle: string;
|
|
25
31
|
}
|