@popmenu/ordering-ui 0.145.0 → 0.148.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 (61) 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 +324 -126
  13. package/build/cjs/index.js.map +1 -1
  14. package/build/esm/components/DishModifierCard/DishModifierCard.styles.js +6 -0
  15. package/build/esm/components/DishModifierCard/DishModifierCard.styles.js.map +1 -1
  16. package/build/esm/components/DishModifierCard/ModifierControls.js +6 -5
  17. package/build/esm/components/DishModifierCard/ModifierControls.js.map +1 -1
  18. package/build/esm/components/MenuItem/MenuItem.js +3 -3
  19. package/build/esm/components/MenuItem/MenuItem.js.map +1 -1
  20. package/build/esm/components/MenuSection/MenuSection.js +3 -3
  21. package/build/esm/components/MenuSection/MenuSection.js.map +1 -1
  22. package/build/esm/components/MenuTab/MenuTab.js +22 -6
  23. package/build/esm/components/MenuTab/MenuTab.js.map +1 -1
  24. package/build/esm/components/MenuTab/MenuTab.styles.d.ts +1 -0
  25. package/build/esm/components/MenuTab/MenuTab.styles.js +26 -14
  26. package/build/esm/components/MenuTab/MenuTab.styles.js.map +1 -1
  27. package/build/esm/components/MenuTab/MenuTabProps.d.ts +8 -2
  28. package/build/esm/components/MenuTabGroup/MenuTabGroup.js +46 -6
  29. package/build/esm/components/MenuTabGroup/MenuTabGroup.js.map +1 -1
  30. package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.d.ts +1 -1
  31. package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.js +41 -39
  32. package/build/esm/components/MenuTabGroup/MenuTabGroup.styles.js.map +1 -1
  33. package/build/esm/components/MenuTabGroup/MenuTabGroupProps.d.ts +6 -6
  34. package/build/esm/components/QuantityPicker/QuantityPicker.d.ts +1 -1
  35. package/build/esm/components/QuantityPicker/QuantityPicker.js +91 -16
  36. package/build/esm/components/QuantityPicker/QuantityPicker.js.map +1 -1
  37. package/build/esm/components/QuantityPicker/QuantityPicker.styles.js +8 -3
  38. package/build/esm/components/QuantityPicker/QuantityPicker.styles.js.map +1 -1
  39. package/build/esm/components/QuantityPicker/QuantityPickerProps.d.ts +7 -1
  40. package/build/esm/components/ReactionCounter/ReactionCounter.js +5 -2
  41. package/build/esm/components/ReactionCounter/ReactionCounter.js.map +1 -1
  42. package/build/esm/components/ReactionCounter/ReactionCounterProps.d.ts +1 -1
  43. package/build/esm/components/SelectableChip/SelectableChip.js +16 -5
  44. package/build/esm/components/SelectableChip/SelectableChip.js.map +1 -1
  45. package/build/esm/components/SelectableChip/SelectableChip.styles.js +9 -21
  46. package/build/esm/components/SelectableChip/SelectableChip.styles.js.map +1 -1
  47. package/build/esm/components/SelectableChip/SelectableChipProps.d.ts +7 -2
  48. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.d.ts +5 -1
  49. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.js +4 -6
  50. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.js.map +1 -1
  51. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.styles.js +4 -4
  52. package/build/esm/components/SelectableChipGroup/SelectableChipGroup.styles.js.map +1 -1
  53. package/build/esm/components/SelectableChipGroup/index.d.ts +0 -1
  54. package/build/esm/components/index.d.ts +0 -1
  55. package/build/esm/theme/overrides.js +36 -1
  56. package/build/esm/theme/overrides.js.map +1 -1
  57. package/build/esm/theme/props.js +9 -0
  58. package/build/esm/theme/props.js.map +1 -1
  59. package/package.json +2 -2
  60. package/build/cjs/components/SelectableChipGroup/SelectableChipGroupProps.d.ts +0 -6
  61. package/build/esm/components/SelectableChipGroup/SelectableChipGroupProps.d.ts +0 -6
