@7shifts/sous-chef 4.3.0 → 4.4.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 (30) hide show
  1. package/dist/controls/ToolbarSelect/ToolbarSelect.d.ts +1 -1
  2. package/dist/forms/AsyncSelectField/AsyncSelectField.d.ts +1 -1
  3. package/dist/forms/CheckboxField/CheckboxField.d.ts +1 -1
  4. package/dist/forms/CurrencyField/CurrencyField.d.ts +2 -2
  5. package/dist/forms/DateField/DateField.d.ts +1 -1
  6. package/dist/forms/DateRangeField/DateRangeField.d.ts +1 -1
  7. package/dist/forms/MultiSelectField/MultiSelectField.d.ts +1 -1
  8. package/dist/forms/NumberField/NumberField.d.ts +1 -2
  9. package/dist/forms/PasswordField/PasswordField.d.ts +1 -1
  10. package/dist/forms/PercentageField/PercentageField.d.ts +1 -2
  11. package/dist/forms/PillSelectField/PillSelectField.d.ts +1 -1
  12. package/dist/forms/RadioGroupField/RadioGroupField.d.ts +1 -1
  13. package/dist/forms/SelectField/SelectField.d.ts +1 -1
  14. package/dist/forms/TextAreaField/TextAreaField.d.ts +1 -0
  15. package/dist/forms/TextField/TextField.d.ts +1 -0
  16. package/dist/forms/TimeField/TimeField.d.ts +2 -2
  17. package/dist/forms/TimeRangeField/TimeRangeField.d.ts +1 -0
  18. package/dist/forms/WeekField/WeekField.d.ts +1 -1
  19. package/dist/hooks/useScrollDetector.d.ts +1 -1
  20. package/dist/index.css +87 -3
  21. package/dist/index.css.map +1 -1
  22. package/dist/index.js +136 -82
  23. package/dist/index.js.map +1 -1
  24. package/dist/index.modern.js +141 -88
  25. package/dist/index.modern.js.map +1 -1
  26. package/dist/navigation/PrimaryNav/PrimaryNav.d.ts +3 -1
  27. package/dist/navigation/PrimaryNav/PrimaryNavContext.d.ts +3 -1
  28. package/dist/navigation/PrimaryNavItem/PrimaryNavItem.d.ts +3 -2
  29. package/dist/navigation/PrimaryNavSubItem/PrimaryNavSubItem.d.ts +3 -2
  30. package/package.json +2 -1
package/dist/index.js CHANGED
@@ -4673,7 +4673,7 @@ var IconMinus = React.forwardRef(function (_ref, ref) {
4673
4673
  viewBox: "0 0 24 24"
4674
4674
  }), React__default["default"].createElement("path", {
4675
4675
  fill: "currentColor",
4676
- d: "M19.714 10H4.286C3.576 10 3 10.597 3 11.333v1.334C3 13.403 3.576 14 4.286 14h15.428c.71 0 1.286-.597 1.286-1.333v-1.334c0-.736-.576-1.333-1.286-1.333Z"
4676
+ d: "M4.286 10.5C3.575 10.5 3 11.17 3 12s.575 1.5 1.286 1.5h15.428c.711 0 1.286-.67 1.286-1.5s-.575-1.5-1.286-1.5H4.286Z"
4677
4677
  }));
4678
4678
  }
4679
4679
  return React__default["default"].createElement("svg", _extends({
@@ -4686,7 +4686,7 @@ var IconMinus = React.forwardRef(function (_ref, ref) {
4686
4686
  viewBox: "0 0 24 24"
4687
4687
  }), React__default["default"].createElement("path", {
4688
4688
  fill: "currentColor",
4689
- d: "M20.625 10.875H3.375A.375.375 0 0 0 3 11.25v1.5c0 .207.168.375.375.375h17.25A.375.375 0 0 0 21 12.75v-1.5a.375.375 0 0 0-.375-.375Z"
4689
+ d: "M3.964 11C3.43 11 3 11.446 3 12s.43 1 .964 1h16.072c.534 0 .964-.446.964-1s-.43-1-.964-1H3.964Z"
4690
4690
  }));
4691
4691
  });
4692
4692
  IconMinus.displayName = 'IconMinus';
@@ -4979,7 +4979,7 @@ var IconPlus = React.forwardRef(function (_ref, ref) {
4979
4979
  viewBox: "0 0 24 24"
4980
4980
  }), React__default["default"].createElement("path", {
4981
4981
  fill: "currentColor",
4982
- d: "M22.287 9.429h-7.714V1.714C14.573.768 13.805 0 12.859 0h-1.715C10.198 0 9.43.768 9.43 1.714V9.43H1.716C.769 9.429 0 10.196 0 11.143v1.714c0 .947.768 1.714 1.715 1.714H9.43v7.715c0 .946.768 1.714 1.714 1.714h1.715c.946 0 1.714-.768 1.714-1.714V14.57h7.714c.947 0 1.715-.767 1.715-1.714v-1.714c0-.947-.768-1.714-1.715-1.714Z"
4982
+ d: "M13.43 3.422c0-.79-.638-1.429-1.428-1.429-.79 0-1.43.639-1.43 1.429v7.143H3.43a1.427 1.427 0 1 0 0 2.857h7.143v7.143c0 .79.638 1.428 1.428 1.428.79 0 1.429-.638 1.429-1.428v-7.143h7.143c.79 0 1.428-.639 1.428-1.429s-.638-1.428-1.428-1.428H13.43V3.422Z"
4983
4983
  }));
4984
4984
  }
4985
4985
  return React__default["default"].createElement("svg", _extends({
@@ -4992,9 +4992,7 @@ var IconPlus = React.forwardRef(function (_ref, ref) {
4992
4992
  viewBox: "0 0 24 24"
4993
4993
  }), React__default["default"].createElement("path", {
4994
4994
  fill: "currentColor",
4995
- fillRule: "evenodd",
4996
- d: "M23.607 10.875h-10.48V.403a.375.375 0 0 0-.376-.375h-1.5a.375.375 0 0 0-.375.375v10.472H.396a.375.375 0 0 0-.375.375v1.5c0 .207.168.375.375.375h10.48v10.458c0 .207.168.375.375.375h1.5a.375.375 0 0 0 .375-.375V13.125h10.48a.375.375 0 0 0 .376-.375v-1.5a.375.375 0 0 0-.375-.375Z",
4997
- clipRule: "evenodd"
4995
+ d: "M13.073 3.065c0-.594-.478-1.072-1.072-1.072-.593 0-1.071.478-1.071 1.072v7.857H3.073c-.594 0-1.072.477-1.072 1.071s.478 1.072 1.072 1.072h7.857v7.857c0 .593.478 1.071 1.072 1.071.593 0 1.07-.477 1.07-1.071v-7.857h7.858c.594 0 1.072-.478 1.072-1.072 0-.594-.478-1.071-1.072-1.071h-7.857V3.065Z"
4998
4996
  }));
4999
4997
  });
