@orfium/ictinus 4.86.0-next.2 → 4.86.0-next.3

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.
@@ -8,7 +8,7 @@ var datePickerStyles = exports.datePickerStyles = function datePickerStyles() {
8
8
  return (
9
9
  /*#__PURE__*/
10
10
  /*#__PURE__*/
11
- (0, _react.css)("position:absolute;background-color:", theme.palette.white, ";z-index:10;margin-top:", theme.spacing.sm, ";box-shadow:", theme.elevation['02'], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:datePickerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0RhdGVQaWNrZXIvRGF0ZVBpY2tlci5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJNkUiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRGF0ZVBpY2tlci9EYXRlUGlja2VyLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5pbXBvcnQgeyBUaGVtZSB9IGZyb20gJy4uLy4uL3RoZW1lJztcblxuZXhwb3J0IGNvbnN0IGRhdGVQaWNrZXJTdHlsZXMgPSAoKSA9PiAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHt0aGVtZS5wYWxldHRlLndoaXRlfTtcbiAgei1pbmRleDogMTA7XG4gIG1hcmdpbi10b3A6ICR7dGhlbWUuc3BhY2luZy5zbX07XG4gIGJveC1zaGFkb3c6ICR7dGhlbWUuZWxldmF0aW9uWycwMiddfTtcbmA7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:datePickerStyles;")
11
+ (0, _react.css)("overflow:auto;max-width:inherit;max-height:inherit;position:absolute;background-color:", theme.palette.white, ";z-index:10;margin-top:", theme.spacing.sm, ";box-shadow:", theme.elevation['02'], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:datePickerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0RhdGVQaWNrZXIvRGF0ZVBpY2tlci5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPTyIsImZpbGUiOiIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9EYXRlUGlja2VyL0RhdGVQaWNrZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmltcG9ydCB7IFRoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUnO1xuXG5leHBvcnQgY29uc3QgZGF0ZVBpY2tlclN0eWxlcyA9XG4gICgpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGF1dG87XG4gICAgICBtYXgtd2lkdGg6IGluaGVyaXQ7XG4gICAgICBtYXgtaGVpZ2h0OiBpbmhlcml0O1xuICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHt0aGVtZS5wYWxldHRlLndoaXRlfTtcbiAgICAgIHotaW5kZXg6IDEwO1xuICAgICAgbWFyZ2luLXRvcDogJHt0aGVtZS5zcGFjaW5nLnNtfTtcbiAgICAgIGJveC1zaGFkb3c6ICR7dGhlbWUuZWxldmF0aW9uWycwMiddfTtcbiAgICBgO1xuIl19 */", process.env.NODE_ENV === "production" ? "" : ";label:datePickerStyles;")
12
12
  );
13
13
  };
14
14
  };
@@ -113,8 +113,6 @@ var Filter = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
113
113
  setIsOpen(!isOpen);
114
114
  };
115
115
  var handleSelect = function handleSelect(option) {
116
- debugger;
117
- console.log('hey');
118
116
  if (multi) {
119
117
  handleMultiSelectOptionClick(option);
120
118
  } else {
@@ -134,9 +132,6 @@ var Filter = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
134
132
  onClear();
135
133
  }
136
134
  };