@@ -1 +1 @@
1
- {"version":3,"file":"MenuItem.js","sources":["../../../../src/components/MenuItem/MenuItem.tsx"],"sourcesContent":["import { Box, Card, CardActionArea, Typography } from '@material-ui/core'\nimport React, { forwardRef } from 'react'\n\nimport { Skeleton } from '@material-ui/lab'\nimport classNames from 'classnames'\nimport { StatusTag } from '../StatusTag'\nimport { useMenuItemStyles } from './MenuItem.styles'\nimport { MenuItemImg } from './MenuItemImg'\nimport { MenuItemInfo } from './MenuItemInfo'\nimport { MenuItemPrice } from './MenuItemPrice'\nimport { MenuItemProps } from './MenuItemProps'\nimport { MenuItemReactions } from './MenuItemReactions'\nimport { MenuItemTags } from './MenuItemTags'\n\nexport const MenuItem = forwardRef((props: MenuItemProps, ref) => {\n const {\n ariaLabel,\n onClick,\n id,\n description,\n title,\n loading,\n statusTags,\n image,\n likeCount,\n reviewCount,\n price,\n available,\n itemTags,\n className,\n ...restProps\n } = props\n const classes = useMenuItemStyles(props)\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onClick(id, event)\n }\n\n return (\n <Card\n className={classNames(classes.card, className)}\n ref={ref}\n elevation={0}\n data-component-type=\"menu-item\"\n {...restProps}\n >\n <CardActionArea\n className={classes.cardActionArea}\n onClick={handleClick}\n disabled={loading}\n aria-label={ariaLabel}\n >\n <MenuItemInfo>\n {statusTags?.featured && <StatusTag {...statusTags.featured} />}\n <Box display=\"flex\" gridGap={8} alignItems=\"center\">\n <Typography component=\"h2\" className={classes.cardTitle}>\n {loading ? <Skeleton /> : title}\n {statusTags?.outOfStock && (\n <span className={classes.statusTags}>\n <StatusTag {...statusTags.outOfStock} />\n </span>\n )}\n {statusTags?.soldOut && (\n <span className={classes.statusTags}>\n <StatusTag {...statusTags.soldOut} />\n </span>\n )}\n {statusTags?.limited && (\n <span className={classes.statusTags}>\n <StatusTag {...statusTags.limited} />\n </span>\n )}\n </Typography>\n </Box>\n <Typography className={classes.cardDescription} paragraph>\n {loading ? <Skeleton /> : description}\n </Typography>\n {loading ? (\n <Skeleton>\n <MenuItemReactions likeCount={likeCount} reviewCount={reviewCount} />\n </Skeleton>\n ) : (\n <MenuItemReactions likeCount={likeCount} reviewCount={reviewCount} />\n )}\n {loading ? (\n <Skeleton style={{ flexGrow: 1 }} width={100} height={48} />\n ) : (\n <Box display=\"flex\" justifyContent=\"space-between\" alignItems=\"end\" flexGrow={1}>\n <MenuItemPrice price={price} available={available} />\n <MenuItemTags itemTags={itemTags} />\n </Box>\n )}\n </MenuItemInfo>\n {loading ? <Skeleton height={100} width={100} /> : <MenuItemImg image={image} />}\n </CardActionArea>\n </Card>\n )\n})\n\nMenuItem.displayName = 'MenuItem'\n"],"names":["React"],"mappings":"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"}
1
+ {"version":3,"file":"MenuItem.js","sources":["../../../../src/components/MenuItem/MenuItem.tsx"],"sourcesContent":["import { Box, Card, CardActionArea, Typography } from '@material-ui/core'\nimport React, { forwardRef } from 'react'\n\nimport { Skeleton } from '@material-ui/lab'\nimport classNames from 'classnames'\nimport { StatusTag } from '../StatusTag'\nimport { useMenuItemStyles } from './MenuItem.styles'\nimport { MenuItemImg } from './MenuItemImg'\nimport { MenuItemInfo } from './MenuItemInfo'\nimport { MenuItemPrice } from './MenuItemPrice'\nimport { MenuItemProps } from './MenuItemProps'\nimport { MenuItemReactions } from './MenuItemReactions'\nimport { MenuItemTags } from './MenuItemTags'\n\nexport const MenuItem = forwardRef((props: MenuItemProps, ref) => {\n const {\n ariaLabel,\n onClick,\n description,\n title,\n loading,\n statusTags,\n image,\n likeCount,\n reviewCount,\n price,\n available,\n itemTags,\n className,\n ...restProps\n } = props\n const classes = useMenuItemStyles(props)\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onClick(props.id, event)\n }\n\n return (\n <Card\n className={classNames(classes.card, className)}\n ref={ref}\n elevation={0}\n data-component-type=\"menu-item\"\n {...restProps}\n >\n <CardActionArea\n className={classes.cardActionArea}\n onClick={handleClick}\n disabled={loading}\n aria-label={ariaLabel}\n >\n <MenuItemInfo>\n {statusTags?.featured && <StatusTag {...statusTags.featured} />}\n <Box display=\"flex\" gridGap={8} alignItems=\"center\">\n <Typography component=\"h3\" className={classes.cardTitle}>\n {loading ? <Skeleton /> : title}\n {statusTags?.outOfStock && (\n <span className={classes.statusTags}>\n <StatusTag {...statusTags.outOfStock} />\n </span>\n )}\n {statusTags?.soldOut && (\n <span className={classes.statusTags}>\n <StatusTag {...statusTags.soldOut} />\n </span>\n )}\n {statusTags?.limited && (\n <span className={classes.statusTags}>\n <StatusTag {...statusTags.limited} />\n </span>\n )}\n </Typography>\n </Box>\n <Typography className={classes.cardDescription} paragraph>\n {loading ? <Skeleton /> : description}\n </Typography>\n {loading ? (\n <Skeleton>\n <MenuItemReactions likeCount={likeCount} reviewCount={reviewCount} />\n </Skeleton>\n ) : (\n <MenuItemReactions likeCount={likeCount} reviewCount={reviewCount} />\n )}\n {loading ? (\n <Skeleton style={{ flexGrow: 1 }} width={100} height={48} />\n ) : (\n <Box display=\"flex\" justifyContent=\"space-between\" alignItems=\"end\" flexGrow={1}>\n <MenuItemPrice price={price} available={available} />\n <MenuItemTags itemTags={itemTags} />\n </Box>\n )}\n </MenuItemInfo>\n {loading ? <Skeleton height={100} width={100} /> : <MenuItemImg image={image} />}\n </CardActionArea>\n </Card>\n )\n})\n\nMenuItem.displayName = 'MenuItem'\n"],"names":["React"],"mappings":"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"}
@@ -1,14 +1,14 @@
1
- import React__default, { forwardRef } from 'react';
2
1
  import { Box, Typography } from '@material-ui/core';