5000
4998
  IconPlus.displayName = 'IconPlus';
@@ -5430,10 +5428,10 @@ var IconTimes = React.forwardRef(function (_ref, ref) {
5430
5428
  }, props, {
5431
5429
  xmlns: "http://www.w3.org/2000/svg",
5432
5430
  fill: "none",
5433
- viewBox: "0 0 24 25"
5431
+ viewBox: "0 0 24 24"
5434
5432
  }), React__default["default"].createElement("path", {
5435
5433
  fill: "currentColor",
5436
- d: "M3.416.592a2.002 2.002 0 0 0-2.83 2.83L9.17 12 .592 20.584a2.002 2.002 0 0 0 2.83 2.83L12 14.83l8.584 8.578a2.002 2.002 0 0 0 2.83-2.83L14.83 12l8.578-8.584a2.002 2.002 0 0 0-2.83-2.83L12 9.17 3.416.592Z"
5434
+ d: "M5.562 3.444a1.502 1.502 0 0 0-2.123 2.123L9.877 12l-6.433 6.438a1.502 1.502 0 0 0 2.123 2.123L12 14.123l6.438 6.433a1.502 1.502 0 0 0 2.123-2.123L14.123 12l6.433-6.438a1.502 1.502 0 0 0-2.123-2.123L12 9.877 5.562 3.444Z"
5437
5435
  }));
5438
5436
  }
5439
5437
  return React__default["default"].createElement("svg", _extends({
@@ -5446,9 +5444,7 @@ var IconTimes = React.forwardRef(function (_ref, ref) {
5446
5444
  viewBox: "0 0 24 24"
5447
5445
  }), React__default["default"].createElement("path", {
5448
5446
  fill: "currentColor",
5449
- fillRule: "evenodd",
5450
- d: "m23.348 21.772-9.761-9.774 9.76-9.81a.375.375 0 0 0 0-.53L22.288.597a.375.375 0 0 0-.53 0l-9.761 9.81L2.23.597a.375.375 0 0 0-.53 0l-1.06 1.06a.375.375 0 0 0 0 .531l9.764 9.81L.64 21.772a.375.375 0 0 0 0 .53l1.061 1.06a.375.375 0 0 0 .53 0l9.765-9.773 9.76 9.774a.375.375 0 0 0 .531 0l1.06-1.061a.375.375 0 0 0 0-.53Z",
5451
- clipRule: "evenodd"
5447
+ d: "M3.33 4.92a1.125 1.125 0 0 1 1.59-1.59L12 10.41l7.08-7.08a1.125 1.125 0 0 1 1.59 1.59L13.59 12l7.08 7.08a1.125 1.125 0 0 1-1.59 1.59L12 13.59l-7.08 7.08a1.125 1.125 0 0 1-1.59-1.59L10.41 12 3.33 4.92Z"
5452
5448
  }));
5453
5449
  });
5454
5450
  IconTimes.displayName = 'IconTimes';
@@ -8012,17 +8008,10 @@ var IconSparkle = React.forwardRef(function (_ref, ref) {
8012
8008
  xmlns: "http://www.w3.org/2000/svg",
8013
8009
  fill: "none",
8014
8010
  viewBox: "0 0 24 24"
8015
- }), React__default["default"].createElement("g", {
8016
- clipPath: "url(#clip0_10467_577)"
8017
- }, React__default["default"].createElement("path", {
8011
+ }), React__default["default"].createElement("path", {
8018
8012
  fill: "currentColor",
8019
- d: "M15.208 4.335 18.001 5.5l1.164 2.793a.375.375 0 0 0 .672 0L21 5.5l2.793-1.165a.375.375 0 0 0 0-.67L21 2.5 19.837-.293a.376.376 0 0 0-.672 0L18.001 2.5l-2.793 1.164a.375.375 0 0 0 0 .671Zm8.586 14.33L21 17.5l-1.164-2.793a.376.376 0 0 0-.672 0L18.001 17.5l-2.793 1.164a.375.375 0 0 0 0 .672l2.793 1.164 1.164 2.793a.375.375 0 0 0 .672 0L21 20.5l2.793-1.164a.375.375 0 0 0 0-.672ZM18 11.482a.752.752 0 0 0-.414-.671L12.31 8.168 9.672 2.882c-.255-.51-1.087-.51-1.342 0L5.692 8.168.415 10.812a.75.75 0 0 0 0 1.343L5.692 14.8l2.638 5.286a.75.75 0 0 0 1.342 0l2.638-5.286 5.277-2.643a.753.753 0 0 0 .414-.673Z"
8020
- })), React__default["default"].createElement("defs", null, React__default["default"].createElement("clipPath", {
8021
- id: "clip0_10467_577"
8022
- }, React__default["default"].createElement("path", {
8023
- fill: "#fff",
8024
- d: "M0 0h24v24H0z"
8025
- }))));
8013
+ d: "M15.352 6.02a.546.546 0 0 0 0 1.019l2.648 1 .994 2.666c.08.212.281.354.506.354a.542.542 0 0 0 .506-.354L21 8.039l2.648-1a.546.546 0 0 0 0-1.02L21 5.02l-.994-2.665A.542.542 0 0 0 19.5 2a.542.542 0 0 0-.506.354L18 5.02l-2.648 1Zm-5.738-.562a.747.747 0 0 0-1.36 0L5.78 10.837.436 13.323a.754.754 0 0 0-.436.69c0 .296.169.56.436.683l5.348 2.487L8.25 22.56a.747.747 0 0 0 1.36 0l2.47-5.383 5.348-2.487a.752.752 0 0 0 .436-.684.752.752 0 0 0-.436-.684l-5.344-2.481-2.47-5.384Z"
8014
+ }));
8026
8015
  }