137
- console.log({
138
- selectedItem: selectedItem
139
- });
140
135
  var getFilter = function getFilter() {
141
136
  return multi ? (0, _react2.jsx)(_MultiFilter["default"], {
142
137
  selectedItems: multiFilters,
@@ -238,7 +238,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
238
238
  } : {
239
239
  name: "aqyt6f-valueSpanStyle",
240
240
  styles: "text-overflow:ellipsis;overflow:hidden;white-space:nowrap;display:inline-block;label:valueSpanStyle;",
241
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AAuOuC","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\nimport { textInputConfig } from 'components/TextInputBase/config';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle =\n  ({ disabled, open, hasSelectedValue, calculatedColor, styleType }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    const activeAndClosed = !disabled && !open;\n    const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n    return {\n      background: 'none',\n      border: 'none',\n      display: 'flex',\n      padding: '0',\n      alignItems: 'center',\n      height: '100%',\n      minWidth: rem(110),\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':hover > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getHover({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getHover({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':active > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getPressed({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getPressed({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // on focus change the two divs of added\n      ':focus-visible > div': {\n        border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n      // target the divider on focus\n      ':focus-visible > span': {\n        borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n        borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n    };\n  };\n\nexport const buttonBaseStyle =\n  ({\n    calculatedColor,\n    disabled,\n    open,\n    styleType,\n    hasSelectedValue,\n    filterType,\n  }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    return {\n      fontSize: theme.typography.fontSizes['13'],\n      cursor: disabled ? 'not-allowed' : 'pointer',\n      height: '100%',\n      opacity: disabled ? 0.5 : 1,\n      transition: 'all 150ms linear',\n      color: getTextColor({\n        theme,\n        open,\n        calculatedColor,\n        hasSelectedValue,\n      }),\n      backgroundColor: getBackgroundColor({\n        theme,\n        open,\n        styleType,\n        hasSelectedValue,\n        calculatedColor,\n      }),\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n      })}`,\n      display: 'flex',\n      justifyContent: 'center',\n      width: '100%',\n      '&:hover': {\n        border: `${borderStyleParams} ${getBorder({\n          styleType,\n          theme,\n          hasSelectedValue,\n          filterType,\n          calculatedColor,\n          open,\n          state: 'hover',\n        })}`,\n      },\n    };\n  };\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => {\n  const borderConfig = textInputConfig.types[theme.colorScheme].outlined.border;\n\n  return css`\n    position: absolute;\n    left: 0;\n    height: auto;\n    border: ${rem(borderConfig.width)} solid\n      ${theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)};\n    border-radius: ${theme.spacing.xsm};\n    background-color: ${theme.palette.white};\n    box-shadow: ${theme.elevation['02']};\n    z-index: 500;\n    overflow: hidden;\n    min-width: 100%;\n    max-width: ${rem(440)};\n  `;\n};\n"]} */",
241
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AAuOuC","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\nimport { textInputConfig } from 'components/TextInputBase/config';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle =\n  ({ disabled, open, hasSelectedValue, calculatedColor, styleType }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    const activeAndClosed = !disabled && !open;\n    const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n    return {\n      background: 'none',\n      border: 'none',\n      display: 'flex',\n      padding: '0',\n      alignItems: 'center',\n      height: '100%',\n      minWidth: rem(110),\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':hover > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getHover({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getHover({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':active > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getPressed({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getPressed({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // on focus change the two divs of added\n      ':focus-visible > div': {\n        border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n      // target the divider on focus\n      ':focus-visible > span': {\n        borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n        borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n    };\n  };\n\nexport const buttonBaseStyle =\n  ({\n    calculatedColor,\n    disabled,\n    open,\n    styleType,\n    hasSelectedValue,\n    filterType,\n  }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    return {\n      fontSize: theme.typography.fontSizes['13'],\n      cursor: disabled ? 'not-allowed' : 'pointer',\n      height: '100%',\n      opacity: disabled ? 0.5 : 1,\n      transition: 'all 150ms linear',\n      color: getTextColor({\n        theme,\n        open,\n        calculatedColor,\n        hasSelectedValue,\n      }),\n      backgroundColor: getBackgroundColor({\n        theme,\n        open,\n        styleType,\n        hasSelectedValue,\n        calculatedColor,\n      }),\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n      })}`,\n      display: 'flex',\n      justifyContent: 'center',\n      width: '100%',\n      '&:hover': {\n        border: `${borderStyleParams} ${getBorder({\n          styleType,\n          theme,\n          hasSelectedValue,\n          filterType,\n          calculatedColor,\n          open,\n          state: 'hover',\n        })}`,\n      },\n    };\n  };\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => {\n  const borderConfig = textInputConfig.types[theme.colorScheme].outlined.border;\n\n  return css`\n    overflow: auto;\n    max-height: inherit;\n\n    border: ${rem(borderConfig.width)} solid\n      ${theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)};\n    border-radius: ${theme.spacing.xsm};\n    background-color: ${theme.palette.white};\n    box-shadow: ${theme.elevation['02']};\n    min-width: 100%;\n    max-width: ${rem(440)};\n  `;\n};\n"]} */",
242
242
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
243
243
  };
244
244
  var valueSpanStyle = exports.valueSpanStyle = function valueSpanStyle() {
@@ -250,7 +250,7 @@ var menuStyle = exports.menuStyle = function menuStyle() {
250
250
  return (
251
251
  /*#__PURE__*/
252
252
  /*#__PURE__*/
253
- (0, _react.css)("position:absolute;left:0;height:auto;border:", (0, _utils.rem)(borderConfig.width), " solid ", theme.utils.getColor(borderConfig.color["default"].name, borderConfig.color["default"].shade), ";border-radius:", theme.spacing.xsm, ";background-color:", theme.palette.white, ";box-shadow:", theme.elevation['02'], ";z-index:500;overflow:hidden;min-width:100%;max-width:", (0, _utils.rem)(440), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AAiPY","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\nimport { textInputConfig } from 'components/TextInputBase/config';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle =\n  ({ disabled, open, hasSelectedValue, calculatedColor, styleType }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    const activeAndClosed = !disabled && !open;\n    const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n    return {\n      background: 'none',\n      border: 'none',\n      display: 'flex',\n      padding: '0',\n      alignItems: 'center',\n      height: '100%',\n      minWidth: rem(110),\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':hover > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getHover({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getHover({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':active > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getPressed({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getPressed({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // on focus change the two divs of added\n      ':focus-visible > div': {\n        border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n      // target the divider on focus\n      ':focus-visible > span': {\n        borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n        borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n    };\n  };\n\nexport const buttonBaseStyle =\n  ({\n    calculatedColor,\n    disabled,\n    open,\n    styleType,\n    hasSelectedValue,\n    filterType,\n  }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    return {\n      fontSize: theme.typography.fontSizes['13'],\n      cursor: disabled ? 'not-allowed' : 'pointer',\n      height: '100%',\n      opacity: disabled ? 0.5 : 1,\n      transition: 'all 150ms linear',\n      color: getTextColor({\n        theme,\n        open,\n        calculatedColor,\n        hasSelectedValue,\n      }),\n      backgroundColor: getBackgroundColor({\n        theme,\n        open,\n        styleType,\n        hasSelectedValue,\n        calculatedColor,\n      }),\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n      })}`,\n      display: 'flex',\n      justifyContent: 'center',\n      width: '100%',\n      '&:hover': {\n        border: `${borderStyleParams} ${getBorder({\n          styleType,\n          theme,\n          hasSelectedValue,\n          filterType,\n          calculatedColor,\n          open,\n          state: 'hover',\n        })}`,\n      },\n    };\n  };\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => {\n  const borderConfig = textInputConfig.types[theme.colorScheme].outlined.border;\n\n  return css`\n    position: absolute;\n    left: 0;\n    height: auto;\n    border: ${rem(borderConfig.width)} solid\n      ${theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)};\n    border-radius: ${theme.spacing.xsm};\n    background-color: ${theme.palette.white};\n    box-shadow: ${theme.elevation['02']};\n    z-index: 500;\n    overflow: hidden;\n    min-width: 100%;\n    max-width: ${rem(440)};\n  `;\n};\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;")
253
+ (0, _react.css)("overflow:auto;max-height:inherit;border:", (0, _utils.rem)(borderConfig.width), " solid ", theme.utils.getColor(borderConfig.color["default"].name, borderConfig.color["default"].shade), ";border-radius:", theme.spacing.xsm, ";background-color:", theme.palette.white, ";box-shadow:", theme.elevation['02'], ";min-width:100%;max-width:", (0, _utils.rem)(440), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AAiPY","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\nimport { textInputConfig } from 'components/TextInputBase/config';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle =\n  ({ disabled, open, hasSelectedValue, calculatedColor, styleType }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    const activeAndClosed = !disabled && !open;\n    const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n    return {\n      background: 'none',\n      border: 'none',\n      display: 'flex',\n      padding: '0',\n      alignItems: 'center',\n      height: '100%',\n      minWidth: rem(110),\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':hover > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getHover({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getHover({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':active > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getPressed({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getPressed({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // on focus change the two divs of added\n      ':focus-visible > div': {\n        border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n      // target the divider on focus\n      ':focus-visible > span': {\n        borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n        borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n    };\n  };\n\nexport const buttonBaseStyle =\n  ({\n    calculatedColor,\n    disabled,\n    open,\n    styleType,\n    hasSelectedValue,\n    filterType,\n  }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    return {\n      fontSize: theme.typography.fontSizes['13'],\n      cursor: disabled ? 'not-allowed' : 'pointer',\n      height: '100%',\n      opacity: disabled ? 0.5 : 1,\n      transition: 'all 150ms linear',\n      color: getTextColor({\n        theme,\n        open,\n        calculatedColor,\n        hasSelectedValue,\n      }),\n      backgroundColor: getBackgroundColor({\n        theme,\n        open,\n        styleType,\n        hasSelectedValue,\n        calculatedColor,\n      }),\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n      })}`,\n      display: 'flex',\n      justifyContent: 'center',\n      width: '100%',\n      '&:hover': {\n        border: `${borderStyleParams} ${getBorder({\n          styleType,\n          theme,\n          hasSelectedValue,\n          filterType,\n          calculatedColor,\n          open,\n          state: 'hover',\n        })}`,\n      },\n    };\n  };\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => {\n  const borderConfig = textInputConfig.types[theme.colorScheme].outlined.border;\n\n  return css`\n    overflow: auto;\n    max-height: inherit;\n\n    border: ${rem(borderConfig.width)} solid\n      ${theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)};\n    border-radius: ${theme.spacing.xsm};\n    background-color: ${theme.palette.white};\n    box-shadow: ${theme.elevation['02']};\n    min-width: 100%;\n    max-width: ${rem(440)};\n  `;\n};\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;")
254
254
  );
255
255
  };
256
256
  };
@@ -2,13 +2,12 @@
2
2
 
3
3
  exports.__esModule = true;
4
4
  exports["default"] = void 0;
5
+ var _polished = require("polished");
5
6
  var _react = _interopRequireWildcard(require("react"));
6
7
  var _reactDom = require("react-dom");
7
8
  var _hooks = require("./hooks");
8
9
  var _PositionInScreen = require("./PositionInScreen.style");
9
- var _ClickAwayListener = _interopRequireDefault(require("../../utils/ClickAwayListener"));
10
10
  var _react2 = require("@emotion/react");
11
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
12
11
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
13
12
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
14
13
  var PositionInScreen = function PositionInScreen(_ref) {
@@ -24,33 +23,133 @@ var PositionInScreen = function PositionInScreen(_ref) {
24
23
  offsetY = _ref$offsetY === void 0 ? 0 : _ref$offsetY,
25
24
  sx = _ref.sx,
26
25
  children = _ref.children;
27
- var _useState = (0, _react.useState)(null),
28
- wrapperRef = _useState[0],
29
- setWrapperRef = _useState[1];
30
- var _useState2 = (0, _react.useState)(null),
31
- itemRef = _useState2[0],
32
- setItemRef = _useState2[1];
33
- var _useWrapperWidth = (0, _hooks.useWrapperWidth)(hasWrapperWidth, wrapperRef),
34
- wrapperWidth = _useWrapperWidth[0];
35
- var _usePositionInScreen = (0, _hooks.usePositionInScreen)(wrapperRef, itemRef, offsetX, offsetY, visible),
26
+ var triggerRef = (0, _react.useRef)(null);
27
+ return (0, _react2.jsx)(_react["default"].Fragment, null, (0, _react2.jsx)("div", {
28
+ ref: triggerRef,
29
+ css: (0, _PositionInScreen.container)(withOverflow, sx)
30
+ }, parent), (0, _react2.jsx)(Overlay, {
31
+ visible: visible,
32
+ setIsVisible: setIsVisible,
33
+ triggerRef: triggerRef,
34
+ offsetX: offsetX,
35
+ offsetY: offsetY,
36
+ hasWrapperWidth: hasWrapperWidth
37
+ }, children));
38
+ };
39
+ function Overlay(_ref2) {
40
+ var triggerRef = _ref2.triggerRef,
41
+ _ref2$offsetX = _ref2.offsetX,
42
+ offsetX = _ref2$offsetX === void 0 ? 0 : _ref2$offsetX,
43
+ _ref2$offsetY = _ref2.offsetY,
44
+ offsetY = _ref2$offsetY === void 0 ? 0 : _ref2$offsetY,
45
+ setIsVisible = _ref2.setIsVisible,
46
+ hasWrapperWidth = _ref2.hasWrapperWidth,
47
+ visible = _ref2.visible,
48
+ sx = _ref2.sx,
49
+ children = _ref2.children;
50
+ var overlayRef = (0, _react.useRef)(null);
51
+ var _useState = (0, _react.useState)(false),
52
+ isMounted = _useState[0],
53
+ setIsMounted = _useState[1];
54
+ var resizeObserverRef = (0, _react.useRef)(null);
55
+ var _usePositionInScreen = (0, _hooks.usePositionInScreen)(triggerRef.current, overlayRef.current, offsetX, offsetY, isMounted === true),
36
56
  x = _usePositionInScreen.x,
37
- y = _usePositionInScreen.y;
38
- var showTooltip = visible && x !== -1 && y !== -1;
39
- return (0, _react2.jsx)("div", {
40
- css: (0, _PositionInScreen.container)(withOverflow, sx),
41
- ref: function ref(_ref3) {
42
- setWrapperRef(_ref3);
43
- }
44
- }, parent, /*#__PURE__*/(0, _reactDom.createPortal)((0, _react2.jsx)(_ClickAwayListener["default"], {
45
- onClick: function onClick() {
46
- return setIsVisible(false);
57
+ y = _usePositionInScreen.y,
58
+ isPositioned = _usePositionInScreen.isPositioned,
59
+ maxHeight = _usePositionInScreen.maxHeight,
60
+ maxWidth = _usePositionInScreen.maxWidth,
61
+ triggerWidth = _usePositionInScreen.triggerWidth,
62
+ calculatePosition = _usePositionInScreen.calculatePosition;
63
+ (0, _react.useEffect)(function () {
64
+ if (!visible || !triggerRef.current || !isMounted) return;
65
+ var isInitialMount = true;
66
+ resizeObserverRef.current = new ResizeObserver(function () {
67
+ // Skip the first callback which happens immediately after observe()
68
+ // since the useLayoutEffect in usePositionInScreen already handles this
69
+ if (isInitialMount) {
70
+ isInitialMount = false;
71
+ return;
72
+ }
73
+ requestAnimationFrame(function () {
74
+ calculatePosition();
75
+ });
76
+ });
77
+ resizeObserverRef.current.observe(triggerRef.current);
78
+ return function () {
79
+ if (resizeObserverRef.current) {
80
+ resizeObserverRef.current.disconnect();
81
+ }
82
+ };
83
+ }, [visible, triggerRef, calculatePosition, isMounted]);
84
+ (0, _react.useEffect)(function () {
85
+ var handleWindowResize = function handleWindowResize() {
86
+ if (visible) {
87
+ setIsVisible(false);
88
+ }
89
+ };
90
+ window.addEventListener('resize', handleWindowResize);
91
+ return function () {
92
+ window.removeEventListener('resize', handleWindowResize);
93
+ };
94
+ }, [visible, setIsVisible]);
95
+ (0, _react.useEffect)(function () {
96
+ if (!visible) {
97
+ setIsMounted(false);
98
+ return;
47
99
  }
48
- }, (0, _react2.jsx)("div", {
49
- css: (0, _PositionInScreen.itemContainer)(x, y, showTooltip, wrapperWidth, sx),
50
- className: 'unique-tooltip-id',
51
- ref: function ref(_ref2) {
52
- setItemRef(_ref2);
100
+ if (!overlayRef.current) return;
101
+ var styleElement = null;
102
+ if (visible) {
103
+ styleElement = document.createElement('style');
104
+ styleElement.type = 'text/css';
105
+ styleElement.appendChild(document.createTextNode(scrollLockStyles));
106
+ document.head.appendChild(styleElement);
107
+ document.body.setAttribute('data-scroll-locked', 'true');
108
+ document.body.style.pointerEvents = 'none';
109
+ overlayRef.current.style.pointerEvents = 'auto';
110
+ requestAnimationFrame(function () {
111
+ setIsMounted(true);
112
+ });
113
+ } else {
114
+ document.body.removeAttribute('data-scroll-locked');
115
+ document.body.style.pointerEvents = '';
53
116
  }
54
- }, children)), document.body));
55
- };
117
+ return function () {
118
+ document.body.removeAttribute('data-scroll-locked');
119
+ document.body.style.pointerEvents = '';
120
+ setIsMounted(false);
121
+ if (styleElement) document.head.removeChild(styleElement);
122
+ };
123
+ }, [overlayRef, visible]);
124
+ (0, _react.useEffect)(function () {
125
+ if (!visible) return;
126
+ var handleClickOutside = function handleClickOutside(event) {
127
+ if (overlayRef.current && overlayRef.current.contains(event.target)) {
128
+ return;
129
+ }
130
+ setIsVisible(false);
131
+ };
132
+ document.addEventListener('mousedown', handleClickOutside);
133
+ return function () {
134
+ document.removeEventListener('mousedown', handleClickOutside);
135
+ };
136
+ }, [visible, setIsVisible, overlayRef]);
137
+ if (!visible) return null;
138
+ return /*#__PURE__*/(0, _reactDom.createPortal)((0, _react2.jsx)("div", {
139
+ ref: overlayRef,
140
+ style: {
141
+ position: 'fixed',
142
+ top: 0,
143
+ left: 0,
144
+ width: isPositioned && triggerWidth && hasWrapperWidth ? (0, _polished.rem)(triggerWidth) : '',
145
+ transform: "translate(" + x + "px, " + y + "px)",
146
+ opacity: isPositioned ? 1 : 0,
147
+ maxWidth: isPositioned ? maxWidth + "px" : '',
148
+ maxHeight: isPositioned ? maxHeight + "px" : '',
149
+ zIndex: 'auto'
150
+ },
151
+ css: sx == null ? void 0 : sx.itemContainer
152
+ }, children), document.body);
153
+ }
154
+ var scrollLockStyles = "\nbody[data-scroll-locked] {\n overflow: hidden !important;\n overscroll-behavior: contain;\n position: relative !important;\n padding-left: 0px;\n padding-top: 0px;\n padding-right: 0px;\n margin-left: 0;\n margin-top: 0;\n margin-right: 0px !important;\n}\n";
56
155
  var _default = exports["default"] = PositionInScreen;
@@ -4,7 +4,3 @@ export declare const container: (withOverflow?: boolean | undefined, sx?: {
4
4
  container?: CSSObject | undefined;
5
5
  itemContainer?: CSSObject | undefined;
6
6
  } | undefined) => () => SerializedStyles;
7
- export declare const itemContainer: (clientX: number, clientY: number, visible: boolean, width?: number | undefined, sx?: {
8
- container?: CSSObject | undefined;
9
- itemContainer?: CSSObject | undefined;
10
- } | undefined) => () => SerializedStyles;
@@ -1,9 +1,8 @@
1
1
  "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
- exports.itemContainer = exports.container = void 0;
4
+ exports.container = void 0;
5
5
  var _react = require("@emotion/react");
6
- var _polished = require("polished");
7
6
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
8
7
  var container = exports.container = function container(withOverflow, sx) {
9
8
  return function () {
@@ -15,27 +14,9 @@ var container = exports.container = function container(withOverflow, sx) {
15
14
  textOverflow: withOverflow ? 'ellipsis' : 'inherit',
16
15
  width: '100%',
17
16
  height: 'inherit',
18
- position: 'relative'
19
- }, sx == null ? void 0 : sx.container), process.env.NODE_ENV === "production" ? "" : ";label:container;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0kiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdXRpbHMvUG9zaXRpb25JblNjcmVlbi9Qb3NpdGlvbkluU2NyZWVuLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENTU09iamVjdCB9IGZyb20gJ0BlbW90aW9uL3NlcmlhbGl6ZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICdwb2xpc2hlZCc7XG5cbmV4cG9ydCBjb25zdCBjb250YWluZXIgPVxuICAod2l0aE92ZXJmbG93PzogYm9vbGVhbiwgc3g/OiB7IGNvbnRhaW5lcj86IENTU09iamVjdDsgaXRlbUNvbnRhaW5lcj86IENTU09iamVjdCB9KSA9PlxuICAoKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBvdmVyZmxvdzogd2l0aE92ZXJmbG93ID8gJ2hpZGRlbicgOiAnaW5oZXJpdCcsXG4gICAgICB0ZXh0T3ZlcmZsb3c6IHdpdGhPdmVyZmxvdyA/ICdlbGxpcHNpcycgOiAnaW5oZXJpdCcsXG4gICAgICB3aWR0aDogJzEwMCUnLFxuICAgICAgaGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICAgIC4uLnN4Py5jb250YWluZXIsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBpdGVtQ29udGFpbmVyID1cbiAgKFxuICAgIGNsaWVudFg6IG51bWJlcixcbiAgICBjbGllbnRZOiBudW1iZXIsXG4gICAgdmlzaWJsZTogYm9vbGVhbixcbiAgICB3aWR0aD86IG51bWJlcixcbiAgICBzeD86IHsgY29udGFpbmVyPzogQ1NTT2JqZWN0OyBpdGVtQ29udGFpbmVyPzogQ1NTT2JqZWN0IH1cbiAgKSA9PlxuICAoKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBvdmVyZmxvdzogdmlzaWJsZSA/ICd2aXNpYmxlJyA6ICdoaWRkZW4nLFxuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6IHJlbShjbGllbnRZKSxcbiAgICAgIGxlZnQ6IHJlbShjbGllbnRYKSxcbiAgICAgIHpJbmRleDogOTk5OTk5OTk5LFxuICAgICAgd2lkdGg6IHdpZHRoID8gcmVtKHdpZHRoKSA6IGBmaXQtY29udGVudGAsXG4gICAgICBoZWlnaHQ6ICdmaXQtY29udGVudCcsXG4gICAgICB2aXNpYmlsaXR5OiB2aXNpYmxlID8gJ3Zpc2libGUnIDogJ2hpZGRlbicsXG4gICAgICBvcGFjaXR5OiBgJHt2aXNpYmxlID8gMSA6IDB9ICFpbXBvcnRhbnRgLFxuICAgICAgLi4uc3g/Lml0ZW1Db250YWluZXIsXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:container;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0kiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdXRpbHMvUG9zaXRpb25JblNjcmVlbi9Qb3NpdGlvbkluU2NyZWVuLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENTU09iamVjdCB9IGZyb20gJ0BlbW90aW9uL3NlcmlhbGl6ZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICdwb2xpc2hlZCc7XG5cbmV4cG9ydCBjb25zdCBjb250YWluZXIgPVxuICAod2l0aE92ZXJmbG93PzogYm9vbGVhbiwgc3g/OiB7IGNvbnRhaW5lcj86IENTU09iamVjdDsgaXRlbUNvbnRhaW5lcj86IENTU09iamVjdCB9KSA9PlxuICAoKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBvdmVyZmxvdzogd2l0aE92ZXJmbG93ID8gJ2hpZGRlbicgOiAnaW5oZXJpdCcsXG4gICAgICB0ZXh0T3ZlcmZsb3c6IHdpdGhPdmVyZmxvdyA/ICdlbGxpcHNpcycgOiAnaW5oZXJpdCcsXG4gICAgICB3aWR0aDogJzEwMCUnLFxuICAgICAgaGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICAgIC4uLnN4Py5jb250YWluZXIsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBpdGVtQ29udGFpbmVyID1cbiAgKFxuICAgIGNsaWVudFg6IG51bWJlcixcbiAgICBjbGllbnRZOiBudW1iZXIsXG4gICAgdmlzaWJsZTogYm9vbGVhbixcbiAgICB3aWR0aD86IG51bWJlcixcbiAgICBzeD86IHsgY29udGFpbmVyPzogQ1NTT2JqZWN0OyBpdGVtQ29udGFpbmVyPzogQ1NTT2JqZWN0IH1cbiAgKSA9PlxuICAoKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBvdmVyZmxvdzogdmlzaWJsZSA/ICd2aXNpYmxlJyA6ICdoaWRkZW4nLFxuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICB0b3A6IHJlbShjbGllbnRZKSxcbiAgICAgIGxlZnQ6IHJlbShjbGllbnRYKSxcbiAgICAgIHpJbmRleDogOTk5OTk5OTk5LFxuICAgICAgd2lkdGg6IHdpZHRoID8gcmVtKHdpZHRoKSA6IGBmaXQtY29udGVudGAsXG4gICAgICBoZWlnaHQ6ICdmaXQtY29udGVudCcsXG4gICAgICB2aXNpYmlsaXR5OiB2aXNpYmxlID8gJ3Zpc2libGUnIDogJ2hpZGRlbicsXG4gICAgICBvcGFjaXR5OiBgJHt2aXNpYmxlID8gMSA6IDB9ICFpbXBvcnRhbnRgLFxuICAgICAgLi4uc3g/Lml0ZW1Db250YWluZXIsXG4gICAgfSk7XG4iXX0= */")
20
- );
21
- };
22
- };
23
- var itemContainer = exports.itemContainer = function itemContainer(clientX, clientY, visible, width, sx) {
24
- return function () {
25
- return (
26
- /*#__PURE__*/
27
- /*#__PURE__*/
28
- (0, _react.css)(_extends({
29
- overflow: visible ? 'visible' : 'hidden',
30
- position: 'absolute',
31
- top: (0, _polished.rem)(clientY),
32
- left: (0, _polished.rem)(clientX),
33
- zIndex: 999999999,
34
- width: width ? (0, _polished.rem)(width) : "fit-content",
35
- height: 'fit-content',
36
- visibility: visible ? 'visible' : 'hidden',
37
- opacity: (visible ? 1 : 0) + " !important"
38
- }, sx == null ? void 0 : sx.itemContainer), process.env.NODE_ENV === "production" ? "" : ";label:itemContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJJIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBDU1NPYmplY3QgfSBmcm9tICdAZW1vdGlvbi9zZXJpYWxpemUnO1xuaW1wb3J0IHsgcmVtIH0gZnJvbSAncG9saXNoZWQnO1xuXG5leHBvcnQgY29uc3QgY29udGFpbmVyID1cbiAgKHdpdGhPdmVyZmxvdz86IGJvb2xlYW4sIHN4PzogeyBjb250YWluZXI/OiBDU1NPYmplY3Q7IGl0ZW1Db250YWluZXI/OiBDU1NPYmplY3QgfSkgPT5cbiAgKCk6IFNlcmlhbGl6ZWRTdHlsZXMgPT5cbiAgICBjc3Moe1xuICAgICAgb3ZlcmZsb3c6IHdpdGhPdmVyZmxvdyA/ICdoaWRkZW4nIDogJ2luaGVyaXQnLFxuICAgICAgdGV4dE92ZXJmbG93OiB3aXRoT3ZlcmZsb3cgPyAnZWxsaXBzaXMnIDogJ2luaGVyaXQnLFxuICAgICAgd2lkdGg6ICcxMDAlJyxcbiAgICAgIGhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICAuLi5zeD8uY29udGFpbmVyLFxuICAgIH0pO1xuXG5leHBvcnQgY29uc3QgaXRlbUNvbnRhaW5lciA9XG4gIChcbiAgICBjbGllbnRYOiBudW1iZXIsXG4gICAgY2xpZW50WTogbnVtYmVyLFxuICAgIHZpc2libGU6IGJvb2xlYW4sXG4gICAgd2lkdGg/OiBudW1iZXIsXG4gICAgc3g/OiB7IGNvbnRhaW5lcj86IENTU09iamVjdDsgaXRlbUNvbnRhaW5lcj86IENTU09iamVjdCB9XG4gICkgPT5cbiAgKCk6IFNlcmlhbGl6ZWRTdHlsZXMgPT5cbiAgICBjc3Moe1xuICAgICAgb3ZlcmZsb3c6IHZpc2libGUgPyAndmlzaWJsZScgOiAnaGlkZGVuJyxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgdG9wOiByZW0oY2xpZW50WSksXG4gICAgICBsZWZ0OiByZW0oY2xpZW50WCksXG4gICAgICB6SW5kZXg6IDk5OTk5OTk5OSxcbiAgICAgIHdpZHRoOiB3aWR0aCA/IHJlbSh3aWR0aCkgOiBgZml0LWNvbnRlbnRgLFxuICAgICAgaGVpZ2h0OiAnZml0LWNvbnRlbnQnLFxuICAgICAgdmlzaWJpbGl0eTogdmlzaWJsZSA/ICd2aXNpYmxlJyA6ICdoaWRkZW4nLFxuICAgICAgb3BhY2l0eTogYCR7dmlzaWJsZSA/IDEgOiAwfSAhaW1wb3J0YW50YCxcbiAgICAgIC4uLnN4Py5pdGVtQ29udGFpbmVyLFxuICAgIH0pO1xuIl19 */", process.env.NODE_ENV === "production" ? "" : ";label:itemContainer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJJIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBDU1NPYmplY3QgfSBmcm9tICdAZW1vdGlvbi9zZXJpYWxpemUnO1xuaW1wb3J0IHsgcmVtIH0gZnJvbSAncG9saXNoZWQnO1xuXG5leHBvcnQgY29uc3QgY29udGFpbmVyID1cbiAgKHdpdGhPdmVyZmxvdz86IGJvb2xlYW4sIHN4PzogeyBjb250YWluZXI/OiBDU1NPYmplY3Q7IGl0ZW1Db250YWluZXI/OiBDU1NPYmplY3QgfSkgPT5cbiAgKCk6IFNlcmlhbGl6ZWRTdHlsZXMgPT5cbiAgICBjc3Moe1xuICAgICAgb3ZlcmZsb3c6IHdpdGhPdmVyZmxvdyA/ICdoaWRkZW4nIDogJ2luaGVyaXQnLFxuICAgICAgdGV4dE92ZXJmbG93OiB3aXRoT3ZlcmZsb3cgPyAnZWxsaXBzaXMnIDogJ2luaGVyaXQnLFxuICAgICAgd2lkdGg6ICcxMDAlJyxcbiAgICAgIGhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICAuLi5zeD8uY29udGFpbmVyLFxuICAgIH0pO1xuXG5leHBvcnQgY29uc3QgaXRlbUNvbnRhaW5lciA9XG4gIChcbiAgICBjbGllbnRYOiBudW1iZXIsXG4gICAgY2xpZW50WTogbnVtYmVyLFxuICAgIHZpc2libGU6IGJvb2xlYW4sXG4gICAgd2lkdGg/OiBudW1iZXIsXG4gICAgc3g/OiB7IGNvbnRhaW5lcj86IENTU09iamVjdDsgaXRlbUNvbnRhaW5lcj86IENTU09iamVjdCB9XG4gICkgPT5cbiAgKCk6IFNlcmlhbGl6ZWRTdHlsZXMgPT5cbiAgICBjc3Moe1xuICAgICAgb3ZlcmZsb3c6IHZpc2libGUgPyAndmlzaWJsZScgOiAnaGlkZGVuJyxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgdG9wOiByZW0oY2xpZW50WSksXG4gICAgICBsZWZ0OiByZW0oY2xpZW50WCksXG4gICAgICB6SW5kZXg6IDk5OTk5OTk5OSxcbiAgICAgIHdpZHRoOiB3aWR0aCA/IHJlbSh3aWR0aCkgOiBgZml0LWNvbnRlbnRgLFxuICAgICAgaGVpZ2h0OiAnZml0LWNvbnRlbnQnLFxuICAgICAgdmlzaWJpbGl0eTogdmlzaWJsZSA/ICd2aXNpYmxlJyA6ICdoaWRkZW4nLFxuICAgICAgb3BhY2l0eTogYCR7dmlzaWJsZSA/IDEgOiAwfSAhaW1wb3J0YW50YCxcbiAgICAgIC4uLnN4Py5pdGVtQ29udGFpbmVyLFxuICAgIH0pO1xuIl19 */")
17
+ position: 'relative',
18
+ isolation: 'isolate'
19
+ }, sx == null ? void 0 : sx.container), process.env.NODE_ENV === "production" ? "" : ";label:container;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUkiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdXRpbHMvUG9zaXRpb25JblNjcmVlbi9Qb3NpdGlvbkluU2NyZWVuLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENTU09iamVjdCB9IGZyb20gJ0BlbW90aW9uL3NlcmlhbGl6ZSc7XG5cbmV4cG9ydCBjb25zdCBjb250YWluZXIgPVxuICAod2l0aE92ZXJmbG93PzogYm9vbGVhbiwgc3g/OiB7IGNvbnRhaW5lcj86IENTU09iamVjdDsgaXRlbUNvbnRhaW5lcj86IENTU09iamVjdCB9KSA9PlxuICAoKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBvdmVyZmxvdzogd2l0aE92ZXJmbG93ID8gJ2hpZGRlbicgOiAnaW5oZXJpdCcsXG4gICAgICB0ZXh0T3ZlcmZsb3c6IHdpdGhPdmVyZmxvdyA/ICdlbGxpcHNpcycgOiAnaW5oZXJpdCcsXG4gICAgICB3aWR0aDogJzEwMCUnLFxuICAgICAgaGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICAgIGlzb2xhdGlvbjogJ2lzb2xhdGUnLFxuICAgICAgLi4uc3g/LmNvbnRhaW5lcixcbiAgICB9KTtcbiJdfQ== */", process.env.NODE_ENV === "production" ? "" : ";label:container;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3V0aWxzL1Bvc2l0aW9uSW5TY3JlZW4vUG9zaXRpb25JblNjcmVlbi5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUkiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdXRpbHMvUG9zaXRpb25JblNjcmVlbi9Qb3NpdGlvbkluU2NyZWVuLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IENTU09iamVjdCB9IGZyb20gJ0BlbW90aW9uL3NlcmlhbGl6ZSc7XG5cbmV4cG9ydCBjb25zdCBjb250YWluZXIgPVxuICAod2l0aE92ZXJmbG93PzogYm9vbGVhbiwgc3g/OiB7IGNvbnRhaW5lcj86IENTU09iamVjdDsgaXRlbUNvbnRhaW5lcj86IENTU09iamVjdCB9KSA9PlxuICAoKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBvdmVyZmxvdzogd2l0aE92ZXJmbG93ID8gJ2hpZGRlbicgOiAnaW5oZXJpdCcsXG4gICAgICB0ZXh0T3ZlcmZsb3c6IHdpdGhPdmVyZmxvdyA/ICdlbGxpcHNpcycgOiAnaW5oZXJpdCcsXG4gICAgICB3aWR0aDogJzEwMCUnLFxuICAgICAgaGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICAgIGlzb2xhdGlvbjogJ2lzb2xhdGUnLFxuICAgICAgLi4uc3g/LmNvbnRhaW5lcixcbiAgICB9KTtcbiJdfQ== */")
39
20
  );
40
21
  };
41
22
  };
@@ -1,5 +1,11 @@
1
1
  export declare const usePositionInScreen: (parentRef: HTMLDivElement | null, itemRef: HTMLDivElement | null, offsetX: number, offsetY: number, visible?: boolean | undefined) => {
2
2
  x: number;
3
3
  y: number;
4
+ maxHeight: number;
5
+ maxWidth: number;
6
+ isPositioned: boolean;
7
+ calculatePosition: () => void;
8
+ placement: 'top' | 'bottom';
9
+ triggerWidth: number;
4
10
  };
5
11
  export declare const useWrapperWidth: (hasWrapperWidth: boolean, wrapperRef: HTMLDivElement | null) => (number | undefined)[];
@@ -6,6 +6,7 @@ var _head = _interopRequireDefault(require("lodash/head"));
6
6
  var _react = require("react");
7
7
  var _utils = require("./utils");
8
8
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
9
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
9
10
  var useHeights = function useHeights(parentRef, itemRef) {
10
11
  var _useState = (0, _react.useState)(0),
11
12
  parentHeight = _useState[0],
@@ -49,17 +50,30 @@ var useHeights = function useHeights(parentRef, itemRef) {
49
50
  };
50
51
  };
51
52
  var usePositionInScreen = exports.usePositionInScreen = function usePositionInScreen(parentRef, itemRef, offsetX, offsetY, visible) {
52
- var _useHeights = useHeights(parentRef, itemRef),
53
- parentHeight = _useHeights.parentHeight,
54
- childHeight = _useHeights.childHeight;
55
53
  var _useState3 = (0, _react.useState)({
56
- x: -1,
57
- y: -1
54
+ x: 0,
55
+ y: 0
58
56
  }),
59
57
  position = _useState3[0],
60
58
  setPosition = _useState3[1];
61
- (0, _react.useLayoutEffect)(function () {
62
- var _itemRef$children$, _childRect$width;
59
+ var _useState4 = (0, _react.useState)(0),
60
+ triggerWidth = _useState4[0],
61
+ setTriggerWidth = _useState4[1];
62
+ var _useState5 = (0, _react.useState)(0),
63
+ maxHeight = _useState5[0],
64
+ setMaxHeight = _useState5[1];
65
+ var _useState6 = (0, _react.useState)(0),
66
+ maxWidth = _useState6[0],
67
+ setMaxWidth = _useState6[1];
68
+ var _useState7 = (0, _react.useState)(false),
69
+ isPositioned = _useState7[0],
70
+ setIsPositioned = _useState7[1];
71
+ var _useState8 = (0, _react.useState)('bottom'),
72
+ placement = _useState8[0],
73
+ setPlacement = _useState8[1];
74
+ var animationFrameRef = (0, _react.useRef)(0);
75
+ var calculatePosition = (0, _react.useCallback)(function () {
76
+ var _itemRef$children$, _childRect$width, _childRect$height;
63
77
  // Define a small buffer for screen edge detection
64
78
  var SCREEN_EDGE_BUFFER = 8;
65
79
 
@@ -67,48 +81,99 @@ var usePositionInScreen = exports.usePositionInScreen = function usePositionInSc
67
81
  var parentRect = parentRef == null ? void 0 : parentRef.getBoundingClientRect();
68
82
  if (!parentRect) return;
69
83
 
70
- // Get viewport-relative coordinates
71
- var parentX = parentRect.left + window.scrollX;
72
- var parentY = parentRect.top + window.scrollY;
84
+ // Get viewport-relative coordinates (without scroll offset)
85
+ var parentX = parentRect.left;
86
+ var parentY = parentRect.top;
73
87
  var parentWidth = parentRect.width;
88
+ var parentHeight = parentRect.height;
74
89
 
75
90
  // Get positioned element dimensions
76
91
  var childRect = itemRef == null || (_itemRef$children$ = itemRef.children[0]) == null ? void 0 : _itemRef$children$.getBoundingClientRect();
77
92
  var childWidth = (_childRect$width = childRect == null ? void 0 : childRect.width) != null ? _childRect$width : 0;
93
+ var childHeight = (_childRect$height = childRect == null ? void 0 : childRect.height) != null ? _childRect$height : 0;
78
94
 
79
- // Check if element would overflow screen bounds (with buffer)
80
- var itemYOutOfScreenHeight = parentRect.top + parentHeight + childHeight > window.innerHeight - SCREEN_EDGE_BUFFER;
81
- var itemXOutOfScreenWidth = parentRect.left + childWidth > window.innerWidth - SCREEN_EDGE_BUFFER;
82
-
83
- // Calculate absolute positions (viewport + scroll)
95
+ // Calculate positions (viewport-relative, without scroll)
84
96
  var x = parentX + offsetX;
85
- var y = parentY;
86
- if (itemYOutOfScreenHeight) {
87
- // Position above parent if would overflow bottom
88
- y = y - childHeight - offsetY;
89
- if (y < SCREEN_EDGE_BUFFER) {
90
- // If would overflow top, fallback to below parent
97
+ var y;
98
+ var currentPlacement = 'bottom';
99
+
100
+ // Check if element would overflow screen bounds (with buffer) when placed below
101
+ var spaceBelow = window.innerHeight - (parentRect.bottom + offsetY) - SCREEN_EDGE_BUFFER;
102
+ var spaceAbove = parentRect.top - offsetY - SCREEN_EDGE_BUFFER;
103
+
104
+ // First try to place it below, if there's not enough space, try above
105
+ if (childHeight <= spaceBelow) {
106
+ // Place below - enough space
107
+ y = parentY + parentHeight + offsetY;
108
+ currentPlacement = 'bottom';
109
+ } else if (childHeight <= spaceAbove) {
110
+ // Place above - enough space above
111
+ y = parentY - childHeight - offsetY;
112
+ currentPlacement = 'top';
113
+ } else {
114
+ // Not enough space either way, place where there's more space and allow scrolling
115
+ if (spaceBelow >= spaceAbove) {
91
116
  y = parentY + parentHeight + offsetY;
117
+ currentPlacement = 'bottom';
118
+ } else {
119
+ y = parentY - childHeight - offsetY;
120
+ currentPlacement = 'top';
92
121
  }
93
- } else {
94
- // Position below parent
95
- y = y + parentHeight + offsetY;
96
122
  }
123
+
124
+ // Check if element would overflow screen bounds horizontally (with buffer)
125
+ var itemXOutOfScreenWidth = x + childWidth > window.innerWidth - SCREEN_EDGE_BUFFER;
97
126
  if (itemXOutOfScreenWidth) {
98
127
  // Align to right edge of parent if would overflow right
99
128
  x = parentX + parentWidth - childWidth - offsetX;
129
+ // Ensure we don't position outside the left edge
130
+ if (x < SCREEN_EDGE_BUFFER) {
131
+ x = SCREEN_EDGE_BUFFER;
132
+ }
100
133
  }
134
+
135
+ // Calculate maxHeight - space available from y position to bottom/top of screen based on placement
136
+ var availableHeight;
137
+ if (currentPlacement === 'top') {
138
+ availableHeight = parentY - SCREEN_EDGE_BUFFER;
139
+ } else {
140
+ availableHeight = window.innerHeight - (parentY + parentHeight + offsetY) - SCREEN_EDGE_BUFFER;
141
+ }
142
+
143
+ // Calculate maxWidth - space available from x position to right edge of screen
144
+ var availableRightSpace = window.innerWidth - x - SCREEN_EDGE_BUFFER;
101
145
  setPosition({
102
146
  x: x,
103
147
  y: y
104
148
  });
105
- }, [parentRef, itemRef, visible, offsetY, offsetX, parentHeight, childHeight]);
106
- return position;
149
+ setMaxHeight(availableHeight);
150
+ setMaxWidth(availableRightSpace);
151
+ setIsPositioned(true);
152
+ setPlacement(currentPlacement);
153
+ setTriggerWidth(parentWidth);
154
+ }, [parentRef, itemRef, offsetY, offsetX]);
155
+ (0, _react.useLayoutEffect)(function () {
156
+ if (!visible) return;
157
+ animationFrameRef.current = requestAnimationFrame(function () {
158
+ calculatePosition();
159
+ });
160
+ return function () {
161
+ cancelAnimationFrame(animationFrameRef.current);
162
+ };
163
+ }, [calculatePosition, visible]);
164
+ return _extends({}, position, {
165
+ maxHeight: maxHeight,
166
+ maxWidth: maxWidth,
167
+ isPositioned: isPositioned,
168
+ calculatePosition: calculatePosition,
169
+ placement: placement,
170
+ triggerWidth: triggerWidth
171
+ });
107
172
  };
108
173
  var useWrapperWidth = exports.useWrapperWidth = function useWrapperWidth(hasWrapperWidth, wrapperRef) {
109
- var _useState4 = (0, _react.useState)(),
110
- width = _useState4[0],
111
- setWidth = _useState4[1];
174
+ var _useState9 = (0, _react.useState)(),
175
+ width = _useState9[0],
176
+ setWidth = _useState9[1];
112
177
  (0, _react.useLayoutEffect)(function () {
113
178
  if (hasWrapperWidth) {
114
179
  var _wrapperRef$getBoundi;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@orfium/ictinus",
3
- "version": "4.86.0-next.2",
3
+ "version": "4.86.0-next.3",
4
4
  "main": "./dist/index.js",
5
5
  "types": "./dist/index.d.ts",
6
6
  "license": "MIT",