react-magma-dom 4.12.0-next.21 → 4.12.0-next.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/esm/index.js CHANGED
@@ -681,7 +681,9 @@ var defaultI18n = {
681
681
  horizontalTabsInstructions: 'use the right and left arrow keys to activate other tabs',
682
682
  verticalTabsInstructions: 'use the down and up arrow keys to activate other tabs',
683
683
  nextButtonLabel: 'Scroll tabs forward',
684
- previousButtonLabel: 'Scroll tabs back'
684
+ previousButtonLabel: 'Scroll tabs back',
685
+ scrolledBackAnnounce: 'Scrolled tabs backward',
686
+ scrolledForwardAnnounce: 'Scrolled tabs forward'
685
687
  },
686
688
  tag: {
687
689
  deleteAriaLabel: 'Delete {labelText} tag'
@@ -6729,7 +6731,7 @@ var StyledFormFieldContainer = /*#__PURE__*/_styled("div", {
6729
6731
  return props.labelWidth && props.labelPosition === LabelPosition.left ? props.labelWidth + "%" : '';
6730
6732
  }, ";margin-top:", function (props) {
6731
6733
  return props.inputSize === 'large' ? '19px' : '';
6732
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTRDIiwiZmlsZSI6IkZvcm1GaWVsZENvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgSW52ZXJzZUNvbnRleHQsIHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBDaGFyYWN0ZXJDb3VudGVyIH0gZnJvbSAnLi4vQ2hhcmFjdGVyQ291bnRlcic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IExhYmVsLCBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuY29uc3QgU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICAgIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gKHByb3BzLmlucHV0U2l6ZSA9PT0gJ2xhcmdlJyA/ICcxOXB4JyA6ICcnKX07XG4gIH1cbmA7XHJcbi8vIElucHV0IGFuZCBoZWxwZXIgdGV4dCA8ZGl2PiB3cmFwcGVyIGJhc2VkIG9uIGxhYmVsUG9zaXRpb24uXHJcbmNvbnN0IFN0eWxlZElucHV0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgYWxpZ24tc2VsZjogY2VudGVyO1xuYDtcclxuLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICdsZWZ0JyB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIElucHV0LCBlcnJvck1lc3NhZ2UsIGhlbHBlck1lc3NhZ2UsIGFuZCBDaGFyYWN0ZXJDb3VudGVyIGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbmZ1bmN0aW9uIElucHV0UG9zaXRpb25XcmFwcGVyKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0KSB7XHJcbiAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXRXcmFwcGVyLCBudWxsLCBwcm9wcy5jaGlsZHJlbik7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbn1cclxuY29uc3QgVXBwZXJXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDBgXHJcbiAgICA6IGAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMGB9O1xuXG4gICYgPiBsYWJlbCB7XG4gICAgbWFyZ2luOiAwO1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgRm9ybUZpZWxkQ29udGFpbmVyID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhY3Rpb25hYmxlID0gdHJ1ZSwgY2hpbGRyZW4sIGNvbnRhaW5lclN0eWxlLCBlcnJvck1lc3NhZ2UsIGZpZWxkSWQsIGhhc0NoYXJhY3RlckNvdW50ZXIgPSB0cnVlLCBoZWxwZXJNZXNzYWdlLCBpY29uUG9zaXRpb24sIGlucHV0U2l6ZSwgaW5wdXRMZW5ndGgsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1heENvdW50LCBtYXhMZW5ndGgsIG1lc3NhZ2VTdHlsZSwgdGVzdElkLCBhZGRpdGlvbmFsQ29udGVudCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IGNvdW50UHJvcHMgPSBtYXhDb3VudCB8fCBtYXhMZW5ndGg7XHJcbiAgICBjb25zdCBjb3VudGVyRGVzY3JpcHRpb25JZCA9IHR5cGVvZiBjb3VudFByb3BzID09PSAnbnVtYmVyJyAmJiBoYXNDaGFyYWN0ZXJDb3VudGVyXHJcbiAgICAgICAgPyBgJHtmaWVsZElkfV9fY291bnRlcmBcclxuICAgICAgICA6IG51bGw7XHJcbiAgICBjb25zdCBtZXNzYWdlRGVzY3JpcHRpb25JZCA9IGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlID8gYCR7ZmllbGRJZH1fX21lc3NhZ2VgIDogbnVsbDtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnZlcnNlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogeyBpc0ludmVyc2UgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCByZXN0LCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaW5wdXRTaXplOiBpbnB1dFNpemUsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGgsIHJlZjogcmVmLCBzdHlsZTogY29udGFpbmVyU3R5bGUsIHRoZW1lOiB0aGVtZSB9KSxcclxuICAgICAgICAgICAgbGFiZWxUZXh0ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFVwcGVyV3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGFiZWwsIHsgYWN0aW9uYWJsZTogYWN0aW9uYWJsZSwgaHRtbEZvcjogZmllbGRJZCwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb24sIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHNpemU6IGlucHV0U2l6ZSwgc3R5bGU6IGxhYmVsU3R5bGUgfSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIG51bGwsIGxhYmVsVGV4dCkpIDogKGxhYmVsVGV4dCkpLFxyXG4gICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQgJiZcclxuICAgICAgICAgICAgICAgICAgICBsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiZcclxuICAgICAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0UG9zaXRpb25XcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGggfSxcclxuICAgICAgICAgICAgICAgIGNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgdHlwZW9mIGNvdW50UHJvcHMgPT09ICdudW1iZXInICYmIGhhc0NoYXJhY3RlckNvdW50ZXIgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2hhcmFjdGVyQ291bnRlciwgeyBoYXNDaGFyYWN0ZXJDb3VudGVyOiBoYXNDaGFyYWN0ZXJDb3VudGVyLCBpZDogY291bnRlckRlc2NyaXB0aW9uSWQsIGlucHV0TGVuZ3RoOiBpbnB1dExlbmd0aCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIG1heENvdW50OiBtYXhDb3VudCwgbWF4TGVuZ3RoOiBtYXhMZW5ndGgsIHRlc3RJZDogdGVzdElkICYmIGAke3Rlc3RJZH0tY2hhcmFjdGVyLWNvdW50ZXJgIH0pKSxcclxuICAgICAgICAgICAgICAgIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRNZXNzYWdlLCB7IGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgaWQ6IG1lc3NhZ2VEZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Gb3JtRmllbGRDb250YWluZXIuanMubWFwIl19 */"));
6734
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTRDIiwiZmlsZSI6IkZvcm1GaWVsZENvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgSW52ZXJzZUNvbnRleHQsIHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBDaGFyYWN0ZXJDb3VudGVyIH0gZnJvbSAnLi4vQ2hhcmFjdGVyQ291bnRlcic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IExhYmVsLCBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuY29uc3QgU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICAgIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gKHByb3BzLmlucHV0U2l6ZSA9PT0gJ2xhcmdlJyA/ICcxOXB4JyA6ICcnKX07XG4gIH1cbmA7XHJcbi8vIElucHV0IGFuZCBoZWxwZXIgdGV4dCA8ZGl2PiB3cmFwcGVyIGJhc2VkIG9uIGxhYmVsUG9zaXRpb24uXHJcbmNvbnN0IFN0eWxlZElucHV0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgYWxpZ24tc2VsZjogY2VudGVyO1xuYDtcclxuLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICdsZWZ0JyB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIElucHV0LCBlcnJvck1lc3NhZ2UsIGhlbHBlck1lc3NhZ2UsIGFuZCBDaGFyYWN0ZXJDb3VudGVyIGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbmZ1bmN0aW9uIElucHV0UG9zaXRpb25XcmFwcGVyKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0KSB7XHJcbiAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXRXcmFwcGVyLCBudWxsLCBwcm9wcy5jaGlsZHJlbik7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbn1cclxuY29uc3QgVXBwZXJXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDBgXHJcbiAgICA6IGAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMGB9O1xuXG4gICYgPiBsYWJlbCB7XG4gICAgbWFyZ2luOiAwO1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgRm9ybUZpZWxkQ29udGFpbmVyID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhY3Rpb25hYmxlID0gdHJ1ZSwgY2hpbGRyZW4sIGNvbnRhaW5lclN0eWxlLCBlcnJvck1lc3NhZ2UsIGZpZWxkSWQsIGhhc0NoYXJhY3RlckNvdW50ZXIgPSB0cnVlLCBoZWxwZXJNZXNzYWdlLCBpY29uUG9zaXRpb24sIGlucHV0U2l6ZSwgaW5wdXRMZW5ndGgsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1heENvdW50LCBtYXhMZW5ndGgsIG1lc3NhZ2VTdHlsZSwgdGVzdElkLCBhZGRpdGlvbmFsQ29udGVudCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IGNvdW50UHJvcHMgPSBtYXhDb3VudCB8fCBtYXhMZW5ndGg7XHJcbiAgICBjb25zdCBjb3VudGVyRGVzY3JpcHRpb25JZCA9IHR5cGVvZiBjb3VudFByb3BzID09PSAnbnVtYmVyJyAmJiBoYXNDaGFyYWN0ZXJDb3VudGVyXHJcbiAgICAgICAgPyBgJHtmaWVsZElkfV9fY291bnRlcmBcclxuICAgICAgICA6IG51bGw7XHJcbiAgICBjb25zdCBtZXNzYWdlRGVzY3JpcHRpb25JZCA9IGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlID8gYCR7ZmllbGRJZH1fX21lc3NhZ2VgIDogbnVsbDtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnZlcnNlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogeyBpc0ludmVyc2UgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCByZXN0LCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaW5wdXRTaXplOiBpbnB1dFNpemUsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGgsIHJlZjogcmVmLCBzdHlsZTogY29udGFpbmVyU3R5bGUsIHRoZW1lOiB0aGVtZSB9KSxcclxuICAgICAgICAgICAgbGFiZWxUZXh0ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFVwcGVyV3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGFiZWwsIHsgYWN0aW9uYWJsZTogYWN0aW9uYWJsZSwgaHRtbEZvcjogZmllbGRJZCwgaWQ6IGAke2ZpZWxkSWR9X19sYWJlbGAsIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBzaXplOiBpbnB1dFNpemUsIHN0eWxlOiBsYWJlbFN0eWxlIH0sIGlzTGFiZWxWaXN1YWxseUhpZGRlbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCBudWxsLCBsYWJlbFRleHQpKSA6IChsYWJlbFRleHQpKSxcclxuICAgICAgICAgICAgICAgIGFkZGl0aW9uYWxDb250ZW50ICYmXHJcbiAgICAgICAgICAgICAgICAgICAgbGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dFBvc2l0aW9uV3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIHR5cGVvZiBjb3VudFByb3BzID09PSAnbnVtYmVyJyAmJiBoYXNDaGFyYWN0ZXJDb3VudGVyICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KENoYXJhY3RlckNvdW50ZXIsIHsgaGFzQ2hhcmFjdGVyQ291bnRlcjogaGFzQ2hhcmFjdGVyQ291bnRlciwgaWQ6IGNvdW50ZXJEZXNjcmlwdGlvbklkLCBpbnB1dExlbmd0aDogaW5wdXRMZW5ndGgsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtYXhDb3VudDogbWF4Q291bnQsIG1heExlbmd0aDogbWF4TGVuZ3RoLCB0ZXN0SWQ6IHRlc3RJZCAmJiBgJHt0ZXN0SWR9LWNoYXJhY3Rlci1jb3VudGVyYCB9KSksXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGlkOiBtZXNzYWdlRGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHN0eWxlOiBtZXNzYWdlU3R5bGUgfSwgKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgZXJyb3JNZXNzYWdlID8gZXJyb3JNZXNzYWdlIDogaGVscGVyTWVzc2FnZSkpKSkpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Rm9ybUZpZWxkQ29udGFpbmVyLmpzLm1hcCJdfQ== */"));
6733
6735
  // Input and helper text <div> wrapper based on labelPosition.
6734
6736
  var StyledInputWrapper = /*#__PURE__*/_styled("div", {
6735
6737
  target: "em9iy461",
@@ -6739,7 +6741,7 @@ var StyledInputWrapper = /*#__PURE__*/_styled("div", {
6739
6741
  styles: "flex:1 1 auto;align-self:center"
6740
6742
  } : {
6741
6743
  name: "118yi7l",
6742
- styles: "flex:1 1 auto;align-self:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JzQyIsImZpbGUiOiJGb3JtRmllbGRDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQ2hhcmFjdGVyQ291bnRlciB9IGZyb20gJy4uL0NoYXJhY3RlckNvdW50ZXInO1xyXG5pbXBvcnQgeyBJbnB1dE1lc3NhZ2UgfSBmcm9tICcuLi9JbnB1dC9JbnB1dE1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuICBsYWJlbCB7XG4gICAgZmxleC1iYXNpczogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFdpZHRoICYmIHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgJHtwcm9wcy5sYWJlbFdpZHRofSVgXHJcbiAgICA6ICcnfTtcbiAgICBtYXJnaW4tdG9wOiAke3Byb3BzID0+IChwcm9wcy5pbnB1dFNpemUgPT09ICdsYXJnZScgPyAnMTlweCcgOiAnJyl9O1xuICB9XG5gO1xyXG4vLyBJbnB1dCBhbmQgaGVscGVyIHRleHQgPGRpdj4gd3JhcHBlciBiYXNlZCBvbiBsYWJlbFBvc2l0aW9uLlxyXG5jb25zdCBTdHlsZWRJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbmA7XHJcbi8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBJbnB1dCwgZXJyb3JNZXNzYWdlLCBoZWxwZXJNZXNzYWdlLCBhbmQgQ2hhcmFjdGVyQ291bnRlciBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG5mdW5jdGlvbiBJbnB1dFBvc2l0aW9uV3JhcHBlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCkge1xyXG4gICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZElucHV0V3JhcHBlciwgbnVsbCwgcHJvcHMuY2hpbGRyZW4pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG59XHJcbmNvbnN0IFVwcGVyV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiBgMCAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDBgfTtcblxuICAmID4gbGFiZWwge1xuICAgIG1hcmdpbjogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEZvcm1GaWVsZENvbnRhaW5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWN0aW9uYWJsZSA9IHRydWUsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlLCBmaWVsZElkLCBoYXNDaGFyYWN0ZXJDb3VudGVyID0gdHJ1ZSwgaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uLCBpbnB1dFNpemUsIGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtYXhDb3VudCwgbWF4TGVuZ3RoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgYWRkaXRpb25hbENvbnRlbnQsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBjb3VudFByb3BzID0gbWF4Q291bnQgfHwgbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgY291bnRlckRlc2NyaXB0aW9uSWQgPSB0eXBlb2YgY291bnRQcm9wcyA9PT0gJ251bWJlcicgJiYgaGFzQ2hhcmFjdGVyQ291bnRlclxyXG4gICAgICAgID8gYCR7ZmllbGRJZH1fX2NvdW50ZXJgXHJcbiAgICAgICAgOiBudWxsO1xyXG4gICAgY29uc3QgbWVzc2FnZURlc2NyaXB0aW9uSWQgPSBlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSA/IGAke2ZpZWxkSWR9X19tZXNzYWdlYCA6IG51bGw7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgcmVzdCwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCByZWY6IHJlZiwgc3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChVcHBlcldyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCB7IGFjdGlvbmFibGU6IGFjdGlvbmFibGUsIGh0bWxGb3I6IGZpZWxkSWQsIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBzaXplOiBpbnB1dFNpemUsIHN0eWxlOiBsYWJlbFN0eWxlIH0sIGlzTGFiZWxWaXN1YWxseUhpZGRlbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCBudWxsLCBsYWJlbFRleHQpKSA6IChsYWJlbFRleHQpKSxcclxuICAgICAgICAgICAgICAgIGFkZGl0aW9uYWxDb250ZW50ICYmXHJcbiAgICAgICAgICAgICAgICAgICAgbGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dFBvc2l0aW9uV3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIHR5cGVvZiBjb3VudFByb3BzID09PSAnbnVtYmVyJyAmJiBoYXNDaGFyYWN0ZXJDb3VudGVyICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KENoYXJhY3RlckNvdW50ZXIsIHsgaGFzQ2hhcmFjdGVyQ291bnRlcjogaGFzQ2hhcmFjdGVyQ291bnRlciwgaWQ6IGNvdW50ZXJEZXNjcmlwdGlvbklkLCBpbnB1dExlbmd0aDogaW5wdXRMZW5ndGgsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtYXhDb3VudDogbWF4Q291bnQsIG1heExlbmd0aDogbWF4TGVuZ3RoLCB0ZXN0SWQ6IHRlc3RJZCAmJiBgJHt0ZXN0SWR9LWNoYXJhY3Rlci1jb3VudGVyYCB9KSksXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGlkOiBtZXNzYWdlRGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHN0eWxlOiBtZXNzYWdlU3R5bGUgfSwgKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgZXJyb3JNZXNzYWdlID8gZXJyb3JNZXNzYWdlIDogaGVscGVyTWVzc2FnZSkpKSkpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Rm9ybUZpZWxkQ29udGFpbmVyLmpzLm1hcCJdfQ== */",
6744
+ styles: "flex:1 1 auto;align-self:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JzQyIsImZpbGUiOiJGb3JtRmllbGRDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQ2hhcmFjdGVyQ291bnRlciB9IGZyb20gJy4uL0NoYXJhY3RlckNvdW50ZXInO1xyXG5pbXBvcnQgeyBJbnB1dE1lc3NhZ2UgfSBmcm9tICcuLi9JbnB1dC9JbnB1dE1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuICBsYWJlbCB7XG4gICAgZmxleC1iYXNpczogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFdpZHRoICYmIHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgJHtwcm9wcy5sYWJlbFdpZHRofSVgXHJcbiAgICA6ICcnfTtcbiAgICBtYXJnaW4tdG9wOiAke3Byb3BzID0+IChwcm9wcy5pbnB1dFNpemUgPT09ICdsYXJnZScgPyAnMTlweCcgOiAnJyl9O1xuICB9XG5gO1xyXG4vLyBJbnB1dCBhbmQgaGVscGVyIHRleHQgPGRpdj4gd3JhcHBlciBiYXNlZCBvbiBsYWJlbFBvc2l0aW9uLlxyXG5jb25zdCBTdHlsZWRJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbmA7XHJcbi8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBJbnB1dCwgZXJyb3JNZXNzYWdlLCBoZWxwZXJNZXNzYWdlLCBhbmQgQ2hhcmFjdGVyQ291bnRlciBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG5mdW5jdGlvbiBJbnB1dFBvc2l0aW9uV3JhcHBlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCkge1xyXG4gICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZElucHV0V3JhcHBlciwgbnVsbCwgcHJvcHMuY2hpbGRyZW4pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG59XHJcbmNvbnN0IFVwcGVyV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiBgMCAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDBgfTtcblxuICAmID4gbGFiZWwge1xuICAgIG1hcmdpbjogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEZvcm1GaWVsZENvbnRhaW5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWN0aW9uYWJsZSA9IHRydWUsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlLCBmaWVsZElkLCBoYXNDaGFyYWN0ZXJDb3VudGVyID0gdHJ1ZSwgaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uLCBpbnB1dFNpemUsIGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtYXhDb3VudCwgbWF4TGVuZ3RoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgYWRkaXRpb25hbENvbnRlbnQsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBjb3VudFByb3BzID0gbWF4Q291bnQgfHwgbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgY291bnRlckRlc2NyaXB0aW9uSWQgPSB0eXBlb2YgY291bnRQcm9wcyA9PT0gJ251bWJlcicgJiYgaGFzQ2hhcmFjdGVyQ291bnRlclxyXG4gICAgICAgID8gYCR7ZmllbGRJZH1fX2NvdW50ZXJgXHJcbiAgICAgICAgOiBudWxsO1xyXG4gICAgY29uc3QgbWVzc2FnZURlc2NyaXB0aW9uSWQgPSBlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSA/IGAke2ZpZWxkSWR9X19tZXNzYWdlYCA6IG51bGw7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgcmVzdCwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCByZWY6IHJlZiwgc3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChVcHBlcldyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCB7IGFjdGlvbmFibGU6IGFjdGlvbmFibGUsIGh0bWxGb3I6IGZpZWxkSWQsIGlkOiBgJHtmaWVsZElkfV9fbGFiZWxgLCBpY29uUG9zaXRpb246IGljb25Qb3NpdGlvbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgc2l6ZTogaW5wdXRTaXplLCBzdHlsZTogbGFiZWxTdHlsZSB9LCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSksXHJcbiAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCAmJlxyXG4gICAgICAgICAgICAgICAgICAgIGxhYmVsUG9zaXRpb24gIT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgICAgIGFkZGl0aW9uYWxDb250ZW50KSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRQb3NpdGlvbldyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCB9LFxyXG4gICAgICAgICAgICAgICAgY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICB0eXBlb2YgY291bnRQcm9wcyA9PT0gJ251bWJlcicgJiYgaGFzQ2hhcmFjdGVyQ291bnRlciAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChDaGFyYWN0ZXJDb3VudGVyLCB7IGhhc0NoYXJhY3RlckNvdW50ZXI6IGhhc0NoYXJhY3RlckNvdW50ZXIsIGlkOiBjb3VudGVyRGVzY3JpcHRpb25JZCwgaW5wdXRMZW5ndGg6IGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgbWF4Q291bnQ6IG1heENvdW50LCBtYXhMZW5ndGg6IG1heExlbmd0aCwgdGVzdElkOiB0ZXN0SWQgJiYgYCR7dGVzdElkfS1jaGFyYWN0ZXItY291bnRlcmAgfSkpLFxyXG4gICAgICAgICAgICAgICAgKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dE1lc3NhZ2UsIHsgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpZDogbWVzc2FnZURlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBzdHlsZTogbWVzc2FnZVN0eWxlIH0sIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsIGVycm9yTWVzc2FnZSA/IGVycm9yTWVzc2FnZSA6IGhlbHBlck1lc3NhZ2UpKSkpKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUZvcm1GaWVsZENvbnRhaW5lci5qcy5tYXAiXX0= */",
6743
6745
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$c
6744
6746
  });
6745
6747
  // If the labelPosition is set to 'left' then a <div> wraps the Input, errorMessage, helperMessage, and CharacterCounter for proper styling alignment.
@@ -6754,7 +6756,7 @@ var UpperWrapper = /*#__PURE__*/_styled("div", {
6754
6756
  label: "UpperWrapper"
6755
6757
  })("display:flex;justify-content:space-between;align-items:center;margin:", function (props) {
6756
6758
  return props.labelPosition === LabelPosition.left ? "0 " + props.theme.spaceScale.spacing03 + " 0 0" : "0 0 " + props.theme.spaceScale.spacing03 + " 0";
6757
- }, ";&>label{margin:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUNnQyIsImZpbGUiOiJGb3JtRmllbGRDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQ2hhcmFjdGVyQ291bnRlciB9IGZyb20gJy4uL0NoYXJhY3RlckNvdW50ZXInO1xyXG5pbXBvcnQgeyBJbnB1dE1lc3NhZ2UgfSBmcm9tICcuLi9JbnB1dC9JbnB1dE1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuICBsYWJlbCB7XG4gICAgZmxleC1iYXNpczogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFdpZHRoICYmIHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgJHtwcm9wcy5sYWJlbFdpZHRofSVgXHJcbiAgICA6ICcnfTtcbiAgICBtYXJnaW4tdG9wOiAke3Byb3BzID0+IChwcm9wcy5pbnB1dFNpemUgPT09ICdsYXJnZScgPyAnMTlweCcgOiAnJyl9O1xuICB9XG5gO1xyXG4vLyBJbnB1dCBhbmQgaGVscGVyIHRleHQgPGRpdj4gd3JhcHBlciBiYXNlZCBvbiBsYWJlbFBvc2l0aW9uLlxyXG5jb25zdCBTdHlsZWRJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbmA7XHJcbi8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBJbnB1dCwgZXJyb3JNZXNzYWdlLCBoZWxwZXJNZXNzYWdlLCBhbmQgQ2hhcmFjdGVyQ291bnRlciBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG5mdW5jdGlvbiBJbnB1dFBvc2l0aW9uV3JhcHBlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCkge1xyXG4gICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZElucHV0V3JhcHBlciwgbnVsbCwgcHJvcHMuY2hpbGRyZW4pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG59XHJcbmNvbnN0IFVwcGVyV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiBgMCAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDBgfTtcblxuICAmID4gbGFiZWwge1xuICAgIG1hcmdpbjogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEZvcm1GaWVsZENvbnRhaW5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWN0aW9uYWJsZSA9IHRydWUsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlLCBmaWVsZElkLCBoYXNDaGFyYWN0ZXJDb3VudGVyID0gdHJ1ZSwgaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uLCBpbnB1dFNpemUsIGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtYXhDb3VudCwgbWF4TGVuZ3RoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgYWRkaXRpb25hbENvbnRlbnQsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBjb3VudFByb3BzID0gbWF4Q291bnQgfHwgbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgY291bnRlckRlc2NyaXB0aW9uSWQgPSB0eXBlb2YgY291bnRQcm9wcyA9PT0gJ251bWJlcicgJiYgaGFzQ2hhcmFjdGVyQ291bnRlclxyXG4gICAgICAgID8gYCR7ZmllbGRJZH1fX2NvdW50ZXJgXHJcbiAgICAgICAgOiBudWxsO1xyXG4gICAgY29uc3QgbWVzc2FnZURlc2NyaXB0aW9uSWQgPSBlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSA/IGAke2ZpZWxkSWR9X19tZXNzYWdlYCA6IG51bGw7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgcmVzdCwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCByZWY6IHJlZiwgc3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChVcHBlcldyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCB7IGFjdGlvbmFibGU6IGFjdGlvbmFibGUsIGh0bWxGb3I6IGZpZWxkSWQsIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBzaXplOiBpbnB1dFNpemUsIHN0eWxlOiBsYWJlbFN0eWxlIH0sIGlzTGFiZWxWaXN1YWxseUhpZGRlbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCBudWxsLCBsYWJlbFRleHQpKSA6IChsYWJlbFRleHQpKSxcclxuICAgICAgICAgICAgICAgIGFkZGl0aW9uYWxDb250ZW50ICYmXHJcbiAgICAgICAgICAgICAgICAgICAgbGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICAgICAgICAgICAgICAgICAgYWRkaXRpb25hbENvbnRlbnQpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dFBvc2l0aW9uV3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIHR5cGVvZiBjb3VudFByb3BzID09PSAnbnVtYmVyJyAmJiBoYXNDaGFyYWN0ZXJDb3VudGVyICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KENoYXJhY3RlckNvdW50ZXIsIHsgaGFzQ2hhcmFjdGVyQ291bnRlcjogaGFzQ2hhcmFjdGVyQ291bnRlciwgaWQ6IGNvdW50ZXJEZXNjcmlwdGlvbklkLCBpbnB1dExlbmd0aDogaW5wdXRMZW5ndGgsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtYXhDb3VudDogbWF4Q291bnQsIG1heExlbmd0aDogbWF4TGVuZ3RoLCB0ZXN0SWQ6IHRlc3RJZCAmJiBgJHt0ZXN0SWR9LWNoYXJhY3Rlci1jb3VudGVyYCB9KSksXHJcbiAgICAgICAgICAgICAgICAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0TWVzc2FnZSwgeyBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGlkOiBtZXNzYWdlRGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHN0eWxlOiBtZXNzYWdlU3R5bGUgfSwgKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgZXJyb3JNZXNzYWdlID8gZXJyb3JNZXNzYWdlIDogaGVscGVyTWVzc2FnZSkpKSkpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Rm9ybUZpZWxkQ29udGFpbmVyLmpzLm1hcCJdfQ== */"));
6759
+ }, ";&>label{margin:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUNnQyIsImZpbGUiOiJGb3JtRmllbGRDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQ2hhcmFjdGVyQ291bnRlciB9IGZyb20gJy4uL0NoYXJhY3RlckNvdW50ZXInO1xyXG5pbXBvcnQgeyBJbnB1dE1lc3NhZ2UgfSBmcm9tICcuLi9JbnB1dC9JbnB1dE1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuICBsYWJlbCB7XG4gICAgZmxleC1iYXNpczogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFdpZHRoICYmIHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgJHtwcm9wcy5sYWJlbFdpZHRofSVgXHJcbiAgICA6ICcnfTtcbiAgICBtYXJnaW4tdG9wOiAke3Byb3BzID0+IChwcm9wcy5pbnB1dFNpemUgPT09ICdsYXJnZScgPyAnMTlweCcgOiAnJyl9O1xuICB9XG5gO1xyXG4vLyBJbnB1dCBhbmQgaGVscGVyIHRleHQgPGRpdj4gd3JhcHBlciBiYXNlZCBvbiBsYWJlbFBvc2l0aW9uLlxyXG5jb25zdCBTdHlsZWRJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbmA7XHJcbi8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBJbnB1dCwgZXJyb3JNZXNzYWdlLCBoZWxwZXJNZXNzYWdlLCBhbmQgQ2hhcmFjdGVyQ291bnRlciBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG5mdW5jdGlvbiBJbnB1dFBvc2l0aW9uV3JhcHBlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCkge1xyXG4gICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZElucHV0V3JhcHBlciwgbnVsbCwgcHJvcHMuY2hpbGRyZW4pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG59XHJcbmNvbnN0IFVwcGVyV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwYFxyXG4gICAgOiBgMCAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDBgfTtcblxuICAmID4gbGFiZWwge1xuICAgIG1hcmdpbjogMDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEZvcm1GaWVsZENvbnRhaW5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWN0aW9uYWJsZSA9IHRydWUsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlLCBmaWVsZElkLCBoYXNDaGFyYWN0ZXJDb3VudGVyID0gdHJ1ZSwgaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uLCBpbnB1dFNpemUsIGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtYXhDb3VudCwgbWF4TGVuZ3RoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgYWRkaXRpb25hbENvbnRlbnQsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBjb3VudFByb3BzID0gbWF4Q291bnQgfHwgbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgY291bnRlckRlc2NyaXB0aW9uSWQgPSB0eXBlb2YgY291bnRQcm9wcyA9PT0gJ251bWJlcicgJiYgaGFzQ2hhcmFjdGVyQ291bnRlclxyXG4gICAgICAgID8gYCR7ZmllbGRJZH1fX2NvdW50ZXJgXHJcbiAgICAgICAgOiBudWxsO1xyXG4gICAgY29uc3QgbWVzc2FnZURlc2NyaXB0aW9uSWQgPSBlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSA/IGAke2ZpZWxkSWR9X19tZXNzYWdlYCA6IG51bGw7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgcmVzdCwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCByZWY6IHJlZiwgc3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChVcHBlcldyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExhYmVsLCB7IGFjdGlvbmFibGU6IGFjdGlvbmFibGUsIGh0bWxGb3I6IGZpZWxkSWQsIGlkOiBgJHtmaWVsZElkfV9fbGFiZWxgLCBpY29uUG9zaXRpb246IGljb25Qb3NpdGlvbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgc2l6ZTogaW5wdXRTaXplLCBzdHlsZTogbGFiZWxTdHlsZSB9LCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSksXHJcbiAgICAgICAgICAgICAgICBhZGRpdGlvbmFsQ29udGVudCAmJlxyXG4gICAgICAgICAgICAgICAgICAgIGxhYmVsUG9zaXRpb24gIT09IExhYmVsUG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgICAgIGFkZGl0aW9uYWxDb250ZW50KSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRQb3NpdGlvbldyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCB9LFxyXG4gICAgICAgICAgICAgICAgY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICB0eXBlb2YgY291bnRQcm9wcyA9PT0gJ251bWJlcicgJiYgaGFzQ2hhcmFjdGVyQ291bnRlciAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChDaGFyYWN0ZXJDb3VudGVyLCB7IGhhc0NoYXJhY3RlckNvdW50ZXI6IGhhc0NoYXJhY3RlckNvdW50ZXIsIGlkOiBjb3VudGVyRGVzY3JpcHRpb25JZCwgaW5wdXRMZW5ndGg6IGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgbWF4Q291bnQ6IG1heENvdW50LCBtYXhMZW5ndGg6IG1heExlbmd0aCwgdGVzdElkOiB0ZXN0SWQgJiYgYCR7dGVzdElkfS1jaGFyYWN0ZXItY291bnRlcmAgfSkpLFxyXG4gICAgICAgICAgICAgICAgKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dE1lc3NhZ2UsIHsgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpZDogbWVzc2FnZURlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBzdHlsZTogbWVzc2FnZVN0eWxlIH0sIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsIGVycm9yTWVzc2FnZSA/IGVycm9yTWVzc2FnZSA6IGhlbHBlck1lc3NhZ2UpKSkpKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUZvcm1GaWVsZENvbnRhaW5lci5qcy5tYXAiXX0= */"));
6758
6760
  var FormFieldContainer = /*#__PURE__*/forwardRef(function (props, ref) {
6759
6761
  var _props$actionable = props.actionable,
6760
6762
  actionable = _props$actionable === void 0 ? true : _props$actionable,
@@ -6804,6 +6806,7 @@ var FormFieldContainer = /*#__PURE__*/forwardRef(function (props, ref) {
6804
6806
  }, createElement(Label, {
6805
6807
  actionable: actionable,
6806
6808
  htmlFor: fieldId,
6809
+ id: fieldId + "__label",
6807
6810
  iconPosition: iconPosition,
6808
6811
  labelPosition: labelPosition,
6809
6812
  size: inputSize,
@@ -7039,7 +7042,7 @@ var StyledNativeSelectWrapper = /*#__PURE__*/_styled("div", {
7039
7042
  return props.theme.spaceScale.spacing03;
7040
7043
  }, " 0 -", function (props) {
7041
7044
  return props.theme.spaceScale.spacing08;
7042
- }, ";pointer-events:none;z-index:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AAW6C","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        switch (e.key) {\r\n            case 'ArrowDown':\r\n                index = (index + 1) % total;\r\n                break;\r\n            case 'ArrowUp':\r\n                index = (index - 1 + total) % total;\r\n                break;\r\n            default:\r\n                return;\r\n        }\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__desc` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7045
+ }, ";pointer-events:none;z-index:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AAW6C","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        const direction = e.key === 'ArrowDown' ? 1 : e.key === 'ArrowUp' ? -1 : 0;\r\n        if (direction === 0)\r\n            return;\r\n        // Skip disabled options\r\n        let attempts = 0;\r\n        do {\r\n            index = (index + direction + total) % total;\r\n            attempts++;\r\n        } while (select.options[index].disabled && attempts < total);\r\n        // If all options are disabled, do nothing\r\n        if (select.options[index].disabled)\r\n            return;\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__message` : undefined, \"aria-invalid\": !!errorMessage || undefined, \"aria-labelledby\": additionalContent && labelText ? `${id}__label` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7043
7046
  function borderColors(props) {
7044
7047
  if (props.isInverse) {
7045
7048
  if (props.hasError) {
@@ -7065,13 +7068,13 @@ var StyledNativeSelect = /*#__PURE__*/_styled("select", {
7065
7068
  return props.theme.spaceScale.spacing08;
7066
7069
  }, ";background:inherit;>option{background:", function (props) {
7067
7070
  return props.isInverse ? props.theme.colors.neutral600 : 'none';
7068
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AA8CyC","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        switch (e.key) {\r\n            case 'ArrowDown':\r\n                index = (index + 1) % total;\r\n                break;\r\n            case 'ArrowUp':\r\n                index = (index - 1 + total) % total;\r\n                break;\r\n            default:\r\n                return;\r\n        }\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__desc` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7071
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AA8CyC","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        const direction = e.key === 'ArrowDown' ? 1 : e.key === 'ArrowUp' ? -1 : 0;\r\n        if (direction === 0)\r\n            return;\r\n        // Skip disabled options\r\n        let attempts = 0;\r\n        do {\r\n            index = (index + direction + total) % total;\r\n            attempts++;\r\n        } while (select.options[index].disabled && attempts < total);\r\n        // If all options are disabled, do nothing\r\n        if (select.options[index].disabled)\r\n            return;\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__message` : undefined, \"aria-invalid\": !!errorMessage || undefined, \"aria-labelledby\": additionalContent && labelText ? `${id}__label` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7069
7072
  var _ref$4 = process.env.NODE_ENV === "production" ? {
7070
7073
  name: "i0lfe0-StyledFormFieldContainer",
7071
7074
  styles: "flex:1;label{display:flex;justify-content:space-between;align-items:center;};label:StyledFormFieldContainer;"
7072
7075
  } : {
7073
7076
  name: "i0lfe0-StyledFormFieldContainer",
7074
- styles: "flex:1;label{display:flex;justify-content:space-between;align-items:center;};label:StyledFormFieldContainer;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AA4DQ","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        switch (e.key) {\r\n            case 'ArrowDown':\r\n                index = (index + 1) % total;\r\n                break;\r\n            case 'ArrowUp':\r\n                index = (index - 1 + total) % total;\r\n                break;\r\n            default:\r\n                return;\r\n        }\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__desc` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */",
7077
+ styles: "flex:1;label{display:flex;justify-content:space-between;align-items:center;};label:StyledFormFieldContainer;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AA4DQ","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        const direction = e.key === 'ArrowDown' ? 1 : e.key === 'ArrowUp' ? -1 : 0;\r\n        if (direction === 0)\r\n            return;\r\n        // Skip disabled options\r\n        let attempts = 0;\r\n        do {\r\n            index = (index + direction + total) % total;\r\n            attempts++;\r\n        } while (select.options[index].disabled && attempts < total);\r\n        // If all options are disabled, do nothing\r\n        if (select.options[index].disabled)\r\n            return;\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__message` : undefined, \"aria-invalid\": !!errorMessage || undefined, \"aria-labelledby\": additionalContent && labelText ? `${id}__label` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */",
7075
7078
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$e
7076
7079
  };
7077
7080
  var StyledFormFieldContainer$1 = /*#__PURE__*/_styled(FormFieldContainer, {
@@ -7081,7 +7084,7 @@ var StyledFormFieldContainer$1 = /*#__PURE__*/_styled(FormFieldContainer, {
7081
7084
  return props.labelPosition === LabelPosition.left ? 'flex' : '';
7082
7085
  }, ";", function (props) {
7083
7086
  return props.additionalContent && _ref$4;
7084
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AAwD4D","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        switch (e.key) {\r\n            case 'ArrowDown':\r\n                index = (index + 1) % total;\r\n                break;\r\n            case 'ArrowUp':\r\n                index = (index - 1 + total) % total;\r\n                break;\r\n            default:\r\n                return;\r\n        }\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__desc` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7087
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AAwD4D","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        const direction = e.key === 'ArrowDown' ? 1 : e.key === 'ArrowUp' ? -1 : 0;\r\n        if (direction === 0)\r\n            return;\r\n        // Skip disabled options\r\n        let attempts = 0;\r\n        do {\r\n            index = (index + direction + total) % total;\r\n            attempts++;\r\n        } while (select.options[index].disabled && attempts < total);\r\n        // If all options are disabled, do nothing\r\n        if (select.options[index].disabled)\r\n            return;\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__message` : undefined, \"aria-invalid\": !!errorMessage || undefined, \"aria-labelledby\": additionalContent && labelText ? `${id}__label` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7085
7088
  var StyledAdditionalContentWrapper = /*#__PURE__*/_styled("div", {
7086
7089
  target: "ek9bqze0",
7087
7090
  label: "StyledAdditionalContentWrapper"
@@ -7089,7 +7092,7 @@ var StyledAdditionalContentWrapper = /*#__PURE__*/_styled("div", {
7089
7092
  return props.theme.spaceScale.spacing03;
7090
7093
  }, " 0 0;}button{margin:0 0 0 ", function (props) {
7091
7094
  return props.theme.spaceScale.spacing03;
7092
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AAqEkD","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        switch (e.key) {\r\n            case 'ArrowDown':\r\n                index = (index + 1) % total;\r\n                break;\r\n            case 'ArrowUp':\r\n                index = (index - 1 + total) % total;\r\n                break;\r\n            default:\r\n                return;\r\n        }\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__desc` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7095
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["NativeSelect.tsx"],"names":[],"mappings":"AAqEkD","file":"NativeSelect.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { FormFieldContainer, } from '../FormFieldContainer';\r\nimport { inputBaseStyles, inputWrapperStyles } from '../InputBase';\r\nimport { LabelPosition } from '../Label';\r\nimport { DefaultDropdownIndicator } from '../Select/components';\r\nconst StyledNativeSelectWrapper = styled.div `\n  ${inputWrapperStyles}\n  border: 1px solid ${borderColors};\n  svg {\n    color: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.disabled\r\n        ? transparentize(0.4, props.theme.colors.neutral500)\r\n        : props.isInverse\r\n            ? props.theme.colors.neutral100\r\n            : props.theme.colors.neutral700};\n    margin: 0 ${props => props.theme.spaceScale.spacing03}\n      0 -${props => props.theme.spaceScale.spacing08};\n    pointer-events: none;\n    z-index: 1;\n  }\n`;\r\nfunction borderColors(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger300;\r\n        }\r\n        if (props.disabled) {\r\n            return transparentize(0.85, props.theme.colors.neutral100);\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.disabled) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nconst StyledNativeSelect = styled.select `\n  ${inputBaseStyles};\n  height: 38px;\n  padding-right: ${props => props.theme.spaceScale.spacing08};\n  // Required for Windows && Chrome support\n  background: inherit;\n  > option {\n    background: ${props => props.isInverse ? props.theme.colors.neutral600 : 'none'};\n  }\n`;\r\nconst StyledFormFieldContainer = styled(FormFieldContainer) `\n  display: ${props => props.labelPosition === LabelPosition.left ? 'flex' : ''};\n\n  ${props => props.additionalContent &&\r\n    css `\n      flex: 1;\n      label {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n      }\n    `}\n`;\r\nconst StyledAdditionalContentWrapper = styled.div `\n  align-items: center;\n  display: flex;\n  label {\n    margin: 0 ${props => props.theme.spaceScale.spacing03} 0 0;\n  }\n  button {\n    margin: 0 0 0 ${props => props.theme.spaceScale.spacing03};\n  }\n`;\r\nexport const NativeSelect = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, containerStyle, disabled, errorMessage, id: defaultId, helperMessage, isInverse: isInverseProp, labelPosition, labelStyle, labelText, labelWidth, messageStyle, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const id = useGenerateId(defaultId);\r\n    const hasLabel = !!labelText;\r\n    const selectRef = React.useRef(null);\r\n    const handleKeyDown = (e) => {\r\n        const select = selectRef.current;\r\n        if (!select)\r\n            return;\r\n        const total = select.options.length;\r\n        let index = select.selectedIndex;\r\n        const direction = e.key === 'ArrowDown' ? 1 : e.key === 'ArrowUp' ? -1 : 0;\r\n        if (direction === 0)\r\n            return;\r\n        // Skip disabled options\r\n        let attempts = 0;\r\n        do {\r\n            index = (index + direction + total) % total;\r\n            attempts++;\r\n        } while (select.options[index].disabled && attempts < total);\r\n        // If all options are disabled, do nothing\r\n        if (select.options[index].disabled)\r\n            return;\r\n        e.preventDefault();\r\n        select.selectedIndex = index;\r\n        select.dispatchEvent(new Event('change', { bubbles: true }));\r\n    };\r\n    const nativeSelect = (React.createElement(StyledFormFieldContainer, { additionalContent: additionalContent, containerStyle: containerStyle, testId: testId && `${testId}-form-field-container`, errorMessage: errorMessage, fieldId: id, hasLabel: !!labelText, labelPosition: labelPosition, labelStyle: labelStyle, labelText: labelText, labelWidth: labelWidth, isInverse: isInverse, helperMessage: helperMessage, messageStyle: messageStyle, ref: ref },\r\n        React.createElement(StyledNativeSelectWrapper, { disabled: disabled, hasError: !!errorMessage, isInverse: isInverse, theme: theme },\r\n            React.createElement(StyledNativeSelect, Object.assign({ \"data-testid\": testId, \"aria-describedby\": errorMessage || helperMessage ? `${id}__message` : undefined, \"aria-invalid\": !!errorMessage || undefined, \"aria-labelledby\": additionalContent && labelText ? `${id}__label` : undefined, hasError: !!errorMessage, disabled: disabled, id: id, isInverse: isInverse, ref: selectRef, onKeyDown: handleKeyDown, theme: theme }, other), children),\r\n            React.createElement(DefaultDropdownIndicator, { disabled: disabled }))));\r\n    // If the labelPosition is set to 'left' then a <div> wraps the FormFieldContainer, NativeSelectWrapper, and NativeSelect for proper styling alignment.\r\n    function AdditionalContentWrapper(props) {\r\n        if (labelPosition === LabelPosition.left ||\r\n            (labelPosition === LabelPosition.top && !hasLabel)) {\r\n            return (React.createElement(StyledAdditionalContentWrapper, { \"data-testid\": `${testId}-additional-content-wrapper`, theme: theme }, props.children));\r\n        }\r\n        return props.children;\r\n    }\r\n    if (additionalContent) {\r\n        return (React.createElement(AdditionalContentWrapper, { labelPosition: labelPosition },\r\n            nativeSelect,\r\n            (labelPosition === LabelPosition.left && additionalContent) ||\r\n                (!labelText && additionalContent)));\r\n    }\r\n    else {\r\n        return nativeSelect;\r\n    }\r\n});\r\n//# sourceMappingURL=NativeSelect.js.map"]} */"));
7093
7096
  var NativeSelect = /*#__PURE__*/forwardRef(function (props, ref) {
7094
7097
  var additionalContent = props.additionalContent,
7095
7098
  children = props.children,
@@ -7116,16 +7119,16 @@ var NativeSelect = /*#__PURE__*/forwardRef(function (props, ref) {
7116
7119
  if (!select) return;
7117
7120
  var total = select.options.length;
7118
7121
  var index = select.selectedIndex;
7119
- switch (e.key) {
7120
- case 'ArrowDown':
7121
- index = (index + 1) % total;
7122
- break;
7123
- case 'ArrowUp':
7124
- index = (index - 1 + total) % total;
7125
- break;
7126
- default:
7127
- return;
7128
- }
7122
+ var direction = e.key === 'ArrowDown' ? 1 : e.key === 'ArrowUp' ? -1 : 0;
7123
+ if (direction === 0) return;
7124
+ // Skip disabled options
7125
+ var attempts = 0;
7126
+ do {
7127
+ index = (index + direction + total) % total;
7128
+ attempts++;
7129
+ } while (select.options[index].disabled && attempts < total);
7130
+ // If all options are disabled, do nothing
7131
+ if (select.options[index].disabled) return;
7129
7132
  e.preventDefault();
7130
7133
  select.selectedIndex = index;
7131
7134
  select.dispatchEvent(new Event('change', {
@@ -7154,7 +7157,9 @@ var NativeSelect = /*#__PURE__*/forwardRef(function (props, ref) {
7154
7157
  theme: theme
7155
7158
  }, createElement(StyledNativeSelect, Object.assign({
7156
7159
  "data-testid": testId,
7157
- "aria-describedby": errorMessage || helperMessage ? id + "__desc" : undefined,
7160
+ "aria-describedby": errorMessage || helperMessage ? id + "__message" : undefined,
7161
+ "aria-invalid": !!errorMessage || undefined,
7162
+ "aria-labelledby": additionalContent && labelText ? id + "__label" : undefined,
7158
7163
  hasError: !!errorMessage,
7159
7164
  disabled: disabled,
7160
7165
  id: id,
@@ -16992,7 +16997,7 @@ var StyledContainer$3 = /*#__PURE__*/_styled('div', {
16992
16997
  return props.orientation === 'vertical' ? '100%' : 'auto';
16993
16998
  }, ";position:relative;width:", function (props) {
16994
16999
  return props.orientation === 'vertical' ? 'auto' : '100%';
16995
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AA2CG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        const previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        const nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
17000
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AA6CG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { Announce } from '../Announce';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    const [scrollAnnouncement, setScrollAnnouncement] = React.useState('');\r\n    const [panelAnnouncement, setPanelAnnouncement] = React.useState('');\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    React.useEffect(() => {\r\n        if (!displayScroll.start) {\r\n            nextButtonRef.current?.focus();\r\n        }\r\n        else if (!displayScroll.end) {\r\n            prevButtonRef.current?.focus();\r\n        }\r\n    }, [displayScroll.start, displayScroll.end]);\r\n    // Announce panel content when active tab changes (including initial mount)\r\n    React.useEffect(() => {\r\n        setTimeout(() => {\r\n            const panelId = `tabpanel-${activeTabIndex}`;\r\n            const panelElement = document.getElementById(panelId);\r\n            if (panelElement) {\r\n                const panelText = panelElement.textContent || '';\r\n                setPanelAnnouncement(panelText.trim());\r\n                setTimeout(() => setPanelAnnouncement(''), 100);\r\n            }\r\n        }, 100);\r\n    }, [activeTabIndex]);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        if (newActiveIndex === activeTabIndex) {\r\n            scrollSelectedIntoView();\r\n        }\r\n        else {\r\n            setActiveTabIndex(newActiveIndex);\r\n        }\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        const previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        const nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const handlePrevScrollWithAnnouncement = () => {\r\n        handleStartScrollClick();\r\n        setScrollAnnouncement(i18n.tabs.scrolledBackAnnounce);\r\n        setTimeout(() => setScrollAnnouncement(''), 100);\r\n    };\r\n    const handleNextScrollWithAnnouncement = () => {\r\n        handleEndScrollClick();\r\n        setScrollAnnouncement(i18n.tabs.scrolledForwardAnnounce);\r\n        setTimeout(() => setScrollAnnouncement(''), 100);\r\n    };\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handlePrevScrollWithAnnouncement, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleNextScrollWithAnnouncement, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme }),\r\n        React.createElement(VisuallyHidden, null,\r\n            React.createElement(Announce, null, scrollAnnouncement)),\r\n        React.createElement(VisuallyHidden, null,\r\n            React.createElement(Announce, null, panelAnnouncement))));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
16996
17001
  var StyledTabsWrapper = /*#__PURE__*/_styled('div', {
16997
17002
  shouldForwardProp: isPropValid,
16998
17003
  target: "exr2c6p1",
@@ -17001,7 +17006,7 @@ var StyledTabsWrapper = /*#__PURE__*/_styled('div', {
17001
17006
  return props.orientation === 'vertical' ? '' : 'auto';
17002
17007
  }, ";overflow-y:", function (props) {
17003
17008
  return props.orientation === 'vertical' ? 'auto' : '';
17004
- }, ";&::-webkit-scrollbar{width:0;height:0;}scrollbar-width:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAsDG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        const previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        const nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
17009
+ }, ";&::-webkit-scrollbar{width:0;height:0;}scrollbar-width:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAwDG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { Announce } from '../Announce';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    const [scrollAnnouncement, setScrollAnnouncement] = React.useState('');\r\n    const [panelAnnouncement, setPanelAnnouncement] = React.useState('');\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    React.useEffect(() => {\r\n        if (!displayScroll.start) {\r\n            nextButtonRef.current?.focus();\r\n        }\r\n        else if (!displayScroll.end) {\r\n            prevButtonRef.current?.focus();\r\n        }\r\n    }, [displayScroll.start, displayScroll.end]);\r\n    // Announce panel content when active tab changes (including initial mount)\r\n    React.useEffect(() => {\r\n        setTimeout(() => {\r\n            const panelId = `tabpanel-${activeTabIndex}`;\r\n            const panelElement = document.getElementById(panelId);\r\n            if (panelElement) {\r\n                const panelText = panelElement.textContent || '';\r\n                setPanelAnnouncement(panelText.trim());\r\n                setTimeout(() => setPanelAnnouncement(''), 100);\r\n            }\r\n        }, 100);\r\n    }, [activeTabIndex]);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        if (newActiveIndex === activeTabIndex) {\r\n            scrollSelectedIntoView();\r\n        }\r\n        else {\r\n            setActiveTabIndex(newActiveIndex);\r\n        }\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        const previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        const nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const handlePrevScrollWithAnnouncement = () => {\r\n        handleStartScrollClick();\r\n        setScrollAnnouncement(i18n.tabs.scrolledBackAnnounce);\r\n        setTimeout(() => setScrollAnnouncement(''), 100);\r\n    };\r\n    const handleNextScrollWithAnnouncement = () => {\r\n        handleEndScrollClick();\r\n        setScrollAnnouncement(i18n.tabs.scrolledForwardAnnounce);\r\n        setTimeout(() => setScrollAnnouncement(''), 100);\r\n    };\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handlePrevScrollWithAnnouncement, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleNextScrollWithAnnouncement, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme }),\r\n        React.createElement(VisuallyHidden, null,\r\n            React.createElement(Announce, null, scrollAnnouncement)),\r\n        React.createElement(VisuallyHidden, null,\r\n            React.createElement(Announce, null, panelAnnouncement))));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
17005
17010
  var StyledTabs = /*#__PURE__*/_styled('ul', {
17006
17011
  shouldForwardProp: isPropValid,
17007
17012
  target: "exr2c6p0",
@@ -17012,7 +17017,7 @@ var StyledTabs = /*#__PURE__*/_styled('ul', {
17012
17017
  return props.alignment === 'center' ? 'center' : props.alignment === 'right' ? 'flex-end' : '';
17013
17018
  }, ";margin:0;padding:0;width:", function (props) {
17014
17019
  return props.orientation === 'vertical' ? 'auto' : '100%';
17015
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAkE2E","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        const previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        const nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
17020
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAoE2E","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport styled from '@emotion/styled';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { Announce } from '../Announce';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    const [scrollAnnouncement, setScrollAnnouncement] = React.useState('');\r\n    const [panelAnnouncement, setPanelAnnouncement] = React.useState('');\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    React.useEffect(() => {\r\n        if (!displayScroll.start) {\r\n            nextButtonRef.current?.focus();\r\n        }\r\n        else if (!displayScroll.end) {\r\n            prevButtonRef.current?.focus();\r\n        }\r\n    }, [displayScroll.start, displayScroll.end]);\r\n    // Announce panel content when active tab changes (including initial mount)\r\n    React.useEffect(() => {\r\n        setTimeout(() => {\r\n            const panelId = `tabpanel-${activeTabIndex}`;\r\n            const panelElement = document.getElementById(panelId);\r\n            if (panelElement) {\r\n                const panelText = panelElement.textContent || '';\r\n                setPanelAnnouncement(panelText.trim());\r\n                setTimeout(() => setPanelAnnouncement(''), 100);\r\n            }\r\n        }, 100);\r\n    }, [activeTabIndex]);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        if (newActiveIndex === activeTabIndex) {\r\n            scrollSelectedIntoView();\r\n        }\r\n        else {\r\n            setActiveTabIndex(newActiveIndex);\r\n        }\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        const previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        const nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const handlePrevScrollWithAnnouncement = () => {\r\n        handleStartScrollClick();\r\n        setScrollAnnouncement(i18n.tabs.scrolledBackAnnounce);\r\n        setTimeout(() => setScrollAnnouncement(''), 100);\r\n    };\r\n    const handleNextScrollWithAnnouncement = () => {\r\n        handleEndScrollClick();\r\n        setScrollAnnouncement(i18n.tabs.scrolledForwardAnnounce);\r\n        setTimeout(() => setScrollAnnouncement(''), 100);\r\n    };\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handlePrevScrollWithAnnouncement, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleNextScrollWithAnnouncement, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme }),\r\n        React.createElement(VisuallyHidden, null,\r\n            React.createElement(Announce, null, scrollAnnouncement)),\r\n        React.createElement(VisuallyHidden, null,\r\n            React.createElement(Announce, null, panelAnnouncement))));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
17016
17021
  var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17017
17022
  var alignment = props.alignment,
17018
17023
  backgroundColor = props.backgroundColor,
@@ -17052,6 +17057,12 @@ var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17052
17057
  buttonRefArray = _useDescendants[0],
17053
17058
  registerTabButton = _useDescendants[1];
17054
17059
  var childrenWrapperRef = React__default.useRef();
17060
+ var _React$useState = React__default.useState(''),
17061
+ scrollAnnouncement = _React$useState[0],
17062
+ setScrollAnnouncement = _React$useState[1];
17063
+ var _React$useState2 = React__default.useState(''),
17064
+ panelAnnouncement = _React$useState2[0],
17065
+ setPanelAnnouncement = _React$useState2[1];
17055
17066
  function getTabsMeta() {
17056
17067
  var tabsNode = tabsWrapperRef.current;
17057
17068
  var tabsMeta;
@@ -17116,13 +17127,40 @@ var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17116
17127
  };
17117
17128
  React__default.useEffect(scrollSelectedIntoView, [activeTabIndex]);
17118
17129
  React__default.useEffect(scrollInitialActiveIndexIntoView, []);
17130
+ React__default.useEffect(function () {
17131
+ if (!displayScroll.start) {
17132
+ var _nextButtonRef$curren;
17133
+ (_nextButtonRef$curren = nextButtonRef.current) == null || _nextButtonRef$curren.focus();
17134
+ } else if (!displayScroll.end) {
17135
+ var _prevButtonRef$curren;
17136
+ (_prevButtonRef$curren = prevButtonRef.current) == null || _prevButtonRef$curren.focus();
17137
+ }
17138
+ }, [displayScroll.start, displayScroll.end]);
17139
+ // Announce panel content when active tab changes (including initial mount)
17140
+ React__default.useEffect(function () {
17141
+ setTimeout(function () {
17142
+ var panelId = "tabpanel-" + activeTabIndex;
17143
+ var panelElement = document.getElementById(panelId);
17144
+ if (panelElement) {
17145
+ var panelText = panelElement.textContent || '';
17146
+ setPanelAnnouncement(panelText.trim());
17147
+ setTimeout(function () {
17148
+ return setPanelAnnouncement('');
17149
+ }, 100);
17150
+ }
17151
+ }, 100);
17152
+ }, [activeTabIndex]);
17119
17153
  function changeHandler(newActiveIndex, event) {
17120
17154
  if (event.target.children[0] && event.target.children[0].hasAttribute('disabled')) {
17121
17155
  event.preventDefault();
17122
17156
  return undefined;
17123
17157
  }
17124
17158
  onChange && typeof onChange === 'function' && onChange(newActiveIndex);
17125
- newActiveIndex === activeTabIndex ? scrollSelectedIntoView() : setActiveTabIndex(newActiveIndex);
17159
+ if (newActiveIndex === activeTabIndex) {
17160
+ scrollSelectedIntoView();
17161
+ } else {
17162
+ setActiveTabIndex(newActiveIndex);
17163
+ }
17126
17164
  }
17127
17165
  function tabIsEnabled(tabIndex) {
17128
17166
  return buttonRefArray.current[tabIndex].current.getAttribute('disabled') === null;
@@ -17182,6 +17220,20 @@ var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17182
17220
  }
17183
17221
  var i18n = React__default.useContext(I18nContext);
17184
17222
  var ariaLabel = (rest['aria-label'] || '') + ", " + (orientation === TabsOrientation.vertical ? i18n.tabs.verticalTabsInstructions : i18n.tabs.horizontalTabsInstructions);
17223
+ var handlePrevScrollWithAnnouncement = function handlePrevScrollWithAnnouncement() {
17224
+ handleStartScrollClick();
17225
+ setScrollAnnouncement(i18n.tabs.scrolledBackAnnounce);
17226
+ setTimeout(function () {
17227
+ return setScrollAnnouncement('');
17228
+ }, 100);
17229
+ };
17230
+ var handleNextScrollWithAnnouncement = function handleNextScrollWithAnnouncement() {
17231
+ handleEndScrollClick();
17232
+ setScrollAnnouncement(i18n.tabs.scrolledForwardAnnounce);
17233
+ setTimeout(function () {
17234
+ return setScrollAnnouncement('');
17235
+ }, 100);
17236
+ };
17185
17237
  var other = omit(['aria-label'], rest);
17186
17238
  return React__default.createElement(StyledContainer$3, Object.assign({
17187
17239
  "data-testid": testId,
@@ -17194,7 +17246,7 @@ var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17194
17246
  backgroundColor: background,
17195
17247
  buttonVisible: displayScroll.start,
17196
17248
  isInverse: isInverse,
17197
- onClick: handleStartScrollClick,
17249
+ onClick: handlePrevScrollWithAnnouncement,
17198
17250
  orientation: orientation || TabsOrientation.horizontal,
17199
17251
  ref: prevButtonRef,
17200
17252
  theme: theme
@@ -17227,11 +17279,11 @@ var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17227
17279
  backgroundColor: background,
17228
17280
  buttonVisible: displayScroll.end,
17229
17281
  isInverse: isInverse,
17230
- onClick: handleEndScrollClick,
17282
+ onClick: handleNextScrollWithAnnouncement,
17231
17283
  orientation: orientation || TabsOrientation.horizontal,
17232
17284
  ref: nextButtonRef,
17233
17285
  theme: theme
17234
- }));
17286
+ }), React__default.createElement(VisuallyHidden, null, React__default.createElement(Announce, null, scrollAnnouncement)), React__default.createElement(VisuallyHidden, null, React__default.createElement(Announce, null, panelAnnouncement)));
17235
17287
  });
17236
17288
 
17237
17289
  var _excluded$1b = ["children", "icon", "disabled", "testId", "unstyled"],
@@ -17241,8 +17293,8 @@ var StyledTabsChild = /*#__PURE__*/_styled('li', {
17241
17293
  target: "e1ym35js2",
17242
17294
  label: "StyledTabsChild"
17243
17295
  })("list-style:none;margin:0;padding:0;position:relative;white-space:normal;", function (props) {
17244
- return !props.unstyled && /*#__PURE__*/css("cursor:", props.disabled ? 'not-allowed' : 'pointer', ";flex-grow:0;flex-shrink:", props.isFullWidth ? '1' : '0', ";height:", props.orientation === 'vertical' ? 'auto' : '100%', ";max-width:", props.isFullWidth ? '100%' : '250px', ";width:", props.isFullWidth || props.orientation === 'vertical' ? '100%' : 'auto', ";&:after{background:", props.isInverse ? props.theme.colors.tertiary : props.theme.colors.primary, ";border-radius:2px;content:'';display:block;height:4px;opacity:", props.isActive ? '1' : '0', ";position:absolute;transition:0.4s all;width:auto;bottom:", props.borderPosition === 'top' ? 'auto' : '0', ";left:", props.isActive ? '0' : '50%', ";right:", props.isActive ? '0' : '50%', ";top:", props.borderPosition === 'top' ? '0' : 'auto', ";", props.orientation === 'vertical' && /*#__PURE__*/css("height:auto;bottom:", props.isActive ? '0' : '50%', ";left:", props.borderPosition === 'right' ? 'auto' : '0', ";right:", props.borderPosition === 'right' ? '0' : 'auto', ";top:", props.isActive ? '0' : '50%', ";width:4px;;label:StyledTabsChild;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AA8CY","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */")), ";};label:StyledTabsChild;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAoBQ","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17245
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAYG","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17296
+ return !props.unstyled && /*#__PURE__*/css("cursor:", props.disabled ? 'not-allowed' : 'pointer', ";flex-grow:0;flex-shrink:", props.isFullWidth ? '1' : '0', ";height:", props.orientation === 'vertical' ? 'auto' : '100%', ";max-width:", props.isFullWidth ? '100%' : '250px', ";width:", props.isFullWidth || props.orientation === 'vertical' ? '100%' : 'auto', ";&:after{background:", props.isInverse ? props.theme.colors.tertiary : props.theme.colors.primary, ";border-radius:2px;content:'';display:block;height:4px;opacity:", props.isActive ? '1' : '0', ";position:absolute;transition:0.4s all;width:auto;bottom:", props.borderPosition === 'top' ? 'auto' : '0', ";left:", props.isActive ? '0' : '50%', ";right:", props.isActive ? '0' : '50%', ";top:", props.borderPosition === 'top' ? '0' : 'auto', ";", props.orientation === 'vertical' && /*#__PURE__*/css("height:auto;bottom:", props.isActive ? '0' : '50%', ";left:", props.borderPosition === 'right' ? 'auto' : '0', ";right:", props.borderPosition === 'right' ? '0' : 'auto', ";top:", props.isActive ? '0' : '50%', ";width:4px;;label:StyledTabsChild;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AA8CY","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    const tabId = `tab-${index}`;\r\n    const panelId = `tabpanel-${index}`;\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-controls': panelId,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            id: tabId,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-controls\": panelId, \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, id: tabId, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */")), ";};label:StyledTabsChild;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAoBQ","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    const tabId = `tab-${index}`;\r\n    const panelId = `tabpanel-${index}`;\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-controls': panelId,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            id: tabId,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-controls\": panelId, \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, id: tabId, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17297
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAYG","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    const tabId = `tab-${index}`;\r\n    const panelId = `tabpanel-${index}`;\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-controls': panelId,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            id: tabId,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-controls\": panelId, \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, id: tabId, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17246
17298
  function getFlexDirection(position) {
17247
17299
  switch (position) {
17248
17300
  case TabsIconPosition.left:
@@ -17276,7 +17328,7 @@ function buildTabStylesColor(props) {
17276
17328
  return props.theme.colors.neutral500;
17277
17329
  }
17278
17330
  var TabStyles = function TabStyles(props) {
17279
- return /*#__PURE__*/css("align-items:center;background:transparent;border:0;color:", buildTabStylesColor(props), ";cursor:", props.disabled ? 'auto' : 'pointer', ";display:flex;flex-direction:", getFlexDirection(props.iconPosition), ";flex-grow:0;flex-shrink:", props.isFullWidth ? '1' : '0', ";font-weight:500;font-size:", props.theme.typeScale.size02.fontSize, ";font-family:", props.theme.bodyFont, ";letter-spacing:", props.theme.typeScale.size02.letterSpacing, ";line-height:", props.theme.typeScale.size02.lineHeight, ";height:100%;justify-content:", props.iconPosition === 'left' ? 'flex-start' : 'center', ";padding:", props.theme.spaceScale.spacing04, " ", props.theme.spaceScale.spacing05, ";position:relative;pointer-events:", props.disabled ? 'none' : '', ";text-align:center;text-decoration:none;text-transform:", props.textTransform, ";width:", props.isFullWidth ? '100%' : 'auto', ";", props.orientation === 'vertical' && /*#__PURE__*/css("align-items:flex-start;justify-content:", props.iconPosition === 'left' ? 'flex-start' : 'flex-end', ";text-align:left;width:100%;align-items:center;;label:TabStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAoHQ","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */")), " &:hover,&:focus{background-color:", props.isActive ? '' : props.isInverse ? curriedTransparentize(0.7, props.theme.colors.neutral900) : curriedTransparentize(0.95, props.theme.colors.neutral900), ";color:", props.isActive ? props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.primary : props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";}&:focus{outline-offset:-2px;outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";};label:TabStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAyFsC","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17331
+ return /*#__PURE__*/css("align-items:center;background:transparent;border:0;color:", buildTabStylesColor(props), ";cursor:", props.disabled ? 'auto' : 'pointer', ";display:flex;flex-direction:", getFlexDirection(props.iconPosition), ";flex-grow:0;flex-shrink:", props.isFullWidth ? '1' : '0', ";font-weight:500;font-size:", props.theme.typeScale.size02.fontSize, ";font-family:", props.theme.bodyFont, ";letter-spacing:", props.theme.typeScale.size02.letterSpacing, ";line-height:", props.theme.typeScale.size02.lineHeight, ";height:100%;justify-content:", props.iconPosition === 'left' ? 'flex-start' : 'center', ";padding:", props.theme.spaceScale.spacing04, " ", props.theme.spaceScale.spacing05, ";position:relative;pointer-events:", props.disabled ? 'none' : '', ";text-align:center;text-decoration:none;text-transform:", props.textTransform, ";width:", props.isFullWidth ? '100%' : 'auto', ";", props.orientation === 'vertical' && /*#__PURE__*/css("align-items:flex-start;justify-content:", props.iconPosition === 'left' ? 'flex-start' : 'flex-end', ";text-align:left;width:100%;align-items:center;;label:TabStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAoHQ","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    const tabId = `tab-${index}`;\r\n    const panelId = `tabpanel-${index}`;\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-controls': panelId,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            id: tabId,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-controls\": panelId, \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, id: tabId, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */")), " &:hover,&:focus{background-color:", props.isActive ? '' : props.isInverse ? curriedTransparentize(0.7, props.theme.colors.neutral900) : curriedTransparentize(0.95, props.theme.colors.neutral900), ";color:", props.isActive ? props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.primary : props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";}&:focus{outline-offset:-2px;outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";};label:TabStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAyFsC","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    const tabId = `tab-${index}`;\r\n    const panelId = `tabpanel-${index}`;\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-controls': panelId,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            id: tabId,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-controls\": panelId, \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, id: tabId, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17280
17332
  };
17281
17333
  var StyledTab = /*#__PURE__*/_styled('button', {
17282
17334
  shouldForwardProp: isPropValid,
@@ -17284,7 +17336,7 @@ var StyledTab = /*#__PURE__*/_styled('button', {
17284
17336
  label: "StyledTab"
17285
17337
  })(function (props) {
17286
17338
  return props.unstyled ? '' : TabStyles;
17287
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAuJuE","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17339
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AAuJuE","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    const tabId = `tab-${index}`;\r\n    const panelId = `tabpanel-${index}`;\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-controls': panelId,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            id: tabId,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-controls\": panelId, \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, id: tabId, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17288
17340
  function getIconMargin(props) {
17289
17341
  if (props.isIconOnly) {
17290
17342
  return "0";
@@ -17311,7 +17363,7 @@ var StyledIcon = /*#__PURE__*/_styled("span", {
17311
17363
  return props.theme.iconSizes.small;
17312
17364
  }, "px;width:", function (props) {
17313
17365
  return props.theme.iconSizes.small;
17314
- }, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AA2KsC","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17366
+ }, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tab.tsx"],"names":[],"mappings":"AA2KsC","file":"Tab.tsx","sourcesContent":["import React from 'react';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { TabsIconPosition, TabsContext } from './Tabs';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport { useForceUpdate } from '../../hooks/useForceUpdate';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nexport const StyledTabsChild = styled('li', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  position: relative;\n  white-space: normal;\n\n  ${props => !props.unstyled &&\r\n    css `\n      cursor: ${props.disabled ? 'not-allowed' : 'pointer'};\n      flex-grow: 0;\n      flex-shrink: ${props.isFullWidth ? '1' : '0'};\n      height: ${props.orientation === 'vertical' ? 'auto' : '100%'};\n      max-width: ${props.isFullWidth ? '100%' : '250px'};\n      width: ${props.isFullWidth || props.orientation === 'vertical'\r\n        ? '100%'\r\n        : 'auto'};\n      &:after {\n        background: ${props.isInverse\r\n        ? props.theme.colors.tertiary\r\n        : props.theme.colors.primary};\n        border-radius: 2px;\n        content: '';\n        display: block;\n        height: 4px;\n        opacity: ${props.isActive ? '1' : '0'};\n        position: absolute;\n        transition: 0.4s all;\n        width: auto;\n        bottom: ${props.borderPosition === 'top' ? 'auto' : '0'};\n        left: ${props.isActive ? '0' : '50%'};\n        right: ${props.isActive ? '0' : '50%'};\n        top: ${props.borderPosition === 'top' ? '0' : 'auto'};\n        ${props.orientation === 'vertical' &&\r\n        css `\n          height: auto;\n          bottom: ${props.isActive ? '0' : '50%'};\n          left: ${props.borderPosition === 'right' ? 'auto' : '0'};\n          right: ${props.borderPosition === 'right' ? '0' : 'auto'};\n          top: ${props.isActive ? '0' : '50%'};\n          width: 4px;\n        `}\n      }\n    `}\n`;\r\nfunction getFlexDirection(position) {\r\n    switch (position) {\r\n        case TabsIconPosition.left:\r\n            return 'row';\r\n        case TabsIconPosition.right:\r\n            return 'row-reverse';\r\n        case TabsIconPosition.top:\r\n            return 'column';\r\n        case TabsIconPosition.bottom:\r\n            return 'column-reverse';\r\n        default:\r\n            return 'column';\r\n    }\r\n}\r\nfunction buildTabStylesColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            return transparentize(0.6, props.theme.colors.neutral100);\r\n        }\r\n        if (props.isActive) {\r\n            return props.theme.colors.neutral100;\r\n        }\r\n        return transparentize(0.3, props.theme.colors.neutral100);\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral500);\r\n    }\r\n    if (props.isActive) {\r\n        return props.theme.colors.primary;\r\n    }\r\n    return props.theme.colors.neutral500;\r\n}\r\nexport const TabStyles = props => css `\n  align-items: center;\n  background: transparent;\n  border: 0;\n  color: ${buildTabStylesColor(props)};\n  cursor: ${props.disabled ? 'auto' : 'pointer'};\n  display: flex;\n  flex-direction: ${getFlexDirection(props.iconPosition)};\n  flex-grow: 0;\n  flex-shrink: ${props.isFullWidth ? '1' : '0'};\n  font-weight: 500;\n  font-size: ${props.theme.typeScale.size02.fontSize};\n  font-family: ${props.theme.bodyFont};\n  letter-spacing: ${props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props.theme.typeScale.size02.lineHeight};\n  height: 100%;\n  justify-content: ${props.iconPosition === 'left' ? 'flex-start' : 'center'};\n  padding: ${props.theme.spaceScale.spacing04}\n    ${props.theme.spaceScale.spacing05};\n  position: relative;\n  pointer-events: ${props.disabled ? 'none' : ''};\n  text-align: center;\n  text-decoration: none;\n  text-transform: ${props.textTransform};\n  width: ${props.isFullWidth ? '100%' : 'auto'};\n\n  ${props.orientation === 'vertical' &&\r\n    css `\n    align-items: flex-start;\n    justify-content: ${props.iconPosition === 'left'\r\n        ? 'flex-start'\r\n        : 'flex-end'};\n    text-align: left;\n    width: 100%;\n\n    align-items: center;\n  `}\n\n  &:hover,\n  &:focus {\n    background-color: ${props.isActive\r\n    ? ''\r\n    : props.isInverse\r\n        ? transparentize(0.7, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)};\n    color: ${props.isActive\r\n    ? props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.primary\r\n    : props.isInverse\r\n        ? props.theme.colors.neutral100\r\n        : props.theme.colors.neutral700};\n  }\n\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledTab = styled('button', { shouldForwardProp: isPropValid }) `\n  ${props => (props.unstyled ? '' : TabStyles)}\n`;\r\nfunction getIconMargin(props) {\r\n    if (props.isIconOnly) {\r\n        return `0`;\r\n    }\r\n    switch (props.iconPosition) {\r\n        case TabsIconPosition.left:\r\n            return `0 ${props.theme.spaceScale.spacing03} 0 0`;\r\n        case TabsIconPosition.right:\r\n            return `0 0 0 ${props.theme.spaceScale.spacing03}`;\r\n        case TabsIconPosition.top:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n        case TabsIconPosition.bottom:\r\n            return `${props.theme.spaceScale.spacing02} 0 0`;\r\n        default:\r\n            return `0 0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n}\r\nexport const StyledIcon = styled.span `\n  display: flex;\n  margin: ${props => getIconMargin(props)};\n\n  svg {\n    height: ${props => props.theme.iconSizes.small}px;\n    width: ${props => props.theme.iconSizes.small}px;\n  }\n`;\r\nexport const Tab = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(TabsContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { children, icon, disabled, testId, unstyled, ...rest } = resolvedProps;\r\n    const { activeTabIndex } = React.useContext(TabsContainerContext);\r\n    const { buttonRefArray, registerTabButton } = React.useContext(TabsContext);\r\n    const ownRef = React.useRef();\r\n    const forceUpdate = useForceUpdate();\r\n    const index = buttonRefArray.current.findIndex(({ current: item }) => {\r\n        if (!item || !ownRef.current)\r\n            return false;\r\n        return item === ownRef.current;\r\n    });\r\n    const isActive = index === activeTabIndex;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const { changeHandler, orientation, borderPosition, iconPosition, isInverse, isFullWidth, textTransform, } = resolvedProps;\r\n    const handleClick = (index, e) => {\r\n        changeHandler(index, e);\r\n        props.onClick && typeof props.onClick === 'function' && props.onClick(e);\r\n    };\r\n    React.useEffect(() => {\r\n        registerTabButton(buttonRefArray, ownRef);\r\n        forceUpdate();\r\n    }, [buttonRefArray, forceUpdate, registerTabButton]);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isIconOnly = !children;\r\n    let tabIconPosition = iconPosition;\r\n    if (!tabIconPosition) {\r\n        tabIconPosition =\r\n            orientation === 'vertical'\r\n                ? TabsIconPosition.left\r\n                : TabsIconPosition.top;\r\n    }\r\n    const tabId = `tab-${index}`;\r\n    const panelId = `tabpanel-${index}`;\r\n    if (unstyled) {\r\n        const child = React.Children.only(children);\r\n        const { \r\n        // props to remove from rest\r\n        borderPosition: _borderPosition, buttonRefArray: _buttonRefArray, changeHandler: _changeHandler, iconPosition: _iconPosition, isFullWidth: _isFullWidth, isInverse: _isInverse, orientation: _orientation, registerTabButton: _registerTabButton, textTransform: _textTransform, ...clonedElProps } = rest;\r\n        return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme, unstyled: true }, React.cloneElement(child, {\r\n            ...clonedElProps,\r\n            'aria-controls': panelId,\r\n            'aria-selected': isActive,\r\n            disabled,\r\n            id: tabId,\r\n            onClick: e => handleClick(index, e),\r\n            ref,\r\n            role: 'tab',\r\n            tabIndex: isActive ? 0 : -1,\r\n        })));\r\n    }\r\n    return (React.createElement(StyledTabsChild, { borderPosition: borderPosition, \"data-testid\": \"tabContainer\", disabled: disabled, isActive: isActive, isFullWidth: isFullWidth, isInverse: isInverse, orientation: orientation, role: \"presentation\", theme: theme },\r\n        React.createElement(StyledTab, Object.assign({}, rest, { \"aria-controls\": panelId, \"aria-selected\": isActive, \"data-testid\": testId, disabled: disabled, iconPosition: tabIconPosition, id: tabId, isActive: isActive, isInverse: isInverse, isFullWidth: isFullWidth, onClick: e => handleClick(index, e), orientation: orientation, ref: ref, role: \"tab\", tabIndex: isActive ? 0 : -1, theme: theme, textTransform: textTransform }),\r\n            icon && (React.createElement(StyledIcon, { theme: theme, iconPosition: tabIconPosition, isIconOnly: isIconOnly }, icon)),\r\n            children)));\r\n});\r\n//# sourceMappingURL=Tab.js.map"]} */"));
17315
17367
  var Tab = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef) {
17316
17368
  var contextProps = React__default.useContext(TabsContext);
17317
17369
  var resolvedProps = resolveProps(contextProps, props);
@@ -17356,6 +17408,8 @@ var Tab = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef)
17356
17408
  if (!tabIconPosition) {
17357
17409
  tabIconPosition = orientation === 'vertical' ? TabsIconPosition.left : TabsIconPosition.top;
17358
17410
  }
17411
+ var tabId = "tab-" + index;
17412
+ var panelId = "tabpanel-" + index;
17359
17413
  if (unstyled) {
17360
17414
  var child = React__default.Children.only(children);
17361
17415
  var clonedElProps = _objectWithoutPropertiesLoose(rest, _excluded2$3);
@@ -17371,8 +17425,10 @@ var Tab = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef)
17371
17425
  theme: theme,
17372
17426
  unstyled: true
17373
17427
  }, React__default.cloneElement(child, _extends({}, clonedElProps, {
17428
+ 'aria-controls': panelId,
17374
17429
  'aria-selected': isActive,
17375
17430
  disabled: disabled,
17431
+ id: tabId,
17376
17432
  onClick: function onClick(e) {
17377
17433
  return handleClick(index, e);
17378
17434
  },
@@ -17392,10 +17448,12 @@ var Tab = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef)
17392
17448
  role: "presentation",
17393
17449
  theme: theme
17394
17450
  }, React__default.createElement(StyledTab, Object.assign({}, rest, {
17451
+ "aria-controls": panelId,
17395
17452
  "aria-selected": isActive,
17396
17453
  "data-testid": testId,
17397
17454
  disabled: disabled,
17398
17455
  iconPosition: tabIconPosition,
17456
+ id: tabId,
17399
17457
  isActive: isActive,
17400
17458
  isInverse: isInverse,
17401
17459
  isFullWidth: isFullWidth,
@@ -17423,7 +17481,7 @@ var StyledTabPanel = /*#__PURE__*/_styled("div", {
17423
17481
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
17424
17482
  }, ";font-family:", function (props) {
17425
17483
  return props.theme.bodyFont;
17426
- }, ";flex:1;height:100%;padding:20px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRhYlBhbmVsLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJa0MiLCJmaWxlIjoiVGFiUGFuZWwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBUYWJzQ29udGFpbmVyQ29udGV4dCB9IGZyb20gJy4vVGFic0NvbnRhaW5lcic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmNvbnN0IFN0eWxlZFRhYlBhbmVsID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZmxleDogMTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBwYWRkaW5nOiAyMHB4O1xuYDtcclxuZXhwb3J0IGNvbnN0IFRhYlBhbmVsID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBpbmRleCwgaXNJbnZlcnNlLCB0ZXN0SWQsIGNoaWxkcmVuLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IHsgYWN0aXZlVGFiSW5kZXggfSA9IFJlYWN0LnVzZUNvbnRleHQoVGFic0NvbnRhaW5lckNvbnRleHQpO1xyXG4gICAgY29uc3QgYWN0aXZlVGFiID0gYWN0aXZlVGFiSW5kZXggPT09IGluZGV4O1xyXG4gICAgcmV0dXJuIGFjdGl2ZVRhYiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRhYlBhbmVsLCBPYmplY3QuYXNzaWduKHsgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sIG90aGVyKSwgY2hpbGRyZW4pKSA6IG51bGw7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UYWJQYW5lbC5qcy5tYXAiXX0= */"));
17484
+ }, ";flex:1;height:100%;padding:20px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRhYlBhbmVsLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJa0MiLCJmaWxlIjoiVGFiUGFuZWwudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBUYWJzQ29udGFpbmVyQ29udGV4dCB9IGZyb20gJy4vVGFic0NvbnRhaW5lcic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmNvbnN0IFN0eWxlZFRhYlBhbmVsID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZmxleDogMTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBwYWRkaW5nOiAyMHB4O1xuYDtcclxuZXhwb3J0IGNvbnN0IFRhYlBhbmVsID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBpbmRleCwgaXNJbnZlcnNlLCB0ZXN0SWQsIGNoaWxkcmVuLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IHsgYWN0aXZlVGFiSW5kZXggfSA9IFJlYWN0LnVzZUNvbnRleHQoVGFic0NvbnRhaW5lckNvbnRleHQpO1xyXG4gICAgY29uc3QgYWN0aXZlVGFiID0gYWN0aXZlVGFiSW5kZXggPT09IGluZGV4O1xyXG4gICAgY29uc3QgcGFuZWxJZCA9IGB0YWJwYW5lbC0ke2luZGV4fWA7XHJcbiAgICBjb25zdCB0YWJJZCA9IGB0YWItJHtpbmRleH1gO1xyXG4gICAgcmV0dXJuIGFjdGl2ZVRhYiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRhYlBhbmVsLCBPYmplY3QuYXNzaWduKHsgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBpZDogcGFuZWxJZCwgcm9sZTogXCJ0YWJwYW5lbFwiLCBcImFyaWEtbGFiZWxsZWRieVwiOiB0YWJJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9LCBvdGhlciksIGNoaWxkcmVuKSkgOiBudWxsO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9VGFiUGFuZWwuanMubWFwIl19 */"));
17427
17485
  var TabPanel = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17428
17486
  var index = props.index,
17429
17487
  isInverse = props.isInverse,
@@ -17434,9 +17492,14 @@ var TabPanel = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
17434
17492
  var _React$useContext = React__default.useContext(TabsContainerContext),
17435
17493
  activeTabIndex = _React$useContext.activeTabIndex;
17436
17494
  var activeTab = activeTabIndex === index;
17495
+ var panelId = "tabpanel-" + index;
17496
+ var tabId = "tab-" + index;
17437
17497
  return activeTab ? React__default.createElement(StyledTabPanel, Object.assign({
17438
17498
  ref: ref,
17439
17499
  "data-testid": testId,
17500
+ id: panelId,
17501
+ role: "tabpanel",
17502
+ "aria-labelledby": tabId,
17440
17503
  isInverse: isInverse,
17441
17504
  theme: theme
17442
17505
  }, other), children) : null;
@@ -17765,6 +17828,10 @@ var NavTabs = /*#__PURE__*/forwardRef(function (props, ref) {
17765
17828
  tabsWrapperRef = tabsRefs.tabsWrapperRef;
17766
17829
  var navTabChildren = Children.toArray(children);
17767
17830
  var childrenWrapperRef = useRef();
17831
+ var _React$useState = useState(''),
17832
+ scrollAnnouncement = _React$useState[0],
17833
+ setScrollAnnouncement = _React$useState[1];
17834
+ var i18n = useContext(I18nContext);
17768
17835
  var hasChildFocus = navTabChildren.some(function (child) {
17769
17836
  if (isValidElement(child)) {
17770
17837
  return Object.keys(child.props).includes('isFocused');
@@ -17833,7 +17900,30 @@ var NavTabs = /*#__PURE__*/forwardRef(function (props, ref) {
17833
17900
  var nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;
17834
17901
  scroll(nextScrollStart);
17835
17902
  };
17903
+ var handlePrevScrollWithAnnouncement = function handlePrevScrollWithAnnouncement() {
17904
+ handleStartScrollClick();
17905
+ setScrollAnnouncement(i18n.tabs.scrolledBackAnnounce);
17906
+ setTimeout(function () {
17907
+ return setScrollAnnouncement('');
17908
+ }, 100);
17909
+ };
17910
+ var handleNextScrollWithAnnouncement = function handleNextScrollWithAnnouncement() {
17911
+ handleEndScrollClick();
17912
+ setScrollAnnouncement(i18n.tabs.scrolledForwardAnnounce);
17913
+ setTimeout(function () {
17914
+ return setScrollAnnouncement('');
17915
+ }, 100);
17916
+ };
17836
17917
  useEffect(scrollInitialActiveIndexIntoView, []);
17918
+ useEffect(function () {
17919
+ if (!displayScroll.start) {
17920
+ var _nextButtonRef$curren;
17921
+ (_nextButtonRef$curren = nextButtonRef.current) == null || _nextButtonRef$curren.focus();
17922
+ } else if (!displayScroll.end) {
17923
+ var _prevButtonRef$curren;
17924
+ (_prevButtonRef$curren = prevButtonRef.current) == null || _prevButtonRef$curren.focus();
17925
+ }
17926
+ }, [displayScroll.start, displayScroll.end]);
17837
17927
  return createElement(StyledContainer$3, Object.assign({
17838
17928
  "aria-label": rest['aria-label'],
17839
17929
  as: "nav",
@@ -17847,7 +17937,7 @@ var NavTabs = /*#__PURE__*/forwardRef(function (props, ref) {
17847
17937
  backgroundColor: background,
17848
17938
  buttonVisible: displayScroll.start,
17849
17939
  isInverse: isInverse,
17850
- onClick: handleStartScrollClick,
17940
+ onClick: handlePrevScrollWithAnnouncement,
17851
17941
  orientation: orientation || TabsOrientation.horizontal,
17852
17942
  ref: prevButtonRef,
17853
17943
  theme: theme
@@ -17873,11 +17963,11 @@ var NavTabs = /*#__PURE__*/forwardRef(function (props, ref) {
17873
17963
  backgroundColor: background,
17874
17964
  buttonVisible: displayScroll.end,
17875
17965
  isInverse: isInverse,
17876
- onClick: handleEndScrollClick,
17966
+ onClick: handleNextScrollWithAnnouncement,
17877
17967
  orientation: orientation || TabsOrientation.horizontal,
17878
17968
  ref: nextButtonRef,
17879
17969
  theme: theme
17880
- }));
17970
+ }), createElement(VisuallyHidden, null, createElement(Announce, null, scrollAnnouncement)));
17881
17971
  });
17882
17972
 
17883
17973
  var _excluded$1i = ["children", "isInverse", "isSelected"];
@@ -20008,6 +20098,7 @@ function defaultOnInputValueChange(changes, items, itemToString, disableCreateIt
20008
20098
 
20009
20099
  var _excluded$1s = ["react_magma__created_item"];
20010
20100
  function InternalCombobox(props) {
20101
+ var _i18n$combobox$clearI;
20011
20102
  var ariaDescribedBy = props.ariaDescribedBy,
20012
20103
  customComponents = props.components,
20013
20104
  defaultItems = props.defaultItems,
@@ -20182,6 +20273,7 @@ function InternalCombobox(props) {
20182
20273
  var inputRef = useRef();
20183
20274
  var ref = useForkedRef(innerRef || null, inputRef);
20184
20275
  function defaultHandleClearIndicatorClick(event) {
20276
+ var _i18n$combobox$clearA;
20185
20277
  event.stopPropagation();
20186
20278
  if (inputRef.current) {
20187
20279
  var inputElement = inputRef.current.querySelector('input');
@@ -20190,7 +20282,7 @@ function InternalCombobox(props) {
20190
20282
  }
20191
20283
  }
20192
20284
  reset();
20193
- setClearAnnouncement(i18n.combobox.clearAnnounce.replace(/\{labelText\}/g, labelText));
20285
+ setClearAnnouncement((_i18n$combobox$clearA = i18n.combobox.clearAnnounce) == null ? void 0 : _i18n$combobox$clearA.replace(/\{labelText\}/g, labelText));
20194
20286
  // Clear the announcement after a delay to allow for re-announcements
20195
20287
  if (clearAnnouncementTimeoutRef.current) {
20196
20288
  clearTimeout(clearAnnouncementTimeoutRef.current);
@@ -20199,7 +20291,7 @@ function InternalCombobox(props) {
20199
20291
  setClearAnnouncement('');
20200
20292
  }, 1000);
20201
20293
  }
20202
- var clearIndicatorAriaLabel = i18n.combobox.clearIndicatorAriaLabel.replace(/\{labelText\}/g, labelText).replace(/\{selectedItem\}/g, itemToString(selectedItem));
20294
+ var clearIndicatorAriaLabel = (_i18n$combobox$clearI = i18n.combobox.clearIndicatorAriaLabel) == null || (_i18n$combobox$clearI = _i18n$combobox$clearI.replace(/\{labelText\}/g, labelText)) == null ? void 0 : _i18n$combobox$clearI.replace(/\{selectedItem\}/g, itemToString(selectedItem));
20203
20295
  function handleOnKeyDown(event) {
20204
20296
  var count = document.querySelectorAll('[aria-modal="true"]').length;
20205
20297
  switch (event.key) {
@@ -20307,6 +20399,7 @@ function InternalCombobox(props) {
20307
20399
  var _excluded$1t = ["react_magma__created_item"],
20308
20400
  _excluded2$7 = ["stateReducer", "onStateChange"];
20309
20401
  function MultiCombobox(props) {
20402
+ var _i18n$combobox$multi, _i18n$combobox, _clearIndicatori18n$r, _i18n$combobox$multi2, _i18n$combobox$multi3;
20310
20403
  var _React$useState = useState(''),
20311
20404
  inputValue = _React$useState[0],
20312
20405
  setInputValue = _React$useState[1];
@@ -20524,12 +20617,13 @@ function MultiCombobox(props) {
20524
20617
  }
20525
20618
  var inputRef = useRef();
20526
20619
  var ref = useForkedRef(innerRef || null, inputRef);
20527
- var clearIndicatori18n = selectedItems.length > 1 ? i18n.combobox.multi.clearIndicatorAriaLabel : i18n.combobox.clearIndicatorAriaLabel;
20528
- var clearIndicatorAriaLabel = clearIndicatori18n.replace(/\{labelText\}/g, labelText).replace(/\{selectedItem\}/g, itemsArrayToString(selectedItems));
20529
- var multiComboboxAriaLabel = selectedItems.length > 0 ? i18n.combobox.multi.ariaLabelWithSelectedItems.replace(/\{labelText\}/g, labelText).replace(/\{selectedItems\}/g, selectedItems.map(function (item) {
20620
+ var clearIndicatori18n = selectedItems.length > 1 ? (_i18n$combobox$multi = i18n.combobox.multi) == null ? void 0 : _i18n$combobox$multi.clearIndicatorAriaLabel : (_i18n$combobox = i18n.combobox) == null ? void 0 : _i18n$combobox.clearIndicatorAriaLabel;
20621
+ var clearIndicatorAriaLabel = clearIndicatori18n == null || (_clearIndicatori18n$r = clearIndicatori18n.replace(/\{labelText\}/g, labelText)) == null ? void 0 : _clearIndicatori18n$r.replace(/\{selectedItem\}/g, itemsArrayToString(selectedItems));
20622
+ var multiComboboxAriaLabel = selectedItems.length > 0 ? (_i18n$combobox$multi2 = i18n.combobox.multi) == null || (_i18n$combobox$multi2 = _i18n$combobox$multi2.ariaLabelWithSelectedItems) == null || (_i18n$combobox$multi2 = _i18n$combobox$multi2.replace(/\{labelText\}/g, labelText)) == null ? void 0 : _i18n$combobox$multi2.replace(/\{selectedItems\}/g, selectedItems.map(function (item) {
20530
20623
  return itemToString(item);
20531
- }).join(', ')) : i18n.combobox.multi.ariaLabelWithoutSelectedItems.replace(/\{labelText\}/g, labelText);
20624
+ }).join(', ')) : (_i18n$combobox$multi3 = i18n.combobox.multi) == null || (_i18n$combobox$multi3 = _i18n$combobox$multi3.ariaLabelWithoutSelectedItems) == null ? void 0 : _i18n$combobox$multi3.replace(/\{labelText\}/g, labelText);
20532
20625
  function defaultHandleClearIndicatorClick(event) {
20626
+ var _i18n$select;
20533
20627
  event.stopPropagation();
20534
20628
  if (inputRef.current) {
20535
20629
  var inputElement = inputRef.current.querySelector('input');
@@ -20538,7 +20632,7 @@ function MultiCombobox(props) {
20538
20632
  }
20539
20633
  }
20540
20634
  reset();
20541
- setClearAnnouncement(i18n.select.clearAnnounce.replace(/\{labelText\}/g, labelText));
20635
+ setClearAnnouncement((_i18n$select = i18n.select) == null || (_i18n$select = _i18n$select.clearAnnounce) == null ? void 0 : _i18n$select.replace(/\{labelText\}/g, labelText));
20542
20636
  // Clear the announcement after a delay to allow for re-announcements
20543
20637
  if (clearAnnouncementTimeoutRef.current) {
20544
20638
  clearTimeout(clearAnnouncementTimeoutRef.current);
@@ -20548,8 +20642,9 @@ function MultiCombobox(props) {
20548
20642
  }, 1000);
20549
20643
  }
20550
20644
  var selectedItemsContent = selectedItems && selectedItems.length > 0 ? createElement(Fragment, null, selectedItems.map(function (multiSelectedItem, index) {
20645
+ var _i18n$multiCombobox$s;
20551
20646
  return createElement(SelectedItemButton, Object.assign({
20552
- "aria-label": i18n.multiCombobox.selectedItemButtonAriaLabel.replace(/\{selectedItem\}/g, itemToString(multiSelectedItem)),
20647
+ "aria-label": (_i18n$multiCombobox$s = i18n.multiCombobox.selectedItemButtonAriaLabel) == null ? void 0 : _i18n$multiCombobox$s.replace(/\{selectedItem\}/g, itemToString(multiSelectedItem)),
20553
20648
  key: "selected-item-" + index
20554
20649
  }, getSelectedItemProps({
20555
20650
  selectedItem: multiSelectedItem,