8027
8016
  return React__default["default"].createElement("svg", _extends({
8028
8017
  style: getIconStyles(styleProps),
@@ -8034,7 +8023,7 @@ var IconSparkle = React.forwardRef(function (_ref, ref) {
8034
8023
  viewBox: "0 0 24 24"
8035
8024
  }), React__default["default"].createElement("path", {
8036
8025
  fill: "currentColor",
8037
- d: "M20.25 1c.413 0 .75.337.75.75V4h2.25c.413 0 .75.338.75.75s-.337.75-.75.75H21v2.25c0 .412-.337.75-.75.75a.752.752 0 0 1-.75-.75V5.5h-2.25a.752.752 0 0 1-.75-.75c0-.412.337-.75.75-.75h2.25V1.75c0-.413.337-.75.75-.75Zm0 13.5c.413 0 .75.338.75.75v2.25h2.25c.413 0 .75.337.75.75s-.337.75-.75.75H21v2.25c0 .413-.337.75-.75.75a.752.752 0 0 1-.75-.75V19h-2.25a.752.752 0 0 1-.75-.75c0-.413.337-.75.75-.75h2.25v-2.25c0-.412.337-.75.75-.75ZM6.413 9.644l-3.872 1.79 3.871 1.786a1.5 1.5 0 0 1 .732.732l1.786 3.871 1.786-3.871a1.5 1.5 0 0 1 .73-.732l3.873-1.786-3.872-1.786a1.5 1.5 0 0 1-.731-.73L8.93 5.044 7.144 8.917a1.5 1.5 0 0 1-.732.731v-.004Zm-.629 4.94-5.348-2.47a.747.747 0 0 1 0-1.36l5.348-2.47L8.25 2.936a.747.747 0 0 1 1.36 0l2.47 5.348 5.348 2.466a.747.747 0 0 1 0 1.36l-5.344 2.474-2.47 5.344a.747.747 0 0 1-1.36 0l-2.47-5.344Z"
8026
+ d: "M20.25 2c.413 0 .75.337.75.75V5h2.25c.413 0 .75.338.75.75s-.337.75-.75.75H21v2.25c0 .412-.337.75-.75.75a.752.752 0 0 1-.75-.75V6.5h-2.25a.752.752 0 0 1-.75-.75c0-.412.337-.75.75-.75h2.25V2.75c0-.413.337-.75.75-.75ZM6.413 10.644l-3.872 1.79 3.871 1.786a1.5 1.5 0 0 1 .732.732l1.786 3.871 1.786-3.871a1.5 1.5 0 0 1 .73-.732l3.873-1.786-3.872-1.786a1.5 1.5 0 0 1-.731-.73L8.93 6.044 7.144 9.917a1.5 1.5 0 0 1-.732.731v-.004Zm-.629 4.94-5.348-2.47a.747.747 0 0 1 0-1.36l5.348-2.47L8.25 3.936a.747.747 0 0 1 1.36 0l2.47 5.348 5.348 2.466a.747.747 0 0 1 0 1.36l-5.344 2.474-2.47 5.344a.747.747 0 0 1-1.36 0l-2.47-5.344Z"
8038
8027
  }));
8039
8028
  });
8040
8029
  IconSparkle.displayName = 'IconSparkle';
@@ -12508,7 +12497,7 @@ var useCheckBoxFieldControllers = function useCheckBoxFieldControllers(_ref) {
12508
12497
  var styles$12 = {"check-box-field":"_Id4qm","check-box-field__caption":"_s9d-m","check-box-field__custom-input":"_kmvBP"};
12509
12498
 
12510
12499
  var _excluded$bj = ["name", "id", "checked", "onChange", "onBlur", "label", "caption", "error", "disabled", "testId"];
12511
- /** CheckboxField form element. */
12500
+ /** A simple check box with an option beside it. Allows the user to confirm a statement or enable an option with a simple boolean action. Use for things like agreeing to terms, or enabling one or more options in a list (where multiple selections are allowed). */
12512
12501
  var CheckboxField = function CheckboxField(_ref) {
12513
12502
  var name = _ref.name,
12514
12503
  inputId = _ref.id,
@@ -15250,7 +15239,7 @@ var useSelectField = function useSelectField(_ref) {
15250
15239
 
15251
15240
  var styles$B = {"select-field__suffix":"_vqC1M"};
15252
15241
 
15253
- /** Component to make possible choose from a predefined options. */
15242
+ /** Simple dropdown field where the user chooses one option from a predefined list. */
15254
15243
  var SelectField = function SelectField(props) {
15255
15244
  var _useSelectField = useSelectField(props),
15256
15245
  fieldProps = _useSelectField.fieldProps,
@@ -15266,7 +15255,7 @@ var SelectField = function SelectField(props) {
15266
15255
  };
15267
15256
 
15268
15257
  var _excluded$b6 = ["name", "value", "options", "onChange", "onBlur", "placeholder", "defaultValue", "menuShouldScrollIntoView", "disabled", "prefix", "testId", "creatableButton", "onCreate"];
15269
- /** Toolbar component to make a possible selection from predefined options. */
15258
+ /** ToolbarSelect is a compact dropdown filter for use in toolbars. It lets a user narrow page content or a paired component content by selecting from a predefined list of options. */
15270
15259
  var ToolbarSelect = function ToolbarSelect(_ref) {
15271
15260
  var name = _ref.name,
15272
15261
  value = _ref.value,
@@ -15821,6 +15810,7 @@ var useGrowTextAreaRef = function useGrowTextAreaRef(minHeight, maxHeight, autoG
15821
15810
  };
15822
15811
  };
15823
15812
 
15813
+ /** A basic open input field used to get text from the user, with options to add a prefix or suffix element if necessary. Accepts any characters, so do not use it if you want to limit the format of the input to numbers only. */
15824
15814
  var TextAreaField = function TextAreaField(_ref) {
15825
15815
  var _classnames;
15826
15816
  var name = _ref.name,
@@ -15933,6 +15923,7 @@ var TextFieldElement = function TextFieldElement(_ref, ref) {
15933
15923
  suffix: suffix
15934
15924
  }, React__default["default"].createElement("input", _extends({}, inputProps))));
15935
15925
  };
15926
+ /** A basic open input field used to get text from the user, with options to add a prefix or suffix element if necessary. Accepts any characters, so do not use it if you want to limit the format of the input to numbers only. */
15936
15927
  var TextField = React.forwardRef(TextFieldElement);
15937
15928
 
15938
15929
  var styles$r = {"pill-select-field":"_Yti6k","pill-select-field__creating-input":"_dw-VP","pill-select-field__custom-input":"_JXakU","pill-select-field__add-new-input":"_MsKVV","pill-select-field__creating-custom-input":"_ZxEwG","pill-select-field__removable-icon":"_Odw1V"};
@@ -16049,7 +16040,7 @@ var CreatableOption = function CreatableOption(_ref) {
16049
16040
  }, __('enterOption')), !!newOptionLabel && newOptionLabel)));
