You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

89 lines
3.3 KiB

2 months ago
  1. import getBasePlacement from "../utils/getBasePlacement.js";
  2. import getLayoutRect from "../dom-utils/getLayoutRect.js";
  3. import contains from "../dom-utils/contains.js";
  4. import getOffsetParent from "../dom-utils/getOffsetParent.js";
  5. import getMainAxisFromPlacement from "../utils/getMainAxisFromPlacement.js";
  6. import { within } from "../utils/within.js";
  7. import mergePaddingObject from "../utils/mergePaddingObject.js";
  8. import expandToHashMap from "../utils/expandToHashMap.js";
  9. import { left, right, basePlacements, top, bottom } from "../enums.js"; // eslint-disable-next-line import/no-unused-modules
  10. var toPaddingObject = function toPaddingObject(padding, state) {
  11. padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {
  12. placement: state.placement
  13. })) : padding;
  14. return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));
  15. };
  16. function arrow(_ref) {
  17. var _state$modifiersData$;
  18. var state = _ref.state,
  19. name = _ref.name,
  20. options = _ref.options;
  21. var arrowElement = state.elements.arrow;
  22. var popperOffsets = state.modifiersData.popperOffsets;
  23. var basePlacement = getBasePlacement(state.placement);
  24. var axis = getMainAxisFromPlacement(basePlacement);
  25. var isVertical = [left, right].indexOf(basePlacement) >= 0;
  26. var len = isVertical ? 'height' : 'width';
  27. if (!arrowElement || !popperOffsets) {
  28. return;
  29. }
  30. var paddingObject = toPaddingObject(options.padding, state);
  31. var arrowRect = getLayoutRect(arrowElement);
  32. var minProp = axis === 'y' ? top : left;
  33. var maxProp = axis === 'y' ? bottom : right;
  34. var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];
  35. var startDiff = popperOffsets[axis] - state.rects.reference[axis];
  36. var arrowOffsetParent = getOffsetParent(arrowElement);
  37. var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;
  38. var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is
  39. // outside of the popper bounds
  40. var min = paddingObject[minProp];
  41. var max = clientSize - arrowRect[len] - paddingObject[maxProp];
  42. var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;
  43. var offset = within(min, center, max); // Prevents breaking syntax highlighting...
  44. var axisProp = axis;
  45. state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);
  46. }
  47. function effect(_ref2) {
  48. var state = _ref2.state,
  49. options = _ref2.options;
  50. var _options$element = options.element,
  51. arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;
  52. if (arrowElement == null) {
  53. return;
  54. } // CSS selector
  55. if (typeof arrowElement === 'string') {
  56. arrowElement = state.elements.popper.querySelector(arrowElement);
  57. if (!arrowElement) {
  58. return;
  59. }
  60. }
  61. if (!contains(state.elements.popper, arrowElement)) {
  62. return;
  63. }
  64. state.elements.arrow = arrowElement;
  65. } // eslint-disable-next-line import/no-unused-modules
  66. export default {
  67. name: 'arrow',
  68. enabled: true,
  69. phase: 'main',
  70. fn: arrow,
  71. effect: effect,
  72. requires: ['popperOffsets'],
  73. requiresIfExists: ['preventOverflow']
  74. };