@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.
Files changed (59) hide show
  1. package/build/cjs/components/MenuTab/MenuTab.styles.d.ts +1 -0
  2. package/build/cjs/components/MenuTab/MenuTabProps.d.ts +8 -2
  3. package/build/cjs/components/MenuTabGroup/MenuTabGroup.styles.d.ts +1 -1
  4. package/build/cjs/components/MenuTabGroup/MenuTabGroupProps.d.ts +6 -6
  5. package/build/cjs/components/QuantityPicker/QuantityPicker.d.ts +1 -1
  6. package/build/cjs/components/QuantityPicker/QuantityPickerProps.d.ts +7 -1
  7. package/build/cjs/components/ReactionCounter/ReactionCounterProps.d.ts +1 -1
  8. package/build/cjs/components/SelectableChip/SelectableChipProps.d.ts +7 -2
  9. package/build/cjs/components/SelectableChipGroup/SelectableChipGroup.d.ts +5 -1
  10. package/build/cjs/components/SelectableChipGroup/index.d.ts +0 -1
  11. package/build/cjs/components/index.d.ts +0 -1
  12. package/build/cjs/index.js +313 -122
  13. package/build/cjs/index.js.map +1 -1
  14. package/build/esm/components/DishModifierCard/ModifierControls.js +1 -1
  15. package/build/esm/components/DishModifierCard/ModifierControls.js.map +1 -1
  16. package/build/esm/components/MenuItem/MenuItem.js +3 -3
  17. package/build/esm/components/MenuItem/MenuItem.js.map +1 -1
  18. package/build/esm/components/MenuSection/MenuSection.js +3 -3
  19. package/build/esm/components/MenuSection/MenuSection.js.map +1 -1
  20. package/build/esm/components/MenuTab/MenuTab.js +22 -6
  21. package/build/esm/components/MenuTab/MenuTab.js.map +1 -1
  22. package/build/esm/components/MenuTab/MenuTab.styles.d.ts +1 -0
  23. package/build/esm/components/MenuTab/MenuTab.styles.js +26 -14
  24. package/build/esm/components/MenuTab/MenuTab.styles.js.map +1 -1
  25. package/build/esm/components/MenuTab/MenuTabProps.d.ts +8 -2
  26. package/build/esm/components/MenuTabGroup/MenuTabGroup.js +46 -6
  27. package/build/esm/components/MenuTabGroup/MenuTabGroup.js.map +1 -1
  28. package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.d.ts +1 -1
  29. package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.js +41 -39
  30. package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.js.map +1 -1
  31. package/build/esm/components/MenuTabGroup/MenuTabGroupProps.d.ts +6 -6
  32. package/build/esm/components/QuantityPicker/QuantityPicker.d.ts +1 -1
  33. package/build/esm/components/QuantityPicker/QuantityPicker.js +91 -16
  34. package/build/esm/components/QuantityPicker/QuantityPicker.js.map +1 -1
  35. package/build/esm/components/QuantityPicker/QuantityPicker.styles.js +8 -3
  36. package/build/esm/components/QuantityPicker/QuantityPicker.styles.js.map +1 -1
  37. package/build/esm/components/QuantityPicker/QuantityPickerProps.d.ts +7 -1
  38. package/build/esm/components/ReactionCounter/ReactionCounter.js +5 -2
  39. package/build/esm/components/ReactionCounter/ReactionCounter.js.map +1 -1
  40. package/build/esm/components/ReactionCounter/ReactionCounterProps.d.ts +1 -1
  41. package/build/esm/components/SelectableChip/SelectableChip.js +16 -5
  42. package/build/esm/components/SelectableChip/SelectableChip.js.map +1 -1
  43. package/build/esm/components/SelectableChip/SelectableChip.styles.js +9 -21
  44. package/build/esm/components/SelectableChip/SelectableChip.styles.js.map +1 -1
  45. package/build/esm/components/SelectableChip/SelectableChipProps.d.ts +7 -2
  46. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.d.ts +5 -1
  47. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.js +4 -6
  48. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.js.map +1 -1
  49. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.styles.js +4 -4
  50. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.styles.js.map +1 -1
  51. package/build/esm/components/SelectableChipGroup/index.d.ts +0 -1
  52. package/build/esm/components/index.d.ts +0 -1
  53. package/build/esm/theme/overrides.js +36 -1
  54. package/build/esm/theme/overrides.js.map +1 -1
  55. package/build/esm/theme/props.js +9 -0
  56. package/build/esm/theme/props.js.map +1 -1
  57. package/package.json +2 -2
  58. package/build/cjs/components/SelectableChipGroup/SelectableChipGroupProps.d.ts +0 -6
  59. package/build/esm/components/SelectableChipGroup/SelectableChipGroupProps.d.ts +0 -6
