@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.
- package/dist/components/DatePicker/DatePicker.style.js +1 -1
- package/dist/components/Filter/Filter.js +0 -5
- package/dist/components/Filter/Filter.style.js +2 -2
- package/dist/components/utils/PositionInScreen/PositionInScreen.js +127 -28
- package/dist/components/utils/PositionInScreen/PositionInScreen.style.d.ts +0 -4
- package/dist/components/utils/PositionInScreen/PositionInScreen.style.js +4 -23
- package/dist/components/utils/PositionInScreen/hooks.d.ts +6 -0
- package/dist/components/utils/PositionInScreen/hooks.js +94 -29
- package/package.json +1 -1
|
@@ -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,
|
|
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) =>
|
|
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
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
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
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
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
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
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
|
-
|
|
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.
|
|
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
|
-
|
|
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:
|
|
57
|
-
y:
|
|
54
|
+
x: 0,
|
|
55
|
+
y: 0
|
|
58
56
|
}),
|
|
59
57
|
position = _useState3[0],
|
|
60
58
|
setPosition = _useState3[1];
|
|
61
|
-
(0, _react.
|
|
62
|
-
|
|
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
|
|
72
|
-
var parentY = parentRect.top
|
|
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
|
-
//
|
|
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
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
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
|
-
|
|
106
|
-
|
|
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
|
|
110
|
-
width =
|
|
111
|
-
setWidth =
|
|
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;
|