16050
16041
  };
16051
16042
 
16052
- /** PillSelectField form element. */
16043
+ /** A field where the user can select one or more from a vertical line of pills. Can also be made fully reactive allowing users to add and delete their own options. Use this to select from a more visual list with a limited number of options, like selecting the day of the week. */
16053
16044
  var PillSelectField = function PillSelectField(_ref) {
16054
16045
  var name = _ref.name,
16055
16046
  inputId = _ref.id,
@@ -16363,7 +16354,7 @@ var BoxOptions = function BoxOptions(_ref) {
16363
16354
  }));
16364
16355
  };
16365
16356
 
16366
- /** RadioGroupField form element. */
16357
+ /** A list of radio options appearing either as an input or box. Use when the user can only select one option from a visual list and the user needs to be able to see all the options to make an informed decision. */
16367
16358
  var RadioGroupField = function RadioGroupField(_ref) {
16368
16359
  var name = _ref.name,
16369
16360
  value = _ref.value,
@@ -16464,7 +16455,7 @@ var groupCriterias = function groupCriterias(criterias) {
16464
16455
  return groupedCriterias;
16465
16456
  };
16466
16457
 
16467
- /** It allows show and hide the password as well as displaying the criteria. */
16458
+ /** A field used for passwords. It obfuscates the input by default, but has the option to reveal the input. Can also include required password criteria. */
16468
16459
  var PasswordField = function PasswordField(_ref) {
16469
16460
  var _classnames, _classNames;
16470
16461
  var name = _ref.name,
@@ -16534,7 +16525,7 @@ var PasswordField = function PasswordField(_ref) {
16534
16525
  }))));
16535
16526
  };
16536
16527
 
16537
- /** Component to make possible choose from a predefined options. */
16528
+ /** A dropdown style field that lets you select and input more than one option within the field. Uses removable chips to represent selected items. */
16538
16529
  var MultiSelectField = function MultiSelectField(_ref) {
16539
16530
  var name = _ref.name,
16540
16531
  inputId = _ref.id,
@@ -16655,7 +16646,7 @@ var CustomList = function CustomList(_ref) {
16655
16646
 
16656
16647
  var _excluded$b3 = ["loadOptions"];
16657
16648
  /**
16658
- * Component to make possible choose from async options. It looks exactly as the [SelectField](./?path=/docs/forms-selectfield--default) but, this one handles asynchronous options.
16649
+ * A variation of select field that loads a dynamic list of options from a source rather than a fixed set of options. Use when you need to select from a dynamic list that can change such as roles, employees, locations, etc.
16659
16650
  * Instead of passing a `options` props, this component requires a `loadOptions` prop.
16660
16651
  * */
16661
16652
  var AsyncSelectField = function AsyncSelectField(_ref) {
@@ -16778,7 +16769,7 @@ var useDateFieldControllers = function useDateFieldControllers(_ref) {
16778
16769
 
16779
16770
  var inputStyles = {"text-field":"_t-FNM","date-field":"_7xqY4","text-field--invalid":"_tANT5","date-field--invalid":"_oq75Z","text-field--prefixed":"_rlqRc","date-field--prefixed":"_fXM80","text-field--suffixed":"_uSKjx","date-field--suffixed":"_eEMy6"};
16780
16771
 
16781
- /** DateField form element. */
16772
+ /** A dropdown style field for selecting a single specific date. It will load a calendar widget when activated allowing the user to find and pick a day. */
16782
16773
  var DateField = function DateField(_ref) {
16783
16774
  var _classnames;
16784
16775
  var name = _ref.name,
@@ -17199,7 +17190,7 @@ var ToDateElement = function ToDateElement(_ref, ref) {
17199
17190
  };
17200
17191
  var ToDate = React.forwardRef(ToDateElement);
17201
17192
 
17202
- /** DateRangeField form element. */
17193
+ /** A dropdown style field with 2 inputs. It allows the user to select a specific start date and end date separately to create a range of dates. . */
17203
17194
  var DateRangeField = function DateRangeField(_ref) {
17204
17195
  var _classnames, _disabledDays$start, _disabledDays$end;
17205
17196
  var name = _ref.name,
@@ -17296,7 +17287,7 @@ var DateRangeField = function DateRangeField(_ref) {
17296
17287
  })));
17297
17288
  };
17298
17289
 
17299
- /** WeekField form element. */
17290
+ /** A special dropdown style field used to select a single week from a calendar widget. Selections must always be 7 consecutive days, but you may customize the day of the week the selectable range starts on. */
17300
17291
  var WeekField = function WeekField(_ref) {
17301
17292
  var _classnames;
17302
17293
  var name = _ref.name,
@@ -17601,9 +17592,9 @@ var TimeFieldElement = function TimeFieldElement(_ref, forwardedRef) {
17601
17592
  // exporting TimeField with all props for use in TimeRangeField
17602
17593
  var TimeRangeSelector = React.forwardRef(TimeFieldElement);
17603
17594
  /**
17604
- * `TimeField` are like `TextField` but it auto-format the value when the user leaves the field.
17595
+ * A special field design for selecting a specific time of the day. Users can choose from a dropdown of preset time intervals, or type directly into the field. When the user leaves the field, the input is automatically formatted into either AM/PM time or 24h time.
17605
17596
  *
17606
- * At the end, it is just a string formatted nicely. **You are in charge of validating the value and parsing it back to a value that you can use on your application**.
17597
+ * **You are in charge of validating the value and parsing it back to a value that you can use on your application**.
17607
17598
  */
17608
17599
  var TimeField = React.forwardRef(TimeFieldElement);
17609
17600
 
@@ -17668,6 +17659,7 @@ var TimeRangeStart = function TimeRangeStart(_ref) {
17668
17659
  });
17669
17660
  };
17670
17661
 
17662
+ /** A special input field for selecting a time range. Comprised of 2 individual time fields, the user selects a start time and an end time individually to. */
17671
17663
  var TimeRangeField = function TimeRangeField(_ref) {
17672
17664
  var _classnames;
17673
17665
  var name = _ref.name,
@@ -17835,9 +17827,9 @@ var CurrencyFieldElement = function CurrencyFieldElement(_ref, forwardedRef) {
17835
17827
  }, formatThousandsSparator(inputProps.value.toString() || ''))));
