@superdispatch/ui-lab 0.20.4 → 0.21.1

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.
@@ -163,7 +163,8 @@ function parseMargin(input) {
163
163
 
164
164
  var normalizeBorderRadius = /*#__PURE__*/createRuleNormalizer({
165
165
  none: 0,
166
- small: 4
166
+ small: 4,
167
+ medium: 8
167
168
  });
168
169
  var normalizeBorderWidth = /*#__PURE__*/createRuleNormalizer({
169
170
  none: 0,
@@ -1061,8 +1062,9 @@ MultilineText.displayName = 'MultilineText';
1061
1062
 
1062
1063
  var NavbarContext = /*#__PURE__*/react.createContext({
1063
1064
  isDrawerOpen: false,
1064
- isExpanded: false,
1065
- setIsExpanded: lodash.noop,
1065
+ isMenuExpanded: false,
1066
+ isNavbarExpanded: false,
1067
+ setMenuExpanded: lodash.noop,
1066
1068
  setDrawerOpen: lodash.noop
1067
1069
  });
1068
1070
  function useNavbarContext() {
@@ -1207,37 +1209,35 @@ function NavbarAccordion(_ref2) {
1207
1209
  } = _ref2;
1208
1210
  var uid = ui.useUID();
1209
1211
  var {
1210
- isExpanded: isMenuExpanded,
1211
- isDrawerOpen,
1212
- setDrawerOpen
1212
+ setDrawerOpen,
1213
+ isNavbarExpanded
1213
1214
  } = useNavbarContext();
1214
- var [isExpanded, setExpanded] = react.useState(false);
1215
+ var [isExpanded, setExpanded] = react.useState(true); // sync accordion state with Desktop menu state
1216
+
1215
1217
  react.useEffect(() => {
1216
- if (!isMenuExpanded) {
1217
- setExpanded(false);
1218
- }
1219
- }, [isMenuExpanded]);
1218
+ setExpanded(isNavbarExpanded);
1219
+ }, [isNavbarExpanded]);
1220
1220
  return /*#__PURE__*/jsxRuntime.jsxs(NavbarAccordionRoot, {
1221
- "aria-labelledby": uid,
1221
+ square: true,
1222
1222
  gutter: !!gutter,
1223
+ "aria-labelledby": uid,
1223
1224
  expanded: isExpanded,
1224
1225
  onClick: event => {
1225
- if (isMenuExpanded || isDrawerOpen) {
1226
+ _onClick === null || _onClick === void 0 ? void 0 : _onClick(event);
1227
+
1228
+ if (isNavbarExpanded) {
1226
1229
  setExpanded(!isExpanded);
1227
1230
  }
1228
-
1229
- _onClick(event);
1230
1231
  },
1231
- square: true,
1232
1232
  children: [/*#__PURE__*/jsxRuntime.jsxs(NavbarAccordionSummary, {
1233
1233
  "data-active": !isExpanded && items.some(item => item.active),
1234
- "data-expanded": isMenuExpanded || isDrawerOpen,
1234
+ "data-expanded": isNavbarExpanded,
1235
1235
  expandIcon: /*#__PURE__*/jsxRuntime.jsx(icons.ExpandMore, {}),
1236
1236
  children: [/*#__PURE__*/jsxRuntime.jsx(IconWrapper$2, {
1237
1237
  children: icon
1238
1238
  }), /*#__PURE__*/jsxRuntime.jsx(NavbarAccordionLabel, {
1239
1239
  id: uid,
1240
- "data-expanded": isMenuExpanded || isDrawerOpen,
1240
+ "data-expanded": isNavbarExpanded,
1241
1241
  children: label
1242
1242
  })]
1243
1243
  }), items.map(item => {
@@ -1248,7 +1248,7 @@ function NavbarAccordion(_ref2) {
1248
1248
  } = item;
1249
1249
  return /*#__PURE__*/react.createElement(NavbarItem, _objectSpread(_objectSpread({}, item), {}, {
1250
1250
  key: item.key,
1251
- ident: ident + 1,
1251
+ ident: ident,
1252
1252
  active: item.active,
1253
1253
  gutter: prev && prev.groupKey !== item.groupKey,
1254
1254
  onClick: event => {
@@ -1333,12 +1333,12 @@ function NavbarList(_ref5) {
1333
1333
  var platform = ui.useResponsiveValue('mobile', 'tablet', 'desktop');
1334
1334
  var isMobile = platform === 'mobile';
1335
1335
  var {
1336
- isExpanded,
1336
+ isMenuExpanded,
1337
1337
  isDrawerOpen,
1338
1338
  setDrawerOpen,
1339
- setIsExpanded
1339
+ setMenuExpanded
1340
1340
  } = useNavbarContext();
1341
- var isSidebarOpened = isMobile ? isDrawerOpen : isExpanded;
1341
+ var isSidebarOpened = isMobile ? isDrawerOpen : isMenuExpanded;
1342
1342
  var filteredItems = react.useMemo(() => items.filter(item => {
1343
1343
  return !item.hide && (isSidebarOpened || !!item.icon);
1344
1344
  }).map(item => _objectSpread(_objectSpread({}, item), {}, {
@@ -1350,13 +1350,13 @@ function NavbarList(_ref5) {
1350
1350
  children: [/*#__PURE__*/jsxRuntime.jsxs(Header, {
1351
1351
  children: [isSidebarOpened && header, !isMobile && /*#__PURE__*/jsxRuntime.jsx(ExpandIconButton, {
1352
1352
  disableRipple: true,
1353
- style: isExpanded ? {
1353
+ style: isMenuExpanded ? {
1354
1354
  paddingRight: 0
1355
1355
  } : {},
1356
1356
  onClick: () => {
1357
- setIsExpanded(!isExpanded);
1357
+ setMenuExpanded(!isMenuExpanded);
1358
1358
  },
1359
- children: isExpanded ? /*#__PURE__*/jsxRuntime.jsx(icons.MenuOpen, {}) : /*#__PURE__*/jsxRuntime.jsx(icons.Menu, {})
1359
+ children: isMenuExpanded ? /*#__PURE__*/jsxRuntime.jsx(icons.MenuOpen, {}) : /*#__PURE__*/jsxRuntime.jsx(icons.Menu, {})
1360
1360
  })]
1361
1361
  }), /*#__PURE__*/jsxRuntime.jsx(Content, {
1362
1362
  "aria-expanded": isSidebarOpened,
@@ -1417,14 +1417,15 @@ function Navbar(_ref) {
1417
1417
  var matches = core.useMediaQuery(theme.breakpoints.up('md'), {
1418
1418
  noSsr: true
1419
1419
  });
1420
- var [isExpanded, setIsExpanded] = react.useState(matches);
1420
+ var [isMenuExpanded, setMenuExpanded] = react.useState(matches);
1421
1421
  var hasBadge = hasExtraBadge || items.some(item => item.badge);
1422
1422
  var ctx = react.useMemo(() => ({
1423
1423
  isDrawerOpen,
1424
- isExpanded,
1425
- setIsExpanded,
1426
- setDrawerOpen
1427
- }), [isDrawerOpen, isExpanded, setIsExpanded, setDrawerOpen]);
1424
+ isMenuExpanded,
1425
+ setDrawerOpen,
1426
+ setMenuExpanded,
1427
+ isNavbarExpanded: isMenuExpanded || isDrawerOpen
1428
+ }), [isDrawerOpen, isMenuExpanded, setMenuExpanded, setDrawerOpen]);
1428
1429
  return /*#__PURE__*/jsxRuntime.jsx(NavbarContext.Provider, {
1429
1430
  value: ctx,
1430
1431
  children: /*#__PURE__*/jsxRuntime.jsxs("div", {
@@ -1480,37 +1481,36 @@ function NavbarAvatar(_ref) {
1480
1481
  props = _objectWithoutProperties(_ref, _excluded$7);
1481
1482
 
1482
1483
  var {
1483
- isExpanded,
1484
- isDrawerOpen
1484
+ isNavbarExpanded
1485
1485
  } = useNavbarContext();
1486
1486
 
1487
- if (isExpanded || isDrawerOpen) {
1488
- return /*#__PURE__*/jsxRuntime.jsxs(ui.Columns, {
1489
- space: "xsmall",
1490
- align: "center",
1491
- children: [/*#__PURE__*/jsxRuntime.jsx(ui.Column, {
1492
- width: "content",
1493
- children: /*#__PURE__*/jsxRuntime.jsx(core.Avatar, _objectSpread(_objectSpread({}, props), {}, {
1494
- children: children
1495
- }))
1496
- }), /*#__PURE__*/jsxRuntime.jsx(ui.Column, {
1497
- children: /*#__PURE__*/jsxRuntime.jsxs(ui.Stack, {
1498
- space: "none",
1499
- children: [/*#__PURE__*/jsxRuntime.jsx(StyledTypography, {
1500
- variant: "caption",
1501
- children: title
1502
- }), /*#__PURE__*/jsxRuntime.jsx(StyledTypography, {
1503
- variant: "caption",
1504
- children: subtitle
1505
- })]
1506
- })
1507
- })]
1508
- });
1487
+ if (!isNavbarExpanded) {
1488
+ return /*#__PURE__*/jsxRuntime.jsx(core.Avatar, _objectSpread(_objectSpread({}, props), {}, {
1489
+ children: children
1490
+ }));
1509
1491
  }
1510
1492
 
1511
- return /*#__PURE__*/jsxRuntime.jsx(core.Avatar, _objectSpread(_objectSpread({}, props), {}, {
1512
- children: children
1513
- }));
1493
+ return /*#__PURE__*/jsxRuntime.jsxs(ui.Columns, {
1494
+ space: "xsmall",
1495
+ align: "center",
1496
+ children: [/*#__PURE__*/jsxRuntime.jsx(ui.Column, {
1497
+ width: "content",
1498
+ children: /*#__PURE__*/jsxRuntime.jsx(core.Avatar, _objectSpread(_objectSpread({}, props), {}, {
1499
+ children: children
1500
+ }))
1501
+ }), /*#__PURE__*/jsxRuntime.jsx(ui.Column, {
1502
+ children: /*#__PURE__*/jsxRuntime.jsxs(ui.Stack, {
1503
+ space: "none",
1504
+ children: [/*#__PURE__*/jsxRuntime.jsx(StyledTypography, {
1505
+ variant: "caption",
1506
+ children: title
1507
+ }), /*#__PURE__*/jsxRuntime.jsx(StyledTypography, {
1508
+ variant: "caption",
1509
+ children: subtitle
1510
+ })]
1511
+ })
1512
+ })]
1513
+ });
1514
1514
  }
1515
1515
 
1516
1516
  var Divider = /*#__PURE__*/styled__default.div.withConfig({