@@ -1,15 +1,31 @@
1
1
  import React__default from 'react';
2
- import { Tab } from '@material-ui/core';
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 { isUnavailable, value } = props;
9
- const classes = useMenuTabStyles({ isUnavailable });
10
- return (React__default.createElement(Tab, { "data-tab-for-section-id": value, classes: {
11
- root: classes.root,
12
- }, icon: isUnavailable ? React__default.createElement(Icon, { icon: Clock, size: "large", className: classes.icon }) : undefined, ...props }));
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 { Tab } from '@material-ui/core'\nimport { Clock } from '@popmenu/web-icons'\nimport { Icon } from '@popmenu/common-ui'\n\nimport { useMenuTabStyles } from './MenuTab.styles'\nimport { MenuTabProps } from './MenuTabProps'\n\nexport const MenuTab = (props: MenuTabProps) => {\n const { isUnavailable, value } = props\n const classes = useMenuTabStyles({ isUnavailable })\n\n return (\n <Tab\n data-tab-for-section-id={value}\n classes={{\n root: classes.root,\n }}\n icon={isUnavailable ? <Icon icon={Clock} size=\"large\" className={classes.icon} /> : undefined}\n {...props}\n />\n )\n}\n"],"names":["React"],"mappings":";;;;;;AAQa,MAAA,OAAO,GAAG,CAAC,KAAmB,KAAI;AAC7C,IAAA,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,GAAG,KAAK;IACtC,MAAM,OAAO,GAAG,gBAAgB,CAAC,EAAE,aAAa,EAAE,CAAC;AAEnD,IAAA,QACEA,cAAC,CAAA,aAAA,CAAA,GAAG,+BACuB,KAAK,EAC9B,OAAO,EAAE;YACP,IAAI,EAAE,OAAO,CAAC,IAAI;AACnB,SAAA,EACD,IAAI,EAAE,aAAa,GAAGA,cAAC,CAAA,aAAA,CAAA,IAAI,EAAC,EAAA,IAAI,EAAE,KAAK,EAAE,IAAI,EAAC,OAAO,EAAC,SAAS,EAAE,OAAO,CAAC,IAAI,EAAI,CAAA,GAAG,SAAS,EAAA,GACzF,KAAK,EAAA,CACT;AAEN;;;;"}
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;;;;"}
@@ -1,4 +1,5 @@
1
1
  export interface MenuTabStylesProps {
2
2
  isUnavailable: boolean | undefined;
3
+ selected: boolean | undefined;
3
4
  }
4
5
  export declare const useMenuTabStyles: (props: MenuTabStylesProps) => import("@material-ui/styles").ClassNameMap<string>;
@@ -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: ({ isUnavailable }) => ({
8
- color: isUnavailable ? `${palette.grey[700]} !important` : 'inherit',
9
- '&.MuiTab-labelIcon': {
10
- minHeight: 'unset',
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
- '& > .MuiTab-wrapper': {
14
- flexDirection: 'row-reverse',
15
- gridGap: spacing(1),
16
- textAlign: 'center',
17
- '& > svg': {
18
- marginBottom: '0 !important',
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 }) => ({\n color: isUnavailable ? `${palette.grey[700]} !important` : 'inherit',\n '&.MuiTab-labelIcon': {\n minHeight: 'unset',\n },\n maxWidth: spacing(29.5),\n '& > .MuiTab-wrapper': {\n flexDirection: 'row-reverse',\n gridGap: spacing(1),\n textAlign: 'center',\n\n '& > svg': {\n marginBottom: '0 !important',\n },\n },\n }),\n}))\n"],"names":[],"mappings":";;AAKO,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;AACvB,KAAA;IACD,IAAI,EAAE,CAAC,EAAE,aAAa,EAAE,MAAM;AAC5B,QAAA,KAAK,EAAE,aAAa,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA,WAAA,CAAa,GAAG,SAAS;AACpE,QAAA,oBAAoB,EAAE;AACpB,YAAA,SAAS,EAAE,OAAO;AACnB,SAAA;AACD,QAAA,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC;AACvB,QAAA,qBAAqB,EAAE;AACrB,YAAA,aAAa,EAAE,aAAa;AAC5B,YAAA,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;AACnB,YAAA,SAAS,EAAE,QAAQ;AAEnB,YAAA,SAAS,EAAE;AACT,gBAAA,YAAY,EAAE,cAAc;AAC7B,aAAA;AACF,SAAA;KACF,CAAC;AACH,CAAA,CAAC;;;;"}
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 { TabProps } from '@material-ui/core/Tab';
2
- export type MenuTabProps = TabProps & {
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 { Tabs } from '@material-ui/core';
2
- import React__default from 'react';
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, ...muiProps } = props;
8
+ const { children, scrollLeftLabel, scrollRightLabel, ...restProps } = props;
7
9
  const classes = useMenuTabGroupStyles();
8
- return (React__default.createElement(Tabs, { scrollButtons: "on", variant: "scrollable", classes: {
9
- root: classes.root,
10
- }, ...muiProps }, children));
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 { Tabs } from '@material-ui/core'\nimport React from 'react'\nimport { MenuTabGroupProps } from './MenuTabGroupProps'\nimport { useMenuTabGroupStyles } from './MenuTabGroup.styles'\n\nexport const MenuTabGroup = (props: MenuTabGroupProps) => {\n const { children, ...muiProps } = props\n const classes = useMenuTabGroupStyles()\n\n return (\n <Tabs\n scrollButtons=\"on\"\n variant=\"scrollable\"\n classes={{\n root: classes.root,\n }}\n {...muiProps}\n >\n {children}\n </Tabs>\n )\n}\n"],"names":["React"],"mappings":";;;;AAKa,MAAA,YAAY,GAAG,CAAC,KAAwB,KAAI;IACvD,MAAM,EAAE,QAAQ,EAAE,GAAG,QAAQ,EAAE,GAAG,KAAK;AACvC,IAAA,MAAM,OAAO,GAAG,qBAAqB,EAAE;AAEvC,IAAA,QACEA,cAAA,CAAA,aAAA,CAAC,IAAI,EAAA,EACH,aAAa,EAAC,IAAI,EAClB,OAAO,EAAC,YAAY,EACpB,OAAO,EAAE;YACP,IAAI,EAAE,OAAO,CAAC,IAAI;AACnB,SAAA,EAAA,GACG,QAAQ,EAAA,EAEX,QAAQ,CACJ;AAEX;;;;"}
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' /* Establish positioning context */,
6
- overflow: 'hidden' /* Prevent scroll buttons from overflowing */,
7
- '& .MuiTabScrollButton-root': {
8
- position: 'absolute',
9
- zIndex: '1',
10
- backgroundColor: 'white',
11
- height: '100%' /* Inherit full height of parent */,
12
- top: '0',
13
- display: 'flex',
14
- alignItems: 'center',
15
- justifyContent: 'center',
16
- width: '40px',
17
- opacity: 1,
18
- /* Position scroller buttons and add gradient to inner sections */
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\nexport const useMenuTabGroupStyles = makeStyles(() => ({\n root: {\n position: 'relative' /* Establish positioning context */,\n overflow: 'hidden' /* Prevent scroll buttons from overflowing */,\n '& .MuiTabScrollButton-root': {\n position: 'absolute',\n zIndex: '1',\n backgroundColor: 'white',\n height: '100%' /* Inherit full height of parent */,\n top: '0',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '40px',\n opacity: 1,\n\n /* Position scroller buttons and add gradient to inner sections */\n '&:first-child': {\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 '&:last-child': {\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 /* Ensure tab container fills height */\n '& .MuiSvgIcon-root': {\n height: '24px',\n width: '24px',\n },\n },\n\n /* Adjust scroller to prevent tabs from being hidden */\n '.MuiTabs-scroller': {\n padding: '0 40px' /* Match scroll button width */,\n height: '100%' /* Ensure it fills parent height */,\n },\n\n /* Ensure tab container fills height */\n '.MuiTabs-flexContainer': {\n height: '100%',\n },\n\n /* Remove buttons when scroll is all the way to the left or right */\n '& .MuiTabScrollButton-root.Mui-disabled': {\n display: 'none',\n },\n },\n}))\n"],"names":[],"mappings":";;MAEa,qBAAqB,GAAG,UAAU,CAAC,OAAO;AACrD,IAAA,IAAI,EAAE;QACJ,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE,QAAQ;AAClB,QAAA,4BAA4B,EAAE;AAC5B,YAAA,QAAQ,EAAE,UAAU;AACpB,YAAA,MAAM,EAAE,GAAG;AACX,YAAA,eAAe,EAAE,OAAO;YACxB,MAAM,EAAE,MAAM;AACd,YAAA,GAAG,EAAE,GAAG;AACR,YAAA,OAAO,EAAE,MAAM;AACf,YAAA,UAAU,EAAE,QAAQ;AACpB,YAAA,cAAc,EAAE,QAAQ;AACxB,YAAA,KAAK,EAAE,MAAM;AACb,YAAA,OAAO,EAAE,CAAC;;AAGV,YAAA,eAAe,EAAE;AACf,gBAAA,IAAI,EAAE,CAAC;AACP,gBAAA,UAAU,EACR,4HAA4H;AAC/H,aAAA;AACD,YAAA,cAAc,EAAE;AACd,gBAAA,KAAK,EAAE,CAAC;AACR,gBAAA,UAAU,EACR,2HAA2H;AAC9H,aAAA;;AAGD,YAAA,oBAAoB,EAAE;AACpB,gBAAA,MAAM,EAAE,MAAM;AACd,gBAAA,KAAK,EAAE,MAAM;AACd,aAAA;AACF,SAAA;;AAGD,QAAA,mBAAmB,EAAE;YACnB,OAAO,EAAE,QAAQ;YACjB,MAAM,EAAE,MAAM;AACf,SAAA;;AAGD,QAAA,wBAAwB,EAAE;AACxB,YAAA,MAAM,EAAE,MAAM;AACf,SAAA;;AAGD,QAAA,yCAAyC,EAAE;AACzC,YAAA,OAAO,EAAE,MAAM;AAChB,SAAA;AACF,KAAA;AACF,CAAA,CAAC;;;;"}
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 { TabsProps } from '@material-ui/core/Tabs';
2
- type MenuTabGroupOnChange = (event: React.ChangeEvent<Record<string, unknown>>, value: number) => void;
3
- export type MenuTabGroupProps = Omit<TabsProps, 'onChange'> & {
4
- onChange?: MenuTabGroupOnChange;
5
- };
6
- export {};
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 QuantityPicker = ({ value, onChange, disabled, preventManualChange, disableIncrement, variation, name, min = 0, max = 99, }) => {
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
- onChange(event, { quantity: value + 1, reason: 'increment' });
36
+ const newValue = value + 1;
37
+ onChange(event, { quantity: newValue, reason: 'increment' });
38
+ announceLiveRegion(String(newValue));
16
39
  };
17
40
  const onDecrement = (event) => {
18
- onChange(event, { quantity: value - 1, reason: 'decrement' });
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
- return (React__default.createElement(TextField, { "aria-label": `${name} Quantity`, classes: fieldClasses, type: "number", variant: variation === 'itemCount' ? 'filled' : 'standard', value: value, disabled: disabled, onChange: handleChange, inputRef: inputRef, InputProps: {
48
- classes: inputClasses,
49
- disableUnderline: true,
50
- endAdornment: (React__default.createElement(IconButton, { "aria-label": `increase quantity ${name}`, className: endAdornmentClasses.root, color: "default", onClick: onIncrement, disabled: disabled || value >= max || disableIncrement },
51
- React__default.createElement(Icon, { icon: PlusCircle }))),
52
- startAdornment: (React__default.createElement(IconButton, { "aria-label": `decrease quantity ${name}`, className: startAdornmentClasses.root, color: "default", onClick: onDecrement, disabled: disabled || value <= min },
53
- React__default.createElement(Icon, { icon: MinusCircle }))),
54
- }, inputProps: {
55
- 'aria-label': `${name} quantity`,
56
- min,
57
- max,
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
- minWidth: (props) => (props.variation === 'modifierCount' ? theme.spacing(5) : theme.spacing(2.75)),
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: (props) => (props.variation === 'modifierCount' ? theme.spacing(0.5, 0) : 0),
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 padding: 0,\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 minWidth: (props) => (props.variation === 'modifierCount' ? theme.spacing(5) : theme.spacing(2.75)),\n borderRadius: (props) => (props.variation === 'modifierCount' ? theme.spacing(1) : 'unset'),\n margin: (props) => (props.variation === 'modifierCount' ? theme.spacing(0.5, 0) : 0),\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;AACxB,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,OAAO,EAAE,CAAC;AACV,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,QAAQ,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACnG,YAAY,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;QAC3F,MAAM,EAAE,CAAC,KAAK,MAAM,KAAK,CAAC,SAAS,KAAK,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACrF,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;;;;"}
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
  }