17836
17828
  };
17837
17829
  /**
17838
- * `CurrencyField` is like `TextField` but it auto-format the value when the user leaves the field.
17830
+ * A variation of a TextField, but it only accepts numbers, and will auto format the number into a currency format when the user leaves the field. Use anytime the user must enter a currency value and nothing else.
17839
17831
  *
17840
- * At the end, it is just a string formatted nicely. **You are in charge of validating the value and parsing it back to a value that you can use on your application**.
17832
+ * **You are in charge of validating the value and parsing it back to a value that you can use on your application**.
17841
17833
  */
17842
17834
  var CurrencyField = React.forwardRef(CurrencyFieldElement);
17843
17835
 
@@ -17921,8 +17913,7 @@ var NumberFieldElement = function NumberFieldElement(_ref, ref) {
17921
17913
  }))));
17922
17914
  };
17923
17915
  /**
17924
- * `NumberField` is an extended `TextField` input with validation and formatting in place to properly display number values.
17925
- * In its default state it only allows whole numbers, but it can be configured to allow decimals and negative values.
17916
+ * A special text input field that only accepts numbers. It has validation and formatting in place to properly display number values. In its default state it only allows whole numbers, but it can be configured to allow decimals and negative values.
17926
17917
  */
17927
17918
  var NumberField = React.forwardRef(NumberFieldElement);
17928
17919
 
@@ -17938,8 +17929,7 @@ var PercentageElement = function PercentageElement(_ref, ref) {
17938
17929
  }));
17939
17930
  };
17940
17931
  /**
17941
- * `PercentageField` is an extended `TextField` input with validation and formatting in place to properly display percentage values.
17942
- * In its default state it only allows integers between 0 and 100, but it can be configured to allow decimals and negative values.
17932
+ * A special text input field that only accepts numbers. Comes with validation and formatting in place to properly display percentage values. In its default state it only allows integers between 0 and 100, but it can be configured to allow decimals and negative values.
17943
17933
  */
17944
17934
  var PercentageField = React.forwardRef(PercentageElement);
17945
17935
 
@@ -62466,7 +62456,7 @@ var SevenShiftsLogo = function SevenShiftsLogo() {
62466
62456
  }));
62467
62457
  };
62468
62458
 
62469
- var styles$9 = {"primary-nav-header":"_6bVLs","primary-nav-header--collapsed":"_AYwpG","primary-nav-header--with-shadow":"_IpBk1"};
62459
+ var styles$9 = {"primary-nav-header":"_6bVLs","primary-nav-header--collapsed":"_AYwpG","primary-nav-header--with-shadow":"_IpBk1","primary-nav-header__toggle":"_lK6PV"};
62470
62460
 
62471
62461
  var SevenShiftsShortLogo = function SevenShiftsShortLogo() {
62472
62462
  return React__default["default"].createElement("svg", {
@@ -62508,6 +62498,9 @@ function PrimaryNavContextProvider(_ref) {
62508
62498
  var _useState = React.useState(false),
62509
62499
  isHoveringNav = _useState[0],
62510
62500
  setIsHoveringNav = _useState[1];
62501
+ var _useState2 = React.useState(false),
62502
+ isFocusWithin = _useState2[0],
62503
+ setIsFocusWithin = _useState2[1];
62511
62504
  var _useLocalStorage = useLocalStorage('vertical-nav-is-expanded', true),
62512
62505
  isInternalNavExpanded = _useLocalStorage[0],
62513
62506
  setIsInternalNavExpanded = _useLocalStorage[1];
@@ -62519,10 +62512,12 @@ function PrimaryNavContextProvider(_ref) {
62519
62512
  setIsNavExpanded: setIsInternalNavExpanded,
62520
62513
  isHoveringNav: isHoveringNav,
62521
62514
  setIsHoveringNav: setIsHoveringNav,
62522
- isOpen: isNavExpanded || isHoveringNav,
62515
+ isFocusWithin: isFocusWithin,
62516
+ setIsFocusWithin: setIsFocusWithin,
62517
+ isOpen: isNavExpanded || isHoveringNav || isFocusWithin,
62523
62518
  contentRef: contentRef
62524
62519
  };
62525
- }, [isNavExpanded, setIsInternalNavExpanded, isHoveringNav, setIsHoveringNav]);
62520
+ }, [isNavExpanded, setIsInternalNavExpanded, isHoveringNav, setIsHoveringNav, isFocusWithin, setIsFocusWithin]);
62526
62521
  return React__default["default"].createElement(PrimaryNavContext.Provider, {
62527
62522
  value: contextValues
62528
62523
  }, children);