3
- import { useStyles } from './MenuSectionStyles.js';
4
2
  import { Skeleton } from '@material-ui/lab';
3
+ import React__default, { forwardRef } from 'react';
4
+ import { useStyles } from './MenuSectionStyles.js';
5
5
 
6
6
  const MenuSection = forwardRef((props, ref) => {
7
7
  const { name, children, loading, ...restProps } = props;
8
8
  const classes = useStyles();
9
9
  return (React__default.createElement(Box, { ...restProps, ref, component: 'section', "data-component-type": "menu-section", style: { scrollMarginTop: '70px' } },
10
10
  React__default.createElement(Box, { marginTop: 1, marginBottom: 4 },
11
- React__default.createElement(Typography, { component: "h1", className: classes.title }, loading ? React__default.createElement(Skeleton, null) : name)),
11
+ React__default.createElement(Typography, { component: "h2", className: classes.title, tabIndex: -1 }, loading ? React__default.createElement(Skeleton, null) : name)),
12
12
  children));
13
13
  });
14
14
  MenuSection.displayName = 'MenuSection';
@@ -1 +1 @@
1
- {"version":3,"file":"MenuSection.js","sources":["../../../../src/components/MenuSection/MenuSection.tsx"],"sourcesContent":["import React, { forwardRef } from 'react'\nimport { Box, Typography } from '@material-ui/core'\nimport { MenuSectionProps } from './MenuSectionProps'\nimport { useStyles } from './MenuSectionStyles'\nimport { Skeleton } from '@material-ui/lab'\n\nexport const MenuSection = forwardRef((props: MenuSectionProps, ref) => {\n const { name, children, loading, ...restProps } = props\n const classes = useStyles()\n return (\n <Box\n {...restProps}\n {...{ ref, component: 'section' }}\n data-component-type=\"menu-section\"\n style={{ scrollMarginTop: '70px' }}\n >\n <Box marginTop={1} marginBottom={4}>\n <Typography component=\"h1\" className={classes.title}>\n {loading ? <Skeleton /> : name}\n </Typography>\n </Box>\n {children}\n </Box>\n )\n})\n\nMenuSection.displayName = 'MenuSection'\n"],"names":["React"],"mappings":";;;;;AAMa,MAAA,WAAW,GAAG,UAAU,CAAC,CAAC,KAAuB,EAAE,GAAG,KAAI;AACrE,IAAA,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,GAAG,KAAK;AACvD,IAAA,MAAM,OAAO,GAAG,SAAS,EAAE;IAC3B,QACEA,6BAAC,GAAG,EAAA,EAAA,GACE,SAAS,EACP,GAAG,EAAE,SAAS,EAAE,SAAS,EACX,qBAAA,EAAA,cAAc,EAClC,KAAK,EAAE,EAAE,eAAe,EAAE,MAAM,EAAE,EAAA;QAElCA,cAAC,CAAA,aAAA,CAAA,GAAG,IAAC,SAAS,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAA;YAChCA,cAAC,CAAA,aAAA,CAAA,UAAU,EAAC,EAAA,SAAS,EAAC,IAAI,EAAC,SAAS,EAAE,OAAO,CAAC,KAAK,EAAA,EAChD,OAAO,GAAGA,cAAA,CAAA,aAAA,CAAC,QAAQ,EAAA,IAAA,CAAG,GAAG,IAAI,CACnB,CACT;QACL,QAAQ,CACL;AAEV,CAAC;AAED,WAAW,CAAC,WAAW,GAAG,aAAa;;;;"}
1
+ {"version":3,"file":"MenuSection.js","sources":["../../../../src/components/MenuSection/MenuSection.tsx"],"sourcesContent":["import { Box, Typography } from '@material-ui/core'\nimport { Skeleton } from '@material-ui/lab'\nimport React, { forwardRef } from 'react'\nimport { MenuSectionProps } from './MenuSectionProps'\nimport { useStyles } from './MenuSectionStyles'\n\nexport const MenuSection = forwardRef((props: MenuSectionProps, ref) => {\n const { name, children, loading, ...restProps } = props\n const classes = useStyles()\n return (\n <Box\n {...restProps}\n {...{ ref, component: 'section' }}\n data-component-type=\"menu-section\"\n style={{ scrollMarginTop: '70px' }}\n >\n <Box marginTop={1} marginBottom={4}>\n <Typography component=\"h2\" className={classes.title} tabIndex={-1}>\n {loading ? <Skeleton /> : name}\n </Typography>\n </Box>\n {children}\n </Box>\n )\n})\n\nMenuSection.displayName = 'MenuSection'\n"],"names":["React"],"mappings":";;;;;AAMa,MAAA,WAAW,GAAG,UAAU,CAAC,CAAC,KAAuB,EAAE,GAAG,KAAI;AACrE,IAAA,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,GAAG,KAAK;AACvD,IAAA,MAAM,OAAO,GAAG,SAAS,EAAE;IAC3B,QACEA,6BAAC,GAAG,EAAA,EAAA,GACE,SAAS,EACP,GAAG,EAAE,SAAS,EAAE,SAAS,EACX,qBAAA,EAAA,cAAc,EAClC,KAAK,EAAE,EAAE,eAAe,EAAE,MAAM,EAAE,EAAA;QAElCA,cAAC,CAAA,aAAA,CAAA,GAAG,IAAC,SAAS,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAA;AAChC,YAAAA,cAAA,CAAA,aAAA,CAAC,UAAU,EAAA,EAAC,SAAS,EAAC,IAAI,EAAC,SAAS,EAAE,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,EAC9D,EAAA,OAAO,GAAGA,cAAA,CAAA,aAAA,CAAC,QAAQ,EAAA,IAAA,CAAG,GAAG,IAAI,CACnB,CACT;QACL,QAAQ,CACL;AAEV,CAAC;AAED,WAAW,CAAC,WAAW,GAAG,aAAa;;;;"}
@@ -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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"}