@@ -62573,7 +62568,8 @@ var PrimaryNavHeader = function PrimaryNavHeader(_ref) {
62573
62568
  setIsNavExpanded = _usePrimaryNavContext.setIsNavExpanded,
62574
62569
  isNavExpanded = _usePrimaryNavContext.isNavExpanded,
62575
62570
  contentRef = _usePrimaryNavContext.contentRef,
62576
- setIsHoveringNav = _usePrimaryNavContext.setIsHoveringNav;
62571
+ setIsHoveringNav = _usePrimaryNavContext.setIsHoveringNav,
62572
+ setIsFocusWithin = _usePrimaryNavContext.setIsFocusWithin;
62577
62573
  var _useScrollDetector = useScrollDetector(contentRef),
62578
62574
  isScrolled = _useScrollDetector.isScrolled;
62579
62575
  var CollapsedLogo = function CollapsedLogo() {
@@ -62587,13 +62583,17 @@ var PrimaryNavHeader = function PrimaryNavHeader(_ref) {
62587
62583
  }, React__default["default"].createElement(Inline, {
62588
62584
  justifyContent: "space-between",
62589
62585
  alignItems: "center"
62590
- }, isOpen ? React__default["default"].createElement(ExpandedLogo, null) : React__default["default"].createElement(CollapsedLogo, null), isOpen && React__default["default"].createElement(Button, {
62591
- theme: "link-icon",
62586
+ }, isOpen ? React__default["default"].createElement(ExpandedLogo, null) : React__default["default"].createElement(CollapsedLogo, null), isOpen && React__default["default"].createElement("button", {
62587
+ type: "button",
62588
+ className: styles$9['primary-nav-header__toggle'],
62589
+ "aria-label": isNavExpanded ? 'Collapse navigation' : 'Expand navigation',
62590
+ "aria-expanded": isNavExpanded,
62592
62591
  onClick: function onClick() {
62593
62592
  var nextExpanded = !isNavExpanded;
62594
62593
  setIsNavExpanded(nextExpanded);
62595
62594
  if (!nextExpanded) {
62596
62595
  setIsHoveringNav(false);
62596
+ setIsFocusWithin(false);
62597
62597
  }
62598
62598
  if (onToggleExpand) {
62599
62599
  onToggleExpand(nextExpanded ? 'expanded' : 'collapsed');
@@ -62610,7 +62610,8 @@ var PrimaryNav = function PrimaryNav(_ref) {
62610
62610
  onToggleExpand = _ref.onToggleExpand,
62611
62611
  footer = _ref.footer,
62612
62612
  shortLogo = _ref.shortLogo,
62613
- longLogo = _ref.longLogo;
62613
+ longLogo = _ref.longLogo,
62614
+ ariaLabel = _ref.ariaLabel;
62614
62615
  return React__default["default"].createElement(PrimaryNavContextProvider, {
62615
62616
  isExpanded: isExpanded
62616
62617
  }, React__default["default"].createElement(PrimaryNavContent, {
@@ -62618,7 +62619,8 @@ var PrimaryNav = function PrimaryNav(_ref) {
62618
62619
  onToggleExpand: onToggleExpand,
62619
62620
  footer: footer,
62620
62621
  shortLogo: shortLogo,
62621
- longLogo: longLogo
62622
+ longLogo: longLogo,
62623
+ ariaLabel: ariaLabel
62622
62624
  }, children));
62623
62625
  };
62624
62626
  var PrimaryNavContent = function PrimaryNavContent(_ref2) {
@@ -62627,32 +62629,55 @@ var PrimaryNavContent = function PrimaryNavContent(_ref2) {
62627
62629
  onToggleExpand = _ref2.onToggleExpand,
62628
62630
  footer = _ref2.footer,
62629
62631
  shortLogo = _ref2.shortLogo,
62630
- longLogo = _ref2.longLogo;
62632
+ longLogo = _ref2.longLogo,
62633
+ _ref2$ariaLabel = _ref2.ariaLabel,
62634
+ ariaLabel = _ref2$ariaLabel === void 0 ? 'Main' : _ref2$ariaLabel;
62631
62635
  var _usePrimaryNavContext = usePrimaryNavContext(),
62632
62636
  setIsHoveringNav = _usePrimaryNavContext.setIsHoveringNav,
62637
+ setIsFocusWithin = _usePrimaryNavContext.setIsFocusWithin,
62633
62638
  isOpen = _usePrimaryNavContext.isOpen,
62634
62639
  contentRef = _usePrimaryNavContext.contentRef;
62635
62640
  var _useProviderConfig = useProviderConfig(),
62636
62641
  theme = _useProviderConfig.theme;
62637
- return React__default["default"].createElement("div", {
62642
+ return React__default["default"].createElement("nav", {
62643
+ "aria-label": ariaLabel,
62638
62644
  className: classnames__default["default"](styles$8['primary-nav'], (_classNames = {}, _classNames[styles$8['primary-nav--dark']] = theme === 'dark', _classNames[styles$8['primary-nav--collapsed']] = !isOpen, _classNames[styles$8['primary-nav--expanded']] = isOpen, _classNames)),
62639
62645
  onMouseEnter: function onMouseEnter() {
62640
62646
  return setIsHoveringNav(true);
62641
62647
  },
62642
62648
  onMouseLeave: function onMouseLeave() {
62643
62649
  return setIsHoveringNav(false);
62650
+ },
62651
+ onFocus: function onFocus(e) {
62652
+ // Only expand on keyboard focus, not on mouse-driven focus
62653
+ // (e.g. clicking an item). :focus-visible reflects the
62654
+ // browser's own heuristic for "focus should be visible".
62655
+ var isKeyboardFocus = false;
62656
+ try {
62657
+ isKeyboardFocus = e.target instanceof Element && e.target.matches(':focus-visible');
62658
+ } catch (_unused) {
62659
+ // :focus-visible not supported in this environment
62660
+ }
62661
+ if (isKeyboardFocus) {
62662
+ setIsFocusWithin(true);
62663
+ }
62664
+ },
62665
+ onBlur: function onBlur(e) {
62666
+ if (!e.currentTarget.contains(e.relatedTarget)) {
62667
+ setIsFocusWithin(false);
62668
+ }
62644
62669
  }
62645
62670
  }, React__default["default"].createElement(PrimaryNavHeader, {
62646
62671
  onToggleExpand: onToggleExpand,
62647
62672
  shortLogo: shortLogo,
62648
62673
  longLogo: longLogo
62649
- }), React__default["default"].createElement("div", {
62674
+ }), React__default["default"].createElement("ul", {
62650
62675
  ref: contentRef,
62651
62676
  className: styles$8['primary-nav__content']
62652
62677
  }, children), footer);
62653
62678
  };
62654
62679
 
62655
- var styles$7 = {"primary-nav-item":"_mWULf","primary-nav-item__content":"_GkDWn","primary-nav-item__icon":"_3LYJx","primary-nav-item__label":"_oz5bt","primary-nav-item__small-badge":"_yCxLl","fade-in":"_aMyIG","primary-nav-item__sub-items":"_SFpch","primary-nav-item--active":"_zfy2L","primary-nav-item--active-subitem":"_els3B","primary-nav-item--has-active-sub-item":"_-RLI8"};
62680
+ var styles$7 = {"primary-nav-item":"_mWULf","primary-nav-item__link":"_PiWFg","primary-nav-item__content":"_GkDWn","primary-nav-item__icon":"_3LYJx","primary-nav-item__label":"_oz5bt","primary-nav-item__label--hidden":"_MFqwx","primary-nav-item__small-badge":"_yCxLl","fade-in":"_aMyIG","primary-nav-item__sub-items":"_SFpch","primary-nav-item--active":"_zfy2L","primary-nav-item--active-subitem":"_els3B","primary-nav-item--has-active-sub-item":"_-RLI8"};
62656
62681
 
62657
62682
  var styles$6 = {"primary-nav-item-badge__small":"_S2i4R","fade-in":"_D9NA6"};
62658
62683
 
@@ -62685,15 +62710,16 @@ var PrimaryNavItemBadge = function PrimaryNavItemBadge(_ref) {
62685
62710
  return null;
62686
62711
  };
62687
62712
 
62688
- var _excluded$1 = ["children", "icon", "isActive", "label", "badge", "onClick"];
62713
+ var _excluded$1 = ["children", "icon", "isActive", "label", "badge", "onClick", "href"];
62689
62714
  var PrimaryNavItem = function PrimaryNavItem(_ref) {
62690
- var _classNames;
62715
+ var _classNames, _classNames2;
62691
62716
  var children = _ref.children,
62692
62717
  icon = _ref.icon,
62693
62718
  isActive = _ref.isActive,
62694
62719
  label = _ref.label,
62695
62720
  badge = _ref.badge,
62696
62721
  onClick = _ref.onClick,
62722
+ href = _ref.href,
62697
62723
  rest = _objectWithoutPropertiesLoose(_ref, _excluded$1);
62698
62724
  var _getDataProps = getDataProps(rest),
62699
62725
  dataProps = _getDataProps.dataProps;
@@ -62704,7 +62730,7 @@ var PrimaryNavItem = function PrimaryNavItem(_ref) {
62704
62730
  isTruncated = _useState[0],
62705
62731
  setIsTruncated = _useState[1];
62706
62732
  var handleLabelMouseEnter = function handleLabelMouseEnter() {
62707
- if (labelRef.current) {
62733
+ if (isOpen && labelRef.current) {
62708
62734
  setIsTruncated(labelRef.current.scrollWidth > labelRef.current.clientWidth);
62709
62735
  }
62710
62736
  };
@@ -62722,38 +62748,50 @@ var PrimaryNavItem = function PrimaryNavItem(_ref) {
62722
62748
  }
62723
62749
  return sum;
62724
62750
  }, 0);
62725
- return React__default["default"].createElement("div", {
62726
- className: classnames__default["default"](styles$7['primary-nav-item'], (_classNames = {}, _classNames[styles$7['primary-nav-item--active']] = isActive, _classNames[styles$7['primary-nav-item--active-subitem']] = hasActiveSubItem, _classNames[styles$7['primary-nav-item--has-active-sub-item']] = hasActiveSubItem, _classNames))
62727
- }, React__default["default"].createElement("button", _extends({
62728
- onClick: onClick
62729
- }, dataProps), React__default["default"].createElement("div", {
62751
+ var innerContent = React__default["default"].createElement("div", {
62730
62752
  className: styles$7['primary-nav-item__content']
62731
62753
  }, React__default["default"].createElement("div", {
62732
- className: styles$7['primary-nav-item__icon']
62733
- }, updatedIcon), isOpen && React__default["default"].createElement("span", {
62754
+ className: styles$7['primary-nav-item__icon'],
62755
+ "aria-hidden": "true"
62756
+ }, updatedIcon), React__default["default"].createElement("span", {
62734
62757
  ref: labelRef,
62735
- className: styles$7['primary-nav-item__label'],
62736
- title: isTruncated ? label : undefined,
62758
+ className: classnames__default["default"](styles$7['primary-nav-item__label'], (_classNames = {}, _classNames[styles$7['primary-nav-item__label--hidden']] = !isOpen, _classNames)),
62759
+ title: isOpen && isTruncated ? label : undefined,
62737
62760
  onMouseEnter: handleLabelMouseEnter
62738
62761
  }, label), React__default["default"].createElement(PrimaryNavItemBadge, {
62739
62762
  badge: badge,
62740
62763
  hasSubItems: hasSubItems,
62741
62764
  hasActiveSubItem: hasActiveSubItem,
62742
62765
  sumOfSubItemsBadges: sumOfSubItemsBadges
62743
- }))), children && hasActiveSubItem && React__default["default"].createElement("div", {
62766
+ }));
62767
+ var ariaCurrent = isActive ? 'page' : undefined;
62768
+ return React__default["default"].createElement("li", {
62769
+ className: classnames__default["default"](styles$7['primary-nav-item'], (_classNames2 = {}, _classNames2[styles$7['primary-nav-item--active']] = isActive, _classNames2[styles$7['primary-nav-item--active-subitem']] = hasActiveSubItem, _classNames2[styles$7['primary-nav-item--has-active-sub-item']] = hasActiveSubItem, _classNames2))
62770
+ }, href ? React__default["default"].createElement(reactRouterDom.Link, _extends({
62771
+ className: styles$7['primary-nav-item__link'],
62772
+ onClick: onClick,
62773
+ to: href,
62774
+ "aria-current": ariaCurrent
62775
+ }, dataProps), innerContent) : React__default["default"].createElement("button", _extends({
62776
+ type: "button",
62777
+ className: styles$7['primary-nav-item__link'],
62778
+ onClick: onClick,
62779
+ "aria-current": ariaCurrent
62780
+ }, dataProps), innerContent), hasSubItems && hasActiveSubItem && React__default["default"].createElement("ul", {
62744
62781
  className: styles$7['primary-nav-item__sub-items']
62745
62782
  }, children));
62746
62783
  };
62747
62784
 
62748
- var styles$5 = {"primary-nav-sub-item":"_kWT6L","primary-nav-sub-item__content":"_c3utS","primary-nav-sub-item__content--collapsed":"_3IImx","primary-nav-sub-item__content--paywalled":"_WwagZ","primary-nav-sub-item__icon":"_uDuDj","primary-nav-sub-item__label":"_Kg1TF","primary-nav-sub-item__circle":"_uMbkq","fade-in":"_eIHTO","primary-nav-sub-item--active":"_nkaWg"};
62785
+ var styles$5 = {"primary-nav-sub-item":"_kWT6L","primary-nav-sub-item__link":"_KXtsV","primary-nav-sub-item__label--hidden":"_nTZxa","primary-nav-sub-item__content":"_c3utS","primary-nav-sub-item__content--collapsed":"_3IImx","primary-nav-sub-item__content--paywalled":"_WwagZ","primary-nav-sub-item__icon":"_uDuDj","primary-nav-sub-item__label":"_Kg1TF","primary-nav-sub-item__circle":"_uMbkq","fade-in":"_eIHTO","primary-nav-sub-item--active":"_nkaWg"};
62749
62786
 
62750
- var _excluded = ["children", "isActive", "badge", "onClick", "isPaywalled"];
62787
+ var _excluded = ["children", "isActive", "badge", "onClick", "href", "isPaywalled"];
62751
62788
  var PrimaryNavSubItem = function PrimaryNavSubItem(_ref) {
62752
62789
  var _classNames, _classNames2;
62753
62790
  var children = _ref.children,
62754
62791
  isActive = _ref.isActive,
62755
62792
  badge = _ref.badge,
62756
62793
  onClick = _ref.onClick,
62794
+ href = _ref.href,
62757
62795
  isPaywalled = _ref.isPaywalled,
62758
62796
  rest = _objectWithoutPropertiesLoose(_ref, _excluded);
62759
62797
  var _usePrimaryNavContext = usePrimaryNavContext(),
@@ -62765,20 +62803,20 @@ var PrimaryNavSubItem = function PrimaryNavSubItem(_ref) {
62765
62803
  isTruncated = _useState[0],
62766
62804
  setIsTruncated = _useState[1];
62767
62805
  var handleLabelMouseEnter = function handleLabelMouseEnter() {
62768
- if (labelRef.current) {
62806
+ if (isOpen && labelRef.current) {
62769
62807
  setIsTruncated(labelRef.current.scrollWidth > labelRef.current.clientWidth);
62770
62808
  }
62771
62809
  };
62772
- return React__default["default"].createElement("button", _extends({
62773
- onClick: onClick
62774
- }, dataProps), React__default["default"].createElement("div", {
62775
- className: classnames__default["default"](styles$5['primary-nav-sub-item'], (_classNames = {}, _classNames[styles$5['primary-nav-sub-item--active']] = isActive, _classNames))
62776
- }, React__default["default"].createElement("div", {
62777
- className: classnames__default["default"](styles$5['primary-nav-sub-item__content'], (_classNames2 = {}, _classNames2[styles$5['primary-nav-sub-item__content--collapsed']] = !isOpen, _classNames2[styles$5['primary-nav-sub-item__content--paywalled']] = isPaywalled && isOpen, _classNames2))
62778
- }, !isOpen ? React__default["default"].createElement("div", {
62779
- className: styles$5['primary-nav-sub-item__circle']
62780
- }) : React__default["default"].createElement(React.Fragment, null, isPaywalled && React__default["default"].createElement("div", {
62781
- className: styles$5['primary-nav-sub-item__icon']
62810
+ var innerContent = React__default["default"].createElement("div", {
62811
+ className: classnames__default["default"](styles$5['primary-nav-sub-item__content'], (_classNames = {}, _classNames[styles$5['primary-nav-sub-item__content--collapsed']] = !isOpen, _classNames[styles$5['primary-nav-sub-item__content--paywalled']] = isPaywalled && isOpen, _classNames))
62812
+ }, !isOpen ? React__default["default"].createElement(React.Fragment, null, React__default["default"].createElement("div", {
62813
+ className: styles$5['primary-nav-sub-item__circle'],
62814
+ "aria-hidden": "true"
62815
+ }), React__default["default"].createElement("span", {
62816
+ className: styles$5['primary-nav-sub-item__label--hidden']
62817
+ }, children)) : React__default["default"].createElement(React.Fragment, null, isPaywalled && React__default["default"].createElement("div", {
62818
+ className: styles$5['primary-nav-sub-item__icon'],
62819
+ "aria-hidden": "true"
62782
62820
  }, React__default["default"].createElement(IconAward, {
62783
62821
  size: "medium",
62784
62822
  color: COLORS['upsell-color']
@@ -62789,13 +62827,29 @@ var PrimaryNavSubItem = function PrimaryNavSubItem(_ref) {
62789
62827
  title: isTruncated ? children : undefined
62790
62828
  }, children)), !!badge && isOpen && React__default["default"].createElement("div", {
62791
62829
  className: styles$5['primary-nav-sub-item__badge']
62792
- }, typeof badge === 'number' ? React__default["default"].createElement(Badge, null, badge > 99 ? '99+' : badge) : React__default["default"].createElement(Chip, null, badge)))));
62830
+ }, typeof badge === 'number' ? React__default["default"].createElement(Badge, null, badge > 99 ? '99+' : badge) : React__default["default"].createElement(Chip, null, badge)));
62831
+ var ariaCurrent = isActive ? 'page' : undefined;
62832
+ return React__default["default"].createElement("li", {
62833
+ className: classnames__default["default"](styles$5['primary-nav-sub-item'], (_classNames2 = {}, _classNames2[styles$5['primary-nav-sub-item--active']] = isActive, _classNames2))
62834
+ }, href ? React__default["default"].createElement(reactRouterDom.Link, _extends({
62835
+ className: styles$5['primary-nav-sub-item__link'],
62836
+ onClick: onClick,
62837
+ to: href,
62838
+ "aria-current": ariaCurrent
62839
+ }, dataProps), innerContent) : React__default["default"].createElement("button", _extends({
62840
+ type: "button",
62841
+ className: styles$5['primary-nav-sub-item__link'],
62842
+ onClick: onClick,
62843
+ "aria-current": ariaCurrent
62844
+ }, dataProps), innerContent));
62793
62845
  };
62794
62846
 
62795
62847
  var styles$4 = {"primary-nav-divider":"_qN8Zl"};
62796
62848
 
62797
62849
  var PrimaryNavDivider = function PrimaryNavDivider() {
62798
- return React__default["default"].createElement("div", {
62850
+ return React__default["default"].createElement("li", {
62851
+ role: "separator",
62852
+ "aria-orientation": "horizontal",
62799
62853
  className: styles$4['primary-nav-divider']
62800
62854
  });
62801
62855
  };
@@ -62809,7 +62863,7 @@ var PrimaryNavFooter = function PrimaryNavFooter(_ref) {
62809
62863
  contentRef = _usePrimaryNavContext.contentRef;
62810
62864
  var _useScrollDetector = useScrollDetector(contentRef),
62811
62865
  hasScroll = _useScrollDetector.hasScroll;
62812
- return React__default["default"].createElement("div", {
62866
+ return React__default["default"].createElement("ul", {
62813
62867
  className: classnames__default["default"](styles$3['primary-nav-footer'], (_classNames = {}, _classNames[styles$3['primary-nav-footer--with-shadow']] = hasScroll, _classNames))
62814
62868
  }, children);
62815
62869
  };